2 * Driver for the ov7660 sensor
4 * Copyright (C) 2009 Erik Andrén
5 * Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project.
6 * Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br>
8 * Portions of code to USB interface and ALi driver software,
9 * Copyright (c) 2006 Willem Duinker
10 * v4l2 interface modeled after the V4L2 driver
11 * for SN9C10x PC Camera Controllers
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License as
15 * published by the Free Software Foundation, version 2.
19 #ifndef M5602_OV7660_H_
20 #define M5602_OV7660_H_
22 #include "m5602_sensor.h"
24 #define OV7660_GAIN 0x00
25 #define OV7660_BLUE_GAIN 0x01
26 #define OV7660_RED_GAIN 0x02
27 #define OV7660_VREF 0x03
28 #define OV7660_COM1 0x04
29 #define OV7660_BAVE 0x05
30 #define OV7660_GEAVE 0x06
31 #define OV7660_AECHH 0x07
32 #define OV7660_RAVE 0x08
33 #define OV7660_COM2 0x09
34 #define OV7660_PID 0x0a
35 #define OV7660_VER 0x0b
36 #define OV7660_COM3 0x0c
37 #define OV7660_COM4 0x0d
38 #define OV7660_COM5 0x0e
39 #define OV7660_COM6 0x0f
40 #define OV7660_AECH 0x10
41 #define OV7660_CLKRC 0x11
42 #define OV7660_COM7 0x12
43 #define OV7660_COM8 0x13
44 #define OV7660_COM9 0x14
45 #define OV7660_COM10 0x15
46 #define OV7660_RSVD16 0x16
47 #define OV7660_HSTART 0x17
48 #define OV7660_HSTOP 0x18
49 #define OV7660_VSTART 0x19
50 #define OV7660_VSTOP 0x1a
51 #define OV7660_PSHFT 0x1b
52 #define OV7660_MIDH 0x1c
53 #define OV7660_MIDL 0x1d
54 #define OV7660_MVFP 0x1e
55 #define OV7660_LAEC 0x1f
56 #define OV7660_BOS 0x20
57 #define OV7660_GBOS 0x21
58 #define OV7660_GROS 0x22
59 #define OV7660_ROS 0x23
60 #define OV7660_AEW 0x24
61 #define OV7660_AEB 0x25
62 #define OV7660_VPT 0x26
63 #define OV7660_BBIAS 0x27
64 #define OV7660_GbBIAS 0x28
65 #define OV7660_RSVD29 0x29
66 #define OV7660_RBIAS 0x2c
67 #define OV7660_HREF 0x32
68 #define OV7660_ADC 0x37
69 #define OV7660_OFON 0x39
70 #define OV7660_TSLB 0x3a
71 #define OV7660_COM12 0x3c
72 #define OV7660_COM13 0x3d
73 #define OV7660_LCC1 0x62
74 #define OV7660_LCC2 0x63
75 #define OV7660_LCC3 0x64
76 #define OV7660_LCC4 0x65
77 #define OV7660_LCC5 0x66
78 #define OV7660_HV 0x69
79 #define OV7660_RSVDA1 0xa1
81 #define OV7660_DEFAULT_GAIN 0x0e
82 #define OV7660_DEFAULT_RED_GAIN 0x80
83 #define OV7660_DEFAULT_BLUE_GAIN 0x80
84 #define OV7660_DEFAULT_SATURATION 0x00
85 #define OV7660_DEFAULT_EXPOSURE 0x20
87 /* Kernel module parameters */
88 extern int force_sensor
;
89 extern bool dump_sensor
;
91 int ov7660_probe(struct sd
*sd
);
92 int ov7660_init(struct sd
*sd
);
93 int ov7660_init(struct sd
*sd
);
94 int ov7660_init_controls(struct sd
*sd
);
95 int ov7660_start(struct sd
*sd
);
96 int ov7660_stop(struct sd
*sd
);
97 void ov7660_disconnect(struct sd
*sd
);
99 static const struct m5602_sensor ov7660
= {
101 .i2c_slave_id
= 0x42,
103 .probe
= ov7660_probe
,
105 .init_controls
= ov7660_init_controls
,
106 .start
= ov7660_start
,
108 .disconnect
= ov7660_disconnect
,
111 static const unsigned char preinit_ov7660
[][4] = {
112 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02},
113 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0},
114 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
115 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
116 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
117 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0d},
118 {BRIDGE
, M5602_XB_SENSOR_CTRL
, 0x00},
119 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x03},
120 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x03},
121 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
122 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
124 {SENSOR
, OV7660_OFON
, 0x0c},
125 {SENSOR
, OV7660_COM2
, 0x11},
126 {SENSOR
, OV7660_COM7
, 0x05},
128 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x01},
129 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x04},
130 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
131 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06},
132 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00},
133 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x08},
134 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
135 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
136 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
137 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
138 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
139 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x05},
140 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x00},
141 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
142 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00}
145 static const unsigned char init_ov7660
[][4] = {
146 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02},
147 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0},
148 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
149 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
150 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
151 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0d},
152 {BRIDGE
, M5602_XB_SENSOR_CTRL
, 0x00},
153 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x01},
154 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x01},
155 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
156 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
157 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
158 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
159 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x05},
160 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x00},
161 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
162 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00},
163 {SENSOR
, OV7660_COM7
, 0x80},
164 {SENSOR
, OV7660_CLKRC
, 0x80},
165 {SENSOR
, OV7660_COM9
, 0x4c},
166 {SENSOR
, OV7660_OFON
, 0x43},
167 {SENSOR
, OV7660_COM12
, 0x28},
168 {SENSOR
, OV7660_COM8
, 0x00},
169 {SENSOR
, OV7660_COM10
, 0x40},
170 {SENSOR
, OV7660_HSTART
, 0x0c},
171 {SENSOR
, OV7660_HSTOP
, 0x61},
172 {SENSOR
, OV7660_HREF
, 0xa4},
173 {SENSOR
, OV7660_PSHFT
, 0x0b},
174 {SENSOR
, OV7660_VSTART
, 0x01},
175 {SENSOR
, OV7660_VSTOP
, 0x7a},
176 {SENSOR
, OV7660_VSTOP
, 0x00},
177 {SENSOR
, OV7660_COM7
, 0x05},
178 {SENSOR
, OV7660_COM6
, 0x42},
179 {SENSOR
, OV7660_BBIAS
, 0x94},
180 {SENSOR
, OV7660_GbBIAS
, 0x94},
181 {SENSOR
, OV7660_RSVD29
, 0x94},
182 {SENSOR
, OV7660_RBIAS
, 0x94},
183 {SENSOR
, OV7660_COM1
, 0x00},
184 {SENSOR
, OV7660_AECH
, 0x00},
185 {SENSOR
, OV7660_AECHH
, 0x00},
186 {SENSOR
, OV7660_ADC
, 0x05},
187 {SENSOR
, OV7660_COM13
, 0x00},
188 {SENSOR
, OV7660_RSVDA1
, 0x23},
189 {SENSOR
, OV7660_TSLB
, 0x0d},
190 {SENSOR
, OV7660_HV
, 0x80},
191 {SENSOR
, OV7660_LCC1
, 0x00},
192 {SENSOR
, OV7660_LCC2
, 0x00},
193 {SENSOR
, OV7660_LCC3
, 0x10},
194 {SENSOR
, OV7660_LCC4
, 0x40},
195 {SENSOR
, OV7660_LCC5
, 0x01},
197 {SENSOR
, OV7660_AECH
, 0x20},
198 {SENSOR
, OV7660_COM1
, 0x00},
199 {SENSOR
, OV7660_OFON
, 0x0c},
200 {SENSOR
, OV7660_COM2
, 0x11},
201 {SENSOR
, OV7660_COM7
, 0x05},
202 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x01},
203 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x04},
204 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
205 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06},
206 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00},
207 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x08},
208 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
209 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
210 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
211 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
212 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
213 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x05},
214 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x00},
215 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
216 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00},
217 {SENSOR
, OV7660_AECH
, 0x5f},
218 {SENSOR
, OV7660_COM1
, 0x03},
219 {SENSOR
, OV7660_OFON
, 0x0c},
220 {SENSOR
, OV7660_COM2
, 0x11},
221 {SENSOR
, OV7660_COM7
, 0x05},
222 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x01},
223 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x04},
224 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
225 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06},
226 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00},
227 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x08},
228 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
229 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
230 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
231 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
232 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
233 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x05},
234 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x00},
235 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06},
236 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00},
238 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x06},
239 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},
240 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0},
241 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0c},
242 {BRIDGE
, M5602_XB_LINE_OF_FRAME_H
, 0x81},
243 {BRIDGE
, M5602_XB_PIX_OF_LINE_H
, 0x82},
244 {BRIDGE
, M5602_XB_SIG_INI
, 0x01},
245 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00},
246 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x08},
247 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00},
248 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00},
249 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x01},
250 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0xec},
251 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00},
252 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00},
253 {BRIDGE
, M5602_XB_SIG_INI
, 0x00},
254 {BRIDGE
, M5602_XB_SIG_INI
, 0x02},
255 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00},
256 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x27},
257 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x02},
258 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0xa7},
259 {BRIDGE
, M5602_XB_SIG_INI
, 0x00},
260 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00},
261 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0},