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