V4L/DVB (13563): gspca - zc3xx: Bad sensor probe of the webcam 0ac8:305b.
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / drivers / media / video / gspca / zc3xx.c
1 /*
2 * Z-Star/Vimicro zc301/zc302p/vc30x library
3 * Copyright (C) 2004 2005 2006 Michel Xhaard
4 * mxhaard@magic.fr
5 *
6 * V4L2 by Jean-Francois Moine <http://moinejf.free.fr>
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 */
22
23 #define MODULE_NAME "zc3xx"
24
25 #include "gspca.h"
26 #include "jpeg.h"
27
28 MODULE_AUTHOR("Michel Xhaard <mxhaard@users.sourceforge.net>, "
29 "Serge A. Suchkov <Serge.A.S@tochka.ru>");
30 MODULE_DESCRIPTION("GSPCA ZC03xx/VC3xx USB Camera Driver");
31 MODULE_LICENSE("GPL");
32
33 static int force_sensor = -1;
34
35 #define QUANT_VAL 1 /* quantization table */
36 #include "zc3xx-reg.h"
37
38 /* specific webcam descriptor */
39 struct sd {
40 struct gspca_dev gspca_dev; /* !! must be the first item */
41
42 __u8 brightness;
43 __u8 contrast;
44 __u8 gamma;
45 __u8 autogain;
46 __u8 lightfreq;
47 __u8 sharpness;
48 u8 quality; /* image quality */
49 #define QUALITY_MIN 40
50 #define QUALITY_MAX 60
51 #define QUALITY_DEF 50
52
53 signed char sensor; /* Type of image sensor chip */
54 /* !! values used in different tables */
55 #define SENSOR_ADCM2700 0
56 #define SENSOR_CS2102 1
57 #define SENSOR_CS2102K 2
58 #define SENSOR_GC0305 3
59 #define SENSOR_HDCS2020b 4
60 #define SENSOR_HV7131B 5
61 #define SENSOR_HV7131C 6
62 #define SENSOR_ICM105A 7
63 #define SENSOR_MC501CB 8
64 #define SENSOR_MI0360SOC 9
65 #define SENSOR_OV7620 10
66 /*#define SENSOR_OV7648 10 - same values */
67 #define SENSOR_OV7630C 11
68 #define SENSOR_PAS106 12
69 #define SENSOR_PAS202B 13
70 #define SENSOR_PB0330 14 /* (MI0360) */
71 #define SENSOR_PO2030 15
72 #define SENSOR_TAS5130CK 16
73 #define SENSOR_TAS5130CXX 17
74 #define SENSOR_TAS5130C_VF0250 18
75 #define SENSOR_MAX 19
76 unsigned short chip_revision;
77
78 u8 *jpeg_hdr;
79 };
80
81 /* V4L2 controls supported by the driver */
82 static int sd_setbrightness(struct gspca_dev *gspca_dev, __s32 val);
83 static int sd_getbrightness(struct gspca_dev *gspca_dev, __s32 *val);
84 static int sd_setcontrast(struct gspca_dev *gspca_dev, __s32 val);
85 static int sd_getcontrast(struct gspca_dev *gspca_dev, __s32 *val);
86 static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val);
87 static int sd_getautogain(struct gspca_dev *gspca_dev, __s32 *val);
88 static int sd_setgamma(struct gspca_dev *gspca_dev, __s32 val);
89 static int sd_getgamma(struct gspca_dev *gspca_dev, __s32 *val);
90 static int sd_setfreq(struct gspca_dev *gspca_dev, __s32 val);
91 static int sd_getfreq(struct gspca_dev *gspca_dev, __s32 *val);
92 static int sd_setsharpness(struct gspca_dev *gspca_dev, __s32 val);
93 static int sd_getsharpness(struct gspca_dev *gspca_dev, __s32 *val);
94
95 static struct ctrl sd_ctrls[] = {
96 #define BRIGHTNESS_IDX 0
97 #define SD_BRIGHTNESS 0
98 {
99 {
100 .id = V4L2_CID_BRIGHTNESS,
101 .type = V4L2_CTRL_TYPE_INTEGER,
102 .name = "Brightness",
103 .minimum = 0,
104 .maximum = 255,
105 .step = 1,
106 .default_value = 128,
107 },
108 .set = sd_setbrightness,
109 .get = sd_getbrightness,
110 },
111 #define SD_CONTRAST 1
112 {
113 {
114 .id = V4L2_CID_CONTRAST,
115 .type = V4L2_CTRL_TYPE_INTEGER,
116 .name = "Contrast",
117 .minimum = 0,
118 .maximum = 256,
119 .step = 1,
120 .default_value = 128,
121 },
122 .set = sd_setcontrast,
123 .get = sd_getcontrast,
124 },
125 #define SD_GAMMA 2
126 {
127 {
128 .id = V4L2_CID_GAMMA,
129 .type = V4L2_CTRL_TYPE_INTEGER,
130 .name = "Gamma",
131 .minimum = 1,
132 .maximum = 6,
133 .step = 1,
134 .default_value = 4,
135 },
136 .set = sd_setgamma,
137 .get = sd_getgamma,
138 },
139 #define SD_AUTOGAIN 3
140 {
141 {
142 .id = V4L2_CID_AUTOGAIN,
143 .type = V4L2_CTRL_TYPE_BOOLEAN,
144 .name = "Auto Gain",
145 .minimum = 0,
146 .maximum = 1,
147 .step = 1,
148 .default_value = 1,
149 },
150 .set = sd_setautogain,
151 .get = sd_getautogain,
152 },
153 #define LIGHTFREQ_IDX 4
154 #define SD_FREQ 4
155 {
156 {
157 .id = V4L2_CID_POWER_LINE_FREQUENCY,
158 .type = V4L2_CTRL_TYPE_MENU,
159 .name = "Light frequency filter",
160 .minimum = 0,
161 .maximum = 2, /* 0: 0, 1: 50Hz, 2:60Hz */
162 .step = 1,
163 .default_value = 1,
164 },
165 .set = sd_setfreq,
166 .get = sd_getfreq,
167 },
168 #define SD_SHARPNESS 5
169 {
170 {
171 .id = V4L2_CID_SHARPNESS,
172 .type = V4L2_CTRL_TYPE_INTEGER,
173 .name = "Sharpness",
174 .minimum = 0,
175 .maximum = 3,
176 .step = 1,
177 .default_value = 2,
178 },
179 .set = sd_setsharpness,
180 .get = sd_getsharpness,
181 },
182 };
183
184 static const struct v4l2_pix_format vga_mode[] = {
185 {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
186 .bytesperline = 320,
187 .sizeimage = 320 * 240 * 3 / 8 + 590,
188 .colorspace = V4L2_COLORSPACE_JPEG,
189 .priv = 1},
190 {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
191 .bytesperline = 640,
192 .sizeimage = 640 * 480 * 3 / 8 + 590,
193 .colorspace = V4L2_COLORSPACE_JPEG,
194 .priv = 0},
195 };
196
197 static const struct v4l2_pix_format sif_mode[] = {
198 {176, 144, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
199 .bytesperline = 176,
200 .sizeimage = 176 * 144 * 3 / 8 + 590,
201 .colorspace = V4L2_COLORSPACE_JPEG,
202 .priv = 1},
203 {352, 288, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
204 .bytesperline = 352,
205 .sizeimage = 352 * 288 * 3 / 8 + 590,
206 .colorspace = V4L2_COLORSPACE_JPEG,
207 .priv = 0},
208 };
209
210 /* usb exchanges */
211 struct usb_action {
212 __u8 req;
213 __u8 val;
214 __u16 idx;
215 };
216
217 static const struct usb_action adcm2700_Initial[] = {
218 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
219 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
220 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
221 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
222 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
223 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
224 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
225 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
226 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
227 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
228 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
229 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
230 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
231 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
232 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
233 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
234 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
235 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
236 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
237 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
238 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
239 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
240 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
241 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
242 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
243 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
244 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
245 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
246 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
247 {0xa0, 0x58, ZC3XX_R116_RGAIN}, /* 01,16,58,cc */
248 {0xa0, 0x5a, ZC3XX_R118_BGAIN}, /* 01,18,5a,cc */
249 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
250 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
251 {0xbb, 0x00, 0x0408}, /* 04,00,08,bb */
252 {0xdd, 0x00, 0x0200}, /* 00,02,00,dd */
253 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
254 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
255 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
256 {0xbb, 0xe0, 0x0c2e}, /* 0c,e0,2e,bb */
257 {0xbb, 0x01, 0x2000}, /* 20,01,00,bb */
258 {0xbb, 0x96, 0x2400}, /* 24,96,00,bb */
259 {0xbb, 0x06, 0x1006}, /* 10,06,06,bb */
260 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
261 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
262 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
263 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
264 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
265 {0xbb, 0x5f, 0x2090}, /* 20,5f,90,bb */
266 {0xbb, 0x01, 0x8000}, /* 80,01,00,bb */
267 {0xbb, 0x09, 0x8400}, /* 84,09,00,bb */
268 {0xbb, 0x86, 0x0002}, /* 00,86,02,bb */
269 {0xbb, 0xe6, 0x0401}, /* 04,e6,01,bb */
270 {0xbb, 0x86, 0x0802}, /* 08,86,02,bb */
271 {0xbb, 0xe6, 0x0c01}, /* 0c,e6,01,bb */
272 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
273 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
274 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
275 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
276 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
277 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
278 {0xaa, 0xfe, 0x0020}, /* 00,fe,20,aa */
279 /*mswin+*/
280 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
281 {0xaa, 0xfe, 0x0002},
282 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
283 {0xaa, 0xb4, 0xcd37},
284 {0xaa, 0xa4, 0x0004},
285 {0xaa, 0xa8, 0x0007},
286 {0xaa, 0xac, 0x0004},
287 /*mswin-*/
288 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
289 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
290 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
291 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
292 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
293 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
294 {0xbb, 0x04, 0x0400}, /* 04,04,00,bb */
295 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
296 {0xbb, 0x01, 0x0400}, /* 04,01,00,bb */
297 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
298 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
299 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
300 {0xbb, 0x41, 0x2803}, /* 28,41,03,bb */
301 {0xbb, 0x40, 0x2c03}, /* 2c,40,03,bb */
302 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
303 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
304 {}
305 };
306 static const struct usb_action adcm2700_InitialScale[] = {
307 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
308 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
309 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
310 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
311 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
312 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
313 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
314 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
315 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
316 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
317 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
318 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
319 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
320 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
321 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
322 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
323 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
324 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
325 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
326 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
327 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
328 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
329 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
330 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
331 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
332 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
333 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
334 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
335 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
336 {0xa0, 0x58, ZC3XX_R116_RGAIN}, /* 01,16,58,cc */
337 {0xa0, 0x5a, ZC3XX_R118_BGAIN}, /* 01,18,5a,cc */
338 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
339 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
340 {0xbb, 0x00, 0x0408}, /* 04,00,08,bb */
341 {0xdd, 0x00, 0x0200}, /* 00,02,00,dd */
342 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
343 {0xdd, 0x00, 0x0050}, /* 00,00,50,dd */
344 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
345 {0xbb, 0xe0, 0x0c2e}, /* 0c,e0,2e,bb */
346 {0xbb, 0x01, 0x2000}, /* 20,01,00,bb */
347 {0xbb, 0x96, 0x2400}, /* 24,96,00,bb */
348 {0xbb, 0x06, 0x1006}, /* 10,06,06,bb */
349 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
350 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
351 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
352 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
353 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
354 {0xbb, 0x5f, 0x2090}, /* 20,5f,90,bb */
355 {0xbb, 0x01, 0x8000}, /* 80,01,00,bb */
356 {0xbb, 0x09, 0x8400}, /* 84,09,00,bb */
357 {0xbb, 0x86, 0x0002}, /* 00,88,02,bb */
358 {0xbb, 0xe6, 0x0401}, /* 04,e6,01,bb */
359 {0xbb, 0x86, 0x0802}, /* 08,88,02,bb */
360 {0xbb, 0xe6, 0x0c01}, /* 0c,e6,01,bb */
361 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
362 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
363 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
364 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
365 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
366 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
367 {0xaa, 0xfe, 0x0020}, /* 00,fe,20,aa */
368 /*******/
369 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
370 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
371 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
372 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
373 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
374 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
375 {0xbb, 0x04, 0x0400}, /* 04,04,00,bb */
376 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
377 {0xbb, 0x01, 0x0400}, /* 04,01,00,bb */
378 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
379 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
380 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
381 {0xbb, 0x41, 0x2803}, /* 28,41,03,bb */
382 {0xbb, 0x40, 0x2c03}, /* 2c,40,03,bb */
383 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
384 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
385 {}
386 };
387 static const struct usb_action adcm2700_50HZ[] = {
388 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
389 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
390 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
391 {0xbb, 0x05, 0x8400}, /* 84,05,00,bb */
392 {0xbb, 0xd0, 0xb007}, /* b0,d0,07,bb */
393 {0xbb, 0xa0, 0xb80f}, /* b8,a0,0f,bb */
394 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
395 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
396 {0xaa, 0x26, 0x00d0}, /* 00,26,d0,aa */
397 {0xaa, 0x28, 0x0002}, /* 00,28,02,aa */
398 {}
399 };
400 static const struct usb_action adcm2700_60HZ[] = {
401 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
402 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
403 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
404 {0xbb, 0x07, 0x8400}, /* 84,07,00,bb */
405 {0xbb, 0x82, 0xb006}, /* b0,82,06,bb */
406 {0xbb, 0x04, 0xb80d}, /* b8,04,0d,bb */
407 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
408 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
409 {0xaa, 0x26, 0x0057}, /* 00,26,57,aa */
410 {0xaa, 0x28, 0x0002}, /* 00,28,02,aa */
411 {}
412 };
413 static const struct usb_action adcm2700_NoFliker[] = {
414 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
415 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
416 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
417 {0xbb, 0x07, 0x8400}, /* 84,07,00,bb */
418 {0xbb, 0x05, 0xb000}, /* b0,05,00,bb */
419 {0xbb, 0xa0, 0xb801}, /* b8,a0,01,bb */
420 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
421 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
422 {}
423 };
424 static const struct usb_action cs2102_Initial[] = { /* 320x240 */
425 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
426 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
427 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
428 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
429 {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
430 {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
431 {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
432 {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
433 {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
434 {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
435 {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
436 {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
437 {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
438 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
439 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
440 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
441 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
442 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
443 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
444 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
445 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
446 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
447 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
448 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
449 {0xaa, 0x02, 0x0008},
450 {0xaa, 0x03, 0x0000},
451 {0xaa, 0x11, 0x0000},
452 {0xaa, 0x12, 0x0089},
453 {0xaa, 0x13, 0x0000},
454 {0xaa, 0x14, 0x00e9},
455 {0xaa, 0x20, 0x0000},
456 {0xaa, 0x22, 0x0000},
457 {0xaa, 0x0b, 0x0004},
458 {0xaa, 0x30, 0x0030},
459 {0xaa, 0x31, 0x0030},
460 {0xaa, 0x32, 0x0030},
461 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
462 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
463 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
464 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
465 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
466 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
467 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
468 {0xa0, 0x10, 0x01ae},
469 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
470 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
471 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
472 {0xa0, 0x00, 0x01ad},
473 {}
474 };
475
476 static const struct usb_action cs2102_InitialScale[] = { /* 640x480 */
477 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
478 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
479 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
480 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
481 {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
482 {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
483 {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
484 {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
485 {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
486 {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
487 {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
488 {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
489 {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
490 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
491 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
492 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
493 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
494 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
495 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
496 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
497 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
498 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
499 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
500 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
501 {0xaa, 0x02, 0x0008},
502 {0xaa, 0x03, 0x0000},
503 {0xaa, 0x11, 0x0001},
504 {0xaa, 0x12, 0x0087},
505 {0xaa, 0x13, 0x0001},
506 {0xaa, 0x14, 0x00e7},
507 {0xaa, 0x20, 0x0000},
508 {0xaa, 0x22, 0x0000},
509 {0xaa, 0x0b, 0x0004},
510 {0xaa, 0x30, 0x0030},
511 {0xaa, 0x31, 0x0030},
512 {0xaa, 0x32, 0x0030},
513 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
514 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
515 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
516 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
517 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
518 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
519 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
520 {0xa0, 0x15, 0x01ae},
521 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
522 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
523 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
524 {0xa0, 0x00, 0x01ad},
525 {}
526 };
527 static const struct usb_action cs2102_50HZ[] = {
528 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
529 {0xaa, 0x23, 0x0001},
530 {0xaa, 0x24, 0x005f},
531 {0xaa, 0x25, 0x0090},
532 {0xaa, 0x21, 0x00dd},
533 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
534 {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
535 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
536 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
537 {0xa0, 0x3a, ZC3XX_R196_ANTIFLICKERMID},
538 {0xa0, 0x98, ZC3XX_R197_ANTIFLICKERLOW},
539 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
540 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
541 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
542 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
543 {0xa0, 0xdd, ZC3XX_R01D_HSYNC_0},
544 {0xa0, 0xe4, ZC3XX_R01E_HSYNC_1},
545 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
546 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
547 {}
548 };
549 static const struct usb_action cs2102_50HZScale[] = {
550 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
551 {0xaa, 0x23, 0x0000},
552 {0xaa, 0x24, 0x00af},
553 {0xaa, 0x25, 0x00c8},
554 {0xaa, 0x21, 0x0068},
555 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
556 {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
557 {0xa0, 0x90, ZC3XX_R192_EXPOSURELIMITLOW},
558 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
559 {0xa0, 0x1d, ZC3XX_R196_ANTIFLICKERMID},
560 {0xa0, 0x4c, ZC3XX_R197_ANTIFLICKERLOW},
561 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
562 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
563 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
564 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
565 {0xa0, 0x68, ZC3XX_R01D_HSYNC_0},
566 {0xa0, 0xe3, ZC3XX_R01E_HSYNC_1},
567 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
568 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
569 {}
570 };
571 static const struct usb_action cs2102_60HZ[] = {
572 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
573 {0xaa, 0x23, 0x0001},
574 {0xaa, 0x24, 0x0055},
575 {0xaa, 0x25, 0x00cc},
576 {0xaa, 0x21, 0x003f},
577 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
578 {0xa0, 0xab, ZC3XX_R191_EXPOSURELIMITMID},
579 {0xa0, 0x98, ZC3XX_R192_EXPOSURELIMITLOW},
580 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
581 {0xa0, 0x30, ZC3XX_R196_ANTIFLICKERMID},
582 {0xa0, 0xd4, ZC3XX_R197_ANTIFLICKERLOW},
583 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
584 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
585 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
586 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
587 {0xa0, 0x39, ZC3XX_R01D_HSYNC_0},
588 {0xa0, 0x70, ZC3XX_R01E_HSYNC_1},
589 {0xa0, 0xb0, ZC3XX_R01F_HSYNC_2},
590 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
591 {}
592 };
593 static const struct usb_action cs2102_60HZScale[] = {
594 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
595 {0xaa, 0x23, 0x0000},
596 {0xaa, 0x24, 0x00aa},
597 {0xaa, 0x25, 0x00e6},
598 {0xaa, 0x21, 0x003f},
599 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
600 {0xa0, 0x55, ZC3XX_R191_EXPOSURELIMITMID},
601 {0xa0, 0xcc, ZC3XX_R192_EXPOSURELIMITLOW},
602 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
603 {0xa0, 0x18, ZC3XX_R196_ANTIFLICKERMID},
604 {0xa0, 0x6a, ZC3XX_R197_ANTIFLICKERLOW},
605 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
606 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
607 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
608 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
609 {0xa0, 0x3f, ZC3XX_R01D_HSYNC_0},
610 {0xa0, 0xa5, ZC3XX_R01E_HSYNC_1},
611 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
612 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
613 {}
614 };
615 static const struct usb_action cs2102_NoFliker[] = {
616 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
617 {0xaa, 0x23, 0x0001},
618 {0xaa, 0x24, 0x005f},
619 {0xaa, 0x25, 0x0000},
620 {0xaa, 0x21, 0x0001},
621 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
622 {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
623 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
624 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
625 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
626 {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
627 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
628 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
629 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
630 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
631 {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
632 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
633 {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
634 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
635 {}
636 };
637 static const struct usb_action cs2102_NoFlikerScale[] = {
638 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
639 {0xaa, 0x23, 0x0000},
640 {0xaa, 0x24, 0x00af},
641 {0xaa, 0x25, 0x0080},
642 {0xaa, 0x21, 0x0001},
643 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
644 {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
645 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},
646 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
647 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
648 {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
649 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
650 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
651 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
652 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
653 {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
654 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
655 {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
656 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
657 {}
658 };
659
660 /* CS2102_KOCOM */
661 static const struct usb_action cs2102K_Initial[] = {
662 {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
663 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
664 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
665 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
666 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
667 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
668 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
669 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
670 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
671 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
672 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
673 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
674 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
675 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
676 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
677 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
678 {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
679 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
680 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
681 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
682 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
683 {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
684 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
685 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
686 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
687 {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
688 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
689 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
690 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
691 {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
692 {0xa0, 0x7c, ZC3XX_R093_I2CSETVALUE},
693 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
694 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
695 {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
696 {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
697 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
698 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
699 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
700 {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
701 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
702 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
703 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
704 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
705 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
706 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
707 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
708 {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
709 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
710 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
711 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
712 {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
713 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
714 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
715 {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
716 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
717 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
718 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
719 {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
720 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
721 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
722 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
723 {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
724 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
725 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
726 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
727 {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
728 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
729 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
730 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
731 {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
732 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
733 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
734 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
735 {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
736 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
737 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
738 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
739 {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
740 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
741 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
742 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
743 {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
744 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
745 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
746 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
747 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
748 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
749 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
750 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
751 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
752 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
753 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
754 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
755 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
756 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
757 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
758 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
759 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
760 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
761 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
762 {0xa0, 0x00, 0x01ad},
763 {0xa0, 0x01, 0x01b1},
764 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
765 {0xa0, 0x60, ZC3XX_R116_RGAIN},
766 {0xa0, 0x40, ZC3XX_R117_GGAIN},
767 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
768 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
769 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
770 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
771 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
772 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
773 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
774 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
775 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
776 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
777 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
778 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
779 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
780 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
781 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
782 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
783 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
784 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
785 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
786 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
787 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
788 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
789 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
790 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
791 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
792 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
793 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
794 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
795 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
796 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
797 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
798 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
799 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
800 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
801 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
802 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
803 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
804 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
805 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
806 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
807 {0xa0, 0x58, ZC3XX_R10E_RGB11},
808 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
809 {0xa0, 0xf4, ZC3XX_R110_RGB20},
810 {0xa0, 0xf4, ZC3XX_R111_RGB21},
811 {0xa0, 0x58, ZC3XX_R112_RGB22},
812 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
813 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
814 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
815 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
816 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
817 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
818 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
819 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
820 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
821 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
822 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
823 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
824 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
825 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
826 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
827 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
828 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
829 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
830 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
831 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
832 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
833 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
834 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
835 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
836 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
837 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
838 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
839 {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
840 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
841 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
842 {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
843 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
844 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
845 {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
846 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
847 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
848 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
849 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
850 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
851 {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
852 {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
853 {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
854 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
855 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
856 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
857 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
858 {0xa0, 0x60, ZC3XX_R116_RGAIN},
859 {0xa0, 0x40, ZC3XX_R117_GGAIN},
860 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
861 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
862 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
863 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
864 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
865 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
866 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
867 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
868 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
869 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
870 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
871 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
872 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
873 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
874 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
875 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
876 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
877 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
878 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
879 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
880 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
881 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
882 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
883 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
884 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
885 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
886 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
887 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
888 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
889 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
890 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
891 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
892 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
893 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
894 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
895 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
896 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
897 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
898 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
899 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
900 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
901 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
902 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
903 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
904 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
905 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
906 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
907 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
908 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
909 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
910 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
911 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
912 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
913 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
914 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
915 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
916 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
917 {}
918 };
919
920 static const struct usb_action cs2102K_InitialScale[] = {
921 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
922 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
923 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
924 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
925 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
926 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
927 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
928 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
929 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
930 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
931 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
932 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
933 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
934 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
935 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
936 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
937 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
938 /*fixme: next sequence = i2c exchanges*/
939 {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
940 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
941 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
942 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
943 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
944 {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
945 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
946 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
947 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
948 {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
949 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
950 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
951 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
952 {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
953 {0xa0, 0x7b, ZC3XX_R093_I2CSETVALUE},
954 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
955 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
956 {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
957 {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
958 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
959 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
960 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
961 {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
962 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
963 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
964 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
965 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
966 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
967 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
968 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
969 {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
970 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
971 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
972 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
973 {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
974 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
975 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
976 {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
977 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
978 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
979 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
980 {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
981 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
982 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
983 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
984 {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
985 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
986 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
987 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
988 {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
989 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
990 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
991 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
992 {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
993 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
994 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
995 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
996 {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
997 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
998 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
999 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1000 {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
1001 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
1002 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1003 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1004 {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
1005 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
1006 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1007 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1008 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1009 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1010 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1011 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1012 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
1013 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1014 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
1015 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1016 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1017 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1018 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1019 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
1020 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
1021 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1022 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1023 {0xa0, 0x00, 0x01ad},
1024 {0xa0, 0x01, 0x01b1},
1025 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1026 {0xa0, 0x60, ZC3XX_R116_RGAIN},
1027 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1028 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
1029 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
1030 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
1031 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
1032 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
1033 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1034 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1035 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1036 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1037 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1038 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1039 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1040 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1041 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1042 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1043 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1044 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1045 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1046 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1047 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1048 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1049 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1050 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1051 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1052 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1053 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1054 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1055 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1056 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1057 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1058 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1059 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1060 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1061 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1062 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1063 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1064 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
1065 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
1066 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
1067 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
1068 {0xa0, 0x58, ZC3XX_R10E_RGB11},
1069 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
1070 {0xa0, 0xf4, ZC3XX_R110_RGB20},
1071 {0xa0, 0xf4, ZC3XX_R111_RGB21},
1072 {0xa0, 0x58, ZC3XX_R112_RGB22},
1073 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1074 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1075 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1076 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1077 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1078 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1079 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1080 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1081 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1082 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1083 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1084 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1085 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1086 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1087 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1088 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1089 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1090 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1091 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1092 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1093 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1094 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1095 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1096 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1097 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1098 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1099 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
1100 {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
1101 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1102 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
1103 {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
1104 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1105 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1106 {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
1107 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1108 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1109 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1110 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1111 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1112 {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
1113 {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
1114 {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
1115 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1116 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1117 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1118 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1119 {0xa0, 0x60, ZC3XX_R116_RGAIN},
1120 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1121 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
1122 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1123 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1124 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1125 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1126 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1127 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1128 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1129 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1130 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1131 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1132 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1133 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1134 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1135 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1136 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1137 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1138 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1139 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1140 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1141 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1142 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1143 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1144 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1145 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1146 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1147 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1148 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1149 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1150 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1151 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1152 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1153 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1154 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1155 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1156 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1157 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1158 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1159 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1160 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1161 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1162 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1163 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1164 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1165 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1166 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1167 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1168 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1169 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1170 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1171 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1172 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1173 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1174 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1175 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1176 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1177 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1178 /*fixme:what does the next sequence?*/
1179 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1180 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1181 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1182 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1183 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1184 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1185 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1186 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1187 {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1188 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1189 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1190 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1191 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1192 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1193 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1194 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1195 {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1196 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1197 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1198 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1199 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1200 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1201 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1202 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1203 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1204 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1205 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1206 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1207 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},
1208 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1209 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1210 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1211 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1212 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1213 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1214 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1215 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1216 {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1217 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1218 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1219 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1220 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1221 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1222 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1223 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1224 {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1225 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1226 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1227 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1228 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1229 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1230 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1231 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1232 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1233 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1234 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1235 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1236 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1237 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1238 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1239 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1240 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1241 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1242 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1243 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1244 {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1245 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1246 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1247 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1248 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1249 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1250 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1251 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1252 {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1253 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1254 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1255 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1256 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1257 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1258 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1259 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1260 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1261 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1262 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1263 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1264 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1265 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1266 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1267 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1268 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1269 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1270 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1271 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1272 {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1273 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1274 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1275 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1276 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1277 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1278 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1279 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1280 {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1281 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1282 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1283 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1284 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1285 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1286 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1287 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1288 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1289 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1290 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1291 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1292 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1293 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1294 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1295 {}
1296 };
1297
1298 static const struct usb_action gc0305_Initial[] = { /* 640x480 */
1299 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1300 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
1301 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
1302 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
1303 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
1304 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1305 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
1306 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
1307 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
1308 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
1309 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
1310 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
1311 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
1312 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
1313 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
1314 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
1315 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
1316 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
1317 {0xaa, 0x13, 0x0002}, /* 00,13,02,aa */
1318 {0xaa, 0x15, 0x0003}, /* 00,15,03,aa */
1319 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
1320 {0xaa, 0x02, 0x0000}, /* 00,02,00,aa */
1321 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
1322 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa */
1323 {0xaa, 0x1d, 0x0080}, /* 00,1d,80,aa */
1324 {0xaa, 0x1f, 0x0008}, /* 00,1f,08,aa */
1325 {0xaa, 0x21, 0x0012}, /* 00,21,12,aa */
1326 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc */
1327 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc */
1328 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc */
1329 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
1330 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa */
1331 {0xaa, 0x0b, 0x00b0}, /* 00,0b,b0,aa */
1332 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa */
1333 {0xaa, 0x0d, 0x00b0}, /* 00,0d,b0,aa */
1334 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa */
1335 {0xaa, 0x0f, 0x00b0}, /* 00,0f,b0,aa */
1336 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
1337 {0xaa, 0x11, 0x00b0}, /* 00,11,b0,aa */
1338 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa */
1339 {0xaa, 0x17, 0x00e6}, /* 00,17,e6,aa */
1340 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa */
1341 {0xaa, 0x19, 0x0086}, /* 00,19,86,aa */
1342 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1343 {0xaa, 0x1b, 0x0020}, /* 00,1b,20,aa */
1344 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
1345 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
1346 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1347 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc */
1348 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc */
1349 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1350 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
1351 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
1352 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
1353 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
1354 {0xa0, 0x85, ZC3XX_R18D_YTARGET}, /* 01,8d,85,cc */
1355 {0xa0, 0x00, 0x011e}, /* 01,1e,00,cc */
1356 {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1357 {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1358 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1359 {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
1360 {}
1361 };
1362 static const struct usb_action gc0305_InitialScale[] = { /* 320x240 */
1363 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1364 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
1365 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
1366 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
1367 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
1368 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1369 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
1370 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
1371 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
1372 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
1373 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
1374 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
1375 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
1376 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
1377 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
1378 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc */
1379 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
1380 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
1381 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
1382 {0xaa, 0x15, 0x0001}, /* 00,15,01,aa */
1383 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
1384 {0xaa, 0x02, 0x0000}, /* 00,02,00,aa */
1385 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
1386 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa */
1387 {0xaa, 0x1d, 0x0080}, /* 00,1d,80,aa */
1388 {0xaa, 0x1f, 0x0008}, /* 00,1f,08,aa */
1389 {0xaa, 0x21, 0x0012}, /* 00,21,12,aa */
1390 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc */
1391 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc */
1392 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc */
1393 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
1394 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa */
1395 {0xaa, 0x0b, 0x00b0}, /* 00,0b,b0,aa */
1396 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa */
1397 {0xaa, 0x0d, 0x00b0}, /* 00,0d,b0,aa */
1398 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa */
1399 {0xaa, 0x0f, 0x00b0}, /* 00,0f,b0,aa */
1400 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
1401 {0xaa, 0x11, 0x00b0}, /* 00,11,b0,aa */
1402 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa */
1403 {0xaa, 0x17, 0x00e8}, /* 00,17,e8,aa */
1404 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa */
1405 {0xaa, 0x19, 0x0088}, /* 00,19,88,aa */
1406 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1407 {0xaa, 0x1b, 0x0020}, /* 00,1b,20,aa */
1408 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
1409 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
1410 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1411 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc */
1412 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc */
1413 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1414 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
1415 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
1416 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
1417 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
1418 {0xa0, 0x00, 0x011e}, /* 01,1e,00,cc */
1419 {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1420 {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1421 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1422 {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
1423 {}
1424 };
1425 static const struct usb_action gc0305_50HZ[] = {
1426 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1427 {0xaa, 0x83, 0x0002}, /* 00,83,02,aa */
1428 {0xaa, 0x84, 0x0038}, /* 00,84,38,aa */ /* win: 00,84,ec */
1429 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1430 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0b,cc */
1431 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
1432 /* win: 01,92,10 */
1433 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1434 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1435 {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,8e,cc */
1436 /* win: 01,97,ec */
1437 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1438 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1439 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
1440 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1441 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1442 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1443 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1444 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1445 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1446 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
1447 /* {0xa0, 0x85, ZC3XX_R18D_YTARGET}, * 01,8d,85,cc *
1448 * if 640x480 */
1449 {}
1450 };
1451 static const struct usb_action gc0305_60HZ[] = {
1452 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1453 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
1454 {0xaa, 0x84, 0x00ec}, /* 00,84,ec,aa */
1455 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1456 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0b,cc */
1457 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc */
1458 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1459 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1460 {0xa0, 0xec, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,ec,cc */
1461 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1462 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1463 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
1464 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1465 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1466 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1467 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1468 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1469 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1470 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
1471 {0xa0, 0x80, ZC3XX_R18D_YTARGET}, /* 01,8d,80,cc */
1472 {}
1473 };
1474
1475 static const struct usb_action gc0305_NoFliker[] = {
1476 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc */
1477 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1478 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
1479 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
1480 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1481 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,00,cc */
1482 {0xa0, 0x48, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,48,cc */
1483 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1484 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1485 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
1486 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1487 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1488 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1489 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1490 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1491 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1492 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1493 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
1494 {0xa0, 0x80, ZC3XX_R18D_YTARGET}, /* 01,8d,80,cc */
1495 {}
1496 };
1497
1498 static const struct usb_action hdcs2020xb_Initial[] = {
1499 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1500 {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
1501 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* qtable 0x05 */
1502 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1503 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1504 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1505 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1506 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1507 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1508 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1509 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1510 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1511 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1512 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1513 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1514 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1515 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
1516 {0xaa, 0x1c, 0x0000},
1517 {0xaa, 0x0a, 0x0001},
1518 {0xaa, 0x0b, 0x0006},
1519 {0xaa, 0x0c, 0x007b},
1520 {0xaa, 0x0d, 0x00a7},
1521 {0xaa, 0x03, 0x00fb},
1522 {0xaa, 0x05, 0x0000},
1523 {0xaa, 0x06, 0x0003},
1524 {0xaa, 0x09, 0x0008},
1525
1526 {0xaa, 0x0f, 0x0018}, /* set sensor gain */
1527 {0xaa, 0x10, 0x0018},
1528 {0xaa, 0x11, 0x0018},
1529 {0xaa, 0x12, 0x0018},
1530
1531 {0xaa, 0x15, 0x004e},
1532 {0xaa, 0x1c, 0x0004},
1533 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
1534 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1535 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1536 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1537 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1538 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1539 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1540 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1541 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1542 {0xa1, 0x01, 0x0002},
1543 {0xa1, 0x01, 0x0008},
1544 {0xa1, 0x01, 0x0180},
1545 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1546 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1547 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1548 {0xa0, 0x40, ZC3XX_R118_BGAIN},
1549 {0xa1, 0x01, 0x0008},
1550 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
1551 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
1552 {0xa1, 0x01, 0x01c8},
1553 {0xa1, 0x01, 0x01c9},
1554 {0xa1, 0x01, 0x01ca},
1555 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
1556 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
1557 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1558 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1559 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1560 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1561 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1562 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1563 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1564 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1565 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1566 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1567 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1568 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1569 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1570 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1571 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1572 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1573 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1574 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1575 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1576 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1577 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1578 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1579 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1580 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1581 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1582 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1583 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1584 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1585 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1586 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1587 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1588
1589 {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1590 {0xa0, 0xed, ZC3XX_R10B_RGB01},
1591 {0xa0, 0xed, ZC3XX_R10C_RGB02},
1592 {0xa0, 0xed, ZC3XX_R10D_RGB10},
1593 {0xa0, 0x66, ZC3XX_R10E_RGB11},
1594 {0xa0, 0xed, ZC3XX_R10F_RGB12},
1595 {0xa0, 0xed, ZC3XX_R110_RGB20},
1596 {0xa0, 0xed, ZC3XX_R111_RGB21},
1597 {0xa0, 0x66, ZC3XX_R112_RGB22},
1598
1599 {0xa1, 0x01, 0x0180},
1600 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1601 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1602 {0xaa, 0x13, 0x0031},
1603 {0xaa, 0x14, 0x0001},
1604 {0xaa, 0x0e, 0x0004},
1605 {0xaa, 0x19, 0x00cd},
1606 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1607 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1608 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1609 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1610 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1611 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1612 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1613 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1614
1615 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 0x14 */
1616 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1617 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1618 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1619 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1620 {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1621 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1622 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1623 {0xa1, 0x01, 0x0180},
1624 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1625 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1626 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1627 {0xa0, 0x40, ZC3XX_R118_BGAIN},
1628 {}
1629 };
1630 static const struct usb_action hdcs2020xb_InitialScale[] = {
1631 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1632 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1633 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
1634 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1635 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1636 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1637 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1638 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1639 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1640 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1641 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1642 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1643 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1644 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1645 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1646 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1647 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
1648 {0xaa, 0x1c, 0x0000},
1649 {0xaa, 0x0a, 0x0001},
1650 {0xaa, 0x0b, 0x0006},
1651 {0xaa, 0x0c, 0x007a},
1652 {0xaa, 0x0d, 0x00a7},
1653 {0xaa, 0x03, 0x00fb},
1654 {0xaa, 0x05, 0x0000},
1655 {0xaa, 0x06, 0x0003},
1656 {0xaa, 0x09, 0x0008},
1657 {0xaa, 0x0f, 0x0018}, /* original setting */
1658 {0xaa, 0x10, 0x0018},
1659 {0xaa, 0x11, 0x0018},
1660 {0xaa, 0x12, 0x0018},
1661 {0xaa, 0x15, 0x004e},
1662 {0xaa, 0x1c, 0x0004},
1663 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
1664 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1665 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1666 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1667 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1668 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1669 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1670 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1671 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1672 {0xa1, 0x01, 0x0002},
1673 {0xa1, 0x01, 0x0008},
1674 {0xa1, 0x01, 0x0180},
1675 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1676 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1677 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1678 {0xa0, 0x40, ZC3XX_R118_BGAIN},
1679 {0xa1, 0x01, 0x0008},
1680 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
1681 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
1682 {0xa1, 0x01, 0x01c8},
1683 {0xa1, 0x01, 0x01c9},
1684 {0xa1, 0x01, 0x01ca},
1685 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
1686 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
1687 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1688 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1689 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1690 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1691 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1692 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1693 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1694 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1695 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1696 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1697 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1698 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1699 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1700 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1701 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1702 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1703 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1704 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1705 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1706 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1707 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1708 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1709 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1710 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1711 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1712 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1713 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1714 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1715 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1716 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1717 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1718 {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1719 {0xa0, 0xed, ZC3XX_R10B_RGB01},
1720 {0xa0, 0xed, ZC3XX_R10C_RGB02},
1721 {0xa0, 0xed, ZC3XX_R10D_RGB10},
1722 {0xa0, 0x66, ZC3XX_R10E_RGB11},
1723 {0xa0, 0xed, ZC3XX_R10F_RGB12},
1724 {0xa0, 0xed, ZC3XX_R110_RGB20},
1725 {0xa0, 0xed, ZC3XX_R111_RGB21},
1726 {0xa0, 0x66, ZC3XX_R112_RGB22},
1727 {0xa1, 0x01, 0x0180},
1728 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1729 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1730 /**** set exposure ***/
1731 {0xaa, 0x13, 0x0031},
1732 {0xaa, 0x14, 0x0001},
1733 {0xaa, 0x0e, 0x0004},
1734 {0xaa, 0x19, 0x00cd},
1735 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1736 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1737 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1738 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1739 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1740 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1741 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1742 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1743 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1744 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1745 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1746 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1747 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1748 {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1749 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1750 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1751 {0xa1, 0x01, 0x0180},
1752 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1753 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1754 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1755 {0xa0, 0x40, ZC3XX_R118_BGAIN},
1756 {}
1757 };
1758 static const struct usb_action hdcs2020b_50HZ[] = {
1759 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1760 {0xaa, 0x13, 0x0018}, /* 00,13,18,aa */
1761 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1762 {0xaa, 0x0e, 0x0005}, /* 00,0e,05,aa */
1763 {0xaa, 0x19, 0x001f}, /* 00,19,1f,aa */
1764 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1765 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1766 {0xa0, 0x76, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,76,cc */
1767 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1768 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1769 {0xa0, 0x46, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,46,cc */
1770 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1771 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1772 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1773 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1774 {0xa0, 0x05, ZC3XX_R01D_HSYNC_0}, /* 00,1d,05,cc */
1775 {0xa0, 0x1a, ZC3XX_R01E_HSYNC_1}, /* 00,1e,1a,cc */
1776 {0xa0, 0x2f, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2f,cc */
1777 {}
1778 };
1779 static const struct usb_action hdcs2020b_60HZ[] = {
1780 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1781 {0xaa, 0x13, 0x0031}, /* 00,13,31,aa */
1782 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1783 {0xaa, 0x0e, 0x0004}, /* 00,0e,04,aa */
1784 {0xaa, 0x19, 0x00cd}, /* 00,19,cd,aa */
1785 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1786 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1787 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,62,cc */
1788 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1789 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1790 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3d,cc */
1791 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1792 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1793 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1794 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1795 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1796 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1}, /* 00,1e,18,cc */
1797 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2c,cc */
1798 {}
1799 };
1800 static const struct usb_action hdcs2020b_NoFliker[] = {
1801 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1802 {0xaa, 0x13, 0x0010}, /* 00,13,10,aa */
1803 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1804 {0xaa, 0x0e, 0x0004}, /* 00,0e,04,aa */
1805 {0xaa, 0x19, 0x0000}, /* 00,19,00,aa */
1806 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1807 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1808 {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
1809 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1810 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1811 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
1812 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1813 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1814 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
1815 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
1816 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1817 {0xa0, 0x17, ZC3XX_R01E_HSYNC_1}, /* 00,1e,17,cc */
1818 {0xa0, 0x2a, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2a,cc */
1819 {}
1820 };
1821
1822 static const struct usb_action hv7131bxx_Initial[] = { /* 320x240 */
1823 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1824 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
1825 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1826 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1827 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
1828 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
1829 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1830 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1831 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1832 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1833 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1834 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1835 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1836 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1837 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1838 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1839 {0xaa, 0x30, 0x002d},
1840 {0xaa, 0x01, 0x0005},
1841 {0xaa, 0x11, 0x0000},
1842 {0xaa, 0x13, 0x0001}, /* {0xaa, 0x13, 0x0000}, */
1843 {0xaa, 0x14, 0x0001},
1844 {0xaa, 0x15, 0x00e8},
1845 {0xaa, 0x16, 0x0002},
1846 {0xaa, 0x17, 0x0086}, /* 00,17,88,aa */
1847 {0xaa, 0x31, 0x0038},
1848 {0xaa, 0x32, 0x0038},
1849 {0xaa, 0x33, 0x0038},
1850 {0xaa, 0x5b, 0x0001},
1851 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1852 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1853 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1854 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
1855 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
1856 {0xa0, 0x00, 0x01ad},
1857 {0xa0, 0xc0, 0x019b},
1858 {0xa0, 0xa0, 0x019c},
1859 {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1860 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1861 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1862 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1863 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1864 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1865 {0xaa, 0x02, 0x0090}, /* 00,02,80,aa */
1866 {}
1867 };
1868
1869 static const struct usb_action hv7131bxx_InitialScale[] = { /* 640x480*/
1870 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1871 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1872 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1873 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1874 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
1875 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
1876 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1877 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1878 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1879 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1880 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1881 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1882 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1883 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1884 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1885 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1886 {0xaa, 0x30, 0x002d},
1887 {0xaa, 0x01, 0x0005},
1888 {0xaa, 0x11, 0x0001},
1889 {0xaa, 0x13, 0x0000}, /* {0xaa, 0x13, 0x0001}; */
1890 {0xaa, 0x14, 0x0001},
1891 {0xaa, 0x15, 0x00e6},
1892 {0xaa, 0x16, 0x0002},
1893 {0xaa, 0x17, 0x0086},
1894 {0xaa, 0x31, 0x0038},
1895 {0xaa, 0x32, 0x0038},
1896 {0xaa, 0x33, 0x0038},
1897 {0xaa, 0x5b, 0x0001},
1898 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1899 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1900 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1901 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1902 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
1903 {0xa0, 0x00, 0x01ad},
1904 {0xa0, 0xc0, 0x019b},
1905 {0xa0, 0xa0, 0x019c},
1906 {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1907 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1908 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1909 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1910 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1911 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1912 {0xaa, 0x02, 0x0090}, /* {0xaa, 0x02, 0x0080}, */
1913 {}
1914 };
1915 static const struct usb_action hv7131b_50HZ[] = { /* 640x480*/
1916 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1917 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1918 {0xaa, 0x26, 0x0053}, /* 00,26,53,aa */
1919 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1920 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1921 {0xaa, 0x21, 0x0050}, /* 00,21,50,aa */
1922 {0xaa, 0x22, 0x001b}, /* 00,22,1b,aa */
1923 {0xaa, 0x23, 0x00fc}, /* 00,23,fc,aa */
1924 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1925 {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,9b,cc */
1926 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
1927 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1928 {0xa0, 0xea, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,ea,cc */
1929 {0xa0, 0x60, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,60,cc */
1930 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
1931 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
1932 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1933 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1934 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1935 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1}, /* 00,1e,50,cc */
1936 {0xa0, 0x1b, ZC3XX_R01F_HSYNC_2}, /* 00,1f,1b,cc */
1937 {0xa0, 0xfc, ZC3XX_R020_HSYNC_3}, /* 00,20,fc,cc */
1938 {}
1939 };
1940 static const struct usb_action hv7131b_50HZScale[] = { /* 320x240 */
1941 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1942 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1943 {0xaa, 0x26, 0x0053}, /* 00,26,53,aa */
1944 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1945 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1946 {0xaa, 0x21, 0x0050}, /* 00,21,50,aa */
1947 {0xaa, 0x22, 0x0012}, /* 00,22,12,aa */
1948 {0xaa, 0x23, 0x0080}, /* 00,23,80,aa */
1949 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1950 {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,9b,cc */
1951 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
1952 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,01,cc */
1953 {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,d4,cc */
1954 {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,c0,cc */
1955 {0xa0, 0x07, ZC3XX_R18C_AEFREEZE}, /* 01,8c,07,cc */
1956 {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,0f,cc */
1957 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1958 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1959 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1960 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1}, /* 00,1e,50,cc */
1961 {0xa0, 0x12, ZC3XX_R01F_HSYNC_2}, /* 00,1f,12,cc */
1962 {0xa0, 0x80, ZC3XX_R020_HSYNC_3}, /* 00,20,80,cc */
1963 {}
1964 };
1965 static const struct usb_action hv7131b_60HZ[] = { /* 640x480*/
1966 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1967 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1968 {0xaa, 0x26, 0x00a1}, /* 00,26,a1,aa */
1969 {0xaa, 0x27, 0x0020}, /* 00,27,20,aa */
1970 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1971 {0xaa, 0x21, 0x0040}, /* 00,21,40,aa */
1972 {0xaa, 0x22, 0x0013}, /* 00,22,13,aa */
1973 {0xaa, 0x23, 0x004c}, /* 00,23,4c,aa */
1974 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1975 {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,4d,cc */
1976 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,60,cc */
1977 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1978 {0xa0, 0xc3, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,c3,cc */
1979 {0xa0, 0x50, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,50,cc */
1980 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
1981 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
1982 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1983 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1984 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1985 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1}, /* 00,1e,40,cc */
1986 {0xa0, 0x13, ZC3XX_R01F_HSYNC_2}, /* 00,1f,13,cc */
1987 {0xa0, 0x4c, ZC3XX_R020_HSYNC_3}, /* 00,20,4c,cc */
1988 {}
1989 };
1990 static const struct usb_action hv7131b_60HZScale[] = { /* 320x240 */
1991 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1992 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1993 {0xaa, 0x26, 0x00a1}, /* 00,26,a1,aa */
1994 {0xaa, 0x27, 0x0020}, /* 00,27,20,aa */
1995 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1996 {0xaa, 0x21, 0x00a0}, /* 00,21,a0,aa */
1997 {0xaa, 0x22, 0x0016}, /* 00,22,16,aa */
1998 {0xaa, 0x23, 0x0040}, /* 00,23,40,aa */
1999 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
2000 {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,4d,cc */
2001 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,60,cc */
2002 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,01,cc */
2003 {0xa0, 0x86, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,86,cc */
2004 {0xa0, 0xa0, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,a0,cc */
2005 {0xa0, 0x07, ZC3XX_R18C_AEFREEZE}, /* 01,8c,07,cc */
2006 {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,0f,cc */
2007 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
2008 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
2009 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
2010 {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,a0,cc */
2011 {0xa0, 0x16, ZC3XX_R01F_HSYNC_2}, /* 00,1f,16,cc */
2012 {0xa0, 0x40, ZC3XX_R020_HSYNC_3}, /* 00,20,40,cc */
2013 {}
2014 };
2015 static const struct usb_action hv7131b_NoFliker[] = { /* 640x480*/
2016 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2017 {0xaa, 0x25, 0x0003}, /* 00,25,03,aa */
2018 {0xaa, 0x26, 0x0000}, /* 00,26,00,aa */
2019 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
2020 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
2021 {0xaa, 0x21, 0x0010}, /* 00,21,10,aa */
2022 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2023 {0xaa, 0x23, 0x0003}, /* 00,23,03,aa */
2024 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
2025 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,f8,cc */
2026 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,00,cc */
2027 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2028 {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,02,cc */
2029 {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,00,cc */
2030 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2031 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2032 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2033 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2034 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
2035 {0xa0, 0x10, ZC3XX_R01E_HSYNC_1}, /* 00,1e,10,cc */
2036 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2}, /* 00,1f,00,cc */
2037 {0xa0, 0x03, ZC3XX_R020_HSYNC_3}, /* 00,20,03,cc */
2038 {}
2039 };
2040 static const struct usb_action hv7131b_NoFlikerScale[] = { /* 320x240 */
2041 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2042 {0xaa, 0x25, 0x0003}, /* 00,25,03,aa */
2043 {0xaa, 0x26, 0x0000}, /* 00,26,00,aa */
2044 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
2045 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
2046 {0xaa, 0x21, 0x00a0}, /* 00,21,a0,aa */
2047 {0xaa, 0x22, 0x0016}, /* 00,22,16,aa */
2048 {0xaa, 0x23, 0x0040}, /* 00,23,40,aa */
2049 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
2050 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,f8,cc */
2051 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,00,cc */
2052 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2053 {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,02,cc */
2054 {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,00,cc */
2055 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2056 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2057 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2058 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2059 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
2060 {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,a0,cc */
2061 {0xa0, 0x16, ZC3XX_R01F_HSYNC_2}, /* 00,1f,16,cc */
2062 {0xa0, 0x40, ZC3XX_R020_HSYNC_3}, /* 00,20,40,cc */
2063 {}
2064 };
2065
2066 static const struct usb_action hv7131cxx_Initial[] = {
2067 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2068 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
2069 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
2070 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2071 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2072 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2073 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2074 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2075 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2076 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2077 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2078 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2079 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2080 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2081 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2082 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2083 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2084 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2085 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2086 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
2087 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2088 {0xaa, 0x01, 0x000c},
2089 {0xaa, 0x11, 0x0000},
2090 {0xaa, 0x13, 0x0000},
2091 {0xaa, 0x14, 0x0001},
2092 {0xaa, 0x15, 0x00e8},
2093 {0xaa, 0x16, 0x0002},
2094 {0xaa, 0x17, 0x0088},
2095
2096 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2097 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2098 {0xa0, 0x89, ZC3XX_R18D_YTARGET},
2099 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
2100 {0xa0, 0x00, 0x01ad},
2101 {0xa0, 0xc0, 0x019b},
2102 {0xa0, 0xa0, 0x019c},
2103 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2104 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2105 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2106 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2107 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2108 {0xa1, 0x01, 0x0002},
2109 {0xa0, 0x00, ZC3XX_R092_I2CADDRESSSELECT},
2110 {0xa0, 0x02, ZC3XX_R090_I2CCOMMAND},
2111 {0xa1, 0x01, 0x0091},
2112 {0xa1, 0x01, 0x0095},
2113 {0xa1, 0x01, 0x0096},
2114
2115 {0xa1, 0x01, 0x0008},
2116 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2117 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
2118 {0xa1, 0x01, 0x01c8},
2119 {0xa1, 0x01, 0x01c9},
2120 {0xa1, 0x01, 0x01ca},
2121 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
2122
2123 {0xa0, 0x60, ZC3XX_R10A_RGB00}, /* matrix */
2124 {0xa0, 0xf0, ZC3XX_R10B_RGB01},
2125 {0xa0, 0xf0, ZC3XX_R10C_RGB02},
2126 {0xa0, 0xf0, ZC3XX_R10D_RGB10},
2127 {0xa0, 0x60, ZC3XX_R10E_RGB11},
2128 {0xa0, 0xf0, ZC3XX_R10F_RGB12},
2129 {0xa0, 0xf0, ZC3XX_R110_RGB20},
2130 {0xa0, 0xf0, ZC3XX_R111_RGB21},
2131 {0xa0, 0x60, ZC3XX_R112_RGB22},
2132 {0xa1, 0x01, 0x0180},
2133 {0xa0, 0x10, ZC3XX_R180_AUTOCORRECTENABLE},
2134 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2135 {0xaa, 0x25, 0x0007},
2136 {0xaa, 0x26, 0x0053},
2137 {0xaa, 0x27, 0x0000},
2138
2139 {0xa0, 0x10, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 2f */
2140 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 9b */
2141 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 80 */
2142 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2143 {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID},
2144 {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW},
2145 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2146 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2147 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
2148 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2149 {0xa0, 0x13, ZC3XX_R1AA_DIGITALGAINSTEP},
2150 {0xa1, 0x01, 0x001d},
2151 {0xa1, 0x01, 0x001e},
2152 {0xa1, 0x01, 0x001f},
2153 {0xa1, 0x01, 0x0020},
2154 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
2155 {0xa1, 0x01, 0x0180},
2156 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2157 {}
2158 };
2159
2160 static const struct usb_action hv7131cxx_InitialScale[] = {
2161 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2162
2163 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* diff */
2164 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
2165 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2166 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2167 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2168
2169 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2170 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2171
2172 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2173 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2174 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2175 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 1e0 */
2176
2177 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2178 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2179 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2180 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2181 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2182 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2183 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2184 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
2185 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2186 {0xaa, 0x01, 0x000c},
2187 {0xaa, 0x11, 0x0000},
2188 {0xaa, 0x13, 0x0000},
2189 {0xaa, 0x14, 0x0001},
2190 {0xaa, 0x15, 0x00e8},
2191 {0xaa, 0x16, 0x0002},
2192 {0xaa, 0x17, 0x0088},
2193
2194 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00 */
2195
2196 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2197 {0xa0, 0x89, ZC3XX_R18D_YTARGET},
2198 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
2199 {0xa0, 0x00, 0x01ad},
2200 {0xa0, 0xc0, 0x019b},
2201 {0xa0, 0xa0, 0x019c},
2202 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2203 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2204 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2205 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2206 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2207 {0xa1, 0x01, 0x0002},
2208 {0xa0, 0x00, ZC3XX_R092_I2CADDRESSSELECT},
2209 /* read the i2c chips ident */
2210 {0xa0, 0x02, ZC3XX_R090_I2CCOMMAND},
2211 {0xa1, 0x01, 0x0091},
2212 {0xa1, 0x01, 0x0095},
2213 {0xa1, 0x01, 0x0096},
2214
2215 {0xa1, 0x01, 0x0008},
2216 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2217 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
2218 {0xa1, 0x01, 0x01c8},
2219 {0xa1, 0x01, 0x01c9},
2220 {0xa1, 0x01, 0x01ca},
2221 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
2222
2223 {0xa0, 0x60, ZC3XX_R10A_RGB00}, /* matrix */
2224 {0xa0, 0xf0, ZC3XX_R10B_RGB01},
2225 {0xa0, 0xf0, ZC3XX_R10C_RGB02},
2226 {0xa0, 0xf0, ZC3XX_R10D_RGB10},
2227 {0xa0, 0x60, ZC3XX_R10E_RGB11},
2228 {0xa0, 0xf0, ZC3XX_R10F_RGB12},
2229 {0xa0, 0xf0, ZC3XX_R110_RGB20},
2230 {0xa0, 0xf0, ZC3XX_R111_RGB21},
2231 {0xa0, 0x60, ZC3XX_R112_RGB22},
2232 {0xa1, 0x01, 0x0180},
2233 {0xa0, 0x10, ZC3XX_R180_AUTOCORRECTENABLE},
2234 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2235 {0xaa, 0x25, 0x0007},
2236 {0xaa, 0x26, 0x0053},
2237 {0xaa, 0x27, 0x0000},
2238
2239 {0xa0, 0x10, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 2f */
2240 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 9b */
2241 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 80 */
2242
2243 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2244 {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID},
2245 {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW},
2246
2247 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2248 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2249 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
2250 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2251 {0xa0, 0x13, ZC3XX_R1AA_DIGITALGAINSTEP},
2252 {0xa1, 0x01, 0x001d},
2253 {0xa1, 0x01, 0x001e},
2254 {0xa1, 0x01, 0x001f},
2255 {0xa1, 0x01, 0x0020},
2256 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
2257 {0xa1, 0x01, 0x0180},
2258 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2259 {}
2260 };
2261
2262 static const struct usb_action icm105axx_Initial[] = {
2263 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2264 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
2265 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2266 {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2267 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2268 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2269 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2270 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2271 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2272 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2273 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2274 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2275 {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2276 {0xa0, 0x01, ZC3XX_R098_WINYSTARTLOW},
2277 {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2278 {0xa0, 0x01, ZC3XX_R09A_WINXSTARTLOW},
2279 {0xa0, 0x01, ZC3XX_R11A_FIRSTYLOW},
2280 {0xa0, 0x01, ZC3XX_R11C_FIRSTXLOW},
2281 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2282 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2283 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2284 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2285 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
2286 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2287 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2288 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2289 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2290 {0xaa, 0x01, 0x0010},
2291 {0xaa, 0x03, 0x0000},
2292 {0xaa, 0x04, 0x0001},
2293 {0xaa, 0x05, 0x0020},
2294 {0xaa, 0x06, 0x0001},
2295 {0xaa, 0x08, 0x0000},
2296 {0xaa, 0x03, 0x0001},
2297 {0xaa, 0x04, 0x0011},
2298 {0xaa, 0x05, 0x00a0},
2299 {0xaa, 0x06, 0x0001},
2300 {0xaa, 0x08, 0x0000},
2301 {0xaa, 0x03, 0x0002},
2302 {0xaa, 0x04, 0x0013},
2303 {0xaa, 0x05, 0x0020},
2304 {0xaa, 0x06, 0x0001},
2305 {0xaa, 0x08, 0x0000},
2306 {0xaa, 0x03, 0x0003},
2307 {0xaa, 0x04, 0x0015},
2308 {0xaa, 0x05, 0x0020},
2309 {0xaa, 0x06, 0x0005},
2310 {0xaa, 0x08, 0x0000},
2311 {0xaa, 0x03, 0x0004},
2312 {0xaa, 0x04, 0x0017},
2313 {0xaa, 0x05, 0x0020},
2314 {0xaa, 0x06, 0x000d},
2315 {0xaa, 0x08, 0x0000},
2316 {0xaa, 0x03, 0x0005},
2317 {0xaa, 0x04, 0x0019},
2318 {0xaa, 0x05, 0x0020},
2319 {0xaa, 0x06, 0x0005},
2320 {0xaa, 0x08, 0x0000},
2321 {0xaa, 0x03, 0x0006},
2322 {0xaa, 0x04, 0x0017},
2323 {0xaa, 0x05, 0x0026},
2324 {0xaa, 0x06, 0x0005},
2325 {0xaa, 0x08, 0x0000},
2326 {0xaa, 0x03, 0x0007},
2327 {0xaa, 0x04, 0x0019},
2328 {0xaa, 0x05, 0x0022},
2329 {0xaa, 0x06, 0x0005},
2330 {0xaa, 0x08, 0x0000},
2331 {0xaa, 0x03, 0x0008},
2332 {0xaa, 0x04, 0x0021},
2333 {0xaa, 0x05, 0x00aa},
2334 {0xaa, 0x06, 0x0005},
2335 {0xaa, 0x08, 0x0000},
2336 {0xaa, 0x03, 0x0009},
2337 {0xaa, 0x04, 0x0023},
2338 {0xaa, 0x05, 0x00aa},
2339 {0xaa, 0x06, 0x000d},
2340 {0xaa, 0x08, 0x0000},
2341 {0xaa, 0x03, 0x000a},
2342 {0xaa, 0x04, 0x0025},
2343 {0xaa, 0x05, 0x00aa},
2344 {0xaa, 0x06, 0x0005},
2345 {0xaa, 0x08, 0x0000},
2346 {0xaa, 0x03, 0x000b},
2347 {0xaa, 0x04, 0x00ec},
2348 {0xaa, 0x05, 0x002e},
2349 {0xaa, 0x06, 0x0005},
2350 {0xaa, 0x08, 0x0000},
2351 {0xaa, 0x03, 0x000c},
2352 {0xaa, 0x04, 0x00fa},
2353 {0xaa, 0x05, 0x002a},
2354 {0xaa, 0x06, 0x0005},
2355 {0xaa, 0x08, 0x0000},
2356 {0xaa, 0x07, 0x000d},
2357 {0xaa, 0x01, 0x0005},
2358 {0xaa, 0x94, 0x0002},
2359 {0xaa, 0x90, 0x0000},
2360 {0xaa, 0x91, 0x001f},
2361 {0xaa, 0x10, 0x0064},
2362 {0xaa, 0x9b, 0x00f0},
2363 {0xaa, 0x9c, 0x0002},
2364 {0xaa, 0x14, 0x001a},
2365 {0xaa, 0x20, 0x0080},
2366 {0xaa, 0x22, 0x0080},
2367 {0xaa, 0x24, 0x0080},
2368 {0xaa, 0x26, 0x0080},
2369 {0xaa, 0x00, 0x0084},
2370 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2371 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2372 {0xaa, 0xa8, 0x00c0},
2373 {0xa1, 0x01, 0x0002},
2374 {0xa1, 0x01, 0x0008},
2375 {0xa1, 0x01, 0x0180},
2376 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2377 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2378 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2379 {0xa0, 0x40, ZC3XX_R118_BGAIN},
2380 {0xa1, 0x01, 0x0008},
2381
2382 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2383 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
2384 {0xa1, 0x01, 0x01c8},
2385 {0xa1, 0x01, 0x01c9},
2386 {0xa1, 0x01, 0x01ca},
2387 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
2388 {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2389 {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2390 {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2391 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2392 {0xa0, 0x52, ZC3XX_R10E_RGB11},
2393 {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2394 {0xa0, 0xf7, ZC3XX_R110_RGB20},
2395 {0xa0, 0xf7, ZC3XX_R111_RGB21},
2396 {0xa0, 0x52, ZC3XX_R112_RGB22},
2397 {0xa1, 0x01, 0x0180},
2398 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2399 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2400 {0xaa, 0x0d, 0x0003},
2401 {0xaa, 0x0c, 0x008c},
2402 {0xaa, 0x0e, 0x0095},
2403 {0xaa, 0x0f, 0x0002},
2404 {0xaa, 0x1c, 0x0094},
2405 {0xaa, 0x1d, 0x0002},
2406 {0xaa, 0x20, 0x0080},
2407 {0xaa, 0x22, 0x0080},
2408 {0xaa, 0x24, 0x0080},
2409 {0xaa, 0x26, 0x0080},
2410 {0xaa, 0x00, 0x0084},
2411 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2412 {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW},
2413 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2414 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2415 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
2416 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2417 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2418 {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW},
2419 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2420 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2421 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2422 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2423 {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0},
2424 {0xa0, 0xec, ZC3XX_R01E_HSYNC_1},
2425 {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2},
2426 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2427 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2428 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN},
2429 {0xa0, 0xc0, ZC3XX_R11D_GLOBALGAIN},
2430 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2431 {0xa1, 0x01, 0x0180},
2432 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2433 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2434 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2435 {0xa0, 0x40, ZC3XX_R118_BGAIN},
2436 {}
2437 };
2438
2439 static const struct usb_action icm105axx_InitialScale[] = {
2440 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2441 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
2442 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2443 {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2444 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2445 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2446 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2447 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2448 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2449 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2450 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2451 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2452 {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2453 {0xa0, 0x02, ZC3XX_R098_WINYSTARTLOW},
2454 {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2455 {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},
2456 {0xa0, 0x02, ZC3XX_R11A_FIRSTYLOW},
2457 {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},
2458 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2459 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
2460 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2461 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
2462 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2463 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2464 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2465 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2466 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2467 {0xaa, 0x01, 0x0010},
2468 {0xaa, 0x03, 0x0000},
2469 {0xaa, 0x04, 0x0001},
2470 {0xaa, 0x05, 0x0020},
2471 {0xaa, 0x06, 0x0001},
2472 {0xaa, 0x08, 0x0000},
2473 {0xaa, 0x03, 0x0001},
2474 {0xaa, 0x04, 0x0011},
2475 {0xaa, 0x05, 0x00a0},
2476 {0xaa, 0x06, 0x0001},
2477 {0xaa, 0x08, 0x0000},
2478 {0xaa, 0x03, 0x0002},
2479 {0xaa, 0x04, 0x0013},
2480 {0xaa, 0x05, 0x0020},
2481 {0xaa, 0x06, 0x0001},
2482 {0xaa, 0x08, 0x0000},
2483 {0xaa, 0x03, 0x0003},
2484 {0xaa, 0x04, 0x0015},
2485 {0xaa, 0x05, 0x0020},
2486 {0xaa, 0x06, 0x0005},
2487 {0xaa, 0x08, 0x0000},
2488 {0xaa, 0x03, 0x0004},
2489 {0xaa, 0x04, 0x0017},
2490 {0xaa, 0x05, 0x0020},
2491 {0xaa, 0x06, 0x000d},
2492 {0xaa, 0x08, 0x0000},
2493 {0xaa, 0x03, 0x0005},
2494 {0xa0, 0x04, ZC3XX_R092_I2CADDRESSSELECT},
2495 {0xa0, 0x19, ZC3XX_R093_I2CSETVALUE},
2496 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
2497 {0xa1, 0x01, 0x0091},
2498 {0xaa, 0x05, 0x0020},
2499 {0xaa, 0x06, 0x0005},
2500 {0xaa, 0x08, 0x0000},
2501 {0xaa, 0x03, 0x0006},
2502 {0xaa, 0x04, 0x0017},
2503 {0xaa, 0x05, 0x0026},
2504 {0xaa, 0x06, 0x0005},
2505 {0xaa, 0x08, 0x0000},
2506 {0xaa, 0x03, 0x0007},
2507 {0xaa, 0x04, 0x0019},
2508 {0xaa, 0x05, 0x0022},
2509 {0xaa, 0x06, 0x0005},
2510 {0xaa, 0x08, 0x0000},
2511 {0xaa, 0x03, 0x0008},
2512 {0xaa, 0x04, 0x0021},
2513 {0xaa, 0x05, 0x00aa},
2514 {0xaa, 0x06, 0x0005},
2515 {0xaa, 0x08, 0x0000},
2516 {0xaa, 0x03, 0x0009},
2517 {0xaa, 0x04, 0x0023},
2518 {0xaa, 0x05, 0x00aa},
2519 {0xaa, 0x06, 0x000d},
2520 {0xaa, 0x08, 0x0000},
2521 {0xaa, 0x03, 0x000a},
2522 {0xaa, 0x04, 0x0025},
2523 {0xaa, 0x05, 0x00aa},
2524 {0xaa, 0x06, 0x0005},
2525 {0xaa, 0x08, 0x0000},
2526 {0xaa, 0x03, 0x000b},
2527 {0xaa, 0x04, 0x00ec},
2528 {0xaa, 0x05, 0x002e},
2529 {0xaa, 0x06, 0x0005},
2530 {0xaa, 0x08, 0x0000},
2531 {0xaa, 0x03, 0x000c},
2532 {0xaa, 0x04, 0x00fa},
2533 {0xaa, 0x05, 0x002a},
2534 {0xaa, 0x06, 0x0005},
2535 {0xaa, 0x08, 0x0000},
2536 {0xaa, 0x07, 0x000d},
2537 {0xaa, 0x01, 0x0005},
2538 {0xaa, 0x94, 0x0002},
2539 {0xaa, 0x90, 0x0000},
2540 {0xaa, 0x91, 0x0010},
2541 {0xaa, 0x10, 0x0064},
2542 {0xaa, 0x9b, 0x00f0},
2543 {0xaa, 0x9c, 0x0002},
2544 {0xaa, 0x14, 0x001a},
2545 {0xaa, 0x20, 0x0080},
2546 {0xaa, 0x22, 0x0080},
2547 {0xaa, 0x24, 0x0080},
2548 {0xaa, 0x26, 0x0080},
2549 {0xaa, 0x00, 0x0084},
2550 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2551 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2552 {0xaa, 0xa8, 0x0080},
2553 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
2554 {0xa1, 0x01, 0x0002},
2555 {0xa1, 0x01, 0x0008},
2556 {0xa1, 0x01, 0x0180},
2557 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2558 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2559 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2560 {0xa0, 0x40, ZC3XX_R118_BGAIN},
2561 {0xa1, 0x01, 0x0008},
2562
2563 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2564 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
2565 {0xa1, 0x01, 0x01c8},
2566 {0xa1, 0x01, 0x01c9},
2567 {0xa1, 0x01, 0x01ca},
2568 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
2569
2570 {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2571 {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2572 {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2573 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2574 {0xa0, 0x52, ZC3XX_R10E_RGB11},
2575 {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2576 {0xa0, 0xf7, ZC3XX_R110_RGB20},
2577 {0xa0, 0xf7, ZC3XX_R111_RGB21},
2578 {0xa0, 0x52, ZC3XX_R112_RGB22},
2579 {0xa1, 0x01, 0x0180},
2580 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2581 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2582 {0xaa, 0x0d, 0x0003},
2583 {0xaa, 0x0c, 0x0020},
2584 {0xaa, 0x0e, 0x000e},
2585 {0xaa, 0x0f, 0x0002},
2586 {0xaa, 0x1c, 0x000d},
2587 {0xaa, 0x1d, 0x0002},
2588 {0xaa, 0x20, 0x0080},
2589 {0xaa, 0x22, 0x0080},
2590 {0xaa, 0x24, 0x0080},
2591 {0xaa, 0x26, 0x0080},
2592 {0xaa, 0x00, 0x0084},
2593 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2594 {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW},
2595 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2596 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2597 {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW},
2598 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2599 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2600 {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW},
2601 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2602 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2603 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2604 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2605 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0},
2606 {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1},
2607 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2},
2608 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2609 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2610 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2611 {0xa1, 0x01, 0x0180},
2612 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2613 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2614 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2615 {0xa0, 0x40, ZC3XX_R118_BGAIN},
2616 {}
2617 };
2618 static const struct usb_action icm105a_50HZ[] = {
2619 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2620 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2621 {0xaa, 0x0c, 0x0020}, /* 00,0c,20,aa */
2622 {0xaa, 0x0e, 0x000e}, /* 00,0e,0e,aa */
2623 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2624 {0xaa, 0x1c, 0x000d}, /* 00,1c,0d,aa */
2625 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2626 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2627 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2628 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2629 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2630 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2631 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2632 {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,0d,cc */
2633 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2634 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2635 {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,1a,cc */
2636 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2637 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2638 {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,4b,cc */
2639 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2640 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2641 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2642 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2643 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
2644 {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d8,cc */
2645 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2646 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2647 {}
2648 };
2649 static const struct usb_action icm105a_50HZScale[] = {
2650 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2651 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2652 {0xaa, 0x0c, 0x008c}, /* 00,0c,8c,aa */
2653 {0xaa, 0x0e, 0x0095}, /* 00,0e,95,aa */
2654 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2655 {0xaa, 0x1c, 0x0094}, /* 00,1c,94,aa */
2656 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2657 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2658 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2659 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2660 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2661 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2662 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2663 {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,94,cc */
2664 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2665 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2666 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2667 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2668 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2669 {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,84,cc */
2670 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2671 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2672 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2673 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2674 {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,e3,cc */
2675 {0xa0, 0xec, ZC3XX_R01E_HSYNC_1}, /* 00,1e,ec,cc */
2676 {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f5,cc */
2677 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2678 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2679 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2680 {}
2681 };
2682 static const struct usb_action icm105a_60HZ[] = {
2683 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2684 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2685 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2686 {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2687 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2688 {0xaa, 0x1c, 0x0008}, /* 00,1c,08,aa */
2689 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2690 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2691 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2692 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2693 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2694 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2695 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2696 {0xa0, 0x08, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,08,cc */
2697 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2698 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2699 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc */
2700 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2701 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2702 {0xa0, 0x41, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,41,cc */
2703 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2704 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2705 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2706 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2707 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2708 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2709 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2710 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2711 {}
2712 };
2713 static const struct usb_action icm105a_60HZScale[] = {
2714 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2715 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2716 {0xaa, 0x0c, 0x0008}, /* 00,0c,08,aa */
2717 {0xaa, 0x0e, 0x0086}, /* 00,0e,86,aa */
2718 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2719 {0xaa, 0x1c, 0x0085}, /* 00,1c,85,aa */
2720 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2721 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2722 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2723 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2724 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2725 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2726 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2727 {0xa0, 0x85, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,85,cc */
2728 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2729 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2730 {0xa0, 0x08, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,08,cc */
2731 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2732 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2733 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,81,cc */
2734 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2735 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2736 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2737 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2738 {0xa0, 0xc2, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c2,cc */
2739 {0xa0, 0xd6, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d6,cc */
2740 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2741 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2742 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2743 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2744 {}
2745 };
2746 static const struct usb_action icm105a_NoFliker[] = {
2747 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2748 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2749 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2750 {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2751 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2752 {0xaa, 0x1c, 0x0000}, /* 00,1c,00,aa */
2753 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2754 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2755 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2756 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2757 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2758 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2759 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2760 {0xa0, 0x00, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,00,cc */
2761 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2762 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2763 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2764 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2765 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2766 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2767 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2768 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2769 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2770 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2771 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2772 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2773 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2774 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2775 {}
2776 };
2777 static const struct usb_action icm105a_NoFlikerScale[] = {
2778 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2779 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2780 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2781 {0xaa, 0x0e, 0x0081}, /* 00,0e,81,aa */
2782 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2783 {0xaa, 0x1c, 0x0080}, /* 00,1c,80,aa */
2784 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2785 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2786 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2787 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2788 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2789 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2790 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2791 {0xa0, 0x80, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,80,cc */
2792 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2793 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2794 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2795 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2796 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2797 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2798 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2799 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2800 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2801 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2802 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2803 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2804 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2805 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2806 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2807 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2808 {}
2809 };
2810
2811 static const struct usb_action MC501CB_InitialScale[] = {
2812 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2813 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc */
2814 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2815 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2816 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2817 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2818 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2819 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2820 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2821 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2822 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
2823 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2824 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2825 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2826 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2827 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2828 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
2829 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2830 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
2831 {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2832 {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2833 {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2834 {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2835 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2836 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2837 {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2838 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2839 {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2840 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2841 {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2842 {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2843 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2844 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2845 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2846 {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2847 {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2848 {0xaa, 0x18, 0x00de}, /* 00,18,de,aa */
2849 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2850 {0xaa, 0x1a, 0x0086}, /* 00,1a,86,aa */
2851 {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
2852 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2853 {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
2854 {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
2855 {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
2856 {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
2857 {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
2858 {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
2859 {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
2860 {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
2861 {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
2862 {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
2863 {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
2864 {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
2865 {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
2866 {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
2867 {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
2868 {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
2869 {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
2870 {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
2871 {0xaa, 0xa0, ZC3XX_R01A_LASTFRAMESTATE}, /* 00,a0,1a,aa */
2872 {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
2873 {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
2874 {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
2875 {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
2876 {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
2877 {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
2878 {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
2879 {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
2880 {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
2881 {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
2882 {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
2883 {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
2884 {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
2885 {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
2886 {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
2887 {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
2888 {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
2889 {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
2890 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2891 {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
2892 {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
2893 {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
2894 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2895 {0xaa, 0x1c, 0x0050}, /* 00,1C,50,aa */
2896 {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
2897 {0xaa, 0x3b, 0x001d}, /* 00,3b,1D,aa */
2898 {0xaa, 0x3c, 0x004c}, /* 00,3c,4C,aa */
2899 {0xaa, 0x3d, 0x0018}, /* 00,3d,18,aa */
2900 {0xaa, 0x3e, 0x006a}, /* 00,3e,6A,aa */
2901 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
2902 {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
2903 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2904 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
2905 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
2906 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
2907 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
2908 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
2909 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
2910 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
2911 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
2912 {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
2913 {0xaa, 0x51, 0x0027}, /* 00,51,27,aa */
2914 {0xaa, 0x52, 0x0020}, /* 00,52,20,aa */
2915 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2916 {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
2917 {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
2918 {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
2919 {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
2920 {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
2921 {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
2922
2923 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2924 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
2925 {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
2926 {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
2927 {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
2928 {}
2929 };
2930
2931 static const struct usb_action MC501CB_Initial[] = { /* 320x240 */
2932 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2933 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
2934 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2935 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2936 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2937 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2938 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2939 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2940 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2941 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2942 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
2943 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2944 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2945 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2946 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2947 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2948 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
2949 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2950 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
2951 {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2952 {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2953 {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2954 {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2955 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2956 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2957 {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2958 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2959 {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2960 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2961 {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2962 {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2963 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2964 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2965 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2966 {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2967 {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2968 {0xaa, 0x18, 0x00d8}, /* 00,18,d8,aa */
2969 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2970 {0xaa, 0x1a, 0x0088}, /* 00,1a,88,aa */
2971 {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
2972 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2973 {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
2974 {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
2975 {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
2976 {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
2977 {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
2978 {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
2979 {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
2980 {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
2981 {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
2982 {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
2983 {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
2984 {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
2985 {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
2986 {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
2987 {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
2988 {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
2989 {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
2990 {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
2991 {0xaa, 0xa0, ZC3XX_R01A_LASTFRAMESTATE}, /* 00,a0,1a,aa */
2992 {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
2993 {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
2994 {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
2995 {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
2996 {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
2997 {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
2998 {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
2999 {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
3000 {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
3001 {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
3002 {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
3003 {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
3004 {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
3005 {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
3006 {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
3007 {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
3008 {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
3009 {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
3010 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
3011 {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
3012 {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
3013 {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
3014 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3015 {0xaa, 0x1c, 0x0050}, /* 00,1c,50,aa */
3016 {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
3017 {0xaa, 0x3b, 0x003a}, /* 00,3b,3A,aa */
3018 {0xaa, 0x3c, 0x0098}, /* 00,3c,98,aa */
3019 {0xaa, 0x3d, 0x0030}, /* 00,3d,30,aa */
3020 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3021 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
3022 {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
3023 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
3024 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3025 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
3026 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3027 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3028 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3029 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3030 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3031 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3032 {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
3033 {0xaa, 0x51, 0x004e}, /* 00,51,4E,aa */
3034 {0xaa, 0x52, 0x0041}, /* 00,52,41,aa */
3035 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3036 {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
3037 {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
3038 {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
3039 {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
3040 {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
3041 {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
3042 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3043 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3044 {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
3045 {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
3046 {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
3047 {}
3048 };
3049
3050 static const struct usb_action MC501CB_50HZ[] = {
3051 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3052 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3053 {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
3054 {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
3055 {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
3056 {0xaa, 0x3c, 0x004c}, /* 00,3C,4C,aa */
3057 {0xaa, 0x3d, 0x001d}, /* 00,3D,1D,aa */
3058 {0xaa, 0x3e, 0x004c}, /* 00,3E,4C,aa */
3059 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3060 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3061 {0xaa, 0x36, 0x003a}, /* 00,36,3A,aa */
3062 {0xaa, 0x37, 0x0098}, /* 00,37,98,aa */
3063 {0xaa, 0x3b, 0x003a}, /* 00,3B,3A,aa */
3064 {}
3065 };
3066
3067 static const struct usb_action MC501CB_50HZScale[] = {
3068 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3069 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3070 {0xaa, 0x36, 0x003a}, /* 00,36,3A,aa */
3071 {0xaa, 0x37, 0x0098}, /* 00,37,98,aa */
3072 {0xaa, 0x3b, 0x003a}, /* 00,3B,3A,aa */
3073 {0xaa, 0x3c, 0x0098}, /* 00,3C,98,aa */
3074 {0xaa, 0x3d, 0x003a}, /* 00,3D,3A,aa */
3075 {0xaa, 0x3e, 0x0098}, /* 00,3E,98,aa */
3076 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3077 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3078 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3079 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3080 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3081 {}
3082 };
3083
3084 static const struct usb_action MC501CB_60HZ[] = {
3085 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3086 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3087 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3088 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3089 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3090 {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3091 {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3092 {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
3093 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3094 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3095 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3096 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3097 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3098 {}
3099 };
3100
3101 static const struct usb_action MC501CB_60HZScale[] = {
3102 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3103 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3104 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3105 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3106 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3107 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3108 {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3109 {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
3110 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3111 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3112 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3113 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3114 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3115 {}
3116 };
3117
3118 static const struct usb_action MC501CB_NoFliker[] = {
3119 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3120 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3121 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3122 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3123 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3124 {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3125 {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3126 {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
3127 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3128 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3129 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3130 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3131 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3132 {}
3133 };
3134
3135 static const struct usb_action MC501CB_NoFlikerScale[] = {
3136 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3137 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3138 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3139 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3140 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3141 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3142 {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3143 {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
3144 {}
3145 };
3146
3147 /* from zs211.inf - HKR,%OV7620%,Initial - 640x480 */
3148 static const struct usb_action OV7620_mode0[] = {
3149 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3150 {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, /* 00,02,40,cc */
3151 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3152 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3153 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3154 {0xa0, 0x02, ZC3XX_R083_RGAINADDR}, /* 00,83,02,cc */
3155 {0xa0, 0x01, ZC3XX_R085_BGAINADDR}, /* 00,85,01,cc */
3156 {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,80,cc */
3157 {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID}, /* 00,87,81,cc */
3158 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW}, /* 00,88,10,cc */
3159 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3160 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3161 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3162 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3163 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3164 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
3165 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3166 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3167 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3168 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
3169 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3170 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
3171 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
3172 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
3173 {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3174 {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3175 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3176 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3177 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3178 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3179 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3180 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3181 {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3182 {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3183 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3184 {0xaa, 0x1a, 0x00f1}, /* 00,1a,f1,aa */
3185 {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3186 {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3187 {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3188 {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3189 {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3190 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3191 {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3192 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3193 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3194 {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3195 {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3196 {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3197 {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3198 {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3199 {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3200 {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
3201 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3202 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3203 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3204 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3205 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3206 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3207 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3208 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3209 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3210 {0xa0, 0x68, ZC3XX_R116_RGAIN}, /* 01,16,68,cc */
3211 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
3212 {0xa0, 0x40, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,40,cc */
3213 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3214 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,50,cc */
3215 {}
3216 };
3217
3218 /* from zs211.inf - HKR,%OV7620%,InitialScale - 320x240 */
3219 static const struct usb_action OV7620_mode1[] = {
3220 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3221 {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT}, /* 00,02,50,cc */
3222 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3223 /* mx change? */
3224 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3225 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3226 {0xa0, 0x02, ZC3XX_R083_RGAINADDR}, /* 00,83,02,cc */
3227 {0xa0, 0x01, ZC3XX_R085_BGAINADDR}, /* 00,85,01,cc */
3228 {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,80,cc */
3229 {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID}, /* 00,87,81,cc */
3230 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW}, /* 00,88,10,cc */
3231 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3232 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3233 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3234 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3235 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3236 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
3237 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3238 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3239 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3240 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
3241 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3242 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
3243 {0xa0, 0xd6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d6,cc */
3244 /* OV7648 00,9c,d8,cc */
3245 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
3246 {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3247 {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3248 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3249 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3250 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3251 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3252 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3253 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3254 {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3255 {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3256 {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3257 {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3258 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3259 {0xaa, 0x1a, 0x00f2}, /* 00,1a,f2,aa */
3260 {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3261 {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3262 {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3263 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3264 {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3265 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3266 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3267 {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3268 {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3269 {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3270 {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3271 {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3272 {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3273 {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
3274 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3275 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3276 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3277 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3278 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3279 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3280 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3281 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3282 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3283 {0xa0, 0x68, ZC3XX_R116_RGAIN}, /* 01,16,68,cc */
3284 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
3285 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,50,cc */
3286 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3287 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,50,cc */
3288 {}
3289 };
3290
3291 /* from zs211.inf - HKR,%OV7620%\AE,50HZ */
3292 static const struct usb_action OV7620_50HZ[] = {
3293 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3294 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3295 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3296 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3297 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3298 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3299 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3300 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3301 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3302 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3303 {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,83,cc */
3304 {0xaa, 0x10, 0x0082}, /* 00,10,82,aa */
3305 {0xaa, 0x76, 0x0003}, /* 00,76,03,aa */
3306 /* {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, * 00,02,40,cc
3307 if mode0 (640x480) */
3308 {}
3309 };
3310
3311 /* from zs211.inf - HKR,%OV7620%\AE,60HZ */
3312 static const struct usb_action OV7620_60HZ[] = {
3313 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3314 /* (bug in zs211.inf) */
3315 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3316 {0xaa, 0x2b, 0x0000}, /* 00,2b,00,aa */
3317 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3318 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3319 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3320 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3321 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3322 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3323 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3324 {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,83,cc */
3325 {0xaa, 0x10, 0x0020}, /* 00,10,20,aa */
3326 {0xaa, 0x76, 0x0003}, /* 00,76,03,aa */
3327 /* {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, * 00,02,40,cc
3328 * if mode0 (640x480) */
3329 /* ?? in gspca v1, it was
3330 {0xa0, 0x00, 0x0039}, * 00,00,00,dd *
3331 {0xa1, 0x01, 0x0037}, */
3332 {}
3333 };
3334
3335 /* from zs211.inf - HKR,%OV7620%\AE,NoFliker */
3336 static const struct usb_action OV7620_NoFliker[] = {
3337 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3338 /* (bug in zs211.inf) */
3339 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3340 {0xaa, 0x2b, 0x0000}, /* 00,2b,00,aa */
3341 {0xaa, 0x75, 0x008e}, /* 00,75,8e,aa */
3342 {0xaa, 0x2d, 0x0001}, /* 00,2d,01,aa */
3343 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3344 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3345 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3346 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3347 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3348 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,01,cc */
3349 /* {0xa0, 0x44, ZC3XX_R002_CLOCKSELECT}, * 00,02,44,cc
3350 - if mode1 (320x240) */
3351 /* ?? was
3352 {0xa0, 0x00, 0x0039}, * 00,00,00,dd *
3353 {0xa1, 0x01, 0x0037}, */
3354 {}
3355 };
3356
3357 static const struct usb_action ov7630c_Initial[] = {
3358 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3359 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3360 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3361 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3362 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3363 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3364 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3365 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3366 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3367 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3368 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3369 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3370 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3371 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3372 {0xaa, 0x12, 0x0080},
3373 {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3374 {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3375 {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3376 {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3377 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3378 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3379 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3380 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3381 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3382 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},
3383 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
3384 {0xaa, 0x12, 0x0069},
3385 {0xaa, 0x04, 0x0020},
3386 {0xaa, 0x06, 0x0050},
3387 {0xaa, 0x13, 0x0083},
3388 {0xaa, 0x14, 0x0000},
3389 {0xaa, 0x15, 0x0024},
3390 {0xaa, 0x17, 0x0018},
3391 {0xaa, 0x18, 0x00ba},
3392 {0xaa, 0x19, 0x0002},
3393 {0xaa, 0x1a, 0x00f6},
3394 {0xaa, 0x1b, 0x0002},
3395 {0xaa, 0x20, 0x00c2},
3396 {0xaa, 0x24, 0x0060},
3397 {0xaa, 0x25, 0x0040},
3398 {0xaa, 0x26, 0x0030},
3399 {0xaa, 0x27, 0x00ea},
3400 {0xaa, 0x28, 0x00a0},
3401 {0xaa, 0x21, 0x0000},
3402 {0xaa, 0x2a, 0x0081},
3403 {0xaa, 0x2b, 0x0096},
3404 {0xaa, 0x2d, 0x0094},
3405 {0xaa, 0x2f, 0x003d},
3406 {0xaa, 0x30, 0x0024},
3407 {0xaa, 0x60, 0x0000},
3408 {0xaa, 0x61, 0x0040},
3409 {0xaa, 0x68, 0x007c},
3410 {0xaa, 0x6f, 0x0015},
3411 {0xaa, 0x75, 0x0088},
3412 {0xaa, 0x77, 0x00b5},
3413 {0xaa, 0x01, 0x0060},
3414 {0xaa, 0x02, 0x0060},
3415 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3416 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3417 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3418 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3419 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
3420 {0xa0, 0x00, 0x01ad},
3421 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3422 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3423 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3424 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3425 {0xa0, 0x60, ZC3XX_R116_RGAIN},
3426 {0xa0, 0x46, ZC3XX_R118_BGAIN},
3427 {0xa0, 0x04, ZC3XX_R113_RGB03},
3428 /* 0x10, */
3429 {0xa1, 0x01, 0x0002},
3430 {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3431 {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3432 {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3433 {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3434 {0xa0, 0x50, ZC3XX_R10E_RGB11},
3435 {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3436 {0xa0, 0xf8, ZC3XX_R110_RGB20},
3437 {0xa0, 0xf8, ZC3XX_R111_RGB21},
3438 {0xa0, 0x50, ZC3XX_R112_RGB22},
3439 /* 0x03, */
3440 {0xa1, 0x01, 0x0008},
3441 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
3442 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
3443 {0xa1, 0x01, 0x01c8},
3444 {0xa1, 0x01, 0x01c9},
3445 {0xa1, 0x01, 0x01ca},
3446 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
3447 {0xa0, 0x01, ZC3XX_R120_GAMMA00}, /* gamma 2 ?*/
3448 {0xa0, 0x0c, ZC3XX_R121_GAMMA01},
3449 {0xa0, 0x1f, ZC3XX_R122_GAMMA02},
3450 {0xa0, 0x3a, ZC3XX_R123_GAMMA03},
3451 {0xa0, 0x53, ZC3XX_R124_GAMMA04},
3452 {0xa0, 0x6d, ZC3XX_R125_GAMMA05},
3453 {0xa0, 0x85, ZC3XX_R126_GAMMA06},
3454 {0xa0, 0x9c, ZC3XX_R127_GAMMA07},
3455 {0xa0, 0xb0, ZC3XX_R128_GAMMA08},
3456 {0xa0, 0xc2, ZC3XX_R129_GAMMA09},
3457 {0xa0, 0xd1, ZC3XX_R12A_GAMMA0A},
3458 {0xa0, 0xde, ZC3XX_R12B_GAMMA0B},
3459 {0xa0, 0xe9, ZC3XX_R12C_GAMMA0C},
3460 {0xa0, 0xf2, ZC3XX_R12D_GAMMA0D},
3461 {0xa0, 0xf9, ZC3XX_R12E_GAMMA0E},
3462 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3463 {0xa0, 0x05, ZC3XX_R130_GAMMA10},
3464 {0xa0, 0x0f, ZC3XX_R131_GAMMA11},
3465 {0xa0, 0x16, ZC3XX_R132_GAMMA12},
3466 {0xa0, 0x1a, ZC3XX_R133_GAMMA13},
3467 {0xa0, 0x19, ZC3XX_R134_GAMMA14},
3468 {0xa0, 0x19, ZC3XX_R135_GAMMA15},
3469 {0xa0, 0x17, ZC3XX_R136_GAMMA16},
3470 {0xa0, 0x15, ZC3XX_R137_GAMMA17},
3471 {0xa0, 0x12, ZC3XX_R138_GAMMA18},
3472 {0xa0, 0x10, ZC3XX_R139_GAMMA19},
3473 {0xa0, 0x0e, ZC3XX_R13A_GAMMA1A},
3474 {0xa0, 0x0b, ZC3XX_R13B_GAMMA1B},
3475 {0xa0, 0x09, ZC3XX_R13C_GAMMA1C},
3476 {0xa0, 0x08, ZC3XX_R13D_GAMMA1D},
3477 {0xa0, 0x06, ZC3XX_R13E_GAMMA1E},
3478 {0xa0, 0x03, ZC3XX_R13F_GAMMA1F},
3479 {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3480 {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3481 {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3482 {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3483 {0xa0, 0x50, ZC3XX_R10E_RGB11},
3484 {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3485 {0xa0, 0xf8, ZC3XX_R110_RGB20},
3486 {0xa0, 0xf8, ZC3XX_R111_RGB21},
3487 {0xa0, 0x50, ZC3XX_R112_RGB22},
3488
3489 {0xa1, 0x01, 0x0180},
3490 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3491 {0xaa, 0x10, 0x001b},
3492 {0xaa, 0x76, 0x0002},
3493 {0xaa, 0x2a, 0x0081},
3494 {0xaa, 0x2b, 0x0000},
3495 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3496 {0xa0, 0x01, ZC3XX_R191_EXPOSURELIMITMID},
3497 {0xa0, 0xb8, ZC3XX_R192_EXPOSURELIMITLOW},
3498 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3499 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3500 {0xa0, 0x37, ZC3XX_R197_ANTIFLICKERLOW},
3501 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3502 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3503 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3504 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3505 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3506 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3507 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3508 {0xaa, 0x13, 0x0083}, /* 40 */
3509 {0xa1, 0x01, 0x0180},
3510 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3511 {}
3512 };
3513
3514 static const struct usb_action ov7630c_InitialScale[] = {
3515 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3516 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
3517 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3518 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3519 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3520 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3521 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3522 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3523 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3524 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3525 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3526 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3527
3528 {0xaa, 0x12, 0x0080},
3529 {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3530 {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3531 {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3532 {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3533 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3534 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3535 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3536 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3537 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3538 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
3539 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
3540 {0xaa, 0x12, 0x0069}, /* i2c */
3541 {0xaa, 0x04, 0x0020},
3542 {0xaa, 0x06, 0x0050},
3543 {0xaa, 0x13, 0x00c3},
3544 {0xaa, 0x14, 0x0000},
3545 {0xaa, 0x15, 0x0024},
3546 {0xaa, 0x19, 0x0003},
3547 {0xaa, 0x1a, 0x00f6},
3548 {0xaa, 0x1b, 0x0002},
3549 {0xaa, 0x20, 0x00c2},
3550 {0xaa, 0x24, 0x0060},
3551 {0xaa, 0x25, 0x0040},
3552 {0xaa, 0x26, 0x0030},
3553 {0xaa, 0x27, 0x00ea},
3554 {0xaa, 0x28, 0x00a0},
3555 {0xaa, 0x21, 0x0000},
3556 {0xaa, 0x2a, 0x0081},
3557 {0xaa, 0x2b, 0x0096},
3558 {0xaa, 0x2d, 0x0084},
3559 {0xaa, 0x2f, 0x003d},
3560 {0xaa, 0x30, 0x0024},
3561 {0xaa, 0x60, 0x0000},
3562 {0xaa, 0x61, 0x0040},
3563 {0xaa, 0x68, 0x007c},
3564 {0xaa, 0x6f, 0x0015},
3565 {0xaa, 0x75, 0x0088},
3566 {0xaa, 0x77, 0x00b5},
3567 {0xaa, 0x01, 0x0060},
3568 {0xaa, 0x02, 0x0060},
3569 {0xaa, 0x17, 0x0018},
3570 {0xaa, 0x18, 0x00ba},
3571 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3572 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3573 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3574 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3575 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
3576 {0xa0, 0x00, 0x01ad},
3577 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3578 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3579 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3580 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3581 {0xa0, 0x60, ZC3XX_R116_RGAIN},
3582 {0xa0, 0x46, ZC3XX_R118_BGAIN},
3583 {0xa0, 0x04, ZC3XX_R113_RGB03},
3584
3585 {0xa1, 0x01, 0x0002},
3586 {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3587 {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3588 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3589 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3590 {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3591 {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3592 {0xa0, 0x00, ZC3XX_R110_RGB20},
3593 {0xa0, 0xf6, ZC3XX_R111_RGB21},
3594 {0xa0, 0x4a, ZC3XX_R112_RGB22},
3595
3596 {0xa1, 0x01, 0x0008},
3597 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
3598 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
3599 {0xa1, 0x01, 0x01c8},
3600 {0xa1, 0x01, 0x01c9},
3601 {0xa1, 0x01, 0x01ca},
3602 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
3603 {0xa0, 0x16, ZC3XX_R120_GAMMA00}, /* gamma ~4 */
3604 {0xa0, 0x3a, ZC3XX_R121_GAMMA01},
3605 {0xa0, 0x5b, ZC3XX_R122_GAMMA02},
3606 {0xa0, 0x7c, ZC3XX_R123_GAMMA03},
3607 {0xa0, 0x94, ZC3XX_R124_GAMMA04},
3608 {0xa0, 0xa9, ZC3XX_R125_GAMMA05},
3609 {0xa0, 0xbb, ZC3XX_R126_GAMMA06},
3610 {0xa0, 0xca, ZC3XX_R127_GAMMA07},
3611 {0xa0, 0xd7, ZC3XX_R128_GAMMA08},
3612 {0xa0, 0xe1, ZC3XX_R129_GAMMA09},
3613 {0xa0, 0xea, ZC3XX_R12A_GAMMA0A},
3614 {0xa0, 0xf1, ZC3XX_R12B_GAMMA0B},
3615 {0xa0, 0xf7, ZC3XX_R12C_GAMMA0C},
3616 {0xa0, 0xfc, ZC3XX_R12D_GAMMA0D},
3617 {0xa0, 0xff, ZC3XX_R12E_GAMMA0E},
3618 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3619 {0xa0, 0x20, ZC3XX_R130_GAMMA10},
3620 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
3621 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
3622 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
3623 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
3624 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
3625 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
3626 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
3627 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
3628 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
3629 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
3630 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
3631 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
3632 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
3633 {0xa0, 0x00, ZC3XX_R13E_GAMMA1E},
3634 {0xa0, 0x01, ZC3XX_R13F_GAMMA1F},
3635 {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3636 {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3637 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3638 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3639 {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3640 {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3641 {0xa0, 0x00, ZC3XX_R110_RGB20},
3642 {0xa0, 0xf6, ZC3XX_R111_RGB21},
3643 {0xa0, 0x4a, ZC3XX_R112_RGB22},
3644
3645 {0xa1, 0x01, 0x0180},
3646 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3647 {0xaa, 0x10, 0x000d},
3648 {0xaa, 0x76, 0x0002},
3649 {0xaa, 0x2a, 0x0081},
3650 {0xaa, 0x2b, 0x0000},
3651 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3652 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},
3653 {0xa0, 0xd8, ZC3XX_R192_EXPOSURELIMITLOW},
3654 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3655 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3656 {0xa0, 0x1b, ZC3XX_R197_ANTIFLICKERLOW},
3657 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3658 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3659 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3660 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3661 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3662 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3663 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3664 {0xaa, 0x13, 0x00c3},
3665
3666 {0xa1, 0x01, 0x0180},
3667 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3668 {}
3669 };
3670
3671 static const struct usb_action pas106b_Initial_com[] = {
3672 /* Sream and Sensor specific */
3673 {0xa1, 0x01, 0x0010}, /* CMOSSensorSelect */
3674 /* System */
3675 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
3676 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
3677 /* Picture size */
3678 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* ClockSelect */
3679 {0xa0, 0x03, 0x003a},
3680 {0xa0, 0x0c, 0x003b},
3681 {0xa0, 0x04, 0x0038},
3682 {}
3683 };
3684
3685 static const struct usb_action pas106b_Initial[] = { /* 176x144 */
3686 /* JPEG control */
3687 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3688 /* Sream and Sensor specific */
3689 {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
3690 /* Picture size */
3691 {0xa0, 0x00, ZC3XX_R003_FRAMEWIDTHHIGH},
3692 {0xa0, 0xb0, ZC3XX_R004_FRAMEWIDTHLOW},
3693 {0xa0, 0x00, ZC3XX_R005_FRAMEHEIGHTHIGH},
3694 {0xa0, 0x90, ZC3XX_R006_FRAMEHEIGHTLOW},
3695 /* System */
3696 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3697 /* Sream and Sensor specific */
3698 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3699 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3700 /* Sensor Interface */
3701 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3702 /* Window inside sensor array */
3703 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3704 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3705 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3706 {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3707 {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
3708 /* Init the sensor */
3709 {0xaa, 0x02, 0x0004},
3710 {0xaa, 0x08, 0x0000},
3711 {0xaa, 0x09, 0x0005},
3712 {0xaa, 0x0a, 0x0002},
3713 {0xaa, 0x0b, 0x0002},
3714 {0xaa, 0x0c, 0x0005},
3715 {0xaa, 0x0d, 0x0000},
3716 {0xaa, 0x0e, 0x0002},
3717 {0xaa, 0x14, 0x0081},
3718
3719 /* Other registors */
3720 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
3721 /* Frame retreiving */
3722 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
3723 /* Gains */
3724 {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
3725 /* Unknown */
3726 {0xa0, 0x00, 0x01ad},
3727 /* Sharpness */
3728 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3729 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3730 /* Other registors */
3731 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3732 /* Auto exposure and white balance */
3733 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3734 /*Dead pixels */
3735 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3736 /* EEPROM */
3737 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3738 /* JPEG control */
3739 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3740 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3741 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3742 /* Other registers */
3743 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3744 /* Auto exposure and white balance */
3745 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3746 /*Dead pixels */
3747 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3748 /* EEPROM */
3749 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3750 /* JPEG control */
3751 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3752 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3753 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3754
3755 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3756 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3757 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3758 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3759 {0xa0, 0x58, ZC3XX_R10E_RGB11},
3760 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3761 {0xa0, 0xf4, ZC3XX_R110_RGB20},
3762 {0xa0, 0xf4, ZC3XX_R111_RGB21},
3763 {0xa0, 0x58, ZC3XX_R112_RGB22},
3764 /* Auto correction */
3765 {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3766 {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3767 {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3768 {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3769 {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3770 {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3771 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3772
3773 /* Auto exposure and white balance */
3774 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3775 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3776 {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
3777 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3778 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3779 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
3780 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
3781 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
3782 /* sensor on */
3783 {0xaa, 0x07, 0x00b1},
3784 {0xaa, 0x05, 0x0003},
3785 {0xaa, 0x04, 0x0001},
3786 {0xaa, 0x03, 0x003b},
3787 /* Gains */
3788 {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3789 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3790 {0xa0, 0xa0, ZC3XX_R11D_GLOBALGAIN},
3791 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
3792 /* Auto correction */
3793 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3794 {0xa1, 0x01, 0x0180}, /* AutoCorrectEnable */
3795 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3796 /* Gains */
3797 {0xa0, 0x40, ZC3XX_R116_RGAIN},
3798 {0xa0, 0x40, ZC3XX_R117_GGAIN},
3799 {0xa0, 0x40, ZC3XX_R118_BGAIN},
3800 {}
3801 };
3802
3803 static const struct usb_action pas106b_InitialScale[] = { /* 352x288 */
3804 /* JPEG control */
3805 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3806 /* Sream and Sensor specific */
3807 {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
3808 /* Picture size */
3809 {0xa0, 0x01, ZC3XX_R003_FRAMEWIDTHHIGH},
3810 {0xa0, 0x60, ZC3XX_R004_FRAMEWIDTHLOW},
3811 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3812 {0xa0, 0x20, ZC3XX_R006_FRAMEHEIGHTLOW},
3813 /* System */
3814 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3815 /* Sream and Sensor specific */
3816 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3817 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3818 /* Sensor Interface */
3819 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3820 /* Window inside sensor array */
3821 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3822 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3823 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3824 {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3825 {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
3826 /* Init the sensor */
3827 {0xaa, 0x02, 0x0004},
3828 {0xaa, 0x08, 0x0000},
3829 {0xaa, 0x09, 0x0005},
3830 {0xaa, 0x0a, 0x0002},
3831 {0xaa, 0x0b, 0x0002},
3832 {0xaa, 0x0c, 0x0005},
3833 {0xaa, 0x0d, 0x0000},
3834 {0xaa, 0x0e, 0x0002},
3835 {0xaa, 0x14, 0x0081},
3836
3837 /* Other registors */
3838 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
3839 /* Frame retreiving */
3840 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
3841 /* Gains */
3842 {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
3843 /* Unknown */
3844 {0xa0, 0x00, 0x01ad},
3845 /* Sharpness */
3846 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3847 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3848 /* Other registors */
3849 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3850 /* Auto exposure and white balance */
3851 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3852 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
3853 /*Dead pixels */
3854 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3855 /* EEPROM */
3856 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3857 /* JPEG control */
3858 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3859 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3860 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3861 /* Other registers */
3862 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3863 /* Auto exposure and white balance */
3864 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3865 /*Dead pixels */
3866 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3867 /* EEPROM */
3868 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3869 /* JPEG control */
3870 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3871 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3872 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3873
3874 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3875 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3876 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3877 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3878 {0xa0, 0x58, ZC3XX_R10E_RGB11},
3879 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3880 {0xa0, 0xf4, ZC3XX_R110_RGB20},
3881 {0xa0, 0xf4, ZC3XX_R111_RGB21},
3882 {0xa0, 0x58, ZC3XX_R112_RGB22},
3883 /* Auto correction */
3884 {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3885 {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3886 {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3887 {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3888 {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3889 {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3890 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3891
3892 /* Auto exposure and white balance */
3893 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3894 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3895 {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
3896
3897 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3898 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3899 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
3900
3901 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3902 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3903 /* sensor on */
3904 {0xaa, 0x07, 0x00b1},
3905 {0xaa, 0x05, 0x0003},
3906 {0xaa, 0x04, 0x0001},
3907 {0xaa, 0x03, 0x003b},
3908 /* Gains */
3909 {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3910 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3911 {0xa0, 0xa0, ZC3XX_R11D_GLOBALGAIN},
3912 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
3913 /* Auto correction */
3914 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3915 {0xa1, 0x01, 0x0180}, /* AutoCorrectEnable */
3916 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3917 /* Gains */
3918 {0xa0, 0x40, ZC3XX_R116_RGAIN},
3919 {0xa0, 0x40, ZC3XX_R117_GGAIN},
3920 {0xa0, 0x40, ZC3XX_R118_BGAIN},
3921
3922 {0xa0, 0x00, 0x0007}, /* AutoCorrectEnable */
3923 {0xa0, 0xff, ZC3XX_R018_FRAMELOST}, /* Frame adjust */
3924 {}
3925 };
3926 static const struct usb_action pas106b_50HZ[] = {
3927 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3928 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3929 {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,54,cc */
3930 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3931 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3932 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,87,cc */
3933 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3934 {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,30,cc */
3935 {0xaa, 0x03, 0x0021}, /* 00,03,21,aa */
3936 {0xaa, 0x04, 0x000c}, /* 00,04,0c,aa */
3937 {0xaa, 0x05, 0x0002}, /* 00,05,02,aa */
3938 {0xaa, 0x07, 0x001c}, /* 00,07,1c,aa */
3939 {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
3940 {}
3941 };
3942 static const struct usb_action pas106b_60HZ[] = {
3943 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3944 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3945 {0xa0, 0x2e, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,2e,cc */
3946 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3947 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3948 {0xa0, 0x71, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,71,cc */
3949 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3950 {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,30,cc */
3951 {0xaa, 0x03, 0x001c}, /* 00,03,1c,aa */
3952 {0xaa, 0x04, 0x0004}, /* 00,04,04,aa */
3953 {0xaa, 0x05, 0x0001}, /* 00,05,01,aa */
3954 {0xaa, 0x07, 0x00c4}, /* 00,07,c4,aa */
3955 {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
3956 {}
3957 };
3958 static const struct usb_action pas106b_NoFliker[] = {
3959 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3960 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3961 {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc */
3962 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3963 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3964 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
3965 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3966 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
3967 {0xaa, 0x03, 0x0013}, /* 00,03,13,aa */
3968 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3969 {0xaa, 0x05, 0x0001}, /* 00,05,01,aa */
3970 {0xaa, 0x07, 0x0030}, /* 00,07,30,aa */
3971 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
3972 {}
3973 };
3974
3975 /* from usbvm31b.inf */
3976 static const struct usb_action pas202b_Initial[] = { /* 640x480 */
3977 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3978 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3979 {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0e,cc */
3980 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc */
3981 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3982 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3983 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3984 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
3985 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3986 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3987 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3988 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3989 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3990 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,03,cc */
3991 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3992 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,03,cc */
3993 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
3994 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
3995 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
3996 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
3997 {0xaa, 0x02, 0x0002}, /* 00,02,04,aa --> 02 */
3998 {0xaa, 0x07, 0x0006}, /* 00,07,06,aa */
3999 {0xaa, 0x08, 0x0002}, /* 00,08,02,aa */
4000 {0xaa, 0x09, 0x0006}, /* 00,09,06,aa */
4001 {0xaa, 0x0a, 0x0001}, /* 00,0a,01,aa */
4002 {0xaa, 0x0b, 0x0001}, /* 00,0b,01,aa */
4003 {0xaa, 0x0c, 0x0008}, /* 00,0c,08,aa */
4004 {0xaa, 0x0d, 0x0000}, /* 00,0d,00,aa */
4005 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
4006 {0xaa, 0x12, 0x0005}, /* 00,12,05,aa */
4007 {0xaa, 0x13, 0x0063}, /* 00,13,63,aa */
4008 {0xaa, 0x15, 0x0070}, /* 00,15,70,aa */
4009 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
4010 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4011 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
4012 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
4013 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4014 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4015 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4016 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4017 {0xa0, 0x70, ZC3XX_R18D_YTARGET}, /* 01,8d,70,cc */
4018 {}
4019 };
4020 static const struct usb_action pas202b_InitialScale[] = { /* 320x240 */
4021 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4022 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
4023 {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0e,cc */
4024 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
4025 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4026 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4027 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4028 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
4029 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4030 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4031 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4032 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
4033 {0xa0, 0x08, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,08,cc */
4034 {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,02,cc */
4035 {0xa0, 0x08, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,08,cc */
4036 {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,02,cc */
4037 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
4038 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
4039 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
4040 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
4041 {0xaa, 0x02, 0x0002}, /* 00,02,02,aa */
4042 {0xaa, 0x07, 0x0006}, /* 00,07,06,aa */
4043 {0xaa, 0x08, 0x0002}, /* 00,08,02,aa */
4044 {0xaa, 0x09, 0x0006}, /* 00,09,06,aa */
4045 {0xaa, 0x0a, 0x0001}, /* 00,0a,01,aa */
4046 {0xaa, 0x0b, 0x0001}, /* 00,0b,01,aa */
4047 {0xaa, 0x0c, 0x0008}, /* 00,0c,08,aa */
4048 {0xaa, 0x0d, 0x0000}, /* 00,0d,00,aa */
4049 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
4050 {0xaa, 0x12, 0x0005}, /* 00,12,05,aa */
4051 {0xaa, 0x13, 0x0063}, /* 00,13,63,aa */
4052 {0xaa, 0x15, 0x0070}, /* 00,15,70,aa */
4053 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
4054 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4055 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
4056 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
4057 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4058 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4059 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4060 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4061 {0xa0, 0x70, ZC3XX_R18D_YTARGET}, /* 01,8d,70,cc */
4062 {}
4063 };
4064 static const struct usb_action pas202b_50HZ[] = {
4065 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4066 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4067 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4068 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4069 {0xaa, 0x21, 0x0068}, /* 00,21,68,aa */
4070 {0xaa, 0x03, 0x0044}, /* 00,03,44,aa */
4071 {0xaa, 0x04, 0x0009}, /* 00,04,09,aa */
4072 {0xaa, 0x05, 0x0028}, /* 00,05,28,aa */
4073 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4074 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4075 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,14,cc */
4076 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4077 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4078 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,07,cc */
4079 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,d2,cc */
4080 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4081 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4082 {0xa0, 0x4d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,4d,cc */
4083 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4084 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4085 {0xa0, 0x44, ZC3XX_R01D_HSYNC_0}, /* 00,1d,44,cc */
4086 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
4087 {0xa0, 0xad, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ad,cc */
4088 {0xa0, 0xeb, ZC3XX_R020_HSYNC_3}, /* 00,20,eb,cc */
4089 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4090 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4091 {}
4092 };
4093 static const struct usb_action pas202b_50HZScale[] = {
4094 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4095 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4096 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4097 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4098 {0xaa, 0x21, 0x006c}, /* 00,21,6c,aa */
4099 {0xaa, 0x03, 0x0041}, /* 00,03,41,aa */
4100 {0xaa, 0x04, 0x0009}, /* 00,04,09,aa */
4101 {0xaa, 0x05, 0x002c}, /* 00,05,2c,aa */
4102 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4103 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4104 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,14,cc */
4105 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4106 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4107 {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0f,cc */
4108 {0xa0, 0xbe, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,be,cc */
4109 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4110 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4111 {0xa0, 0x9b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,9b,cc */
4112 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4113 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4114 {0xa0, 0x41, ZC3XX_R01D_HSYNC_0}, /* 00,1d,41,cc */
4115 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
4116 {0xa0, 0xad, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ad,cc */
4117 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4118 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4119 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4120 {}
4121 };
4122 static const struct usb_action pas202b_60HZ[] = {
4123 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4124 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4125 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4126 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4127 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4128 {0xaa, 0x03, 0x0045}, /* 00,03,45,aa */
4129 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
4130 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
4131 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4132 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4133 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,14,cc */
4134 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4135 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4136 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,07,cc */
4137 {0xa0, 0xc0, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,c0,cc */
4138 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4139 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4140 {0xa0, 0x40, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,40,cc */
4141 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4142 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4143 {0xa0, 0x45, ZC3XX_R01D_HSYNC_0}, /* 00,1d,45,cc */
4144 {0xa0, 0x8e, ZC3XX_R01E_HSYNC_1}, /* 00,1e,8e,cc */
4145 {0xa0, 0xc1, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c1,cc */
4146 {0xa0, 0xf5, ZC3XX_R020_HSYNC_3}, /* 00,20,f5,cc */
4147 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4148 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4149 {}
4150 };
4151 static const struct usb_action pas202b_60HZScale[] = {
4152 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4153 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4154 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4155 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4156 {0xaa, 0x21, 0x0004}, /* 00,21,04,aa */
4157 {0xaa, 0x03, 0x0042}, /* 00,03,42,aa */
4158 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
4159 {0xaa, 0x05, 0x0004}, /* 00,05,04,aa */
4160 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4161 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4162 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,14,cc */
4163 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4164 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4165 {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0f,cc */
4166 {0xa0, 0x9f, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,9f,cc */
4167 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4168 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4169 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,81,cc */
4170 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4171 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4172 {0xa0, 0x42, ZC3XX_R01D_HSYNC_0}, /* 00,1d,42,cc */
4173 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
4174 {0xa0, 0xaf, ZC3XX_R01F_HSYNC_2}, /* 00,1f,af,cc */
4175 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4176 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4177 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4178 {}
4179 };
4180 static const struct usb_action pas202b_NoFliker[] = {
4181 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4182 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4183 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4184 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4185 {0xaa, 0x21, 0x0020}, /* 00,21,20,aa */
4186 {0xaa, 0x03, 0x0040}, /* 00,03,40,aa */
4187 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
4188 {0xaa, 0x05, 0x0020}, /* 00,05,20,aa */
4189 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4190 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4191 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4192 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,07,cc */
4193 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,f0,cc */
4194 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4195 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4196 {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,02,cc */
4197 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4198 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4199 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
4200 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
4201 {0xa0, 0x40, ZC3XX_R01D_HSYNC_0}, /* 00,1d,40,cc */
4202 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1}, /* 00,1e,60,cc */
4203 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2}, /* 00,1f,90,cc */
4204 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4205 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4206 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4207 {}
4208 };
4209 static const struct usb_action pas202b_NoFlikerScale[] = {
4210 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4211 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4212 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4213 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4214 {0xaa, 0x21, 0x0010}, /* 00,21,10,aa */
4215 {0xaa, 0x03, 0x0040}, /* 00,03,40,aa */
4216 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
4217 {0xaa, 0x05, 0x0010}, /* 00,05,10,aa */
4218 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4219 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4220 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
4221 {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0f,cc */
4222 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,f0,cc */
4223 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4224 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4225 {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,02,cc */
4226 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4227 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4228 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
4229 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
4230 {0xa0, 0x40, ZC3XX_R01D_HSYNC_0}, /* 00,1d,40,cc */
4231 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1}, /* 00,1e,60,cc */
4232 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2}, /* 00,1f,90,cc */
4233 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4234 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4235 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4236 {}
4237 };
4238
4239 /* mi0360soc and pb0330 from vm30x.inf for 0ac8:301b and 0ac8:303b 07/02/13 */
4240 static const struct usb_action mi0360soc_Initial[] = { /* 640x480 */
4241 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4242 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4243 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4244 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4245 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4246 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4247 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4248 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4249 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4250 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4251 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC}, /*jfm: was 03*/
4252 /* {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, */
4253 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4254 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4255 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4256 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4257 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4258 {0xdd, 0x00, 0x0200},
4259 {0xaa, 0x01, 0x0001},
4260 {0xaa, 0x06, 0x0000},
4261 {0xaa, 0x08, 0x0483},
4262 {0xaa, 0x01, 0x0004},
4263 {0xaa, 0x08, 0x0006},
4264 {0xaa, 0x02, 0x0011},
4265 {0xaa, 0x03, 0x01e5}, /*jfm: was 01e7*/
4266 {0xaa, 0x04, 0x0285}, /*jfm: was 0287*/
4267 {0xaa, 0x07, 0x3002},
4268 {0xaa, 0x20, 0x5100}, /*jfm: was 1100*/
4269 {0xaa, 0x35, 0x507f}, /*jfm: was 0050*/
4270 {0xaa, 0x30, 0x0005},
4271 {0xaa, 0x31, 0x0000},
4272 {0xaa, 0x58, 0x0078},
4273 {0xaa, 0x62, 0x0411},
4274 {0xaa, 0x2b, 0x0028},
4275 {0xaa, 0x2c, 0x007f}, /*jfm: was 0030*/
4276 {0xaa, 0x2d, 0x007f}, /*jfm: was 0030*/
4277 {0xaa, 0x2e, 0x007f}, /*jfm: was 0030*/
4278 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4279 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /*jfm: was 37*/
4280 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4281 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4282 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4283 {0xa0, 0x09, 0x01ad}, /*jfm: was 00*/
4284 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4285 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4286 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4287 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4288 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4289 {0xa0, 0x6c, ZC3XX_R18D_YTARGET}, /* jfm: was 78 */
4290 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4291 {0xa0, 0x65, ZC3XX_R118_BGAIN},
4292 {}
4293 };
4294 static const struct usb_action mi0360soc_InitialScale[] = { /* 320x240 */
4295 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4296 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4297 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4298 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4299 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4300 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4301 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4302 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4303 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4304 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4305 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC}, /*jfm: was 03*/
4306 /* {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, */
4307 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4308 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4309 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4310 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4311 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4312 {0xdd, 0x00, 0x0200},
4313 {0xaa, 0x01, 0x0001},
4314 {0xaa, 0x06, 0x0000},
4315 {0xaa, 0x08, 0x0483},
4316 {0xaa, 0x01, 0x0004},
4317 {0xaa, 0x08, 0x0006},
4318 {0xaa, 0x02, 0x0011},
4319 {0xaa, 0x03, 0x01e7},
4320 {0xaa, 0x04, 0x0287},
4321 {0xaa, 0x07, 0x3002},
4322 {0xaa, 0x20, 0x5100}, /*jfm: was 1100*/
4323 {0xaa, 0x35, 0x007f}, /*jfm: was 0050*/
4324 {0xaa, 0x30, 0x0005},
4325 {0xaa, 0x31, 0x0000},
4326 {0xaa, 0x58, 0x0078},
4327 {0xaa, 0x62, 0x0411},
4328 {0xaa, 0x2b, 0x007f}, /*jfm: was 28*/
4329 {0xaa, 0x2c, 0x007f}, /*jfm: was 30*/
4330 {0xaa, 0x2d, 0x007f}, /*jfm: was 30*/
4331 {0xaa, 0x2e, 0x007f}, /*jfm: was 28*/
4332 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4333 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /*jfm: was 37*/
4334 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4335 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4336 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4337 {0xa0, 0x09, 0x01ad}, /*jfm: was 00*/
4338 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4339 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4340 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4341 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4342 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4343 {0xa0, 0x6c, ZC3XX_R18D_YTARGET}, /*jfm: was 78*/
4344 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4345 {0xa0, 0x65, ZC3XX_R118_BGAIN},
4346 {}
4347 };
4348 static const struct usb_action mi360soc_AE50HZ[] = {
4349 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4350 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4351 {0xbb, 0x00, 0x0562},
4352 {0xbb, 0x01, 0x09aa},
4353 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4354 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
4355 {0xa0, 0x9b, ZC3XX_R192_EXPOSURELIMITLOW},
4356 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4357 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4358 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4359 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4360 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4361 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4362 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4363 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4364 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4365 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4366 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4367 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4368 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4369 {}
4370 };
4371 static const struct usb_action mi360soc_AE50HZScale[] = {
4372 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4373 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4374 {0xbb, 0x00, 0x0509},
4375 {0xbb, 0x01, 0x0934},
4376 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4377 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4378 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4379 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4380 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4381 {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4382 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4383 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4384 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4385 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4386 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4387 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4388 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4389 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4390 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4391 {}
4392 };
4393 static const struct usb_action mi360soc_AE60HZ[] = {
4394 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4395 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4396 {0xbb, 0x00, 0x053d},
4397 {0xbb, 0x01, 0x096e},
4398 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4399 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4400 {0xa0, 0xdd, ZC3XX_R192_EXPOSURELIMITLOW},
4401 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4402 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4403 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
4404 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4405 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4406 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4407 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4408 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4409 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4410 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4411 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4412 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4413 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4414 {}
4415 };
4416 static const struct usb_action mi360soc_AE60HZScale[] = {
4417 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4418 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4419 {0xbb, 0x00, 0x0509},
4420 {0xbb, 0x01, 0x0983},
4421 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4422 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4423 {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4424 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4425 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4426 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4427 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4428 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4429 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4430 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4431 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4432 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4433 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4434 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4435 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4436 {}
4437 };
4438 static const struct usb_action mi360soc_AENoFliker[] = {
4439 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4440 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4441 {0xbb, 0x00, 0x0509},
4442 {0xbb, 0x01, 0x0960},
4443 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4444 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4445 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4446 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4447 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4448 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4449 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4450 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4451 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4452 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4453 {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4454 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4455 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4456 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4457 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4458 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4459 {}
4460 };
4461 static const struct usb_action mi360soc_AENoFlikerScale[] = {
4462 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4463 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4464 {0xbb, 0x00, 0x0534},
4465 {0xbb, 0x02, 0x0960},
4466 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4467 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4468 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4469 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4470 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4471 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4472 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4473 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4474 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4475 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4476 {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4477 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4478 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4479 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4480 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4481 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4482 {}
4483 };
4484
4485 static const struct usb_action pb0330_Initial[] = { /* 640x480 */
4486 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4487 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
4488 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4489 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4490 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4491 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4492 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4493 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4494 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4495 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4496 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4497 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4498 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4499 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4500 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4501 {0xdd, 0x00, 0x0200},
4502 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4503 {0xaa, 0x01, 0x0006},
4504 {0xaa, 0x02, 0x0011},
4505 {0xaa, 0x03, 0x01e5}, /*jfm: was 1e7*/
4506 {0xaa, 0x04, 0x0285}, /*jfm: was 0287*/
4507 {0xaa, 0x06, 0x0003},
4508 {0xaa, 0x07, 0x3002},
4509 {0xaa, 0x20, 0x1100},
4510 {0xaa, 0x2f, 0xf7b0},
4511 {0xaa, 0x30, 0x0005},
4512 {0xaa, 0x31, 0x0000},
4513 {0xaa, 0x34, 0x0100},
4514 {0xaa, 0x35, 0x0060},
4515 {0xaa, 0x3d, 0x068f},
4516 {0xaa, 0x40, 0x01e0},
4517 {0xaa, 0x58, 0x0078},
4518 {0xaa, 0x62, 0x0411},
4519 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4520 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4521 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4522 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4523 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4524 {0xa0, 0x09, 0x01ad}, /*jfm: was 00 */
4525 {0xa0, 0x15, 0x01ae},
4526 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4527 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4528 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4529 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4530 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4531 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /*jfm: was 6c*/
4532 {}
4533 };
4534 static const struct usb_action pb0330_InitialScale[] = { /* 320x240 */
4535 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4536 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
4537 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4538 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4539 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4540 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4541 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4542 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4543 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4544 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4545 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4546 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4547 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4548 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4549 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4550 {0xdd, 0x00, 0x0200},
4551 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4552 {0xaa, 0x01, 0x0006},
4553 {0xaa, 0x02, 0x0011},
4554 {0xaa, 0x03, 0x01e7},
4555 {0xaa, 0x04, 0x0287},
4556 {0xaa, 0x06, 0x0003},
4557 {0xaa, 0x07, 0x3002},
4558 {0xaa, 0x20, 0x1100},
4559 {0xaa, 0x2f, 0xf7b0},
4560 {0xaa, 0x30, 0x0005},
4561 {0xaa, 0x31, 0x0000},
4562 {0xaa, 0x34, 0x0100},
4563 {0xaa, 0x35, 0x0060},
4564 {0xaa, 0x3d, 0x068f},
4565 {0xaa, 0x40, 0x01e0},
4566 {0xaa, 0x58, 0x0078},
4567 {0xaa, 0x62, 0x0411},
4568 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4569 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4570 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4571 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4572 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4573 {0xa0, 0x09, 0x01ad},
4574 {0xa0, 0x15, 0x01ae},
4575 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4576 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4577 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4578 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4579 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4580 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /*jfm: was 6c*/
4581 {}
4582 };
4583 static const struct usb_action pb0330_50HZ[] = {
4584 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4585 {0xbb, 0x00, 0x055c},
4586 {0xbb, 0x01, 0x09aa},
4587 {0xbb, 0x00, 0x1001},
4588 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4589 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4590 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4591 {0xa0, 0xc4, ZC3XX_R192_EXPOSURELIMITLOW},
4592 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4593 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4594 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4595 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4596 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4597 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4598 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4599 {0xa0, 0x5c, ZC3XX_R01D_HSYNC_0},
4600 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4601 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4602 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4603 {}
4604 };
4605 static const struct usb_action pb0330_50HZScale[] = {
4606 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4607 {0xbb, 0x00, 0x0566},
4608 {0xbb, 0x02, 0x09b2},
4609 {0xbb, 0x00, 0x1002},
4610 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4611 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4612 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4613 {0xa0, 0x8c, ZC3XX_R192_EXPOSURELIMITLOW},
4614 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4615 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4616 {0xa0, 0x8a, ZC3XX_R197_ANTIFLICKERLOW},
4617 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4618 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4619 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4620 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4621 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4622 {0xa0, 0xf0, ZC3XX_R01E_HSYNC_1},
4623 {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2},
4624 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4625 {}
4626 };
4627 static const struct usb_action pb0330_60HZ[] = {
4628 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4629 {0xbb, 0x00, 0x0535},
4630 {0xbb, 0x01, 0x0974},
4631 {0xbb, 0x00, 0x1001},
4632 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4633 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4634 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4635 {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
4636 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4637 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4638 {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW},
4639 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4640 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4641 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4642 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4643 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4644 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4645 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4646 {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
4647 {}
4648 };
4649 static const struct usb_action pb0330_60HZScale[] = {
4650 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4651 {0xbb, 0x00, 0x0535},
4652 {0xbb, 0x02, 0x096c},
4653 {0xbb, 0x00, 0x1002},
4654 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4655 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4656 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4657 {0xa0, 0xc0, ZC3XX_R192_EXPOSURELIMITLOW},
4658 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4659 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4660 {0xa0, 0x7c, ZC3XX_R197_ANTIFLICKERLOW},
4661 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4662 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4663 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4664 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4665 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4666 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4667 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4668 {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
4669 {}
4670 };
4671 static const struct usb_action pb0330_NoFliker[] = {
4672 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4673 {0xbb, 0x00, 0x0509},
4674 {0xbb, 0x02, 0x0940},
4675 {0xbb, 0x00, 0x1002},
4676 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4677 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4678 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4679 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4680 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4681 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4682 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4683 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4684 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4685 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4686 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4687 {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4688 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4689 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4690 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4691 {}
4692 };
4693 static const struct usb_action pb0330_NoFlikerScale[] = {
4694 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4695 {0xbb, 0x00, 0x0535},
4696 {0xbb, 0x01, 0x0980},
4697 {0xbb, 0x00, 0x1001},
4698 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4699 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4700 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4701 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4702 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4703 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4704 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4705 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4706 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4707 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4708 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4709 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4710 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4711 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4712 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4713 {}
4714 };
4715
4716 /* from oem9.inf - HKR,%PO2030%,Initial - 640x480 - (close to CS2102) */
4717 static const struct usb_action PO2030_mode0[] = {
4718 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4719 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
4720 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
4721 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4722 {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
4723 {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
4724 {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
4725 {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
4726 {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
4727 {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
4728 {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
4729 {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
4730 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
4731 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4732 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4733 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4734 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4735 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4736 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
4737 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4738 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4739 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
4740 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
4741 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
4742 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
4743 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
4744 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
4745 {0xaa, 0x09, 0x00ce}, /* 00,09,ce,aa */
4746 {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
4747 {0xaa, 0x0d, 0x0054}, /* 00,0d,54,aa */
4748 {0xaa, 0x0f, 0x00eb}, /* 00,0f,eb,aa */
4749 {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
4750 {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
4751 {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
4752 {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
4753 {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
4754 {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
4755 {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
4756 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
4757 {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
4758 {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
4759 {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
4760 {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
4761 {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
4762 {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
4763 {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
4764 {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
4765 {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
4766 {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
4767 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4768 {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
4769 {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
4770 {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
4771 {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
4772 {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
4773 {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
4774 {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
4775 {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
4776 {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
4777 {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
4778 {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
4779 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
4780 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
4781 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4782 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
4783 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
4784 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4785 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4786 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4787 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4788 {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
4789 {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
4790 {}
4791 };
4792
4793 /* from oem9.inf - HKR,%PO2030%,InitialScale - 320x240 */
4794 static const struct usb_action PO2030_mode1[] = {
4795 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4796 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
4797 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
4798 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4799 {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
4800 {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
4801 {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
4802 {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
4803 {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
4804 {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
4805 {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
4806 {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
4807 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
4808 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4809 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4810 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4811 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4812 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4813 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
4814 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4815 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4816 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
4817 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
4818 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
4819 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
4820 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc */
4821 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
4822 {0xaa, 0x09, 0x00cc}, /* 00,09,cc,aa */
4823 {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
4824 {0xaa, 0x0d, 0x0058}, /* 00,0d,58,aa */
4825 {0xaa, 0x0f, 0x00ed}, /* 00,0f,ed,aa */
4826 {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
4827 {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
4828 {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
4829 {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
4830 {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
4831 {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
4832 {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
4833 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
4834 {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
4835 {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
4836 {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
4837 {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
4838 {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
4839 {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
4840 {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
4841 {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
4842 {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
4843 {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
4844 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4845 {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
4846 {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
4847 {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
4848 {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
4849 {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
4850 {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
4851 {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
4852 {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
4853 {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
4854 {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
4855 {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
4856 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
4857 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
4858 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4859 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
4860 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
4861 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4862 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4863 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4864 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4865 {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
4866 {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
4867 {}
4868 };
4869
4870 static const struct usb_action PO2030_50HZ[] = {
4871 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4872 {0xaa, 0x1a, 0x0001}, /* 00,1a,01,aa */
4873 {0xaa, 0x1b, 0x000a}, /* 00,1b,0a,aa */
4874 {0xaa, 0x1c, 0x00b0}, /* 00,1c,b0,aa */
4875 {0xa0, 0x05, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,05,cc */
4876 {0xa0, 0x35, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,35,cc */
4877 {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
4878 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4879 {0xa0, 0x85, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,85,cc */
4880 {0xa0, 0x58, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,58,cc */
4881 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
4882 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
4883 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
4884 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
4885 {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,22,cc */
4886 {0xa0, 0x88, ZC3XX_R18D_YTARGET}, /* 01,8d,88,cc */
4887 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc */
4888 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4889 {}
4890 };
4891
4892 static const struct usb_action PO2030_60HZ[] = {
4893 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4894 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
4895 {0xaa, 0x1b, 0x00de}, /* 00,1b,de,aa */
4896 {0xaa, 0x1c, 0x0040}, /* 00,1c,40,aa */
4897 {0xa0, 0x08, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,08,cc */
4898 {0xa0, 0xae, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,ae,cc */
4899 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
4900 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4901 {0xa0, 0x6f, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,6f,cc */
4902 {0xa0, 0x20, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,20,cc */
4903 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
4904 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
4905 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
4906 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
4907 {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,22,cc */
4908 {0xa0, 0x88, ZC3XX_R18D_YTARGET}, /* 01,8d,88,cc */
4909 /* win: 01,8d,80 */
4910 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc */
4911 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4912 {}
4913 };
4914
4915 static const struct usb_action PO2030_NoFliker[] = {
4916 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
4917 {0xaa, 0x8d, 0x000d}, /* 00,8d,0d,aa */
4918 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
4919 {0xaa, 0x1b, 0x0002}, /* 00,1b,02,aa */
4920 {0xaa, 0x1c, 0x0078}, /* 00,1c,78,aa */
4921 {0xaa, 0x46, 0x0000}, /* 00,46,00,aa */
4922 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
4923 {}
4924 };
4925
4926 /* TEST */
4927 static const struct usb_action tas5130CK_Initial[] = {
4928 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4929 {0xa0, 0x01, 0x003b},
4930 {0xa0, 0x0e, 0x003a},
4931 {0xa0, 0x01, 0x0038},
4932 {0xa0, 0x0b, 0x0039},
4933 {0xa0, 0x00, 0x0038},
4934 {0xa0, 0x0b, 0x0039},
4935 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4936 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4937 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4938 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4939 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4940 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4941 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4942 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4943 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4944 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4945 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4946 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4947 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4948 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4949 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4950 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4951 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4952 {0xa0, 0x01, ZC3XX_R092_I2CADDRESSSELECT},
4953 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
4954 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4955 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4956 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
4957 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
4958 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4959 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4960 {0xa0, 0x08, ZC3XX_R092_I2CADDRESSSELECT},
4961 {0xa0, 0x83, ZC3XX_R093_I2CSETVALUE},
4962 {0xa0, 0x04, ZC3XX_R094_I2CWRITEACK},
4963 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4964 {0xa0, 0x01, ZC3XX_R092_I2CADDRESSSELECT},
4965 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
4966 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4967 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4968 {0xa0, 0x08, ZC3XX_R092_I2CADDRESSSELECT},
4969 {0xa0, 0x06, ZC3XX_R093_I2CSETVALUE},
4970 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4971 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4972 {0xa0, 0x02, ZC3XX_R092_I2CADDRESSSELECT},
4973 {0xa0, 0x11, ZC3XX_R093_I2CSETVALUE},
4974 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4975 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4976 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
4977 {0xa0, 0xE7, ZC3XX_R093_I2CSETVALUE},
4978 {0xa0, 0x01, ZC3XX_R094_I2CWRITEACK},
4979 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4980 {0xa0, 0x04, ZC3XX_R092_I2CADDRESSSELECT},
4981 {0xa0, 0x87, ZC3XX_R093_I2CSETVALUE},
4982 {0xa0, 0x02, ZC3XX_R094_I2CWRITEACK},
4983 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4984 {0xa0, 0x07, ZC3XX_R092_I2CADDRESSSELECT},
4985 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
4986 {0xa0, 0x30, ZC3XX_R094_I2CWRITEACK},
4987 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4988 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
4989 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
4990 {0xa0, 0x51, ZC3XX_R094_I2CWRITEACK},
4991 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4992 {0xa0, 0x35, ZC3XX_R092_I2CADDRESSSELECT},
4993 {0xa0, 0x7F, ZC3XX_R093_I2CSETVALUE},
4994 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4995 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
4996 {0xa0, 0x30, ZC3XX_R092_I2CADDRESSSELECT},
4997 {0xa0, 0x05, ZC3XX_R093_I2CSETVALUE},
4998 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
4999 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5000 {0xa0, 0x31, ZC3XX_R092_I2CADDRESSSELECT},
5001 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
5002 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5003 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5004 {0xa0, 0x58, ZC3XX_R092_I2CADDRESSSELECT},
5005 {0xa0, 0x78, ZC3XX_R093_I2CSETVALUE},
5006 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5007 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5008 {0xa0, 0x62, ZC3XX_R092_I2CADDRESSSELECT},
5009 {0xa0, 0x11, ZC3XX_R093_I2CSETVALUE},
5010 {0xa0, 0x04, ZC3XX_R094_I2CWRITEACK},
5011 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5012 {0xa0, 0x2B, ZC3XX_R092_I2CADDRESSSELECT},
5013 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5014 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5015 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5016 {0xa0, 0x2c, ZC3XX_R092_I2CADDRESSSELECT},
5017 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5018 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5019 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5020 {0xa0, 0x2D, ZC3XX_R092_I2CADDRESSSELECT},
5021 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5022 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5023 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5024 {0xa0, 0x2e, ZC3XX_R092_I2CADDRESSSELECT},
5025 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5026 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5027 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5028 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
5029 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
5030 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5031 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5032 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5033 {0xa0, 0x09, 0x01ad},
5034 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5035 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5036 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5037 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5038 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
5039 {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
5040 {0xa0, 0x61, ZC3XX_R116_RGAIN},
5041 {0xa0, 0x65, ZC3XX_R118_BGAIN},
5042 {0xa0, 0x09, 0x01ad},
5043 {0xa0, 0x15, 0x01ae},
5044 {0xa0, 0x4c, ZC3XX_R10A_RGB00}, /* matrix */
5045 {0xa0, 0xf1, ZC3XX_R10B_RGB01},
5046 {0xa0, 0x03, ZC3XX_R10C_RGB02},
5047 {0xa0, 0xfe, ZC3XX_R10D_RGB10},
5048 {0xa0, 0x51, ZC3XX_R10E_RGB11},
5049 {0xa0, 0xf1, ZC3XX_R10F_RGB12},
5050 {0xa0, 0xec, ZC3XX_R110_RGB20},
5051 {0xa0, 0x03, ZC3XX_R111_RGB21},
5052 {0xa0, 0x51, ZC3XX_R112_RGB22},
5053 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5054 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
5055 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
5056 {0xa0, 0x38, ZC3XX_R120_GAMMA00}, /* gamma > 5 */
5057 {0xa0, 0x51, ZC3XX_R121_GAMMA01},
5058 {0xa0, 0x6e, ZC3XX_R122_GAMMA02},
5059 {0xa0, 0x8c, ZC3XX_R123_GAMMA03},
5060 {0xa0, 0xa2, ZC3XX_R124_GAMMA04},
5061 {0xa0, 0xb6, ZC3XX_R125_GAMMA05},
5062 {0xa0, 0xc8, ZC3XX_R126_GAMMA06},
5063 {0xa0, 0xd6, ZC3XX_R127_GAMMA07},
5064 {0xa0, 0xe2, ZC3XX_R128_GAMMA08},
5065 {0xa0, 0xed, ZC3XX_R129_GAMMA09},
5066 {0xa0, 0xf5, ZC3XX_R12A_GAMMA0A},
5067 {0xa0, 0xfc, ZC3XX_R12B_GAMMA0B},
5068 {0xa0, 0xff, ZC3XX_R12C_GAMMA0C},
5069 {0xa0, 0xff, ZC3XX_R12D_GAMMA0D},
5070 {0xa0, 0xff, ZC3XX_R12E_GAMMA0E},
5071 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
5072 {0xa0, 0x12, ZC3XX_R130_GAMMA10},
5073 {0xa0, 0x1b, ZC3XX_R131_GAMMA11},
5074 {0xa0, 0x1d, ZC3XX_R132_GAMMA12},
5075 {0xa0, 0x1a, ZC3XX_R133_GAMMA13},
5076 {0xa0, 0x15, ZC3XX_R134_GAMMA14},
5077 {0xa0, 0x12, ZC3XX_R135_GAMMA15},
5078 {0xa0, 0x0f, ZC3XX_R136_GAMMA16},
5079 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
5080 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
5081 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
5082 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
5083 {0xa0, 0x05, ZC3XX_R13B_GAMMA1B},
5084 {0xa0, 0x00, ZC3XX_R13C_GAMMA1C},
5085 {0xa0, 0x00, ZC3XX_R13D_GAMMA1D},
5086 {0xa0, 0x00, ZC3XX_R13E_GAMMA1E},
5087 {0xa0, 0x01, ZC3XX_R13F_GAMMA1F},
5088 {0xa0, 0x4c, ZC3XX_R10A_RGB00}, /* matrix */
5089 {0xa0, 0xf1, ZC3XX_R10B_RGB01},
5090 {0xa0, 0x03, ZC3XX_R10C_RGB02},
5091 {0xa0, 0xfe, ZC3XX_R10D_RGB10},
5092 {0xa0, 0x51, ZC3XX_R10E_RGB11},
5093 {0xa0, 0xf1, ZC3XX_R10F_RGB12},
5094 {0xa0, 0xec, ZC3XX_R110_RGB20},
5095 {0xa0, 0x03, ZC3XX_R111_RGB21},
5096 {0xa0, 0x51, ZC3XX_R112_RGB22},
5097 {0xa0, 0x10, ZC3XX_R180_AUTOCORRECTENABLE},
5098 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
5099 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
5100 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
5101 {0xa0, 0x09, ZC3XX_R093_I2CSETVALUE},
5102 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5103 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5104 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
5105 {0xa0, 0x34, ZC3XX_R093_I2CSETVALUE},
5106 {0xa0, 0x01, ZC3XX_R094_I2CWRITEACK},
5107 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5108 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
5109 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
5110 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
5111 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5112 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5113 {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
5114 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
5115 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
5116 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
5117 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
5118 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
5119 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
5120 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
5121 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
5122 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
5123 {0xa0, 0x09, 0x01ad},
5124 {0xa0, 0x15, 0x01ae},
5125 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
5126 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
5127 {}
5128 };
5129
5130 static const struct usb_action tas5130CK_InitialScale[] = {
5131 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5132 {0xa0, 0x01, 0x003b},
5133 {0xa0, 0x0e, 0x003a},
5134 {0xa0, 0x01, 0x0038},
5135 {0xa0, 0x0b, 0x0039},
5136 {0xa0, 0x00, 0x0038},
5137 {0xa0, 0x0b, 0x0039},
5138 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5139 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5140 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
5141 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
5142 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5143 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5144 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5145 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5146 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
5147 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5148 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
5149 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
5150 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
5151 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
5152 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
5153 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
5154 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5155 {0xa0, 0x01, ZC3XX_R092_I2CADDRESSSELECT},
5156 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
5157 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5158 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5159 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
5160 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
5161 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5162 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5163 {0xa0, 0x08, ZC3XX_R092_I2CADDRESSSELECT},
5164 {0xa0, 0x83, ZC3XX_R093_I2CSETVALUE},
5165 {0xa0, 0x04, ZC3XX_R094_I2CWRITEACK},
5166 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5167 {0xa0, 0x01, ZC3XX_R092_I2CADDRESSSELECT},
5168 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
5169 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5170 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5171 {0xa0, 0x08, ZC3XX_R092_I2CADDRESSSELECT},
5172 {0xa0, 0x06, ZC3XX_R093_I2CSETVALUE},
5173 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5174 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5175 {0xa0, 0x02, ZC3XX_R092_I2CADDRESSSELECT},
5176 {0xa0, 0x11, ZC3XX_R093_I2CSETVALUE},
5177 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5178 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5179 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
5180 {0xa0, 0xe5, ZC3XX_R093_I2CSETVALUE},
5181 {0xa0, 0x01, ZC3XX_R094_I2CWRITEACK},
5182 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5183 {0xa0, 0x04, ZC3XX_R092_I2CADDRESSSELECT},
5184 {0xa0, 0x85, ZC3XX_R093_I2CSETVALUE},
5185 {0xa0, 0x02, ZC3XX_R094_I2CWRITEACK},
5186 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5187 {0xa0, 0x07, ZC3XX_R092_I2CADDRESSSELECT},
5188 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
5189 {0xa0, 0x30, ZC3XX_R094_I2CWRITEACK},
5190 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5191 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
5192 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
5193 {0xa0, 0x51, ZC3XX_R094_I2CWRITEACK},
5194 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5195 {0xa0, 0x35, ZC3XX_R092_I2CADDRESSSELECT},
5196 {0xa0, 0x7F, ZC3XX_R093_I2CSETVALUE},
5197 {0xa0, 0x50, ZC3XX_R094_I2CWRITEACK},
5198 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5199 {0xa0, 0x30, ZC3XX_R092_I2CADDRESSSELECT},
5200 {0xa0, 0x05, ZC3XX_R093_I2CSETVALUE},
5201 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5202 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5203 {0xa0, 0x31, ZC3XX_R092_I2CADDRESSSELECT},
5204 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
5205 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5206 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5207 {0xa0, 0x58, ZC3XX_R092_I2CADDRESSSELECT},
5208 {0xa0, 0x78, ZC3XX_R093_I2CSETVALUE},
5209 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5210 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5211 {0xa0, 0x62, ZC3XX_R092_I2CADDRESSSELECT},
5212 {0xa0, 0x11, ZC3XX_R093_I2CSETVALUE},
5213 {0xa0, 0x04, ZC3XX_R094_I2CWRITEACK},
5214 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5215 {0xa0, 0x2B, ZC3XX_R092_I2CADDRESSSELECT},
5216 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5217 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5218 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5219 {0xa0, 0x2C, ZC3XX_R092_I2CADDRESSSELECT},
5220 {0xa0, 0x7F, ZC3XX_R093_I2CSETVALUE},
5221 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5222 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5223 {0xa0, 0x2D, ZC3XX_R092_I2CADDRESSSELECT},
5224 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5225 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5226 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5227 {0xa0, 0x2e, ZC3XX_R092_I2CADDRESSSELECT},
5228 {0xa0, 0x7f, ZC3XX_R093_I2CSETVALUE},
5229 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5230 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5231 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
5232 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
5233 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5234 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5235 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5236 {0xa0, 0x09, 0x01ad},
5237 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5238 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5239 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5240 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5241 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
5242 {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
5243 {0xa0, 0x61, ZC3XX_R116_RGAIN},
5244 {0xa0, 0x65, ZC3XX_R118_BGAIN},
5245 {0xa0, 0x09, 0x01ad},
5246 {0xa0, 0x15, 0x01ae},
5247 {0xa0, 0x4c, ZC3XX_R10A_RGB00}, /* matrix */
5248 {0xa0, 0xf1, ZC3XX_R10B_RGB01},
5249 {0xa0, 0x03, ZC3XX_R10C_RGB02},
5250 {0xa0, 0xfe, ZC3XX_R10D_RGB10},
5251 {0xa0, 0x51, ZC3XX_R10E_RGB11},
5252 {0xa0, 0xf1, ZC3XX_R10F_RGB12},
5253 {0xa0, 0xec, ZC3XX_R110_RGB20},
5254 {0xa0, 0x03, ZC3XX_R111_RGB21},
5255 {0xa0, 0x51, ZC3XX_R112_RGB22},
5256 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5257 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
5258 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
5259 {0xa0, 0x38, ZC3XX_R120_GAMMA00}, /* gamma > 5 */
5260 {0xa0, 0x51, ZC3XX_R121_GAMMA01},
5261 {0xa0, 0x6e, ZC3XX_R122_GAMMA02},
5262 {0xa0, 0x8c, ZC3XX_R123_GAMMA03},
5263 {0xa0, 0xa2, ZC3XX_R124_GAMMA04},
5264 {0xa0, 0xb6, ZC3XX_R125_GAMMA05},
5265 {0xa0, 0xc8, ZC3XX_R126_GAMMA06},
5266 {0xa0, 0xd6, ZC3XX_R127_GAMMA07},
5267 {0xa0, 0xe2, ZC3XX_R128_GAMMA08},
5268 {0xa0, 0xed, ZC3XX_R129_GAMMA09},
5269 {0xa0, 0xf5, ZC3XX_R12A_GAMMA0A},
5270 {0xa0, 0xfc, ZC3XX_R12B_GAMMA0B},
5271 {0xa0, 0xff, ZC3XX_R12C_GAMMA0C},
5272 {0xa0, 0xff, ZC3XX_R12D_GAMMA0D},
5273 {0xa0, 0xff, ZC3XX_R12E_GAMMA0E},
5274 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
5275 {0xa0, 0x12, ZC3XX_R130_GAMMA10},
5276 {0xa0, 0x1b, ZC3XX_R131_GAMMA11},
5277 {0xa0, 0x1d, ZC3XX_R132_GAMMA12},
5278 {0xa0, 0x1a, ZC3XX_R133_GAMMA13},
5279 {0xa0, 0x15, ZC3XX_R134_GAMMA14},
5280 {0xa0, 0x12, ZC3XX_R135_GAMMA15},
5281 {0xa0, 0x0f, ZC3XX_R136_GAMMA16},
5282 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
5283 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
5284 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
5285 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
5286 {0xa0, 0x05, ZC3XX_R13B_GAMMA1B},
5287 {0xa0, 0x00, ZC3XX_R13C_GAMMA1C},
5288 {0xa0, 0x00, ZC3XX_R13D_GAMMA1D},
5289 {0xa0, 0x00, ZC3XX_R13E_GAMMA1E},
5290 {0xa0, 0x01, ZC3XX_R13F_GAMMA1F},
5291 {0xa0, 0x4c, ZC3XX_R10A_RGB00}, /* matrix */
5292 {0xa0, 0xf1, ZC3XX_R10B_RGB01},
5293 {0xa0, 0x03, ZC3XX_R10C_RGB02},
5294 {0xa0, 0xfe, ZC3XX_R10D_RGB10},
5295 {0xa0, 0x51, ZC3XX_R10E_RGB11},
5296 {0xa0, 0xf1, ZC3XX_R10F_RGB12},
5297 {0xa0, 0xec, ZC3XX_R110_RGB20},
5298 {0xa0, 0x03, ZC3XX_R111_RGB21},
5299 {0xa0, 0x51, ZC3XX_R112_RGB22},
5300 {0xa0, 0x10, ZC3XX_R180_AUTOCORRECTENABLE},
5301 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
5302 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
5303 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
5304 {0xa0, 0x62, ZC3XX_R093_I2CSETVALUE},
5305 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
5306 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5307 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
5308 {0xa0, 0xaa, ZC3XX_R093_I2CSETVALUE},
5309 {0xa0, 0x01, ZC3XX_R094_I2CWRITEACK},
5310 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
5311 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
5312 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
5313 {0xa0, 0x9b, ZC3XX_R192_EXPOSURELIMITLOW},
5314 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5315 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5316 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
5317 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
5318 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
5319 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
5320 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
5321 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
5322 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
5323 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
5324 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
5325 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
5326 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
5327 {0xa0, 0x09, 0x01ad},
5328 {0xa0, 0x15, 0x01ae},
5329 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
5330 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
5331 {0xa0, 0x30, 0x0007},
5332 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},
5333 {0xa0, 0x00, 0x0007},
5334 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5335 {}
5336 };
5337
5338 static const struct usb_action tas5130cxx_InitialScale[] = { /* 320x240 */
5339 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5340 {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT},
5341 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5342 {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5343 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5344 {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5345 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5346 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5347 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5348 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5349 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5350 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5351 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5352
5353 {0xa0, 0x04, ZC3XX_R098_WINYSTARTLOW},
5354 {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5355 {0xa0, 0x04, ZC3XX_R11A_FIRSTYLOW},
5356 {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5357 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
5358 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5359 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
5360 {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5361 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
5362 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5363 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5364 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
5365 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
5366 {0xa0, 0x00, 0x01ad},
5367 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5368 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5369 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5370 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5371 {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5372 {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
5373 {}
5374 };
5375 static const struct usb_action tas5130cxx_Initial[] = { /* 640x480 */
5376 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5377 {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT},
5378 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},
5379 {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5380 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5381 {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5382 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5383 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5384 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5385 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5386 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5387 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5388 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5389 {0xa0, 0x05, ZC3XX_R098_WINYSTARTLOW},
5390 {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5391 {0xa0, 0x05, ZC3XX_R11A_FIRSTYLOW},
5392 {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5393 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
5394 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5395 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
5396 {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5397 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
5398 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5399 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5400 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
5401 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
5402 {0xa0, 0x00, 0x01ad},
5403 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5404 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5405 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5406 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5407 {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5408 {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
5409 {}
5410 };
5411 static const struct usb_action tas5130cxx_50HZ[] = {
5412 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5413 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5414 {0xaa, 0xa4, 0x0063}, /* 00,a4,63,aa */
5415 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5416 {0xa0, 0x63, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,63,cc */
5417 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5418 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
5419 {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
5420 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5421 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5422 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,47,cc */
5423 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5424 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5425 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5426 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5427 {0xa0, 0xd3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,d3,cc */
5428 {0xa0, 0xda, ZC3XX_R01E_HSYNC_1}, /* 00,1e,da,cc */
5429 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
5430 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5431 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5432 {0xa0, 0x4c, ZC3XX_R0A0_MAXXLOW},
5433 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5434 {}
5435 };
5436 static const struct usb_action tas5130cxx_50HZScale[] = {
5437 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5438 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5439 {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
5440 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5441 {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5442 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5443 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
5444 {0xa0, 0xd0, ZC3XX_R192_EXPOSURELIMITLOW},
5445 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5446 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5447 {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
5448 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5449 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5450 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5451 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5452 {0xa0, 0xf0, ZC3XX_R01D_HSYNC_0}, /* 00,1d,f0,cc */
5453 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,f4,cc */
5454 {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f8,cc */
5455 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5456 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5457 {0xa0, 0xc0, ZC3XX_R0A0_MAXXLOW},
5458 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5459 {}
5460 };
5461 static const struct usb_action tas5130cxx_60HZ[] = {
5462 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5463 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5464 {0xaa, 0xa4, 0x0036}, /* 00,a4,36,aa */
5465 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5466 {0xa0, 0x36, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,36,cc */
5467 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5468 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5469 {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW},
5470 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5471 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5472 {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3e,cc */
5473 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5474 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5475 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5476 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5477 {0xa0, 0xca, ZC3XX_R01D_HSYNC_0}, /* 00,1d,ca,cc */
5478 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5479 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5480 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5481 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5482 {0xa0, 0x28, ZC3XX_R0A0_MAXXLOW},
5483 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5484 {}
5485 };
5486 static const struct usb_action tas5130cxx_60HZScale[] = {
5487 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5488 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5489 {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
5490 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5491 {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5492 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5493 {0xa0, 0x09, ZC3XX_R191_EXPOSURELIMITMID},
5494 {0xa0, 0x47, ZC3XX_R192_EXPOSURELIMITLOW},
5495 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5496 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5497 {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
5498 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5499 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5500 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5501 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5502 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
5503 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5504 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5505 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5506 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5507 {0xa0, 0x20, ZC3XX_R0A0_MAXXLOW},
5508 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5509 {}
5510 };
5511 static const struct usb_action tas5130cxx_NoFliker[] = {
5512 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5513 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5514 {0xaa, 0xa4, 0x0040}, /* 00,a4,40,aa */
5515 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5516 {0xa0, 0x40, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,40,cc */
5517 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5518 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5519 {0xa0, 0xa0, ZC3XX_R192_EXPOSURELIMITLOW},
5520 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5521 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5522 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5523 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5524 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5525 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5526 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5527 {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5528 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5529 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5530 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5531 {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
5532 {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5533 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5534 {}
5535 };
5536
5537 static const struct usb_action tas5130cxx_NoFlikerScale[] = {
5538 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5539 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5540 {0xaa, 0xa4, 0x0090}, /* 00,a4,90,aa */
5541 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5542 {0xa0, 0x90, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,90,cc */
5543 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5544 {0xa0, 0x0a, ZC3XX_R191_EXPOSURELIMITMID},
5545 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
5546 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5547 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5548 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5549 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5550 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5551 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5552 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5553 {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5554 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5555 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5556 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5557 {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
5558 {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5559 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5560 {}
5561 };
5562
5563 static const struct usb_action tas5130c_vf0250_Initial[] = {
5564 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc, */
5565 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, /* 00,08,02,cc, */
5566 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc, */
5567 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc,
5568 * 0<->10 */
5569 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc, */
5570 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc, */
5571 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc, */
5572 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc, */
5573 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5574 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc, */
5575 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc, */
5576 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc, */
5577 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc, */
5578 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc, */
5579 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc, */
5580 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc, */
5581 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc,
5582 * 6<->8 */
5583 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc,
5584 * 6<->8 */
5585 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID}, /* 00,87,10,cc, */
5586 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5587 {0xaa, 0x1b, 0x0024}, /* 00,1b,24,aa, */
5588 {0xdd, 0x00, 0x0080}, /* 00,00,80,dd, */
5589 {0xaa, 0x1b, 0x0000}, /* 00,1b,00,aa, */
5590 {0xaa, 0x13, 0x0002}, /* 00,13,02,aa, */
5591 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
5592 /*?? {0xaa, 0x01, 0x0000}, */
5593 {0xaa, 0x01, 0x0000},
5594 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa, */
5595 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa, */
5596 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc, */
5597 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc, */
5598 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc, */
5599 {0xaa, 0x05, 0x0010}, /* 00,05,10,aa, */
5600 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa, */
5601 {0xaa, 0x0b, 0x00a0}, /* 00,0b,a0,aa, */
5602 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa, */
5603 {0xaa, 0x0d, 0x00a0}, /* 00,0d,a0,aa, */
5604 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa, */
5605 {0xaa, 0x0f, 0x00a0}, /* 00,0f,a0,aa, */
5606 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa, */
5607 {0xaa, 0x11, 0x00a0}, /* 00,11,a0,aa, */
5608 /*?? {0xa0, 0x00, 0x0039},
5609 {0xa1, 0x01, 0x0037}, */
5610 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa, */
5611 {0xaa, 0x17, 0x00e8}, /* 00,17,e6,aa, (e6 -> e8) */
5612 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa, */
5613 {0xaa, 0x19, 0x0088}, /* 00,19,86,aa, */
5614 {0xaa, 0x20, 0x0020}, /* 00,20,20,aa, */
5615 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc, */
5616 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc, */
5617 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc, */
5618 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc, */
5619 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc, */
5620 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc, */
5621 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc, */
5622 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc, */
5623 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc, */
5624 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc, */
5625 {0xa0, 0x61, ZC3XX_R116_RGAIN}, /* 01,16,61,cc, */
5626 {0xa0, 0x65, ZC3XX_R118_BGAIN}, /* 01,18,65,cc */
5627 {}
5628 };
5629
5630 static const struct usb_action tas5130c_vf0250_InitialScale[] = {
5631 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc, */
5632 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, /* 00,08,02,cc, */
5633 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc, */
5634 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc, */
5635 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc, */
5636 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc, */
5637 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc, */
5638 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc, */
5639 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5640 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc, */
5641 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc, */
5642 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc, */
5643 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc, */
5644 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc, */
5645 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc, */
5646 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc, */
5647 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc,
5648 * 8<->6 */
5649 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc,
5650 * 8<->6 */
5651 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID}, /* 00,87,10,cc, */
5652 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5653 {0xaa, 0x1b, 0x0024}, /* 00,1b,24,aa, */
5654 {0xdd, 0x00, 0x0080}, /* 00,00,80,dd, */
5655 {0xaa, 0x1b, 0x0000}, /* 00,1b,00,aa, */
5656 {0xaa, 0x13, 0x0002}, /* 00,13,02,aa, */
5657 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
5658 /*?? {0xaa, 0x01, 0x0000}, */
5659 {0xaa, 0x01, 0x0000},
5660 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa, */
5661 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa, */
5662 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc, */
5663 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc, */
5664 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc, */
5665 {0xaa, 0x05, 0x0010}, /* 00,05,10,aa, */
5666 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa, */
5667 {0xaa, 0x0b, 0x00a0}, /* 00,0b,a0,aa, */
5668 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa, */
5669 {0xaa, 0x0d, 0x00a0}, /* 00,0d,a0,aa, */
5670 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa, */
5671 {0xaa, 0x0f, 0x00a0}, /* 00,0f,a0,aa, */
5672 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa, */
5673 {0xaa, 0x11, 0x00a0}, /* 00,11,a0,aa, */
5674 /*?? {0xa0, 0x00, 0x0039},
5675 {0xa1, 0x01, 0x0037}, */
5676 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa, */
5677 {0xaa, 0x17, 0x00e8}, /* 00,17,e6,aa (e6 -> e8) */
5678 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa, */
5679 {0xaa, 0x19, 0x0088}, /* 00,19,88,aa, */
5680 {0xaa, 0x20, 0x0020}, /* 00,20,20,aa, */
5681 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc, */
5682 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc, */
5683 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc, */
5684 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc, */
5685 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc, */
5686 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc, */
5687 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc, */
5688 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc, */
5689 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc, */
5690 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc, */
5691 {0xa0, 0x61, ZC3XX_R116_RGAIN}, /* 01,16,61,cc, */
5692 {0xa0, 0x65, ZC3XX_R118_BGAIN}, /* 01,18,65,cc */
5693 {}
5694 };
5695 /* "50HZ" light frequency banding filter */
5696 static const struct usb_action tas5130c_vf0250_50HZ[] = {
5697 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5698 {0xaa, 0x83, 0x0001}, /* 00,83,01,aa */
5699 {0xaa, 0x84, 0x00aa}, /* 00,84,aa,aa */
5700 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5701 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0d,cc, */
5702 {0xa0, 0xa8, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc, */
5703 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5704 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5705 {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,47,cc, */
5706 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5707 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5708 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
5709 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc, */
5710 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5711 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5712 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5713 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5714 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5715 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
5716 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /* 01,8d,78,cc */
5717 {}
5718 };
5719
5720 /* "50HZScale" light frequency banding filter */
5721 static const struct usb_action tas5130c_vf0250_50HZScale[] = {
5722 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5723 {0xaa, 0x83, 0x0003}, /* 00,83,03,aa */
5724 {0xaa, 0x84, 0x0054}, /* 00,84,54,aa */
5725 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5726 {0xa0, 0x0d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0d,cc, */
5727 {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc, */
5728 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5729 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5730 {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,8e,cc, */
5731 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5732 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5733 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
5734 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc, */
5735 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5736 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5737 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5738 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5739 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5740 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
5741 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /* 01,8d,78,cc */
5742 {}
5743 };
5744
5745 /* "60HZ" light frequency banding filter */
5746 static const struct usb_action tas5130c_vf0250_60HZ[] = {
5747 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5748 {0xaa, 0x83, 0x0001}, /* 00,83,01,aa */
5749 {0xaa, 0x84, 0x0062}, /* 00,84,62,aa */
5750 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5751 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,05,cc, */
5752 {0xa0, 0x88, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,88,cc, */
5753 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5754 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5755 {0xa0, 0x3b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3b,cc, */
5756 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5757 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5758 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
5759 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc, */
5760 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5761 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5762 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5763 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5764 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5765 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
5766 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /* 01,8d,78,cc */
5767 {}
5768 };
5769
5770 /* "60HZScale" light frequency banding ilter */
5771 static const struct usb_action tas5130c_vf0250_60HZScale[] = {
5772 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5773 {0xaa, 0x83, 0x0002}, /* 00,83,02,aa */
5774 {0xaa, 0x84, 0x00c4}, /* 00,84,c4,aa */
5775 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5776 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,1,0b,cc, */
5777 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,2,10,cc, */
5778 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,5,00,cc, */
5779 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,6,00,cc, */
5780 {0xa0, 0x76, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,7,76,cc, */
5781 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,c,0e,cc, */
5782 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,f,15,cc, */
5783 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,9,10,cc, */
5784 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,a,24,cc, */
5785 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,d,62,cc, */
5786 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,e,90,cc, */
5787 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,f,c8,cc, */
5788 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,0,ff,cc, */
5789 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,d,58,cc, */
5790 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
5791 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /* 01,d,78,cc */
5792 {}
5793 };
5794
5795 /* "NoFliker" light frequency banding flter */
5796 static const struct usb_action tas5130c_vf0250_NoFliker[] = {
5797 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc, */
5798 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5799 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
5800 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
5801 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,0,00,cc, */
5802 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,05,cc, */
5803 {0xa0, 0x88, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,88,cc, */
5804 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5805 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5806 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc, */
5807 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5808 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5809 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5810 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5811 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5812 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5813 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5814 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
5815 {}
5816 };
5817
5818 /* "NoFlikerScale" light frequency banding filter */
5819 static const struct usb_action tas5130c_vf0250_NoFlikerScale[] = {
5820 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc, */
5821 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5822 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
5823 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
5824 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5825 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0b,cc, */
5826 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc, */
5827 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5828 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5829 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc, */
5830 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5831 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5832 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5833 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5834 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5835 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5836 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5837 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
5838 {}
5839 };
5840
5841 static u8 reg_r_i(struct gspca_dev *gspca_dev,
5842 __u16 index)
5843 {
5844 usb_control_msg(gspca_dev->dev,
5845 usb_rcvctrlpipe(gspca_dev->dev, 0),
5846 0xa1,
5847 USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5848 0x01, /* value */
5849 index, gspca_dev->usb_buf, 1,
5850 500);
5851 return gspca_dev->usb_buf[0];
5852 }
5853
5854 static u8 reg_r(struct gspca_dev *gspca_dev,
5855 __u16 index)
5856 {
5857 u8 ret;
5858
5859 ret = reg_r_i(gspca_dev, index);
5860 PDEBUG(D_USBI, "reg r [%04x] -> %02x", index, ret);
5861 return ret;
5862 }
5863
5864 static void reg_w_i(struct usb_device *dev,
5865 __u8 value,
5866 __u16 index)
5867 {
5868 usb_control_msg(dev,
5869 usb_sndctrlpipe(dev, 0),
5870 0xa0,
5871 USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5872 value, index, NULL, 0,
5873 500);
5874 }
5875
5876 static void reg_w(struct usb_device *dev,
5877 __u8 value,
5878 __u16 index)
5879 {
5880 PDEBUG(D_USBO, "reg w [%04x] = %02x", index, value);
5881 reg_w_i(dev, value, index);
5882 }
5883
5884 static __u16 i2c_read(struct gspca_dev *gspca_dev,
5885 __u8 reg)
5886 {
5887 __u8 retbyte;
5888 __u16 retval;
5889
5890 reg_w_i(gspca_dev->dev, reg, 0x0092);
5891 reg_w_i(gspca_dev->dev, 0x02, 0x0090); /* <- read command */
5892 msleep(20);
5893 retbyte = reg_r_i(gspca_dev, 0x0091); /* read status */
5894 if (retbyte != 0x00)
5895 err("i2c_r status error %02x", retbyte);
5896 retval = reg_r_i(gspca_dev, 0x0095); /* read Lowbyte */
5897 retval |= reg_r_i(gspca_dev, 0x0096) << 8; /* read Hightbyte */
5898 PDEBUG(D_USBI, "i2c r [%02x] -> %04x (%02x)",
5899 reg, retval, retbyte);
5900 return retval;
5901 }
5902
5903 static __u8 i2c_write(struct gspca_dev *gspca_dev,
5904 __u8 reg,
5905 __u8 valL,
5906 __u8 valH)
5907 {
5908 __u8 retbyte;
5909
5910 reg_w_i(gspca_dev->dev, reg, 0x92);
5911 reg_w_i(gspca_dev->dev, valL, 0x93);
5912 reg_w_i(gspca_dev->dev, valH, 0x94);
5913 reg_w_i(gspca_dev->dev, 0x01, 0x90); /* <- write command */
5914 msleep(1);
5915 retbyte = reg_r_i(gspca_dev, 0x0091); /* read status */
5916 if (retbyte != 0x00)
5917 err("i2c_w status error %02x", retbyte);
5918 PDEBUG(D_USBO, "i2c w [%02x] = %02x%02x (%02x)",
5919 reg, valH, valL, retbyte);
5920 return retbyte;
5921 }
5922
5923 static void usb_exchange(struct gspca_dev *gspca_dev,
5924 const struct usb_action *action)
5925 {
5926 while (action->req) {
5927 switch (action->req) {
5928 case 0xa0: /* write register */
5929 reg_w(gspca_dev->dev, action->val, action->idx);
5930 break;
5931 case 0xa1: /* read status */
5932 reg_r(gspca_dev, action->idx);
5933 break;
5934 case 0xaa:
5935 i2c_write(gspca_dev,
5936 action->val, /* reg */
5937 action->idx & 0xff, /* valL */
5938 action->idx >> 8); /* valH */
5939 break;
5940 case 0xbb:
5941 i2c_write(gspca_dev,
5942 action->idx >> 8, /* reg */
5943 action->idx & 0xff, /* valL */
5944 action->val); /* valH */
5945 break;
5946 default:
5947 /* case 0xdd: * delay */
5948 msleep(action->val / 64 + 10);
5949 break;
5950 }
5951 action++;
5952 msleep(1);
5953 }
5954 }
5955
5956 static void setmatrix(struct gspca_dev *gspca_dev)
5957 {
5958 struct sd *sd = (struct sd *) gspca_dev;
5959 int i;
5960 const __u8 *matrix;
5961 static const u8 adcm2700_matrix[9] =
5962 /* {0x66, 0xed, 0xed, 0xed, 0x66, 0xed, 0xed, 0xed, 0x66}; */
5963 /*ms-win*/
5964 {0x74, 0xed, 0xed, 0xed, 0x74, 0xed, 0xed, 0xed, 0x74};
5965 static const __u8 gc0305_matrix[9] =
5966 {0x50, 0xf8, 0xf8, 0xf8, 0x50, 0xf8, 0xf8, 0xf8, 0x50};
5967 static const __u8 ov7620_matrix[9] =
5968 {0x58, 0xf4, 0xf4, 0xf4, 0x58, 0xf4, 0xf4, 0xf4, 0x58};
5969 static const __u8 pas202b_matrix[9] =
5970 {0x4c, 0xf5, 0xff, 0xf9, 0x51, 0xf5, 0xfb, 0xed, 0x5f};
5971 static const __u8 po2030_matrix[9] =
5972 {0x60, 0xf0, 0xf0, 0xf0, 0x60, 0xf0, 0xf0, 0xf0, 0x60};
5973 static const u8 tas5130c_matrix[9] =
5974 {0x68, 0xec, 0xec, 0xec, 0x68, 0xec, 0xec, 0xec, 0x68};
5975 static const __u8 vf0250_matrix[9] =
5976 {0x7b, 0xea, 0xea, 0xea, 0x7b, 0xea, 0xea, 0xea, 0x7b};
5977 static const __u8 *matrix_tb[SENSOR_MAX] = {
5978 adcm2700_matrix, /* SENSOR_ADCM2700 0 */
5979 ov7620_matrix, /* SENSOR_CS2102 1 */
5980 NULL, /* SENSOR_CS2102K 2 */
5981 gc0305_matrix, /* SENSOR_GC0305 3 */
5982 NULL, /* SENSOR_HDCS2020b 4 */
5983 NULL, /* SENSOR_HV7131B 5 */
5984 NULL, /* SENSOR_HV7131C 6 */
5985 NULL, /* SENSOR_ICM105A 7 */
5986 NULL, /* SENSOR_MC501CB 8 */
5987 gc0305_matrix, /* SENSOR_MI0360SOC 9 */
5988 ov7620_matrix, /* SENSOR_OV7620 10 */
5989 NULL, /* SENSOR_OV7630C 11 */
5990 NULL, /* SENSOR_PAS106 12 */
5991 pas202b_matrix, /* SENSOR_PAS202B 13 */
5992 gc0305_matrix, /* SENSOR_PB0330 14 */
5993 po2030_matrix, /* SENSOR_PO2030 15 */
5994 NULL, /* SENSOR_TAS5130CK 16 */
5995 tas5130c_matrix, /* SENSOR_TAS5130CXX 17 */
5996 vf0250_matrix, /* SENSOR_TAS5130C_VF0250 18 */
5997 };
5998
5999 matrix = matrix_tb[sd->sensor];
6000 if (matrix == NULL)
6001 return; /* matrix already loaded */
6002 for (i = 0; i < ARRAY_SIZE(ov7620_matrix); i++)
6003 reg_w(gspca_dev->dev, matrix[i], 0x010a + i);
6004 }
6005
6006 static void setbrightness(struct gspca_dev *gspca_dev)
6007 {
6008 struct sd *sd = (struct sd *) gspca_dev;
6009 __u8 brightness;
6010
6011 switch (sd->sensor) {
6012 case SENSOR_GC0305:
6013 case SENSOR_OV7620:
6014 case SENSOR_PO2030:
6015 return;
6016 }
6017 /*fixme: is it really write to 011d and 018d for all other sensors? */
6018 brightness = sd->brightness;
6019 reg_w(gspca_dev->dev, brightness, 0x011d);
6020 switch (sd->sensor) {
6021 case SENSOR_ADCM2700:
6022 case SENSOR_HV7131B:
6023 return;
6024 }
6025 if (brightness < 0x70)
6026 brightness += 0x10;
6027 else
6028 brightness = 0x80;
6029 reg_w(gspca_dev->dev, brightness, 0x018d);
6030 }
6031
6032 static void setsharpness(struct gspca_dev *gspca_dev)
6033 {
6034 struct sd *sd = (struct sd *) gspca_dev;
6035 struct usb_device *dev = gspca_dev->dev;
6036 int sharpness;
6037 static const __u8 sharpness_tb[][2] = {
6038 {0x02, 0x03},
6039 {0x04, 0x07},
6040 {0x08, 0x0f},
6041 {0x10, 0x1e}
6042 };
6043
6044 sharpness = sd->sharpness;
6045 reg_w(dev, sharpness_tb[sharpness][0], 0x01c6);
6046 reg_r(gspca_dev, 0x01c8);
6047 reg_r(gspca_dev, 0x01c9);
6048 reg_r(gspca_dev, 0x01ca);
6049 reg_w(dev, sharpness_tb[sharpness][1], 0x01cb);
6050 }
6051
6052 static void setcontrast(struct gspca_dev *gspca_dev)
6053 {
6054 struct sd *sd = (struct sd *) gspca_dev;
6055 struct usb_device *dev = gspca_dev->dev;
6056 const __u8 *Tgamma, *Tgradient;
6057 int g, i, k;
6058 static const __u8 kgamma_tb[16] = /* delta for contrast */
6059 {0x15, 0x0d, 0x0a, 0x09, 0x08, 0x08, 0x08, 0x08,
6060 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08};
6061 static const __u8 kgrad_tb[16] =
6062 {0x1b, 0x06, 0x03, 0x02, 0x00, 0x00, 0x00, 0x00,
6063 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x06, 0x04};
6064 static const __u8 Tgamma_1[16] =
6065 {0x00, 0x00, 0x03, 0x0d, 0x1b, 0x2e, 0x45, 0x5f,
6066 0x79, 0x93, 0xab, 0xc1, 0xd4, 0xe5, 0xf3, 0xff};
6067 static const __u8 Tgradient_1[16] =
6068 {0x00, 0x01, 0x05, 0x0b, 0x10, 0x15, 0x18, 0x1a,
6069 0x1a, 0x18, 0x16, 0x14, 0x12, 0x0f, 0x0d, 0x06};
6070 static const __u8 Tgamma_2[16] =
6071 {0x01, 0x0c, 0x1f, 0x3a, 0x53, 0x6d, 0x85, 0x9c,
6072 0xb0, 0xc2, 0xd1, 0xde, 0xe9, 0xf2, 0xf9, 0xff};
6073 static const __u8 Tgradient_2[16] =
6074 {0x05, 0x0f, 0x16, 0x1a, 0x19, 0x19, 0x17, 0x15,
6075 0x12, 0x10, 0x0e, 0x0b, 0x09, 0x08, 0x06, 0x03};
6076 static const __u8 Tgamma_3[16] =
6077 {0x04, 0x16, 0x30, 0x4e, 0x68, 0x81, 0x98, 0xac,
6078 0xbe, 0xcd, 0xda, 0xe4, 0xed, 0xf5, 0xfb, 0xff};
6079 static const __u8 Tgradient_3[16] =
6080 {0x0c, 0x16, 0x1b, 0x1c, 0x19, 0x18, 0x15, 0x12,
6081 0x10, 0x0d, 0x0b, 0x09, 0x08, 0x06, 0x05, 0x03};
6082 static const __u8 Tgamma_4[16] =
6083 {0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
6084 0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff};
6085 static const __u8 Tgradient_4[16] =
6086 {0x26, 0x22, 0x20, 0x1c, 0x16, 0x13, 0x10, 0x0d,
6087 0x0b, 0x09, 0x07, 0x06, 0x05, 0x04, 0x03, 0x02};
6088 static const __u8 Tgamma_5[16] =
6089 {0x20, 0x4b, 0x6e, 0x8d, 0xa3, 0xb5, 0xc5, 0xd2,
6090 0xdc, 0xe5, 0xec, 0xf2, 0xf6, 0xfa, 0xfd, 0xff};
6091 static const __u8 Tgradient_5[16] =
6092 {0x37, 0x26, 0x20, 0x1a, 0x14, 0x10, 0x0e, 0x0b,
6093 0x09, 0x07, 0x06, 0x05, 0x04, 0x03, 0x02, 0x02};
6094 static const __u8 Tgamma_6[16] = /* ?? was gamma 5 */
6095 {0x24, 0x44, 0x64, 0x84, 0x9d, 0xb2, 0xc4, 0xd3,
6096 0xe0, 0xeb, 0xf4, 0xff, 0xff, 0xff, 0xff, 0xff};
6097 static const __u8 Tgradient_6[16] =
6098 {0x18, 0x20, 0x20, 0x1c, 0x16, 0x13, 0x10, 0x0e,
6099 0x0b, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00, 0x01};
6100 static const __u8 *gamma_tb[] = {
6101 NULL, Tgamma_1, Tgamma_2,
6102 Tgamma_3, Tgamma_4, Tgamma_5, Tgamma_6
6103 };
6104 static const __u8 *gradient_tb[] = {
6105 NULL, Tgradient_1, Tgradient_2,
6106 Tgradient_3, Tgradient_4, Tgradient_5, Tgradient_6
6107 };
6108 #ifdef GSPCA_DEBUG
6109 __u8 v[16];
6110 #endif
6111
6112 Tgamma = gamma_tb[sd->gamma];
6113 Tgradient = gradient_tb[sd->gamma];
6114
6115 k = (sd->contrast - 128) /* -128 / 128 */
6116 * Tgamma[0];
6117 PDEBUG(D_CONF, "gamma:%d contrast:%d gamma coeff: %d/128",
6118 sd->gamma, sd->contrast, k);
6119 for (i = 0; i < 16; i++) {
6120 g = Tgamma[i] + kgamma_tb[i] * k / 128;
6121 if (g > 0xff)
6122 g = 0xff;
6123 else if (g <= 0)
6124 g = 1;
6125 reg_w(dev, g, 0x0120 + i); /* gamma */
6126 #ifdef GSPCA_DEBUG
6127 if (gspca_debug & D_CONF)
6128 v[i] = g;
6129 #endif
6130 }
6131 PDEBUG(D_CONF, "tb: %02x %02x %02x %02x %02x %02x %02x %02x",
6132 v[0], v[1], v[2], v[3], v[4], v[5], v[6], v[7]);
6133 PDEBUG(D_CONF, " %02x %02x %02x %02x %02x %02x %02x %02x",
6134 v[8], v[9], v[10], v[11], v[12], v[13], v[14], v[15]);
6135 for (i = 0; i < 16; i++) {
6136 g = Tgradient[i] - kgrad_tb[i] * k / 128;
6137 if (g > 0xff)
6138 g = 0xff;
6139 else if (g <= 0) {
6140 if (i != 15)
6141 g = 0;
6142 else
6143 g = 1;
6144 }
6145 reg_w(dev, g, 0x0130 + i); /* gradient */
6146 #ifdef GSPCA_DEBUG
6147 if (gspca_debug & D_CONF)
6148 v[i] = g;
6149 #endif
6150 }
6151 PDEBUG(D_CONF, " %02x %02x %02x %02x %02x %02x %02x %02x",
6152 v[0], v[1], v[2], v[3], v[4], v[5], v[6], v[7]);
6153 PDEBUG(D_CONF, " %02x %02x %02x %02x %02x %02x %02x %02x",
6154 v[8], v[9], v[10], v[11], v[12], v[13], v[14], v[15]);
6155 }
6156
6157 static void setquality(struct gspca_dev *gspca_dev)
6158 {
6159 struct sd *sd = (struct sd *) gspca_dev;
6160 struct usb_device *dev = gspca_dev->dev;
6161 __u8 frxt;
6162
6163 switch (sd->sensor) {
6164 case SENSOR_ADCM2700:
6165 case SENSOR_GC0305:
6166 case SENSOR_HV7131B:
6167 case SENSOR_OV7620:
6168 case SENSOR_PO2030:
6169 return;
6170 }
6171 /*fixme: is it really 0008 0007 0018 for all other sensors? */
6172 reg_w(dev, QUANT_VAL, 0x0008);
6173 frxt = 0x30;
6174 reg_w(dev, frxt, 0x0007);
6175 #if QUANT_VAL == 0 || QUANT_VAL == 1 || QUANT_VAL == 2
6176 frxt = 0xff;
6177 #elif QUANT_VAL == 3
6178 frxt = 0xf0;
6179 #elif QUANT_VAL == 4
6180 frxt = 0xe0;
6181 #else
6182 frxt = 0x20;
6183 #endif
6184 reg_w(dev, frxt, 0x0018);
6185 }
6186
6187 /* Matches the sensor's internal frame rate to the lighting frequency.
6188 * Valid frequencies are:
6189 * 50Hz, for European and Asian lighting (default)
6190 * 60Hz, for American lighting
6191 * 0 = No Fliker (for outdoore usage)
6192 * Returns: 0 for success
6193 */
6194 static int setlightfreq(struct gspca_dev *gspca_dev)
6195 {
6196 struct sd *sd = (struct sd *) gspca_dev;
6197 int i, mode;
6198 const struct usb_action *zc3_freq;
6199 static const struct usb_action *freq_tb[SENSOR_MAX][6] = {
6200 /* SENSOR_ADCM2700 0 */
6201 {adcm2700_NoFliker, adcm2700_NoFliker,
6202 adcm2700_50HZ, adcm2700_50HZ,
6203 adcm2700_60HZ, adcm2700_60HZ},
6204 /* SENSOR_CS2102 1 */
6205 {cs2102_NoFliker, cs2102_NoFlikerScale,
6206 cs2102_50HZ, cs2102_50HZScale,
6207 cs2102_60HZ, cs2102_60HZScale},
6208 /* SENSOR_CS2102K 2 */
6209 {cs2102_NoFliker, cs2102_NoFlikerScale,
6210 NULL, NULL, /* currently disabled */
6211 NULL, NULL},
6212 /* SENSOR_GC0305 3 */
6213 {gc0305_NoFliker, gc0305_NoFliker,
6214 gc0305_50HZ, gc0305_50HZ,
6215 gc0305_60HZ, gc0305_60HZ},
6216 /* SENSOR_HDCS2020b 4 */
6217 {hdcs2020b_NoFliker, hdcs2020b_NoFliker,
6218 hdcs2020b_50HZ, hdcs2020b_50HZ,
6219 hdcs2020b_60HZ, hdcs2020b_60HZ},
6220 /* SENSOR_HV7131B 5 */
6221 {hv7131b_NoFlikerScale, hv7131b_NoFliker,
6222 hv7131b_50HZScale, hv7131b_50HZ,
6223 hv7131b_60HZScale, hv7131b_60HZ},
6224 /* SENSOR_HV7131C 6 */
6225 {NULL, NULL,
6226 NULL, NULL,
6227 NULL, NULL},
6228 /* SENSOR_ICM105A 7 */
6229 {icm105a_NoFliker, icm105a_NoFlikerScale,
6230 icm105a_50HZ, icm105a_50HZScale,
6231 icm105a_60HZ, icm105a_60HZScale},
6232 /* SENSOR_MC501CB 8 */
6233 {MC501CB_NoFliker, MC501CB_NoFlikerScale,
6234 MC501CB_50HZ, MC501CB_50HZScale,
6235 MC501CB_60HZ, MC501CB_60HZScale},
6236 /* SENSOR_MI0360SOC 9 */
6237 {mi360soc_AENoFlikerScale, mi360soc_AENoFliker,
6238 mi360soc_AE50HZScale, mi360soc_AE50HZ,
6239 mi360soc_AE60HZScale, mi360soc_AE60HZ},
6240 /* SENSOR_OV7620 10 */
6241 {OV7620_NoFliker, OV7620_NoFliker,
6242 OV7620_50HZ, OV7620_50HZ,
6243 OV7620_60HZ, OV7620_60HZ},
6244 /* SENSOR_OV7630C 11 */
6245 {NULL, NULL,
6246 NULL, NULL,
6247 NULL, NULL},
6248 /* SENSOR_PAS106 12 */
6249 {pas106b_NoFliker, pas106b_NoFliker,
6250 pas106b_50HZ, pas106b_50HZ,
6251 pas106b_60HZ, pas106b_60HZ},
6252 /* SENSOR_PAS202B 13 */
6253 {pas202b_NoFlikerScale, pas202b_NoFliker,
6254 pas202b_50HZScale, pas202b_50HZ,
6255 pas202b_60HZScale, pas202b_60HZ},
6256 /* SENSOR_PB0330 14 */
6257 {pb0330_NoFlikerScale, pb0330_NoFliker,
6258 pb0330_50HZScale, pb0330_50HZ,
6259 pb0330_60HZScale, pb0330_60HZ},
6260 /* SENSOR_PO2030 15 */
6261 {PO2030_NoFliker, PO2030_NoFliker,
6262 PO2030_50HZ, PO2030_50HZ,
6263 PO2030_60HZ, PO2030_60HZ},
6264 /* SENSOR_TAS5130CK 16 */
6265 {tas5130cxx_NoFlikerScale, tas5130cxx_NoFliker,
6266 tas5130cxx_50HZScale, tas5130cxx_50HZ,
6267 tas5130cxx_60HZScale, tas5130cxx_60HZ},
6268 /* SENSOR_TAS5130CXX 17 */
6269 {tas5130cxx_NoFlikerScale, tas5130cxx_NoFliker,
6270 tas5130cxx_50HZScale, tas5130cxx_50HZ,
6271 tas5130cxx_60HZScale, tas5130cxx_60HZ},
6272 /* SENSOR_TAS5130C_VF0250 18 */
6273 {tas5130c_vf0250_NoFliker, tas5130c_vf0250_NoFlikerScale,
6274 tas5130c_vf0250_50HZ, tas5130c_vf0250_50HZScale,
6275 tas5130c_vf0250_60HZ, tas5130c_vf0250_60HZScale},
6276 };
6277
6278 i = sd->lightfreq * 2;
6279 mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv;
6280 if (!mode)
6281 i++; /* 640x480 */
6282 zc3_freq = freq_tb[(int) sd->sensor][i];
6283 if (zc3_freq != NULL) {
6284 usb_exchange(gspca_dev, zc3_freq);
6285 switch (sd->sensor) {
6286 case SENSOR_GC0305:
6287 if (mode /* if 320x240 */
6288 && sd->lightfreq == 1) /* and 50Hz */
6289 reg_w(gspca_dev->dev, 0x85, 0x018d);
6290 /* win: 0x80, 0x018d */
6291 break;
6292 case SENSOR_OV7620:
6293 if (!mode) { /* if 640x480 */
6294 if (sd->lightfreq != 0) /* and 50 or 60 Hz */
6295 reg_w(gspca_dev->dev, 0x40, 0x0002);
6296 else
6297 reg_w(gspca_dev->dev, 0x44, 0x0002);
6298 }
6299 break;
6300 }
6301 }
6302 return 0;
6303 }
6304
6305 static void setautogain(struct gspca_dev *gspca_dev)
6306 {
6307 struct sd *sd = (struct sd *) gspca_dev;
6308 __u8 autoval;
6309
6310 if (sd->autogain)
6311 autoval = 0x42;
6312 else
6313 autoval = 0x02;
6314 reg_w(gspca_dev->dev, autoval, 0x0180);
6315 }
6316
6317 static void send_unknown(struct usb_device *dev, int sensor)
6318 {
6319 reg_w(dev, 0x01, 0x0000); /* led off */
6320 switch (sensor) {
6321 case SENSOR_PAS106:
6322 reg_w(dev, 0x03, 0x003a);
6323 reg_w(dev, 0x0c, 0x003b);
6324 reg_w(dev, 0x08, 0x0038);
6325 break;
6326 case SENSOR_ADCM2700:
6327 case SENSOR_GC0305:
6328 case SENSOR_OV7620:
6329 case SENSOR_MI0360SOC:
6330 case SENSOR_PB0330:
6331 case SENSOR_PO2030:
6332 reg_w(dev, 0x0d, 0x003a);
6333 reg_w(dev, 0x02, 0x003b);
6334 reg_w(dev, 0x00, 0x0038);
6335 break;
6336 }
6337 }
6338
6339 /* start probe 2 wires */
6340 static void start_2wr_probe(struct usb_device *dev, int sensor)
6341 {
6342 reg_w(dev, 0x01, 0x0000);
6343 reg_w(dev, sensor, 0x0010);
6344 reg_w(dev, 0x01, 0x0001);
6345 reg_w(dev, 0x03, 0x0012);
6346 reg_w(dev, 0x01, 0x0012);
6347 /* msleep(2); */
6348 }
6349
6350 static int sif_probe(struct gspca_dev *gspca_dev)
6351 {
6352 __u16 checkword;
6353
6354 start_2wr_probe(gspca_dev->dev, 0x0f); /* PAS106 */
6355 reg_w(gspca_dev->dev, 0x08, 0x008d);
6356 msleep(150);
6357 checkword = ((i2c_read(gspca_dev, 0x00) & 0x0f) << 4)
6358 | ((i2c_read(gspca_dev, 0x01) & 0xf0) >> 4);
6359 PDEBUG(D_PROBE, "probe sif 0x%04x", checkword);
6360 if (checkword == 0x0007) {
6361 send_unknown(gspca_dev->dev, SENSOR_PAS106);
6362 return 0x0f; /* PAS106 */
6363 }
6364 return -1;
6365 }
6366
6367 static int vga_2wr_probe(struct gspca_dev *gspca_dev)
6368 {
6369 struct usb_device *dev = gspca_dev->dev;
6370 u16 retword;
6371
6372 start_2wr_probe(dev, 0x00); /* HV7131B */
6373 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6374 retword = i2c_read(gspca_dev, 0x01);
6375 if (retword != 0)
6376 return 0x00; /* HV7131B */
6377
6378 start_2wr_probe(dev, 0x04); /* CS2102 */
6379 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6380 retword = i2c_read(gspca_dev, 0x01);
6381 if (retword != 0)
6382 return 0x04; /* CS2102 */
6383
6384 start_2wr_probe(dev, 0x06); /* OmniVision */
6385 reg_w(dev, 0x08, 0x008d);
6386 i2c_write(gspca_dev, 0x11, 0xaa, 0x00);
6387 retword = i2c_read(gspca_dev, 0x11);
6388 if (retword != 0) {
6389 /* (should have returned 0xaa) --> Omnivision? */
6390 /* reg_r 0x10 -> 0x06 --> */
6391 goto ov_check;
6392 }
6393
6394 start_2wr_probe(dev, 0x08); /* HDCS2020 */
6395 i2c_write(gspca_dev, 0x15, 0xaa, 0x00);
6396 retword = i2c_read(gspca_dev, 0x15);
6397 if (retword != 0)
6398 return 0x08; /* HDCS2020 */
6399
6400 start_2wr_probe(dev, 0x0a); /* PB0330 */
6401 i2c_write(gspca_dev, 0x07, 0xaa, 0xaa);
6402 retword = i2c_read(gspca_dev, 0x07);
6403 if (retword != 0)
6404 return 0x0a; /* PB0330 */
6405 retword = i2c_read(gspca_dev, 0x03);
6406 if (retword != 0)
6407 return 0x0a; /* PB0330 ?? */
6408 retword = i2c_read(gspca_dev, 0x04);
6409 if (retword != 0)
6410 return 0x0a; /* PB0330 ?? */
6411
6412 start_2wr_probe(dev, 0x0c); /* ICM105A */
6413 i2c_write(gspca_dev, 0x01, 0x11, 0x00);
6414 retword = i2c_read(gspca_dev, 0x01);
6415 if (retword != 0)
6416 return 0x0c; /* ICM105A */
6417
6418 start_2wr_probe(dev, 0x0e); /* PAS202BCB */
6419 reg_w(dev, 0x08, 0x008d);
6420 i2c_write(gspca_dev, 0x03, 0xaa, 0x00);
6421 msleep(50);
6422 retword = i2c_read(gspca_dev, 0x03);
6423 if (retword != 0)
6424 return 0x0e; /* PAS202BCB */
6425
6426 start_2wr_probe(dev, 0x02); /* TAS5130C */
6427 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6428 retword = i2c_read(gspca_dev, 0x01);
6429 if (retword != 0)
6430 return 0x02; /* TAS5130C */
6431 ov_check:
6432 reg_r(gspca_dev, 0x0010); /* ?? */
6433 reg_r(gspca_dev, 0x0010);
6434
6435 reg_w(dev, 0x01, 0x0000);
6436 reg_w(dev, 0x01, 0x0001);
6437 reg_w(dev, 0x06, 0x0010); /* OmniVision */
6438 reg_w(dev, 0xa1, 0x008b);
6439 reg_w(dev, 0x08, 0x008d);
6440 msleep(500);
6441 reg_w(dev, 0x01, 0x0012);
6442 i2c_write(gspca_dev, 0x12, 0x80, 0x00); /* sensor reset */
6443 retword = i2c_read(gspca_dev, 0x0a) << 8;
6444 retword |= i2c_read(gspca_dev, 0x0b);
6445 PDEBUG(D_PROBE, "probe 2wr ov vga 0x%04x", retword);
6446 switch (retword) {
6447 case 0x7631: /* OV7630C */
6448 reg_w(dev, 0x06, 0x0010);
6449 break;
6450 case 0x7620: /* OV7620 */
6451 case 0x7648: /* OV7648 */
6452 break;
6453 default:
6454 return -1; /* not OmniVision */
6455 }
6456 return retword;
6457 }
6458
6459 struct sensor_by_chipset_revision {
6460 __u16 revision;
6461 __u8 internal_sensor_id;
6462 };
6463 static const struct sensor_by_chipset_revision chipset_revision_sensor[] = {
6464 {0xc000, 0x12}, /* TAS5130C */
6465 {0xc001, 0x13}, /* MI0360SOC */
6466 {0xe001, 0x13},
6467 {0x8001, 0x13},
6468 {0x8000, 0x14}, /* CS2102K */
6469 {0x8400, 0x15}, /* TAS5130K */
6470 };
6471
6472 static int vga_3wr_probe(struct gspca_dev *gspca_dev)
6473 {
6474 struct sd *sd = (struct sd *) gspca_dev;
6475 struct usb_device *dev = gspca_dev->dev;
6476 int i;
6477 __u8 retbyte;
6478 u16 retword;
6479
6480 /*fixme: lack of 8b=b3 (11,12)-> 10, 8b=e0 (14,15,16)-> 12 found in gspcav1*/
6481 reg_w(dev, 0x02, 0x0010);
6482 reg_r(gspca_dev, 0x0010);
6483 reg_w(dev, 0x01, 0x0000);
6484 reg_w(dev, 0x00, 0x0010);
6485 reg_w(dev, 0x01, 0x0001);
6486 reg_w(dev, 0x91, 0x008b);
6487 reg_w(dev, 0x03, 0x0012);
6488 reg_w(dev, 0x01, 0x0012);
6489 reg_w(dev, 0x05, 0x0012);
6490 retword = i2c_read(gspca_dev, 0x14);
6491 if (retword != 0)
6492 return 0x11; /* HV7131R */
6493 retword = i2c_read(gspca_dev, 0x15);
6494 if (retword != 0)
6495 return 0x11; /* HV7131R */
6496 retword = i2c_read(gspca_dev, 0x16);
6497 if (retword != 0)
6498 return 0x11; /* HV7131R */
6499
6500 reg_w(dev, 0x02, 0x0010);
6501 retword = reg_r(gspca_dev, 0x000b) << 8;
6502 retword |= reg_r(gspca_dev, 0x000a);
6503 PDEBUG(D_PROBE, "probe 3wr vga 1 0x%04x", retword);
6504 reg_r(gspca_dev, 0x0010);
6505 /* value 0x4001 is meaningless */
6506 if (retword != 0x4001) {
6507 if ((retword & 0xff00) == 0x6400)
6508 return 0x02; /* TAS5130C */
6509 for (i = 0; i < ARRAY_SIZE(chipset_revision_sensor); i++) {
6510 if (chipset_revision_sensor[i].revision == retword) {
6511 sd->chip_revision = retword;
6512 send_unknown(dev, SENSOR_PB0330);
6513 return chipset_revision_sensor[i]
6514 .internal_sensor_id;
6515 }
6516 }
6517 }
6518
6519 reg_w(dev, 0x01, 0x0000); /* check PB0330 */
6520 reg_w(dev, 0x01, 0x0001);
6521 reg_w(dev, 0xdd, 0x008b);
6522 reg_w(dev, 0x0a, 0x0010);
6523 reg_w(dev, 0x03, 0x0012);
6524 reg_w(dev, 0x01, 0x0012);
6525 retword = i2c_read(gspca_dev, 0x00);
6526 if (retword != 0) {
6527 PDEBUG(D_PROBE, "probe 3wr vga type 0a ?");
6528 return 0x0a; /* PB0330 */
6529 }
6530
6531 reg_w(dev, 0x01, 0x0000);
6532 reg_w(dev, 0x01, 0x0001);
6533 reg_w(dev, 0x98, 0x008b);
6534 reg_w(dev, 0x01, 0x0010);
6535 reg_w(dev, 0x03, 0x0012);
6536 msleep(2);
6537 reg_w(dev, 0x01, 0x0012);
6538 retword = i2c_read(gspca_dev, 0x00);
6539 if (retword != 0) {
6540 PDEBUG(D_PROBE, "probe 3wr vga type %02x", retword);
6541 if (retword == 0x0011) /* VF0250 */
6542 return 0x0250;
6543 if (retword == 0x0029) /* gc0305 */
6544 send_unknown(dev, SENSOR_GC0305);
6545 return retword;
6546 }
6547
6548 reg_w(dev, 0x01, 0x0000); /* check OmniVision */
6549 reg_w(dev, 0x01, 0x0001);
6550 reg_w(dev, 0xa1, 0x008b);
6551 reg_w(dev, 0x08, 0x008d);
6552 reg_w(dev, 0x06, 0x0010);
6553 reg_w(dev, 0x01, 0x0012);
6554 reg_w(dev, 0x05, 0x0012);
6555 if (i2c_read(gspca_dev, 0x1c) == 0x007f /* OV7610 - manufacturer ID */
6556 && i2c_read(gspca_dev, 0x1d) == 0x00a2) {
6557 send_unknown(dev, SENSOR_OV7620);
6558 return 0x06; /* OmniVision confirm ? */
6559 }
6560
6561 reg_w(dev, 0x01, 0x0000);
6562 reg_w(dev, 0x00, 0x0002);
6563 reg_w(dev, 0x01, 0x0010);
6564 reg_w(dev, 0x01, 0x0001);
6565 reg_w(dev, 0xee, 0x008b);
6566 reg_w(dev, 0x03, 0x0012);
6567 reg_w(dev, 0x01, 0x0012);
6568 reg_w(dev, 0x05, 0x0012);
6569 retword = i2c_read(gspca_dev, 0x00) << 8; /* ID 0 */
6570 retword |= i2c_read(gspca_dev, 0x01); /* ID 1 */
6571 PDEBUG(D_PROBE, "probe 3wr vga 2 0x%04x", retword);
6572 if (retword == 0x2030) {
6573 retbyte = i2c_read(gspca_dev, 0x02); /* revision number */
6574 PDEBUG(D_PROBE, "sensor PO2030 rev 0x%02x", retbyte);
6575 send_unknown(dev, SENSOR_PO2030);
6576 return retword;
6577 }
6578
6579 reg_w(dev, 0x01, 0x0000);
6580 reg_w(dev, 0x0a, 0x0010);
6581 reg_w(dev, 0xd3, 0x008b);
6582 reg_w(dev, 0x01, 0x0001);
6583 reg_w(dev, 0x03, 0x0012);
6584 reg_w(dev, 0x01, 0x0012);
6585 reg_w(dev, 0x05, 0x0012);
6586 reg_w(dev, 0xd3, 0x008b);
6587 retword = i2c_read(gspca_dev, 0x01);
6588 if (retword != 0) {
6589 PDEBUG(D_PROBE, "probe 3wr vga type 0a ? ret: %04x", retword);
6590 return 0x16; /* adcm2700 (6100/6200) */
6591 }
6592 return -1;
6593 }
6594
6595 static int zcxx_probeSensor(struct gspca_dev *gspca_dev)
6596 {
6597 struct sd *sd = (struct sd *) gspca_dev;
6598 int sensor;
6599
6600 switch (sd->sensor) {
6601 case SENSOR_MC501CB:
6602 return -1; /* don't probe */
6603 case SENSOR_TAS5130C_VF0250:
6604 /* may probe but with no write in reg 0x0010 */
6605 return -1; /* don't probe */
6606 case SENSOR_PAS106:
6607 sensor = sif_probe(gspca_dev);
6608 if (sensor >= 0)
6609 return sensor;
6610 break;
6611 }
6612 sensor = vga_2wr_probe(gspca_dev);
6613 if (sensor >= 0)
6614 return sensor;
6615 return vga_3wr_probe(gspca_dev);
6616 }
6617
6618 /* this function is called at probe time */
6619 static int sd_config(struct gspca_dev *gspca_dev,
6620 const struct usb_device_id *id)
6621 {
6622 struct sd *sd = (struct sd *) gspca_dev;
6623 struct cam *cam;
6624 int sensor;
6625 int vga = 1; /* 1: vga, 0: sif */
6626 static const __u8 gamma[SENSOR_MAX] = {
6627 4, /* SENSOR_ADCM2700 0 */
6628 4, /* SENSOR_CS2102 1 */
6629 5, /* SENSOR_CS2102K 2 */
6630 4, /* SENSOR_GC0305 3 */
6631 4, /* SENSOR_HDCS2020b 4 */
6632 4, /* SENSOR_HV7131B 5 */
6633 4, /* SENSOR_HV7131C 6 */
6634 4, /* SENSOR_ICM105A 7 */
6635 4, /* SENSOR_MC501CB 8 */
6636 4, /* SENSOR_MI0360SOC 9 */
6637 3, /* SENSOR_OV7620 10 */
6638 4, /* SENSOR_OV7630C 11 */
6639 4, /* SENSOR_PAS106 12 */
6640 4, /* SENSOR_PAS202B 13 */
6641 4, /* SENSOR_PB0330 14 */
6642 4, /* SENSOR_PO2030 15 */
6643 4, /* SENSOR_TAS5130CK 16 */
6644 3, /* SENSOR_TAS5130CXX 17 */
6645 3, /* SENSOR_TAS5130C_VF0250 18 */
6646 };
6647
6648 /* define some sensors from the vendor/product */
6649 sd->sharpness = 2;
6650 sd->sensor = id->driver_info;
6651 sensor = zcxx_probeSensor(gspca_dev);
6652 if (sensor >= 0)
6653 PDEBUG(D_PROBE, "probe sensor -> %04x", sensor);
6654 if ((unsigned) force_sensor < SENSOR_MAX) {
6655 sd->sensor = force_sensor;
6656 PDEBUG(D_PROBE, "sensor forced to %d", force_sensor);
6657 } else {
6658 switch (sensor) {
6659 case -1:
6660 switch (sd->sensor) {
6661 case SENSOR_MC501CB:
6662 PDEBUG(D_PROBE, "Sensor MC501CB");
6663 break;
6664 case SENSOR_TAS5130C_VF0250:
6665 PDEBUG(D_PROBE, "Sensor Tas5130 (VF0250)");
6666 break;
6667 default:
6668 PDEBUG(D_PROBE,
6669 "Sensor UNKNOWN_0 force Tas5130");
6670 sd->sensor = SENSOR_TAS5130CXX;
6671 }
6672 break;
6673 case 0:
6674 PDEBUG(D_PROBE, "Find Sensor HV7131B");
6675 sd->sensor = SENSOR_HV7131B;
6676 break;
6677 case 0x02:
6678 PDEBUG(D_PROBE, "Sensor TAS5130C");
6679 sd->sensor = SENSOR_TAS5130CXX;
6680 break;
6681 case 0x04:
6682 PDEBUG(D_PROBE, "Find Sensor CS2102");
6683 sd->sensor = SENSOR_CS2102;
6684 break;
6685 case 0x08:
6686 PDEBUG(D_PROBE, "Find Sensor HDCS2020(b)");
6687 sd->sensor = SENSOR_HDCS2020b;
6688 break;
6689 case 0x0a:
6690 PDEBUG(D_PROBE,
6691 "Find Sensor PB0330. Chip revision %x",
6692 sd->chip_revision);
6693 sd->sensor = SENSOR_PB0330;
6694 break;
6695 case 0x0c:
6696 PDEBUG(D_PROBE, "Find Sensor ICM105A");
6697 sd->sensor = SENSOR_ICM105A;
6698 break;
6699 case 0x0e:
6700 PDEBUG(D_PROBE, "Find Sensor PAS202B");
6701 sd->sensor = SENSOR_PAS202B;
6702 sd->sharpness = 1;
6703 break;
6704 case 0x0f:
6705 PDEBUG(D_PROBE, "Find Sensor PAS106");
6706 sd->sensor = SENSOR_PAS106;
6707 vga = 0; /* SIF */
6708 break;
6709 case 0x10:
6710 case 0x12:
6711 PDEBUG(D_PROBE, "Find Sensor TAS5130C");
6712 sd->sensor = SENSOR_TAS5130CXX;
6713 break;
6714 case 0x11:
6715 PDEBUG(D_PROBE, "Find Sensor HV7131R(c)");
6716 sd->sensor = SENSOR_HV7131C;
6717 break;
6718 case 0x13:
6719 PDEBUG(D_PROBE,
6720 "Find Sensor MI0360SOC. Chip revision %x",
6721 sd->chip_revision);
6722 sd->sensor = SENSOR_MI0360SOC;
6723 break;
6724 case 0x14:
6725 PDEBUG(D_PROBE,
6726 "Find Sensor CS2102K?. Chip revision %x",
6727 sd->chip_revision);
6728 sd->sensor = SENSOR_CS2102K;
6729 break;
6730 case 0x15:
6731 PDEBUG(D_PROBE,
6732 "Find Sensor TAS5130CK?. Chip revision %x",
6733 sd->chip_revision);
6734 sd->sensor = SENSOR_TAS5130CK;
6735 break;
6736 case 0x16:
6737 PDEBUG(D_PROBE, "Find Sensor ADCM2700");
6738 sd->sensor = SENSOR_ADCM2700;
6739 break;
6740 case 0x29:
6741 PDEBUG(D_PROBE, "Find Sensor GC0305");
6742 sd->sensor = SENSOR_GC0305;
6743 break;
6744 case 0x0250:
6745 PDEBUG(D_PROBE, "Sensor Tas5130 (VF0250)");
6746 sd->sensor = SENSOR_TAS5130C_VF0250;
6747 break;
6748 case 0x2030:
6749 PDEBUG(D_PROBE, "Find Sensor PO2030");
6750 sd->sensor = SENSOR_PO2030;
6751 sd->sharpness = 0; /* from win traces */
6752 break;
6753 case 0x7620:
6754 PDEBUG(D_PROBE, "Find Sensor OV7620");
6755 sd->sensor = SENSOR_OV7620;
6756 break;
6757 case 0x7631:
6758 PDEBUG(D_PROBE, "Find Sensor OV7630C");
6759 sd->sensor = SENSOR_OV7630C;
6760 break;
6761 case 0x7648:
6762 PDEBUG(D_PROBE, "Find Sensor OV7648");
6763 sd->sensor = SENSOR_OV7620; /* same sensor (?) */
6764 break;
6765 default:
6766 PDEBUG(D_ERR|D_PROBE, "Unknown sensor %04x", sensor);
6767 return -EINVAL;
6768 }
6769 }
6770 if (sensor < 0x20) {
6771 if (sensor == -1 || sensor == 0x10 || sensor == 0x12)
6772 reg_w(gspca_dev->dev, 0x02, 0x0010);
6773 else
6774 reg_w(gspca_dev->dev, sensor & 0x0f, 0x0010);
6775 reg_r(gspca_dev, 0x0010);
6776 }
6777
6778 cam = &gspca_dev->cam;
6779 /*fixme:test*/
6780 gspca_dev->nbalt--;
6781 if (vga) {
6782 cam->cam_mode = vga_mode;
6783 cam->nmodes = ARRAY_SIZE(vga_mode);
6784 } else {
6785 cam->cam_mode = sif_mode;
6786 cam->nmodes = ARRAY_SIZE(sif_mode);
6787 }
6788 sd->brightness = sd_ctrls[SD_BRIGHTNESS].qctrl.default_value;
6789 sd->contrast = sd_ctrls[SD_CONTRAST].qctrl.default_value;
6790 sd->gamma = gamma[(int) sd->sensor];
6791 sd->autogain = sd_ctrls[SD_AUTOGAIN].qctrl.default_value;
6792 sd->lightfreq = sd_ctrls[SD_FREQ].qctrl.default_value;
6793 sd->quality = QUALITY_DEF;
6794
6795 switch (sd->sensor) {
6796 case SENSOR_GC0305:
6797 case SENSOR_OV7620:
6798 case SENSOR_PO2030:
6799 gspca_dev->ctrl_dis = (1 << BRIGHTNESS_IDX);
6800 break;
6801 case SENSOR_HV7131B:
6802 case SENSOR_HV7131C:
6803 case SENSOR_OV7630C:
6804 gspca_dev->ctrl_dis = (1 << LIGHTFREQ_IDX);
6805 break;
6806 }
6807
6808 /* switch the led off */
6809 reg_w(gspca_dev->dev, 0x01, 0x0000);
6810 return 0;
6811 }
6812
6813 /* this function is called at probe and resume time */
6814 static int sd_init(struct gspca_dev *gspca_dev)
6815 {
6816 reg_w(gspca_dev->dev, 0x01, 0x0000);
6817 return 0;
6818 }
6819
6820 static int sd_start(struct gspca_dev *gspca_dev)
6821 {
6822 struct sd *sd = (struct sd *) gspca_dev;
6823 struct usb_device *dev = gspca_dev->dev;
6824 const struct usb_action *zc3_init;
6825 int mode;
6826 static const struct usb_action *init_tb[SENSOR_MAX][2] = {
6827 {adcm2700_Initial, adcm2700_InitialScale}, /* 0 */
6828 {cs2102_InitialScale, cs2102_Initial}, /* 1 */
6829 {cs2102K_InitialScale, cs2102K_Initial}, /* 2 */
6830 {gc0305_Initial, gc0305_InitialScale}, /* 3 */
6831 {hdcs2020xb_InitialScale, hdcs2020xb_Initial}, /* 4 */
6832 {hv7131bxx_InitialScale, hv7131bxx_Initial}, /* 5 */
6833 {hv7131cxx_InitialScale, hv7131cxx_Initial}, /* 6 */
6834 {icm105axx_InitialScale, icm105axx_Initial}, /* 7 */
6835 {MC501CB_InitialScale, MC501CB_Initial}, /* 8 */
6836 {mi0360soc_Initial, mi0360soc_InitialScale}, /* 9 */
6837 {OV7620_mode0, OV7620_mode1}, /* 10 */
6838 {ov7630c_InitialScale, ov7630c_Initial}, /* 11 */
6839 {pas106b_InitialScale, pas106b_Initial}, /* 12 */
6840 {pas202b_Initial, pas202b_InitialScale}, /* 13 */
6841 {pb0330_Initial, pb0330_InitialScale}, /* 14 */
6842 {PO2030_mode0, PO2030_mode1}, /* 15 */
6843 {tas5130CK_InitialScale, tas5130CK_Initial}, /* 16 */
6844 {tas5130cxx_Initial, tas5130cxx_InitialScale}, /* 17 */
6845 {tas5130c_vf0250_InitialScale, tas5130c_vf0250_Initial},
6846 /* 18 */
6847 };
6848
6849 /* create the JPEG header */
6850 sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL);
6851 if (!sd->jpeg_hdr)
6852 return -ENOMEM;
6853 jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width,
6854 0x21); /* JPEG 422 */
6855 jpeg_set_qual(sd->jpeg_hdr, sd->quality);
6856
6857 mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv;
6858 zc3_init = init_tb[(int) sd->sensor][mode];
6859 switch (sd->sensor) {
6860 case SENSOR_HV7131C:
6861 zcxx_probeSensor(gspca_dev);
6862 break;
6863 case SENSOR_PAS106:
6864 usb_exchange(gspca_dev, pas106b_Initial_com);
6865 break;
6866 }
6867 usb_exchange(gspca_dev, zc3_init);
6868
6869 switch (sd->sensor) {
6870 case SENSOR_ADCM2700:
6871 case SENSOR_GC0305:
6872 case SENSOR_OV7620:
6873 case SENSOR_PO2030:
6874 case SENSOR_TAS5130CXX:
6875 case SENSOR_TAS5130C_VF0250:
6876 /* msleep(100); * ?? */
6877 reg_r(gspca_dev, 0x0002); /* --> 0x40 */
6878 reg_w(dev, 0x09, 0x01ad); /* (from win traces) */
6879 reg_w(dev, 0x15, 0x01ae);
6880 if (sd->sensor == SENSOR_TAS5130CXX)
6881 break;
6882 reg_w(dev, 0x0d, 0x003a);
6883 reg_w(dev, 0x02, 0x003b);
6884 reg_w(dev, 0x00, 0x0038);
6885 break;
6886 }
6887
6888 setmatrix(gspca_dev);
6889 setbrightness(gspca_dev);
6890 switch (sd->sensor) {
6891 case SENSOR_ADCM2700:
6892 case SENSOR_OV7620:
6893 reg_r(gspca_dev, 0x0008);
6894 reg_w(dev, 0x00, 0x0008);
6895 break;
6896 case SENSOR_PAS202B:
6897 case SENSOR_GC0305:
6898 case SENSOR_TAS5130CXX:
6899 reg_r(gspca_dev, 0x0008);
6900 /* fall thru */
6901 case SENSOR_PO2030:
6902 reg_w(dev, 0x03, 0x0008);
6903 break;
6904 }
6905 setsharpness(gspca_dev);
6906
6907 /* set the gamma tables when not set */
6908 switch (sd->sensor) {
6909 case SENSOR_CS2102K: /* gamma set in xxx_Initial */
6910 case SENSOR_HDCS2020b:
6911 case SENSOR_OV7630C:
6912 case SENSOR_TAS5130CK:
6913 break;
6914 default:
6915 setcontrast(gspca_dev);
6916 break;
6917 }
6918 setmatrix(gspca_dev); /* one more time? */
6919 switch (sd->sensor) {
6920 case SENSOR_OV7620:
6921 case SENSOR_PAS202B:
6922 case SENSOR_TAS5130CXX:
6923 reg_r(gspca_dev, 0x0180); /* from win */
6924 reg_w(dev, 0x00, 0x0180);
6925 break;
6926 default:
6927 setquality(gspca_dev);
6928 break;
6929 }
6930 setlightfreq(gspca_dev);
6931
6932 switch (sd->sensor) {
6933 case SENSOR_ADCM2700:
6934 reg_w(dev, 0x09, 0x01ad); /* (from win traces) */
6935 reg_w(dev, 0x15, 0x01ae);
6936 reg_w(dev, 0x02, 0x0180);
6937 /* ms-win + */
6938 reg_w(dev, 0x40, 0x0117);
6939 break;
6940 case SENSOR_GC0305:
6941 case SENSOR_TAS5130CXX:
6942 reg_w(dev, 0x09, 0x01ad); /* (from win traces) */
6943 reg_w(dev, 0x15, 0x01ae);
6944 /* fall thru */
6945 case SENSOR_PAS202B:
6946 case SENSOR_PO2030:
6947 /* reg_w(dev, 0x40, ZC3XX_R117_GGAIN); * (from win traces) */
6948 reg_r(gspca_dev, 0x0180);
6949 break;
6950 case SENSOR_OV7620:
6951 reg_w(dev, 0x09, 0x01ad);
6952 reg_w(dev, 0x15, 0x01ae);
6953 i2c_read(gspca_dev, 0x13); /*fixme: returns 0xa3 */
6954 i2c_write(gspca_dev, 0x13, 0xa3, 0x00);
6955 /*fixme: returned value to send? */
6956 reg_w(dev, 0x40, 0x0117);
6957 reg_r(gspca_dev, 0x0180);
6958 break;
6959 }
6960
6961 setautogain(gspca_dev);
6962 switch (sd->sensor) {
6963 case SENSOR_PO2030:
6964 msleep(50);
6965 reg_r(gspca_dev, 0x0008);
6966 reg_r(gspca_dev, 0x0007);
6967 /*fall thru*/
6968 case SENSOR_PAS202B:
6969 reg_w(dev, 0x00, 0x0007); /* (from win traces) */
6970 reg_w(dev, 0x02, ZC3XX_R008_CLOCKSETTING);
6971 break;
6972 }
6973 return 0;
6974 }
6975
6976 /* called on streamoff with alt 0 and on disconnect */
6977 static void sd_stop0(struct gspca_dev *gspca_dev)
6978 {
6979 struct sd *sd = (struct sd *) gspca_dev;
6980
6981 kfree(sd->jpeg_hdr);
6982 if (!gspca_dev->present)
6983 return;
6984 send_unknown(gspca_dev->dev, sd->sensor);
6985 }
6986
6987 static void sd_pkt_scan(struct gspca_dev *gspca_dev,
6988 u8 *data,
6989 int len)
6990 {
6991 struct sd *sd = (struct sd *) gspca_dev;
6992
6993 if (data[0] == 0xff && data[1] == 0xd8) { /* start of frame */
6994 gspca_frame_add(gspca_dev, LAST_PACKET,
6995 NULL, 0);
6996 /* put the JPEG header in the new frame */
6997 gspca_frame_add(gspca_dev, FIRST_PACKET,
6998 sd->jpeg_hdr, JPEG_HDR_SZ);
6999
7000 /* remove the webcam's header:
7001 * ff d8 ff fe 00 0e 00 00 ss ss 00 01 ww ww hh hh pp pp
7002 * - 'ss ss' is the frame sequence number (BE)
7003 * - 'ww ww' and 'hh hh' are the window dimensions (BE)
7004 * - 'pp pp' is the packet sequence number (BE)
7005 */
7006 data += 18;
7007 len -= 18;
7008 }
7009 gspca_frame_add(gspca_dev, INTER_PACKET, data, len);
7010 }
7011
7012 static int sd_setbrightness(struct gspca_dev *gspca_dev, __s32 val)
7013 {
7014 struct sd *sd = (struct sd *) gspca_dev;
7015
7016 sd->brightness = val;
7017 if (gspca_dev->streaming)
7018 setbrightness(gspca_dev);
7019 return 0;
7020 }
7021
7022 static int sd_getbrightness(struct gspca_dev *gspca_dev, __s32 *val)
7023 {
7024 struct sd *sd = (struct sd *) gspca_dev;
7025
7026 *val = sd->brightness;
7027 return 0;
7028 }
7029
7030 static int sd_setcontrast(struct gspca_dev *gspca_dev, __s32 val)
7031 {
7032 struct sd *sd = (struct sd *) gspca_dev;
7033
7034 sd->contrast = val;
7035 if (gspca_dev->streaming)
7036 setcontrast(gspca_dev);
7037 return 0;
7038 }
7039
7040 static int sd_getcontrast(struct gspca_dev *gspca_dev, __s32 *val)
7041 {
7042 struct sd *sd = (struct sd *) gspca_dev;
7043
7044 *val = sd->contrast;
7045 return 0;
7046 }
7047
7048 static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val)
7049 {
7050 struct sd *sd = (struct sd *) gspca_dev;
7051
7052 sd->autogain = val;
7053 if (gspca_dev->streaming)
7054 setautogain(gspca_dev);
7055 return 0;
7056 }
7057
7058 static int sd_getautogain(struct gspca_dev *gspca_dev, __s32 *val)
7059 {
7060 struct sd *sd = (struct sd *) gspca_dev;
7061
7062 *val = sd->autogain;
7063 return 0;
7064 }
7065
7066 static int sd_setgamma(struct gspca_dev *gspca_dev, __s32 val)
7067 {
7068 struct sd *sd = (struct sd *) gspca_dev;
7069
7070 sd->gamma = val;
7071 if (gspca_dev->streaming)
7072 setcontrast(gspca_dev);
7073 return 0;
7074 }
7075
7076 static int sd_getgamma(struct gspca_dev *gspca_dev, __s32 *val)
7077 {
7078 struct sd *sd = (struct sd *) gspca_dev;
7079
7080 *val = sd->gamma;
7081 return 0;
7082 }
7083
7084 static int sd_setfreq(struct gspca_dev *gspca_dev, __s32 val)
7085 {
7086 struct sd *sd = (struct sd *) gspca_dev;
7087
7088 sd->lightfreq = val;
7089 if (gspca_dev->streaming)
7090 setlightfreq(gspca_dev);
7091 return 0;
7092 }
7093
7094 static int sd_getfreq(struct gspca_dev *gspca_dev, __s32 *val)
7095 {
7096 struct sd *sd = (struct sd *) gspca_dev;
7097
7098 *val = sd->lightfreq;
7099 return 0;
7100 }
7101
7102 static int sd_setsharpness(struct gspca_dev *gspca_dev, __s32 val)
7103 {
7104 struct sd *sd = (struct sd *) gspca_dev;
7105
7106 sd->sharpness = val;
7107 if (gspca_dev->streaming)
7108 setsharpness(gspca_dev);
7109 return 0;
7110 }
7111
7112 static int sd_getsharpness(struct gspca_dev *gspca_dev, __s32 *val)
7113 {
7114 struct sd *sd = (struct sd *) gspca_dev;
7115
7116 *val = sd->sharpness;
7117 return 0;
7118 }
7119
7120 static int sd_querymenu(struct gspca_dev *gspca_dev,
7121 struct v4l2_querymenu *menu)
7122 {
7123 switch (menu->id) {
7124 case V4L2_CID_POWER_LINE_FREQUENCY:
7125 switch (menu->index) {
7126 case 0: /* V4L2_CID_POWER_LINE_FREQUENCY_DISABLED */
7127 strcpy((char *) menu->name, "NoFliker");
7128 return 0;
7129 case 1: /* V4L2_CID_POWER_LINE_FREQUENCY_50HZ */
7130 strcpy((char *) menu->name, "50 Hz");
7131 return 0;
7132 case 2: /* V4L2_CID_POWER_LINE_FREQUENCY_60HZ */
7133 strcpy((char *) menu->name, "60 Hz");
7134 return 0;
7135 }
7136 break;
7137 }
7138 return -EINVAL;
7139 }
7140
7141 static int sd_set_jcomp(struct gspca_dev *gspca_dev,
7142 struct v4l2_jpegcompression *jcomp)
7143 {
7144 struct sd *sd = (struct sd *) gspca_dev;
7145
7146 if (jcomp->quality < QUALITY_MIN)
7147 sd->quality = QUALITY_MIN;
7148 else if (jcomp->quality > QUALITY_MAX)
7149 sd->quality = QUALITY_MAX;
7150 else
7151 sd->quality = jcomp->quality;
7152 if (gspca_dev->streaming)
7153 jpeg_set_qual(sd->jpeg_hdr, sd->quality);
7154 return 0;
7155 }
7156
7157 static int sd_get_jcomp(struct gspca_dev *gspca_dev,
7158 struct v4l2_jpegcompression *jcomp)
7159 {
7160 struct sd *sd = (struct sd *) gspca_dev;
7161
7162 memset(jcomp, 0, sizeof *jcomp);
7163 jcomp->quality = sd->quality;
7164 jcomp->jpeg_markers = V4L2_JPEG_MARKER_DHT
7165 | V4L2_JPEG_MARKER_DQT;
7166 return 0;
7167 }
7168
7169 static const struct sd_desc sd_desc = {
7170 .name = MODULE_NAME,
7171 .ctrls = sd_ctrls,
7172 .nctrls = ARRAY_SIZE(sd_ctrls),
7173 .config = sd_config,
7174 .init = sd_init,
7175 .start = sd_start,
7176 .stop0 = sd_stop0,
7177 .pkt_scan = sd_pkt_scan,
7178 .querymenu = sd_querymenu,
7179 .get_jcomp = sd_get_jcomp,
7180 .set_jcomp = sd_set_jcomp,
7181 };
7182
7183 static const __devinitdata struct usb_device_id device_table[] = {
7184 {USB_DEVICE(0x041e, 0x041e)},
7185 {USB_DEVICE(0x041e, 0x4017)},
7186 {USB_DEVICE(0x041e, 0x401c), .driver_info = SENSOR_PAS106},
7187 {USB_DEVICE(0x041e, 0x401e)},
7188 {USB_DEVICE(0x041e, 0x401f)},
7189 {USB_DEVICE(0x041e, 0x4022)},
7190 {USB_DEVICE(0x041e, 0x4029)},
7191 {USB_DEVICE(0x041e, 0x4034), .driver_info = SENSOR_PAS106},
7192 {USB_DEVICE(0x041e, 0x4035), .driver_info = SENSOR_PAS106},
7193 {USB_DEVICE(0x041e, 0x4036)},
7194 {USB_DEVICE(0x041e, 0x403a)},
7195 {USB_DEVICE(0x041e, 0x4051), .driver_info = SENSOR_TAS5130C_VF0250},
7196 {USB_DEVICE(0x041e, 0x4053), .driver_info = SENSOR_TAS5130C_VF0250},
7197 {USB_DEVICE(0x0458, 0x7007)},
7198 {USB_DEVICE(0x0458, 0x700c)},
7199 {USB_DEVICE(0x0458, 0x700f)},
7200 {USB_DEVICE(0x0461, 0x0a00)},
7201 {USB_DEVICE(0x046d, 0x089d), .driver_info = SENSOR_MC501CB},
7202 {USB_DEVICE(0x046d, 0x08a0)},
7203 {USB_DEVICE(0x046d, 0x08a1)},
7204 {USB_DEVICE(0x046d, 0x08a2)},
7205 {USB_DEVICE(0x046d, 0x08a3)},
7206 {USB_DEVICE(0x046d, 0x08a6)},
7207 {USB_DEVICE(0x046d, 0x08a7)},
7208 {USB_DEVICE(0x046d, 0x08a9)},
7209 {USB_DEVICE(0x046d, 0x08aa)},
7210 {USB_DEVICE(0x046d, 0x08ac)},
7211 {USB_DEVICE(0x046d, 0x08ad)},
7212 #if !defined CONFIG_USB_ZC0301 && !defined CONFIG_USB_ZC0301_MODULE
7213 {USB_DEVICE(0x046d, 0x08ae)},
7214 #endif
7215 {USB_DEVICE(0x046d, 0x08af)},
7216 {USB_DEVICE(0x046d, 0x08b9)},
7217 {USB_DEVICE(0x046d, 0x08d7)},
7218 {USB_DEVICE(0x046d, 0x08d9)},
7219 {USB_DEVICE(0x046d, 0x08d8)},
7220 {USB_DEVICE(0x046d, 0x08da)},
7221 {USB_DEVICE(0x046d, 0x08dd), .driver_info = SENSOR_MC501CB},
7222 {USB_DEVICE(0x0471, 0x0325), .driver_info = SENSOR_PAS106},
7223 {USB_DEVICE(0x0471, 0x0326), .driver_info = SENSOR_PAS106},
7224 {USB_DEVICE(0x0471, 0x032d), .driver_info = SENSOR_PAS106},
7225 {USB_DEVICE(0x0471, 0x032e), .driver_info = SENSOR_PAS106},
7226 {USB_DEVICE(0x055f, 0xc005)},
7227 {USB_DEVICE(0x055f, 0xd003)},
7228 {USB_DEVICE(0x055f, 0xd004)},
7229 {USB_DEVICE(0x0698, 0x2003)},
7230 {USB_DEVICE(0x0ac8, 0x0301), .driver_info = SENSOR_PAS106},
7231 {USB_DEVICE(0x0ac8, 0x0302), .driver_info = SENSOR_PAS106},
7232 {USB_DEVICE(0x0ac8, 0x301b)},
7233 {USB_DEVICE(0x0ac8, 0x303b)},
7234 {USB_DEVICE(0x0ac8, 0x305b)},
7235 {USB_DEVICE(0x0ac8, 0x307b)},
7236 {USB_DEVICE(0x10fd, 0x0128)},
7237 {USB_DEVICE(0x10fd, 0x804d)},
7238 {USB_DEVICE(0x10fd, 0x8050)},
7239 {} /* end of entry */
7240 };
7241 #undef DVNAME
7242 MODULE_DEVICE_TABLE(usb, device_table);
7243
7244 /* -- device connect -- */
7245 static int sd_probe(struct usb_interface *intf,
7246 const struct usb_device_id *id)
7247 {
7248 return gspca_dev_probe(intf, id, &sd_desc, sizeof(struct sd),
7249 THIS_MODULE);
7250 }
7251
7252 /* USB driver */
7253 static struct usb_driver sd_driver = {
7254 .name = MODULE_NAME,
7255 .id_table = device_table,
7256 .probe = sd_probe,
7257 .disconnect = gspca_disconnect,
7258 #ifdef CONFIG_PM
7259 .suspend = gspca_suspend,
7260 .resume = gspca_resume,
7261 #endif
7262 };
7263
7264 static int __init sd_mod_init(void)
7265 {
7266 int ret;
7267 ret = usb_register(&sd_driver);
7268 if (ret < 0)
7269 return ret;
7270 PDEBUG(D_PROBE, "registered");
7271 return 0;
7272 }
7273
7274 static void __exit sd_mod_exit(void)
7275 {
7276 usb_deregister(&sd_driver);
7277 PDEBUG(D_PROBE, "deregistered");
7278 }
7279
7280 module_init(sd_mod_init);
7281 module_exit(sd_mod_exit);
7282
7283 module_param(force_sensor, int, 0644);
7284 MODULE_PARM_DESC(force_sensor,
7285 "Force sensor. Only for experts!!!");