2 * Driver for the s5k83a sensor
4 * Copyright (C) 2008 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_S5K83A_H_
20 #define M5602_S5K83A_H_
22 #include "m5602_sensor.h"
24 #define S5K83A_FLIP 0x01
25 #define S5K83A_HFLIP_TUNE 0x03
26 #define S5K83A_VFLIP_TUNE 0x05
27 #define S5K83A_WHITENESS 0x0a
28 #define S5K83A_GAIN 0x18
29 #define S5K83A_BRIGHTNESS 0x1b
30 #define S5K83A_PAGE_MAP 0xec
32 #define S5K83A_DEFAULT_BRIGHTNESS 0x71
33 #define S5K83A_DEFAULT_WHITENESS 0x7e
34 #define S5K83A_DEFAULT_GAIN 0x00
35 #define S5K83A_MAXIMUM_GAIN 0x3c
36 #define S5K83A_FLIP_MASK 0x10
39 /*****************************************************************************/
41 /* Kernel module parameters */
42 extern int force_sensor
;
43 extern int dump_sensor
;
45 int s5k83a_probe(struct sd
*sd
);
46 int s5k83a_init(struct sd
*sd
);
47 int s5k83a_power_down(struct sd
*sd
);
49 int s5k83a_set_brightness(struct gspca_dev
*gspca_dev
, __s32 val
);
50 int s5k83a_get_brightness(struct gspca_dev
*gspca_dev
, __s32
*val
);
51 int s5k83a_set_whiteness(struct gspca_dev
*gspca_dev
, __s32 val
);
52 int s5k83a_get_whiteness(struct gspca_dev
*gspca_dev
, __s32
*val
);
53 int s5k83a_set_gain(struct gspca_dev
*gspca_dev
, __s32 val
);
54 int s5k83a_get_gain(struct gspca_dev
*gspca_dev
, __s32
*val
);
55 int s5k83a_get_vflip(struct gspca_dev
*gspca_dev
, __s32
*val
);
56 int s5k83a_set_vflip(struct gspca_dev
*gspca_dev
, __s32 val
);
57 int s5k83a_get_hflip(struct gspca_dev
*gspca_dev
, __s32
*val
);
58 int s5k83a_set_hflip(struct gspca_dev
*gspca_dev
, __s32 val
);
60 static struct m5602_sensor s5k83a
= {
62 .probe
= s5k83a_probe
,
64 .power_down
= s5k83a_power_down
,
71 .id
= V4L2_CID_BRIGHTNESS
,
72 .type
= V4L2_CTRL_TYPE_INTEGER
,
77 .default_value
= S5K83A_DEFAULT_BRIGHTNESS
,
78 .flags
= V4L2_CTRL_FLAG_SLIDER
80 .set
= s5k83a_set_brightness
,
81 .get
= s5k83a_get_brightness
85 .id
= V4L2_CID_WHITENESS
,
86 .type
= V4L2_CTRL_TYPE_INTEGER
,
91 .default_value
= S5K83A_DEFAULT_WHITENESS
,
92 .flags
= V4L2_CTRL_FLAG_SLIDER
94 .set
= s5k83a_set_whiteness
,
95 .get
= s5k83a_get_whiteness
,
99 .type
= V4L2_CTRL_TYPE_INTEGER
,
102 .maximum
= S5K83A_MAXIMUM_GAIN
,
104 .default_value
= S5K83A_DEFAULT_GAIN
,
105 .flags
= V4L2_CTRL_FLAG_SLIDER
107 .set
= s5k83a_set_gain
,
108 .get
= s5k83a_get_gain
111 .id
= V4L2_CID_HFLIP
,
112 .type
= V4L2_CTRL_TYPE_BOOLEAN
,
113 .name
= "horizontal flip",
119 .set
= s5k83a_set_hflip
,
120 .get
= s5k83a_get_hflip
123 .id
= V4L2_CID_VFLIP
,
124 .type
= V4L2_CTRL_TYPE_BOOLEAN
,
125 .name
= "vertical flip",
131 .set
= s5k83a_set_vflip
,
132 .get
= s5k83a_get_vflip
138 M5602_DEFAULT_FRAME_WIDTH
,
139 M5602_DEFAULT_FRAME_HEIGHT
,
143 M5602_DEFAULT_FRAME_WIDTH
* M5602_DEFAULT_FRAME_HEIGHT
,
144 .bytesperline
= M5602_DEFAULT_FRAME_WIDTH
,
145 .colorspace
= V4L2_COLORSPACE_SRGB
,
151 static const unsigned char preinit_s5k83a
[][4] =
153 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02, 0x00},
154 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0, 0x00},
155 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
156 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
157 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
158 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x0d, 0x00},
159 {BRIDGE
, M5602_XB_SENSOR_CTRL
, 0x00, 0x00},
161 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
162 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
163 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x08, 0x00},
164 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x3f, 0x00},
165 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x3f, 0x00},
166 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
167 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0xff, 0x00},
168 {BRIDGE
, M5602_XB_GPIO_DIR_L
, 0xff, 0x00},
169 {BRIDGE
, M5602_XB_GPIO_DAT_L
, 0x00, 0x00},
170 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0xb0, 0x00},
171 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0x80, 0x00},
172 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
173 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
174 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
175 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
176 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02, 0x00},
177 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0, 0x00},
178 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
179 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xf0, 0x00},
180 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
181 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x1c, 0x00},
182 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06, 0x00},
183 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06, 0x00},
184 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
185 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00, 0x00},
186 {BRIDGE
, M5602_XB_I2C_CLK_DIV
, 0x20, 0x00},
188 {SENSOR
, S5K83A_PAGE_MAP
, 0x00, 0x00}
191 /* This could probably be considerably shortened.
192 I don't have the hardware to experiment with it, patches welcome
194 static const unsigned char init_s5k83a
[][4] =
196 {SENSOR
, S5K83A_PAGE_MAP
, 0x04, 0x00},
197 {SENSOR
, 0xaf, 0x01, 0x00},
198 {SENSOR
, S5K83A_PAGE_MAP
, 0x00, 0x00},
199 {SENSOR
, 0x7b, 0xff, 0x00},
200 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
201 {SENSOR
, 0x01, 0x50, 0x00},
202 {SENSOR
, 0x12, 0x20, 0x00},
203 {SENSOR
, 0x17, 0x40, 0x00},
204 {SENSOR
, S5K83A_BRIGHTNESS
, 0x0f, 0x00},
205 {SENSOR
, 0x1c, 0x00, 0x00},
206 {SENSOR
, 0x02, 0x70, 0x00},
207 {SENSOR
, 0x03, 0x0b, 0x00},
208 {SENSOR
, 0x04, 0xf0, 0x00},
209 {SENSOR
, 0x05, 0x0b, 0x00},
210 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
212 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x06, 0x00},
213 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
214 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
215 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
216 {BRIDGE
, M5602_XB_LINE_OF_FRAME_H
, 0x81, 0x00},
217 {BRIDGE
, M5602_XB_PIX_OF_LINE_H
, 0x82, 0x00},
218 {BRIDGE
, M5602_XB_SIG_INI
, 0x01, 0x00},
219 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
220 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
221 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
222 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
223 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x01, 0x00},
224 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0xe4, 0x00},
225 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
226 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
227 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
228 {BRIDGE
, M5602_XB_SIG_INI
, 0x02, 0x00},
229 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
230 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
231 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x02, 0x00},
232 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x87, 0x00},
233 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
234 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
235 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
237 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
238 {SENSOR
, 0x06, 0x71, 0x00},
239 {SENSOR
, 0x07, 0xe8, 0x00},
240 {SENSOR
, 0x08, 0x02, 0x00},
241 {SENSOR
, 0x09, 0x88, 0x00},
242 {SENSOR
, 0x14, 0x00, 0x00},
243 {SENSOR
, 0x15, 0x20, 0x00},
244 {SENSOR
, 0x19, 0x00, 0x00},
245 {SENSOR
, 0x1a, 0x98, 0x00},
246 {SENSOR
, 0x0f, 0x02, 0x00},
247 {SENSOR
, 0x10, 0xe5, 0x00},
248 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
249 {SENSOR_LONG
, 0x14, 0x00, 0x20},
250 {SENSOR_LONG
, 0x0d, 0x00, 0x7d},
251 {SENSOR_LONG
, 0x1b, 0x0d, 0x05},
253 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x06, 0x00},
254 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
255 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
256 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
257 {BRIDGE
, M5602_XB_LINE_OF_FRAME_H
, 0x81, 0x00},
258 {BRIDGE
, M5602_XB_PIX_OF_LINE_H
, 0x82, 0x00},
259 {BRIDGE
, M5602_XB_SIG_INI
, 0x01, 0x00},
260 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
261 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
262 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
263 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
264 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x01, 0x00},
265 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0xe4, 0x00},
266 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
267 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
268 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
269 {BRIDGE
, M5602_XB_SIG_INI
, 0x02, 0x00},
270 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
271 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
272 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x02, 0x00},
273 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x87, 0x00},
275 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
276 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
277 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x08, 0x00},
278 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x3f, 0x00},
279 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x3f, 0x00},
280 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
281 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0xff, 0x00},
282 {BRIDGE
, M5602_XB_GPIO_DIR_L
, 0xff, 0x00},
283 {BRIDGE
, M5602_XB_GPIO_DAT_L
, 0x00, 0x00},
284 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0xb0, 0x00},
285 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0x80, 0x00},
286 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
287 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
288 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
289 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
290 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02, 0x00},
291 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0, 0x00},
292 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
293 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xf0, 0x00},
294 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
295 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x1c, 0x00},
296 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06, 0x00},
297 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06, 0x00},
298 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
299 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00, 0x00},
300 {BRIDGE
, M5602_XB_I2C_CLK_DIV
, 0x20, 0x00},
302 {SENSOR
, S5K83A_PAGE_MAP
, 0x04, 0x00},
303 {SENSOR
, 0xaf, 0x01, 0x00},
304 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
305 /* ff ( init value )is very dark) || 71 and f0 better */
306 {SENSOR
, 0x7b, 0xff, 0x00},
307 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
308 {SENSOR
, 0x01, 0x50, 0x00},
309 {SENSOR
, 0x12, 0x20, 0x00},
310 {SENSOR
, 0x17, 0x40, 0x00},
311 {SENSOR
, S5K83A_BRIGHTNESS
, 0x0f, 0x00},
312 {SENSOR
, 0x1c, 0x00, 0x00},
313 {SENSOR
, 0x02, 0x70, 0x00},
314 /* some values like 0x10 give a blue-purple image */
315 {SENSOR
, 0x03, 0x0b, 0x00},
316 {SENSOR
, 0x04, 0xf0, 0x00},
317 {SENSOR
, 0x05, 0x0b, 0x00},
318 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
320 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x06, 0x00},
321 /* under 80 don't work, highter depend on value */
322 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
324 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
325 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
326 {BRIDGE
, M5602_XB_LINE_OF_FRAME_H
, 0x81, 0x00},
327 {BRIDGE
, M5602_XB_PIX_OF_LINE_H
, 0x82, 0x00},
328 {BRIDGE
, M5602_XB_SIG_INI
, 0x01, 0x00},
329 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
330 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
331 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
332 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
333 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x01, 0x00},
334 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0xe4, 0x00},
335 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
336 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
337 {BRIDGE
, M5602_XB_SIG_INI
, 0x02, 0x00},
338 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
339 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
340 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x02, 0x00},
341 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x7f, 0x00},
343 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
344 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
345 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
347 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
348 {SENSOR
, 0x06, 0x71, 0x00},
349 {SENSOR
, 0x07, 0xe8, 0x00},
350 {SENSOR
, 0x08, 0x02, 0x00},
351 {SENSOR
, 0x09, 0x88, 0x00},
352 {SENSOR
, 0x14, 0x00, 0x00},
353 {SENSOR
, 0x15, 0x20, 0x00},
354 {SENSOR
, 0x19, 0x00, 0x00},
355 {SENSOR
, 0x1a, 0x98, 0x00},
356 {SENSOR
, 0x0f, 0x02, 0x00},
357 {SENSOR
, 0x10, 0xe5, 0x00},
358 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
359 {SENSOR_LONG
, 0x14, 0x00, 0x20},
360 {SENSOR_LONG
, 0x0d, 0x00, 0x7d},
361 {SENSOR_LONG
, 0x1b, 0x0d, 0x05},
363 /* The following sequence is useless after a clean boot
364 but is necessary after resume from suspend */
365 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
366 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x08, 0x00},
367 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x3f, 0x00},
368 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x3f, 0x00},
369 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
370 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0xff, 0x00},
371 {BRIDGE
, M5602_XB_GPIO_DIR_L
, 0xff, 0x00},
372 {BRIDGE
, M5602_XB_GPIO_DAT_L
, 0x00, 0x00},
373 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0xb0, 0x00},
374 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0x80, 0x00},
375 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
376 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
377 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
378 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
379 {BRIDGE
, M5602_XB_MCU_CLK_DIV
, 0x02, 0x00},
380 {BRIDGE
, M5602_XB_MCU_CLK_CTRL
, 0xb0, 0x00},
381 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
382 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xf0, 0x00},
383 {BRIDGE
, M5602_XB_GPIO_DIR
, 0x1d, 0x00},
384 {BRIDGE
, M5602_XB_GPIO_DAT
, 0x1c, 0x00},
385 {BRIDGE
, M5602_XB_GPIO_EN_H
, 0x06, 0x00},
386 {BRIDGE
, M5602_XB_GPIO_DIR_H
, 0x06, 0x00},
387 {BRIDGE
, M5602_XB_GPIO_DAT_H
, 0x00, 0x00},
388 {BRIDGE
, M5602_XB_GPIO_EN_L
, 0x00, 0x00},
389 {BRIDGE
, M5602_XB_I2C_CLK_DIV
, 0x20, 0x00},
391 {SENSOR
, S5K83A_PAGE_MAP
, 0x04, 0x00},
392 {SENSOR
, 0xaf, 0x01, 0x00},
393 {SENSOR
, S5K83A_PAGE_MAP
, 0x00, 0x00},
394 {SENSOR
, 0x7b, 0xff, 0x00},
395 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
396 {SENSOR
, 0x01, 0x50, 0x00},
397 {SENSOR
, 0x12, 0x20, 0x00},
398 {SENSOR
, 0x17, 0x40, 0x00},
399 {SENSOR
, S5K83A_BRIGHTNESS
, 0x0f, 0x00},
400 {SENSOR
, 0x1c, 0x00, 0x00},
401 {SENSOR
, 0x02, 0x70, 0x00},
402 {SENSOR
, 0x03, 0x0b, 0x00},
403 {SENSOR
, 0x04, 0xf0, 0x00},
404 {SENSOR
, 0x05, 0x0b, 0x00},
405 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
407 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x06, 0x00},
408 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
409 {BRIDGE
, M5602_XB_ADC_CTRL
, 0xc0, 0x00},
410 {BRIDGE
, M5602_XB_SENSOR_TYPE
, 0x09, 0x00},
411 {BRIDGE
, M5602_XB_LINE_OF_FRAME_H
, 0x81, 0x00},
412 {BRIDGE
, M5602_XB_PIX_OF_LINE_H
, 0x82, 0x00},
413 {BRIDGE
, M5602_XB_SIG_INI
, 0x01, 0x00},
414 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
415 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
416 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
417 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
418 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x01, 0x00},
419 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0xe4, 0x00},
420 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
421 {BRIDGE
, M5602_XB_VSYNC_PARA
, 0x00, 0x00},
422 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
423 {BRIDGE
, M5602_XB_SIG_INI
, 0x02, 0x00},
424 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
425 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x00, 0x00},
426 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x02, 0x00},
427 {BRIDGE
, M5602_XB_HSYNC_PARA
, 0x7f, 0x00},
428 {BRIDGE
, M5602_XB_SIG_INI
, 0x00, 0x00},
429 {BRIDGE
, M5602_XB_SEN_CLK_DIV
, 0x00, 0x00},
430 {BRIDGE
, M5602_XB_SEN_CLK_CTRL
, 0xb0, 0x00},
432 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
433 {SENSOR
, 0x06, 0x71, 0x00},
434 {SENSOR
, 0x07, 0xe8, 0x00},
435 {SENSOR
, 0x08, 0x02, 0x00},
436 {SENSOR
, 0x09, 0x88, 0x00},
437 {SENSOR
, 0x14, 0x00, 0x00},
438 {SENSOR
, 0x15, 0x20, 0x00},
439 {SENSOR
, 0x19, 0x00, 0x00},
440 {SENSOR
, 0x1a, 0x98, 0x00},
441 {SENSOR
, 0x0f, 0x02, 0x00},
443 {SENSOR
, 0x10, 0xe5, 0x00},
444 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
445 {SENSOR_LONG
, 0x14, 0x00, 0x20},
446 {SENSOR_LONG
, 0x0d, 0x00, 0x7d},
447 {SENSOR_LONG
, 0x1b, 0x0d, 0x05},
450 (this is value after boot, but after tries can be different) */
451 {SENSOR
, 0x00, 0x06, 0x00},
453 /* set default brightness */
454 {SENSOR_LONG
, 0x14, 0x00, 0x20},
455 {SENSOR_LONG
, 0x0d, 0x01, 0x00},
456 {SENSOR_LONG
, 0x1b, S5K83A_DEFAULT_BRIGHTNESS
>> 3,
457 S5K83A_DEFAULT_BRIGHTNESS
>> 1},
459 /* set default whiteness */
460 {SENSOR
, S5K83A_WHITENESS
, S5K83A_DEFAULT_WHITENESS
, 0x00},
462 /* set default gain */
463 {SENSOR_LONG
, 0x18, 0x00, S5K83A_DEFAULT_GAIN
},
465 /* set default flip */
466 {SENSOR
, S5K83A_PAGE_MAP
, 0x05, 0x00},
467 {SENSOR
, S5K83A_FLIP
, 0x00 | S5K83A_FLIP_MASK
, 0x00},
468 {SENSOR
, S5K83A_HFLIP_TUNE
, 0x0b, 0x00},
469 {SENSOR
, S5K83A_VFLIP_TUNE
, 0x0a, 0x00}