162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Driver for the ov9650 sensor
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2008 Erik Andrén
662306a36Sopenharmony_ci * Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project.
762306a36Sopenharmony_ci * Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br>
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Portions of code to USB interface and ALi driver software,
1062306a36Sopenharmony_ci * Copyright (c) 2006 Willem Duinker
1162306a36Sopenharmony_ci * v4l2 interface modeled after the V4L2 driver
1262306a36Sopenharmony_ci * for SN9C10x PC Camera Controllers
1362306a36Sopenharmony_ci */
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci#ifndef M5602_OV9650_H_
1662306a36Sopenharmony_ci#define M5602_OV9650_H_
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci#include <linux/dmi.h>
1962306a36Sopenharmony_ci#include "m5602_sensor.h"
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci/*****************************************************************************/
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci#define OV9650_GAIN			0x00
2462306a36Sopenharmony_ci#define OV9650_BLUE			0x01
2562306a36Sopenharmony_ci#define OV9650_RED			0x02
2662306a36Sopenharmony_ci#define OV9650_VREF			0x03
2762306a36Sopenharmony_ci#define OV9650_COM1			0x04
2862306a36Sopenharmony_ci#define OV9650_BAVE			0x05
2962306a36Sopenharmony_ci#define OV9650_GEAVE			0x06
3062306a36Sopenharmony_ci#define OV9650_RSVD7			0x07
3162306a36Sopenharmony_ci#define OV9650_COM2			0x09
3262306a36Sopenharmony_ci#define OV9650_PID			0x0a
3362306a36Sopenharmony_ci#define OV9650_VER			0x0b
3462306a36Sopenharmony_ci#define OV9650_COM3			0x0c
3562306a36Sopenharmony_ci#define OV9650_COM4			0x0d
3662306a36Sopenharmony_ci#define OV9650_COM5			0x0e
3762306a36Sopenharmony_ci#define OV9650_COM6			0x0f
3862306a36Sopenharmony_ci#define OV9650_AECH			0x10
3962306a36Sopenharmony_ci#define OV9650_CLKRC			0x11
4062306a36Sopenharmony_ci#define OV9650_COM7			0x12
4162306a36Sopenharmony_ci#define OV9650_COM8			0x13
4262306a36Sopenharmony_ci#define OV9650_COM9			0x14
4362306a36Sopenharmony_ci#define OV9650_COM10			0x15
4462306a36Sopenharmony_ci#define OV9650_RSVD16			0x16
4562306a36Sopenharmony_ci#define OV9650_HSTART			0x17
4662306a36Sopenharmony_ci#define OV9650_HSTOP			0x18
4762306a36Sopenharmony_ci#define OV9650_VSTRT			0x19
4862306a36Sopenharmony_ci#define OV9650_VSTOP			0x1a
4962306a36Sopenharmony_ci#define OV9650_PSHFT			0x1b
5062306a36Sopenharmony_ci#define OV9650_MVFP			0x1e
5162306a36Sopenharmony_ci#define OV9650_AEW			0x24
5262306a36Sopenharmony_ci#define OV9650_AEB			0x25
5362306a36Sopenharmony_ci#define OV9650_VPT			0x26
5462306a36Sopenharmony_ci#define OV9650_BBIAS			0x27
5562306a36Sopenharmony_ci#define OV9650_GbBIAS			0x28
5662306a36Sopenharmony_ci#define OV9650_Gr_COM			0x29
5762306a36Sopenharmony_ci#define OV9650_RBIAS			0x2c
5862306a36Sopenharmony_ci#define OV9650_HREF			0x32
5962306a36Sopenharmony_ci#define OV9650_CHLF			0x33
6062306a36Sopenharmony_ci#define OV9650_ARBLM			0x34
6162306a36Sopenharmony_ci#define OV9650_RSVD35			0x35
6262306a36Sopenharmony_ci#define OV9650_RSVD36			0x36
6362306a36Sopenharmony_ci#define OV9650_ADC			0x37
6462306a36Sopenharmony_ci#define OV9650_ACOM38			0x38
6562306a36Sopenharmony_ci#define OV9650_OFON			0x39
6662306a36Sopenharmony_ci#define OV9650_TSLB			0x3a
6762306a36Sopenharmony_ci#define OV9650_COM12			0x3c
6862306a36Sopenharmony_ci#define OV9650_COM13			0x3d
6962306a36Sopenharmony_ci#define OV9650_COM15			0x40
7062306a36Sopenharmony_ci#define OV9650_COM16			0x41
7162306a36Sopenharmony_ci#define OV9650_LCC1			0x62
7262306a36Sopenharmony_ci#define OV9650_LCC2			0x63
7362306a36Sopenharmony_ci#define OV9650_LCC3			0x64
7462306a36Sopenharmony_ci#define OV9650_LCC4			0x65
7562306a36Sopenharmony_ci#define OV9650_LCC5			0x66
7662306a36Sopenharmony_ci#define OV9650_HV			0x69
7762306a36Sopenharmony_ci#define OV9650_DBLV			0x6b
7862306a36Sopenharmony_ci#define OV9650_COM21			0x8b
7962306a36Sopenharmony_ci#define OV9650_COM22			0x8c
8062306a36Sopenharmony_ci#define OV9650_COM24			0x8e
8162306a36Sopenharmony_ci#define OV9650_DBLC1			0x8f
8262306a36Sopenharmony_ci#define OV9650_RSVD94			0x94
8362306a36Sopenharmony_ci#define OV9650_RSVD95			0x95
8462306a36Sopenharmony_ci#define OV9650_RSVD96			0x96
8562306a36Sopenharmony_ci#define OV9650_LCCFB			0x9d
8662306a36Sopenharmony_ci#define OV9650_LCCFR			0x9e
8762306a36Sopenharmony_ci#define OV9650_AECHM			0xa1
8862306a36Sopenharmony_ci#define OV9650_COM26			0xa5
8962306a36Sopenharmony_ci#define OV9650_ACOMA8			0xa8
9062306a36Sopenharmony_ci#define OV9650_ACOMA9			0xa9
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci#define OV9650_REGISTER_RESET		(1 << 7)
9362306a36Sopenharmony_ci#define OV9650_VGA_SELECT		(1 << 6)
9462306a36Sopenharmony_ci#define OV9650_CIF_SELECT		(1 << 5)
9562306a36Sopenharmony_ci#define OV9650_QVGA_SELECT		(1 << 4)
9662306a36Sopenharmony_ci#define OV9650_QCIF_SELECT		(1 << 3)
9762306a36Sopenharmony_ci#define OV9650_RGB_SELECT		(1 << 2)
9862306a36Sopenharmony_ci#define OV9650_RAW_RGB_SELECT		(1 << 0)
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci#define OV9650_FAST_AGC_AEC		(1 << 7)
10162306a36Sopenharmony_ci#define OV9650_AEC_UNLIM_STEP_SIZE	(1 << 6)
10262306a36Sopenharmony_ci#define OV9650_BANDING			(1 << 5)
10362306a36Sopenharmony_ci#define OV9650_AGC_EN			(1 << 2)
10462306a36Sopenharmony_ci#define OV9650_AWB_EN			(1 << 1)
10562306a36Sopenharmony_ci#define OV9650_AEC_EN			(1 << 0)
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci#define OV9650_VARIOPIXEL		(1 << 2)
10862306a36Sopenharmony_ci#define OV9650_SYSTEM_CLK_SEL		(1 << 7)
10962306a36Sopenharmony_ci#define OV9650_SLAM_MODE		(1 << 4)
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci#define OV9650_QVGA_VARIOPIXEL		(1 << 7)
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci#define OV9650_VFLIP			(1 << 4)
11462306a36Sopenharmony_ci#define OV9650_HFLIP			(1 << 5)
11562306a36Sopenharmony_ci
11662306a36Sopenharmony_ci#define OV9650_SOFT_SLEEP		(1 << 4)
11762306a36Sopenharmony_ci#define OV9650_OUTPUT_DRIVE_2X		(1 << 0)
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ci#define OV9650_DENOISE_ENABLE		(1 << 5)
12062306a36Sopenharmony_ci#define OV9650_WHITE_PIXEL_ENABLE	(1 << 1)
12162306a36Sopenharmony_ci#define OV9650_WHITE_PIXEL_OPTION	(1 << 0)
12262306a36Sopenharmony_ci
12362306a36Sopenharmony_ci#define OV9650_LEFT_OFFSET		0x62
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_ci#define GAIN_DEFAULT			0x14
12662306a36Sopenharmony_ci#define RED_GAIN_DEFAULT		0x70
12762306a36Sopenharmony_ci#define BLUE_GAIN_DEFAULT		0x20
12862306a36Sopenharmony_ci#define EXPOSURE_DEFAULT		0x1ff
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci/*****************************************************************************/
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ci/* Kernel module parameters */
13362306a36Sopenharmony_ciextern int force_sensor;
13462306a36Sopenharmony_ciextern bool dump_sensor;
13562306a36Sopenharmony_ci
13662306a36Sopenharmony_ciint ov9650_probe(struct sd *sd);
13762306a36Sopenharmony_ciint ov9650_init(struct sd *sd);
13862306a36Sopenharmony_ciint ov9650_init_controls(struct sd *sd);
13962306a36Sopenharmony_ciint ov9650_start(struct sd *sd);
14062306a36Sopenharmony_ciint ov9650_stop(struct sd *sd);
14162306a36Sopenharmony_civoid ov9650_disconnect(struct sd *sd);
14262306a36Sopenharmony_ci
14362306a36Sopenharmony_cistatic const struct m5602_sensor ov9650 = {
14462306a36Sopenharmony_ci	.name = "OV9650",
14562306a36Sopenharmony_ci	.i2c_slave_id = 0x60,
14662306a36Sopenharmony_ci	.i2c_regW = 1,
14762306a36Sopenharmony_ci	.probe = ov9650_probe,
14862306a36Sopenharmony_ci	.init = ov9650_init,
14962306a36Sopenharmony_ci	.init_controls = ov9650_init_controls,
15062306a36Sopenharmony_ci	.start = ov9650_start,
15162306a36Sopenharmony_ci	.stop = ov9650_stop,
15262306a36Sopenharmony_ci	.disconnect = ov9650_disconnect,
15362306a36Sopenharmony_ci};
15462306a36Sopenharmony_ci
15562306a36Sopenharmony_ci#endif
156