blob: ad7194029031f17b5b68b2b69291c433302d29ea [file] [log] [blame]
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001/*
Jean-François Moine0b74e2c2012-02-27 08:26:05 -03002 * Z-Star/Vimicro zc301/zc302p/vc30x driver
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003 *
Jean-François Moine0b74e2c2012-02-27 08:26:05 -03004 * Copyright (C) 2009-2012 Jean-Francois Moine <http://moinejf.free.fr>
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005 * Copyright (C) 2004 2005 2006 Michel Xhaard mxhaard@magic.fr
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006 *
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.
Jean-Francois Moined43fa322008-06-12 10:58:58 -030016 */
17
Joe Perches133a9fe2011-08-21 19:56:57 -030018#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
19
Hans de Goede1a3510262010-01-29 11:05:25 -030020#include <linux/input.h>
Jean-Francois Moined43fa322008-06-12 10:58:58 -030021#include "gspca.h"
Jean-Francois Moine71cb2762009-03-03 05:33:41 -030022#include "jpeg.h"
Jean-Francois Moined43fa322008-06-12 10:58:58 -030023
Mauro Carvalho Chehab1ddc9f72016-10-18 17:44:16 -020024MODULE_AUTHOR("Jean-Francois Moine <http://moinejf.free.fr>, Serge A. Suchkov <Serge.A.S@tochka.ru>");
Jean-Francois Moined43fa322008-06-12 10:58:58 -030025MODULE_DESCRIPTION("GSPCA ZC03xx/VC3xx USB Camera Driver");
26MODULE_LICENSE("GPL");
27
Jean-Francois Moined43fa322008-06-12 10:58:58 -030028static int force_sensor = -1;
29
Hans de Goede83fb2e22012-05-06 09:28:24 -030030#define REG08_DEF 3 /* default JPEG compression (75%) */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -030031#include "zc3xx-reg.h"
Jean-Francois Moined43fa322008-06-12 10:58:58 -030032
33/* specific webcam descriptor */
34struct sd {
35 struct gspca_dev gspca_dev; /* !! must be the first item */
36
Hans Verkuilc06ba282012-05-06 09:28:28 -030037 struct { /* gamma/brightness/contrast control cluster */
38 struct v4l2_ctrl *gamma;
39 struct v4l2_ctrl *brightness;
40 struct v4l2_ctrl *contrast;
41 };
42 struct { /* autogain/exposure control cluster */
43 struct v4l2_ctrl *autogain;
44 struct v4l2_ctrl *exposure;
45 };
46 struct v4l2_ctrl *plfreq;
47 struct v4l2_ctrl *sharpness;
48 struct v4l2_ctrl *jpegqual;
Jean-François Moine49fb5e62010-12-28 07:09:34 -030049
Jean-François Moinef1801902012-02-27 07:48:32 -030050 struct work_struct work;
Jean-François Moinef1801902012-02-27 07:48:32 -030051
Jean-François Moine30c73d42012-02-27 07:26:30 -030052 u8 reg08; /* webcam compression quality */
Jean-Francois Moined43fa322008-06-12 10:58:58 -030053
Jean-François Moinea484dd92010-08-04 07:25:12 -030054 u8 bridge;
Jean-Francois Moine47c833922010-01-07 15:59:12 -030055 u8 sensor; /* Type of image sensor chip */
Jean-François Moine83d1aa32010-08-04 05:11:23 -030056 u16 chip_revision;
Jean-Francois Moine71cb2762009-03-03 05:33:41 -030057
Jean-François Moine9a731a32010-06-04 05:26:42 -030058 u8 jpeg_hdr[JPEG_HDR_SZ];
Jean-Francois Moined43fa322008-06-12 10:58:58 -030059};
Jean-François Moinea484dd92010-08-04 07:25:12 -030060enum bridges {
61 BRIDGE_ZC301,
62 BRIDGE_ZC303,
63};
Jean-François Moine83d1aa32010-08-04 05:11:23 -030064enum sensors {
65 SENSOR_ADCM2700,
66 SENSOR_CS2102,
67 SENSOR_CS2102K,
Jean-François Moine7fbee992010-12-28 07:17:40 -030068 SENSOR_GC0303,
Jean-François Moine83d1aa32010-08-04 05:11:23 -030069 SENSOR_GC0305,
Jean-François Moine4e5144e2011-02-26 13:56:20 -030070 SENSOR_HDCS2020,
Jean-François Moine83d1aa32010-08-04 05:11:23 -030071 SENSOR_HV7131B,
72 SENSOR_HV7131R,
73 SENSOR_ICM105A,
74 SENSOR_MC501CB,
Jean-François Moinea484dd92010-08-04 07:25:12 -030075 SENSOR_MT9V111_1, /* (mi360soc) zc301 */
76 SENSOR_MT9V111_3, /* (mi360soc) zc303 */
Jean-François Moine83d1aa32010-08-04 05:11:23 -030077 SENSOR_OV7620, /* OV7648 - same values */
78 SENSOR_OV7630C,
79 SENSOR_PAS106,
80 SENSOR_PAS202B,
81 SENSOR_PB0330,
82 SENSOR_PO2030,
Jean-François Moine83d1aa32010-08-04 05:11:23 -030083 SENSOR_TAS5130C,
Jean-François Moine83d1aa32010-08-04 05:11:23 -030084 SENSOR_MAX
85};
Jean-Francois Moined43fa322008-06-12 10:58:58 -030086
Jean-Francois Moinecc611b82008-12-29 07:49:41 -030087static const struct v4l2_pix_format vga_mode[] = {
Jean-Francois Moinec2446b32008-07-05 11:49:20 -030088 {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
89 .bytesperline = 320,
90 .sizeimage = 320 * 240 * 3 / 8 + 590,
91 .colorspace = V4L2_COLORSPACE_JPEG,
92 .priv = 1},
93 {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
94 .bytesperline = 640,
95 .sizeimage = 640 * 480 * 3 / 8 + 590,
96 .colorspace = V4L2_COLORSPACE_JPEG,
97 .priv = 0},
Jean-Francois Moined43fa322008-06-12 10:58:58 -030098};
99
Hans de Goede9919fe82010-01-13 07:12:28 -0300100static const struct v4l2_pix_format broken_vga_mode[] = {
101 {320, 232, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
102 .bytesperline = 320,
103 .sizeimage = 320 * 232 * 4 / 8 + 590,
104 .colorspace = V4L2_COLORSPACE_JPEG,
105 .priv = 1},
106 {640, 472, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
107 .bytesperline = 640,
108 .sizeimage = 640 * 472 * 3 / 8 + 590,
109 .colorspace = V4L2_COLORSPACE_JPEG,
110 .priv = 0},
111};
112
Jean-Francois Moinecc611b82008-12-29 07:49:41 -0300113static const struct v4l2_pix_format sif_mode[] = {
Jean-Francois Moinec2446b32008-07-05 11:49:20 -0300114 {176, 144, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
115 .bytesperline = 176,
116 .sizeimage = 176 * 144 * 3 / 8 + 590,
117 .colorspace = V4L2_COLORSPACE_JPEG,
118 .priv = 1},
119 {352, 288, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
120 .bytesperline = 352,
121 .sizeimage = 352 * 288 * 3 / 8 + 590,
122 .colorspace = V4L2_COLORSPACE_JPEG,
123 .priv = 0},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300124};
125
Hans de Goede1b3bbcf2012-05-06 09:28:26 -0300126/*
127 * Bridge reg08 bits 1-2 -> JPEG quality conversion table. Note the highest
128 * quality setting is not usable as USB 1 does not have enough bandwidth.
129 */
130static u8 jpeg_qual[] = {50, 75, 87, /* 94 */};
Jean-François Moine30c73d42012-02-27 07:26:30 -0300131
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300132/* usb exchanges */
133struct usb_action {
Jean-Francois Moine47c833922010-01-07 15:59:12 -0300134 u8 req;
135 u8 val;
136 u16 idx;
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300137};
138
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300139static const struct usb_action adcm2700_Initial[] = {
140 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
141 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300142 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300143 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
144 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
145 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
146 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
147 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
148 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
149 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
150 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
151 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
152 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
153 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
154 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
155 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
156 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
157 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
158 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
159 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
160 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
161 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300162 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300163 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
164 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
165 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
166 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
167 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
168 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
169 {0xa0, 0x58, ZC3XX_R116_RGAIN}, /* 01,16,58,cc */
170 {0xa0, 0x5a, ZC3XX_R118_BGAIN}, /* 01,18,5a,cc */
171 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
172 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
173 {0xbb, 0x00, 0x0408}, /* 04,00,08,bb */
174 {0xdd, 0x00, 0x0200}, /* 00,02,00,dd */
175 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
176 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
177 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
178 {0xbb, 0xe0, 0x0c2e}, /* 0c,e0,2e,bb */
179 {0xbb, 0x01, 0x2000}, /* 20,01,00,bb */
180 {0xbb, 0x96, 0x2400}, /* 24,96,00,bb */
181 {0xbb, 0x06, 0x1006}, /* 10,06,06,bb */
182 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
183 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
184 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
185 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
186 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
187 {0xbb, 0x5f, 0x2090}, /* 20,5f,90,bb */
188 {0xbb, 0x01, 0x8000}, /* 80,01,00,bb */
189 {0xbb, 0x09, 0x8400}, /* 84,09,00,bb */
190 {0xbb, 0x86, 0x0002}, /* 00,86,02,bb */
191 {0xbb, 0xe6, 0x0401}, /* 04,e6,01,bb */
192 {0xbb, 0x86, 0x0802}, /* 08,86,02,bb */
193 {0xbb, 0xe6, 0x0c01}, /* 0c,e6,01,bb */
194 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
195 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
196 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
197 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
198 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
199 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
200 {0xaa, 0xfe, 0x0020}, /* 00,fe,20,aa */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300201/*mswin+*/
202 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
203 {0xaa, 0xfe, 0x0002},
204 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
205 {0xaa, 0xb4, 0xcd37},
206 {0xaa, 0xa4, 0x0004},
207 {0xaa, 0xa8, 0x0007},
208 {0xaa, 0xac, 0x0004},
209/*mswin-*/
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300210 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
211 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
212 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
213 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
214 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
215 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
216 {0xbb, 0x04, 0x0400}, /* 04,04,00,bb */
217 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
218 {0xbb, 0x01, 0x0400}, /* 04,01,00,bb */
219 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
220 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
221 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
222 {0xbb, 0x41, 0x2803}, /* 28,41,03,bb */
223 {0xbb, 0x40, 0x2c03}, /* 2c,40,03,bb */
224 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
225 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
226 {}
227};
228static const struct usb_action adcm2700_InitialScale[] = {
229 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
230 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300231 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300232 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
233 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
234 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
235 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
236 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
237 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
238 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
239 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
240 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
241 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
242 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
243 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
244 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
245 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
246 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
247 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
248 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
249 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
250 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300251 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300252 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
253 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
254 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
255 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
256 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
257 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
258 {0xa0, 0x58, ZC3XX_R116_RGAIN}, /* 01,16,58,cc */
259 {0xa0, 0x5a, ZC3XX_R118_BGAIN}, /* 01,18,5a,cc */
260 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
261 {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,d3,cc */
262 {0xbb, 0x00, 0x0408}, /* 04,00,08,bb */
263 {0xdd, 0x00, 0x0200}, /* 00,02,00,dd */
264 {0xbb, 0x00, 0x0400}, /* 04,00,00,bb */
265 {0xdd, 0x00, 0x0050}, /* 00,00,50,dd */
266 {0xbb, 0x0f, 0x140f}, /* 14,0f,0f,bb */
267 {0xbb, 0xe0, 0x0c2e}, /* 0c,e0,2e,bb */
268 {0xbb, 0x01, 0x2000}, /* 20,01,00,bb */
269 {0xbb, 0x96, 0x2400}, /* 24,96,00,bb */
270 {0xbb, 0x06, 0x1006}, /* 10,06,06,bb */
271 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
272 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
273 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
274 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
275 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
276 {0xbb, 0x5f, 0x2090}, /* 20,5f,90,bb */
277 {0xbb, 0x01, 0x8000}, /* 80,01,00,bb */
278 {0xbb, 0x09, 0x8400}, /* 84,09,00,bb */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300279 {0xbb, 0x86, 0x0002}, /* 00,88,02,bb */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300280 {0xbb, 0xe6, 0x0401}, /* 04,e6,01,bb */
Jean-Francois Moinec675e792009-01-26 05:29:06 -0300281 {0xbb, 0x86, 0x0802}, /* 08,88,02,bb */
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300282 {0xbb, 0xe6, 0x0c01}, /* 0c,e6,01,bb */
283 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
284 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
285 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
286 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
287 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
288 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
289 {0xaa, 0xfe, 0x0020}, /* 00,fe,20,aa */
290 /*******/
291 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
292 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
293 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
294 {0xaa, 0xfe, 0x0000}, /* 00,fe,00,aa */
295 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
296 {0xdd, 0x00, 0x0010}, /* 00,00,10,dd */
297 {0xbb, 0x04, 0x0400}, /* 04,04,00,bb */
298 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
299 {0xbb, 0x01, 0x0400}, /* 04,01,00,bb */
300 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
301 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
302 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
303 {0xbb, 0x41, 0x2803}, /* 28,41,03,bb */
304 {0xbb, 0x40, 0x2c03}, /* 2c,40,03,bb */
305 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
306 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
307 {}
308};
309static const struct usb_action adcm2700_50HZ[] = {
310 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
311 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
312 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
313 {0xbb, 0x05, 0x8400}, /* 84,05,00,bb */
314 {0xbb, 0xd0, 0xb007}, /* b0,d0,07,bb */
315 {0xbb, 0xa0, 0xb80f}, /* b8,a0,0f,bb */
316 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
317 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
318 {0xaa, 0x26, 0x00d0}, /* 00,26,d0,aa */
319 {0xaa, 0x28, 0x0002}, /* 00,28,02,aa */
320 {}
321};
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300322static const struct usb_action adcm2700_60HZ[] = {
323 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
324 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
325 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
326 {0xbb, 0x07, 0x8400}, /* 84,07,00,bb */
327 {0xbb, 0x82, 0xb006}, /* b0,82,06,bb */
328 {0xbb, 0x04, 0xb80d}, /* b8,04,0d,bb */
329 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
330 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
331 {0xaa, 0x26, 0x0057}, /* 00,26,57,aa */
332 {0xaa, 0x28, 0x0002}, /* 00,28,02,aa */
333 {}
334};
Jean-Francois Moine3d221182009-01-19 15:18:44 -0300335static const struct usb_action adcm2700_NoFliker[] = {
336 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
337 {0xaa, 0xfe, 0x0002}, /* 00,fe,02,aa */
338 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0a,cc */
339 {0xbb, 0x07, 0x8400}, /* 84,07,00,bb */
340 {0xbb, 0x05, 0xb000}, /* b0,05,00,bb */
341 {0xbb, 0xa0, 0xb801}, /* b8,a0,01,bb */
342 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
343 {0xaa, 0xfe, 0x0010}, /* 00,fe,10,aa */
344 {}
345};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300346static const struct usb_action cs2102_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300347 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
348 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
349 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
350 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
351 {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
352 {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
353 {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
354 {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
355 {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
356 {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
357 {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
358 {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
359 {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
360 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
361 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
362 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
363 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
364 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
365 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
366 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
367 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
368 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
369 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
370 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300371 {0xaa, 0x02, 0x0008},
372 {0xaa, 0x03, 0x0000},
373 {0xaa, 0x11, 0x0000},
374 {0xaa, 0x12, 0x0089},
375 {0xaa, 0x13, 0x0000},
376 {0xaa, 0x14, 0x00e9},
377 {0xaa, 0x20, 0x0000},
378 {0xaa, 0x22, 0x0000},
379 {0xaa, 0x0b, 0x0004},
380 {0xaa, 0x30, 0x0030},
381 {0xaa, 0x31, 0x0030},
382 {0xaa, 0x32, 0x0030},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300383 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
384 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
385 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
386 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
387 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
388 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
389 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300390 {0xa0, 0x10, 0x01ae},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300391 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
392 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
393 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300394 {0xa0, 0x00, 0x01ad},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -0300395 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300396};
397
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300398static const struct usb_action cs2102_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300399 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
400 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
401 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
402 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
403 {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
404 {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
405 {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
406 {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
407 {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
408 {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
409 {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
410 {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
411 {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
412 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
413 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
414 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
415 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
416 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
417 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
418 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
419 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
420 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
421 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
422 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300423 {0xaa, 0x02, 0x0008},
424 {0xaa, 0x03, 0x0000},
425 {0xaa, 0x11, 0x0001},
426 {0xaa, 0x12, 0x0087},
427 {0xaa, 0x13, 0x0001},
428 {0xaa, 0x14, 0x00e7},
429 {0xaa, 0x20, 0x0000},
430 {0xaa, 0x22, 0x0000},
431 {0xaa, 0x0b, 0x0004},
432 {0xaa, 0x30, 0x0030},
433 {0xaa, 0x31, 0x0030},
434 {0xaa, 0x32, 0x0030},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300435 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
436 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
437 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
438 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
439 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
440 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
441 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300442 {0xa0, 0x15, 0x01ae},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300443 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
444 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
445 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300446 {0xa0, 0x00, 0x01ad},
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300447 {}
448};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300449static const struct usb_action cs2102_50HZScale[] = {
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300450 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
451 {0xaa, 0x23, 0x0001},
452 {0xaa, 0x24, 0x005f},
453 {0xaa, 0x25, 0x0090},
454 {0xaa, 0x21, 0x00dd},
455 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
456 {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
457 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
458 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
459 {0xa0, 0x3a, ZC3XX_R196_ANTIFLICKERMID},
460 {0xa0, 0x98, ZC3XX_R197_ANTIFLICKERLOW},
461 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
462 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
463 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
464 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
465 {0xa0, 0xdd, ZC3XX_R01D_HSYNC_0},
466 {0xa0, 0xe4, ZC3XX_R01E_HSYNC_1},
467 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
468 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
469 {}
470};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300471static const struct usb_action cs2102_50HZ[] = {
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300472 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
473 {0xaa, 0x23, 0x0000},
474 {0xaa, 0x24, 0x00af},
475 {0xaa, 0x25, 0x00c8},
476 {0xaa, 0x21, 0x0068},
477 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
478 {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
479 {0xa0, 0x90, ZC3XX_R192_EXPOSURELIMITLOW},
480 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
481 {0xa0, 0x1d, ZC3XX_R196_ANTIFLICKERMID},
482 {0xa0, 0x4c, ZC3XX_R197_ANTIFLICKERLOW},
483 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
484 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
485 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
486 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
487 {0xa0, 0x68, ZC3XX_R01D_HSYNC_0},
488 {0xa0, 0xe3, ZC3XX_R01E_HSYNC_1},
489 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
490 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
491 {}
492};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300493static const struct usb_action cs2102_60HZScale[] = {
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300494 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
495 {0xaa, 0x23, 0x0001},
496 {0xaa, 0x24, 0x0055},
497 {0xaa, 0x25, 0x00cc},
498 {0xaa, 0x21, 0x003f},
499 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
500 {0xa0, 0xab, ZC3XX_R191_EXPOSURELIMITMID},
501 {0xa0, 0x98, ZC3XX_R192_EXPOSURELIMITLOW},
502 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
503 {0xa0, 0x30, ZC3XX_R196_ANTIFLICKERMID},
504 {0xa0, 0xd4, ZC3XX_R197_ANTIFLICKERLOW},
505 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
506 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
507 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
508 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
509 {0xa0, 0x39, ZC3XX_R01D_HSYNC_0},
510 {0xa0, 0x70, ZC3XX_R01E_HSYNC_1},
511 {0xa0, 0xb0, ZC3XX_R01F_HSYNC_2},
512 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
513 {}
514};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300515static const struct usb_action cs2102_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300516 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300517 {0xaa, 0x23, 0x0000},
518 {0xaa, 0x24, 0x00aa},
519 {0xaa, 0x25, 0x00e6},
520 {0xaa, 0x21, 0x003f},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300521 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
522 {0xa0, 0x55, ZC3XX_R191_EXPOSURELIMITMID},
523 {0xa0, 0xcc, ZC3XX_R192_EXPOSURELIMITLOW},
524 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
525 {0xa0, 0x18, ZC3XX_R196_ANTIFLICKERMID},
526 {0xa0, 0x6a, ZC3XX_R197_ANTIFLICKERLOW},
527 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
528 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
529 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
530 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
531 {0xa0, 0x3f, ZC3XX_R01D_HSYNC_0},
532 {0xa0, 0xa5, ZC3XX_R01E_HSYNC_1},
533 {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
534 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -0300535 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300536};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300537static const struct usb_action cs2102_NoFlikerScale[] = {
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300538 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
539 {0xaa, 0x23, 0x0001},
540 {0xaa, 0x24, 0x005f},
541 {0xaa, 0x25, 0x0000},
542 {0xaa, 0x21, 0x0001},
543 {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
544 {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
545 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
546 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
547 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
548 {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
549 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
550 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
551 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
552 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
553 {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
554 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
555 {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
556 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -0300557 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300558};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300559static const struct usb_action cs2102_NoFliker[] = {
Jean-Francois Moine1d763312009-09-18 05:36:24 -0300560 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
561 {0xaa, 0x23, 0x0000},
562 {0xaa, 0x24, 0x00af},
563 {0xaa, 0x25, 0x0080},
564 {0xaa, 0x21, 0x0001},
565 {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
566 {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
567 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},
568 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
569 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
570 {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
571 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
572 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
573 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
574 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
575 {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
576 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
577 {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
578 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -0300579 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300580};
581
582/* CS2102_KOCOM */
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300583static const struct usb_action cs2102K_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300584 {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
585 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
586 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
587 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
588 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
589 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
590 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
591 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
592 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
593 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
594 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
595 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
596 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
597 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
598 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
599 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
600 {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
601 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
602 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
603 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
604 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
605 {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
606 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
607 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
608 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
609 {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
610 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
611 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
612 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
613 {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
614 {0xa0, 0x7c, ZC3XX_R093_I2CSETVALUE},
615 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
616 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
617 {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
618 {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
619 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
620 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
621 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
622 {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
623 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
624 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
625 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
626 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
627 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
628 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
629 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
630 {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
631 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
632 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
633 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
634 {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
635 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
636 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
637 {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
638 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
639 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
640 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
641 {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
642 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
643 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
644 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
645 {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
646 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
647 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
648 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
649 {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
650 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
651 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
652 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
653 {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
654 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
655 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
656 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
657 {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
658 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
659 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
660 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
661 {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
662 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
663 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
664 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
665 {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
666 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
667 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
668 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
669 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
670 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
671 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
672 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
673 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
674 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
675 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
676 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
677 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
678 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
679 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
680 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
681 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
682 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
683 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300684 {0xa0, 0x00, 0x01ad},
685 {0xa0, 0x01, 0x01b1},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300686 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
687 {0xa0, 0x60, ZC3XX_R116_RGAIN},
688 {0xa0, 0x40, ZC3XX_R117_GGAIN},
689 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
690 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
691 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
692 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
693 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
694 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
695 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
696 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
697 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
698 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
699 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
700 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
701 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
702 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
703 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
704 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
705 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
706 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
707 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
708 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
709 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
710 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
711 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
712 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
713 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
714 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
715 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
716 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
717 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
718 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
719 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
720 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
721 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
722 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
723 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
724 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
725 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
726 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
727 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
728 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
729 {0xa0, 0x58, ZC3XX_R10E_RGB11},
730 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
731 {0xa0, 0xf4, ZC3XX_R110_RGB20},
732 {0xa0, 0xf4, ZC3XX_R111_RGB21},
733 {0xa0, 0x58, ZC3XX_R112_RGB22},
734 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
735 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
736 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
737 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
738 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
739 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
740 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
741 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
742 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
743 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
744 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
745 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
746 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
747 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
748 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
749 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
750 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
751 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
752 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
753 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
754 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
755 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
756 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
757 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
758 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
759 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
760 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
761 {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
762 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
763 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
764 {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
765 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
766 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
767 {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
768 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
769 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
770 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
771 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
772 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
773 {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
774 {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
775 {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
776 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
777 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
778 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
779 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
780 {0xa0, 0x60, ZC3XX_R116_RGAIN},
781 {0xa0, 0x40, ZC3XX_R117_GGAIN},
782 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
783 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
784 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
785 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
786 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
787 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
788 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
789 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
790 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
791 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
792 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
793 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
794 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
795 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
796 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
797 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
798 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
799 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
800 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
801 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
802 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
803 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
804 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
805 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
806 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
807 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
808 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
809 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
810 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
811 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
812 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
813 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
814 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
815 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
816 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
817 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
818 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
819 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
820 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
821 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
822 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
823 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
824 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
825 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
826 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
827 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
828 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
829 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
830 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
831 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
832 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
833 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
834 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
835 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
836 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
837 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
838 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -0300839 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300840};
841
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -0300842static const struct usb_action cs2102K_Initial[] = {
Jean-Francois Moinef1ee8e82009-01-20 08:14:17 -0300843 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300844 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
845 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
846 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
847 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
848 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
849 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
850 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
851 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
852 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
853 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
854 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
855 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
856 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
857 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
858 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
859 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moinef1ee8e82009-01-20 08:14:17 -0300860/*fixme: next sequence = i2c exchanges*/
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300861 {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
862 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
863 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
864 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
865 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
866 {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
867 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
868 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
869 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
870 {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
871 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
872 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
873 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
874 {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
875 {0xa0, 0x7b, ZC3XX_R093_I2CSETVALUE},
876 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
877 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
878 {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
879 {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
880 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
881 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
882 {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
883 {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
884 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
885 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
886 {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
887 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
888 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
889 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
890 {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
891 {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
892 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
893 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
894 {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
895 {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
896 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
897 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
898 {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
899 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
900 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
901 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
902 {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
903 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
904 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
905 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
906 {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
907 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
908 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
909 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
910 {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
911 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
912 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
913 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
914 {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
915 {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
916 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
917 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
918 {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
919 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
920 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
921 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
922 {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
923 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
924 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
925 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
926 {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
927 {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
928 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
929 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
930 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
931 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
932 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
933 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
934 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
935 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
936 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
937 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
938 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
939 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
940 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
941 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
942 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
943 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
944 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -0300945 {0xa0, 0x00, 0x01ad},
946 {0xa0, 0x01, 0x01b1},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300947 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
948 {0xa0, 0x60, ZC3XX_R116_RGAIN},
949 {0xa0, 0x40, ZC3XX_R117_GGAIN},
950 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
951 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
952 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
953 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
954 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
955 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
956 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
957 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
958 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
959 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
960 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
961 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
962 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
963 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
964 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
965 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
966 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
967 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
968 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
969 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
970 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
971 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
972 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
973 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
974 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
975 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
976 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
977 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
978 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
979 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
980 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
981 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
982 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
983 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
984 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
985 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
986 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
987 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
988 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
989 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
990 {0xa0, 0x58, ZC3XX_R10E_RGB11},
991 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
992 {0xa0, 0xf4, ZC3XX_R110_RGB20},
993 {0xa0, 0xf4, ZC3XX_R111_RGB21},
994 {0xa0, 0x58, ZC3XX_R112_RGB22},
995 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
996 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
997 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
998 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
999 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1000 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1001 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1002 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1003 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1004 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1005 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1006 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1007 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1008 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1009 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1010 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1011 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1012 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1013 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1014 {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1015 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1016 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1017 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1018 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1019 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1020 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1021 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
1022 {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
1023 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1024 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
1025 {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
1026 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1027 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1028 {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
1029 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1030 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1031 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1032 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1033 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1034 {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
1035 {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
1036 {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
1037 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1038 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1039 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1040 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1041 {0xa0, 0x60, ZC3XX_R116_RGAIN},
1042 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1043 {0xa0, 0x4c, ZC3XX_R118_BGAIN},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001044 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1045 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1046 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1047 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1048 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1049 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1050 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1051 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1052 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1053 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1054 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1055 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1056 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1057 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1058 {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1059 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1060 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1061 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1062 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1063 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1064 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1065 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1066 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1067 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1068 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1069 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1070 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1071 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1072 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1073 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1074 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1075 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1076 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1077 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1078 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1079 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1080 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1081 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1082 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1083 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1084 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1085 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1086 {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1087 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1088 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1089 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1090 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1091 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1092 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1093 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1094 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1095 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1096 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1097 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1098 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1099 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
Jean-Francois Moinef1ee8e82009-01-20 08:14:17 -03001100/*fixme:what does the next sequence?*/
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001101 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1102 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1103 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1104 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1105 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1106 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1107 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1108 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1109 {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1110 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1111 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1112 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1113 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1114 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1115 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1116 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1117 {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1118 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1119 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1120 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1121 {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1122 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1123 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1124 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1125 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1126 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1127 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1128 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1129 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},
1130 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1131 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1132 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1133 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1134 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1135 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1136 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1137 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1138 {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1139 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1140 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1141 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1142 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1143 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1144 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1145 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1146 {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1147 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1148 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1149 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1150 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1151 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1152 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1153 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1154 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1155 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1156 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1157 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1158 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1159 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1160 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1161 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1162 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1163 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1164 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1165 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1166 {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1167 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1168 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1169 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1170 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1171 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1172 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1173 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1174 {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1175 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1176 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1177 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1178 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1179 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1180 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1181 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1182 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1183 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1184 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1185 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1186 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1187 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1188 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1189 {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1190 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1191 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1192 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1193 {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1194 {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1195 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1196 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1197 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1198 {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1199 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1200 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1201 {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1202 {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1203 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1204 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1205 {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1206 {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1207 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1208 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1209 {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1210 {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1211 {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1212 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1213 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1214 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1215 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1216 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001217 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001218};
1219
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03001220static const struct usb_action gc0305_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001221 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1222 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
1223 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
1224 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
1225 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
1226 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1227 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
1228 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
1229 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
1230 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
1231 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
1232 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
1233 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
1234 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
1235 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
1236 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
1237 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
1238 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001239 {0xaa, 0x13, 0x0002}, /* 00,13,02,aa */
1240 {0xaa, 0x15, 0x0003}, /* 00,15,03,aa */
1241 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
1242 {0xaa, 0x02, 0x0000}, /* 00,02,00,aa */
1243 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
1244 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa */
1245 {0xaa, 0x1d, 0x0080}, /* 00,1d,80,aa */
1246 {0xaa, 0x1f, 0x0008}, /* 00,1f,08,aa */
1247 {0xaa, 0x21, 0x0012}, /* 00,21,12,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001248 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc */
1249 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc */
1250 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001251 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
1252 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa */
1253 {0xaa, 0x0b, 0x00b0}, /* 00,0b,b0,aa */
1254 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa */
1255 {0xaa, 0x0d, 0x00b0}, /* 00,0d,b0,aa */
1256 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa */
1257 {0xaa, 0x0f, 0x00b0}, /* 00,0f,b0,aa */
1258 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
1259 {0xaa, 0x11, 0x00b0}, /* 00,11,b0,aa */
1260 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa */
1261 {0xaa, 0x17, 0x00e6}, /* 00,17,e6,aa */
1262 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa */
1263 {0xaa, 0x19, 0x0086}, /* 00,19,86,aa */
1264 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1265 {0xaa, 0x1b, 0x0020}, /* 00,1b,20,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001266 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
1267 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
1268 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1269 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001270 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001271 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1272 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
1273 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
1274 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
1275 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
1276 {0xa0, 0x85, ZC3XX_R18D_YTARGET}, /* 01,8d,85,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001277 {0xa0, 0x00, 0x011e}, /* 01,1e,00,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001278 {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1279 {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1280 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1281 {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001282 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001283};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03001284static const struct usb_action gc0305_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001285 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1286 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
1287 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
1288 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
1289 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
1290 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1291 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
1292 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
1293 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
1294 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
1295 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
1296 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
1297 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
1298 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
1299 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
1300 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc */
1301 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
1302 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001303 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
1304 {0xaa, 0x15, 0x0001}, /* 00,15,01,aa */
1305 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
1306 {0xaa, 0x02, 0x0000}, /* 00,02,00,aa */
1307 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
1308 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa */
1309 {0xaa, 0x1d, 0x0080}, /* 00,1d,80,aa */
1310 {0xaa, 0x1f, 0x0008}, /* 00,1f,08,aa */
1311 {0xaa, 0x21, 0x0012}, /* 00,21,12,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001312 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc */
1313 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc */
1314 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001315 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
1316 {0xaa, 0x0a, 0x0000}, /* 00,0a,00,aa */
1317 {0xaa, 0x0b, 0x00b0}, /* 00,0b,b0,aa */
1318 {0xaa, 0x0c, 0x0000}, /* 00,0c,00,aa */
1319 {0xaa, 0x0d, 0x00b0}, /* 00,0d,b0,aa */
1320 {0xaa, 0x0e, 0x0000}, /* 00,0e,00,aa */
1321 {0xaa, 0x0f, 0x00b0}, /* 00,0f,b0,aa */
1322 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
1323 {0xaa, 0x11, 0x00b0}, /* 00,11,b0,aa */
1324 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa */
1325 {0xaa, 0x17, 0x00e8}, /* 00,17,e8,aa */
1326 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa */
1327 {0xaa, 0x19, 0x0088}, /* 00,19,88,aa */
1328 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1329 {0xaa, 0x1b, 0x0020}, /* 00,1b,20,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001330 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
1331 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
1332 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1333 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001334 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001335 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1336 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
1337 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
1338 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
1339 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001340 {0xa0, 0x00, 0x011e}, /* 01,1e,00,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001341 {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1342 {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1343 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1344 {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001345 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001346};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03001347static const struct usb_action gc0305_50HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001348 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1349 {0xaa, 0x83, 0x0002}, /* 00,83,02,aa */
1350 {0xaa, 0x84, 0x0038}, /* 00,84,38,aa */ /* win: 00,84,ec */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001351 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1352 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0b,cc */
1353 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
1354 /* win: 01,92,10 */
1355 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1356 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1357 {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,8e,cc */
1358 /* win: 01,97,ec */
1359 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1360 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1361 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
1362 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1363 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1364 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1365 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1366 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1367 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1368 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
1369/* {0xa0, 0x85, ZC3XX_R18D_YTARGET}, * 01,8d,85,cc *
1370 * if 640x480 */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001371 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001372};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03001373static const struct usb_action gc0305_60HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001374 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1375 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
1376 {0xaa, 0x84, 0x00ec}, /* 00,84,ec,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001377 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1378 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0b,cc */
1379 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc */
1380 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1381 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1382 {0xa0, 0xec, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,ec,cc */
1383 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1384 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1385 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
1386 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1387 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1388 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1389 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1390 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1391 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1392 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
1393 {0xa0, 0x80, ZC3XX_R18D_YTARGET}, /* 01,8d,80,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001394 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001395};
1396
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03001397static const struct usb_action gc0305_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001398 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001399 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
1400 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
1401 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001402 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1403 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,00,cc */
1404 {0xa0, 0x48, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,48,cc */
1405 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1406 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1407 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
1408 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc */
1409 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc */
1410 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc */
1411 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc */
1412 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc */
1413 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
1414 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,60,cc */
1415 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
1416 {0xa0, 0x80, ZC3XX_R18D_YTARGET}, /* 01,8d,80,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001417 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001418};
1419
Jean-François Moine4e5144e2011-02-26 13:56:20 -03001420static const struct usb_action hdcs2020_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001421 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1422 {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
1423 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* qtable 0x05 */
1424 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1425 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1426 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1427 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1428 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1429 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1430 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1431 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1432 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1433 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1434 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1435 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1436 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1437 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001438 {0xaa, 0x1c, 0x0000},
1439 {0xaa, 0x0a, 0x0001},
1440 {0xaa, 0x0b, 0x0006},
1441 {0xaa, 0x0c, 0x007b},
1442 {0xaa, 0x0d, 0x00a7},
1443 {0xaa, 0x03, 0x00fb},
1444 {0xaa, 0x05, 0x0000},
1445 {0xaa, 0x06, 0x0003},
1446 {0xaa, 0x09, 0x0008},
1447
1448 {0xaa, 0x0f, 0x0018}, /* set sensor gain */
1449 {0xaa, 0x10, 0x0018},
1450 {0xaa, 0x11, 0x0018},
1451 {0xaa, 0x12, 0x0018},
1452
1453 {0xaa, 0x15, 0x004e},
1454 {0xaa, 0x1c, 0x0004},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001455 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
1456 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1457 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1458 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1459 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1460 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1461 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1462 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1463 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001464 {0xa1, 0x01, 0x0002},
1465 {0xa1, 0x01, 0x0008},
1466 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001467 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1468 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1469 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1470 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001471 {0xa1, 0x01, 0x0008},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001472 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
1473 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001474 {0xa1, 0x01, 0x01c8},
1475 {0xa1, 0x01, 0x01c9},
1476 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001477 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
1478 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
1479 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1480 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1481 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1482 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1483 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1484 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1485 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1486 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1487 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1488 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1489 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1490 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1491 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1492 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1493 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1494 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1495 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1496 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1497 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1498 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1499 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1500 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1501 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1502 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1503 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1504 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1505 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1506 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1507 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1508 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1509 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001510
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001511 {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1512 {0xa0, 0xed, ZC3XX_R10B_RGB01},
1513 {0xa0, 0xed, ZC3XX_R10C_RGB02},
1514 {0xa0, 0xed, ZC3XX_R10D_RGB10},
1515 {0xa0, 0x66, ZC3XX_R10E_RGB11},
1516 {0xa0, 0xed, ZC3XX_R10F_RGB12},
1517 {0xa0, 0xed, ZC3XX_R110_RGB20},
1518 {0xa0, 0xed, ZC3XX_R111_RGB21},
1519 {0xa0, 0x66, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001520
1521 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001522 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1523 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001524 {0xaa, 0x13, 0x0031},
1525 {0xaa, 0x14, 0x0001},
1526 {0xaa, 0x0e, 0x0004},
1527 {0xaa, 0x19, 0x00cd},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001528 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1529 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1530 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1531 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1532 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1533 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1534 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1535 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001536
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001537 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 0x14 */
1538 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1539 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1540 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1541 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1542 {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1543 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1544 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001545 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001546 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1547 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1548 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1549 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001550 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001551};
Jean-François Moine4e5144e2011-02-26 13:56:20 -03001552static const struct usb_action hdcs2020_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001553 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1554 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1555 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
1556 {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1557 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1558 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1559 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1560 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1561 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1562 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1563 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1564 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1565 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1566 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1567 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1568 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1569 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001570 {0xaa, 0x1c, 0x0000},
1571 {0xaa, 0x0a, 0x0001},
1572 {0xaa, 0x0b, 0x0006},
1573 {0xaa, 0x0c, 0x007a},
1574 {0xaa, 0x0d, 0x00a7},
1575 {0xaa, 0x03, 0x00fb},
1576 {0xaa, 0x05, 0x0000},
1577 {0xaa, 0x06, 0x0003},
1578 {0xaa, 0x09, 0x0008},
1579 {0xaa, 0x0f, 0x0018}, /* original setting */
1580 {0xaa, 0x10, 0x0018},
1581 {0xaa, 0x11, 0x0018},
1582 {0xaa, 0x12, 0x0018},
1583 {0xaa, 0x15, 0x004e},
1584 {0xaa, 0x1c, 0x0004},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001585 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
1586 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1587 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1588 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1589 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1590 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1591 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1592 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1593 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001594 {0xa1, 0x01, 0x0002},
1595 {0xa1, 0x01, 0x0008},
1596 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001597 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1598 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1599 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1600 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001601 {0xa1, 0x01, 0x0008},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001602 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
1603 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001604 {0xa1, 0x01, 0x01c8},
1605 {0xa1, 0x01, 0x01c9},
1606 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001607 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
1608 {0xa0, 0x13, ZC3XX_R120_GAMMA00}, /* gamma 4 */
1609 {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1610 {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1611 {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1612 {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1613 {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1614 {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1615 {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1616 {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1617 {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1618 {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1619 {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1620 {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1621 {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1622 {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1623 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1624 {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1625 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1626 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1627 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1628 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1629 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1630 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1631 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1632 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1633 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1634 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1635 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1636 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1637 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1638 {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1639 {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1640 {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1641 {0xa0, 0xed, ZC3XX_R10B_RGB01},
1642 {0xa0, 0xed, ZC3XX_R10C_RGB02},
1643 {0xa0, 0xed, ZC3XX_R10D_RGB10},
1644 {0xa0, 0x66, ZC3XX_R10E_RGB11},
1645 {0xa0, 0xed, ZC3XX_R10F_RGB12},
1646 {0xa0, 0xed, ZC3XX_R110_RGB20},
1647 {0xa0, 0xed, ZC3XX_R111_RGB21},
1648 {0xa0, 0x66, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001649 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001650 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1651 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001652 /**** set exposure ***/
1653 {0xaa, 0x13, 0x0031},
1654 {0xaa, 0x14, 0x0001},
1655 {0xaa, 0x0e, 0x0004},
1656 {0xaa, 0x19, 0x00cd},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001657 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1658 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1659 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1660 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1661 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1662 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1663 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1664 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1665 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1666 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1667 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1668 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1669 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1670 {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1671 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1672 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001673 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001674 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1675 {0xa0, 0x40, ZC3XX_R116_RGAIN},
1676 {0xa0, 0x40, ZC3XX_R117_GGAIN},
1677 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001678 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001679};
Jean-François Moine4e5144e2011-02-26 13:56:20 -03001680static const struct usb_action hdcs2020_50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001681 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03001682 {0xaa, 0x13, 0x0018}, /* 00,13,18,aa */
1683 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1684 {0xaa, 0x0e, 0x0005}, /* 00,0e,05,aa */
1685 {0xaa, 0x19, 0x001f}, /* 00,19,1f,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001686 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1687 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1688 {0xa0, 0x76, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,76,cc */
1689 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1690 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1691 {0xa0, 0x46, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,46,cc */
1692 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1693 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1694 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1695 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1696 {0xa0, 0x05, ZC3XX_R01D_HSYNC_0}, /* 00,1d,05,cc */
1697 {0xa0, 0x1a, ZC3XX_R01E_HSYNC_1}, /* 00,1e,1a,cc */
1698 {0xa0, 0x2f, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2f,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001699 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001700};
Jean-François Moine4e5144e2011-02-26 13:56:20 -03001701static const struct usb_action hdcs2020_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001702 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03001703 {0xaa, 0x13, 0x0031}, /* 00,13,31,aa */
1704 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1705 {0xaa, 0x0e, 0x0004}, /* 00,0e,04,aa */
1706 {0xaa, 0x19, 0x00cd}, /* 00,19,cd,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001707 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1708 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1709 {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,62,cc */
1710 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1711 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1712 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3d,cc */
1713 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1714 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1715 {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1716 {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1717 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1718 {0xa0, 0x18, ZC3XX_R01E_HSYNC_1}, /* 00,1e,18,cc */
1719 {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2c,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001720 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001721};
Jean-François Moine4e5144e2011-02-26 13:56:20 -03001722static const struct usb_action hdcs2020_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001723 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03001724 {0xaa, 0x13, 0x0010}, /* 00,13,10,aa */
1725 {0xaa, 0x14, 0x0001}, /* 00,14,01,aa */
1726 {0xaa, 0x0e, 0x0004}, /* 00,0e,04,aa */
1727 {0xaa, 0x19, 0x0000}, /* 00,19,00,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001728 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1729 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1730 {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
1731 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1732 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1733 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
1734 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1735 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1736 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
1737 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
1738 {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1739 {0xa0, 0x17, ZC3XX_R01E_HSYNC_1}, /* 00,1e,17,cc */
1740 {0xa0, 0x2a, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2a,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001741 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001742};
1743
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03001744static const struct usb_action hv7131b_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001745 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1746 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
1747 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1748 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1749 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
1750 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
1751 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1752 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1753 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1754 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1755 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1756 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1757 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1758 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1759 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1760 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001761 {0xaa, 0x30, 0x002d},
1762 {0xaa, 0x01, 0x0005},
1763 {0xaa, 0x11, 0x0000},
1764 {0xaa, 0x13, 0x0001}, /* {0xaa, 0x13, 0x0000}, */
1765 {0xaa, 0x14, 0x0001},
1766 {0xaa, 0x15, 0x00e8},
1767 {0xaa, 0x16, 0x0002},
Jean-Francois Moinec9ff1b62008-11-06 15:29:47 -03001768 {0xaa, 0x17, 0x0086}, /* 00,17,88,aa */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001769 {0xaa, 0x31, 0x0038},
1770 {0xaa, 0x32, 0x0038},
1771 {0xaa, 0x33, 0x0038},
1772 {0xaa, 0x5b, 0x0001},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001773 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1774 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1775 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1776 {0xa0, 0x68, ZC3XX_R18D_YTARGET},
1777 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001778 {0xa0, 0x00, 0x01ad},
1779 {0xa0, 0xc0, 0x019b},
1780 {0xa0, 0xa0, 0x019c},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001781 {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1782 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1783 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1784 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1785 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1786 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moinec9ff1b62008-11-06 15:29:47 -03001787 {0xaa, 0x02, 0x0090}, /* 00,02,80,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001788 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001789};
1790
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03001791static const struct usb_action hv7131b_Initial[] = { /* 640x480*/
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001792 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1793 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1794 {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1795 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1796 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
1797 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
1798 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1799 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1800 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1801 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1802 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1803 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1804 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1805 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1806 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1807 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001808 {0xaa, 0x30, 0x002d},
1809 {0xaa, 0x01, 0x0005},
1810 {0xaa, 0x11, 0x0001},
1811 {0xaa, 0x13, 0x0000}, /* {0xaa, 0x13, 0x0001}; */
1812 {0xaa, 0x14, 0x0001},
1813 {0xaa, 0x15, 0x00e6},
1814 {0xaa, 0x16, 0x0002},
1815 {0xaa, 0x17, 0x0086},
1816 {0xaa, 0x31, 0x0038},
1817 {0xaa, 0x32, 0x0038},
1818 {0xaa, 0x33, 0x0038},
1819 {0xaa, 0x5b, 0x0001},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001820 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1821 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1822 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1823 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1824 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001825 {0xa0, 0x00, 0x01ad},
1826 {0xa0, 0xc0, 0x019b},
1827 {0xa0, 0xa0, 0x019c},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001828 {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1829 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1830 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1831 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1832 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1833 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001834 {0xaa, 0x02, 0x0090}, /* {0xaa, 0x02, 0x0080}, */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001835 {}
1836};
1837static const struct usb_action hv7131b_50HZ[] = { /* 640x480*/
1838 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1839 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1840 {0xaa, 0x26, 0x0053}, /* 00,26,53,aa */
1841 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1842 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1843 {0xaa, 0x21, 0x0050}, /* 00,21,50,aa */
1844 {0xaa, 0x22, 0x001b}, /* 00,22,1b,aa */
1845 {0xaa, 0x23, 0x00fc}, /* 00,23,fc,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001846 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1847 {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,9b,cc */
1848 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
1849 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1850 {0xa0, 0xea, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,ea,cc */
1851 {0xa0, 0x60, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,60,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001852 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
1853 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
1854 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1855 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1856 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1857 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1}, /* 00,1e,50,cc */
1858 {0xa0, 0x1b, ZC3XX_R01F_HSYNC_2}, /* 00,1f,1b,cc */
1859 {0xa0, 0xfc, ZC3XX_R020_HSYNC_3}, /* 00,20,fc,cc */
1860 {}
1861};
1862static const struct usb_action hv7131b_50HZScale[] = { /* 320x240 */
1863 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1864 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1865 {0xaa, 0x26, 0x0053}, /* 00,26,53,aa */
1866 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1867 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1868 {0xaa, 0x21, 0x0050}, /* 00,21,50,aa */
1869 {0xaa, 0x22, 0x0012}, /* 00,22,12,aa */
1870 {0xaa, 0x23, 0x0080}, /* 00,23,80,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001871 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1872 {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,9b,cc */
1873 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
1874 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,01,cc */
1875 {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,d4,cc */
1876 {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,c0,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001877 {0xa0, 0x07, ZC3XX_R18C_AEFREEZE}, /* 01,8c,07,cc */
1878 {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,0f,cc */
1879 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1880 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1881 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1882 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1}, /* 00,1e,50,cc */
1883 {0xa0, 0x12, ZC3XX_R01F_HSYNC_2}, /* 00,1f,12,cc */
1884 {0xa0, 0x80, ZC3XX_R020_HSYNC_3}, /* 00,20,80,cc */
1885 {}
1886};
1887static const struct usb_action hv7131b_60HZ[] = { /* 640x480*/
1888 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1889 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1890 {0xaa, 0x26, 0x00a1}, /* 00,26,a1,aa */
1891 {0xaa, 0x27, 0x0020}, /* 00,27,20,aa */
1892 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1893 {0xaa, 0x21, 0x0040}, /* 00,21,40,aa */
1894 {0xaa, 0x22, 0x0013}, /* 00,22,13,aa */
1895 {0xaa, 0x23, 0x004c}, /* 00,23,4c,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001896 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1897 {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,4d,cc */
1898 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,60,cc */
1899 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1900 {0xa0, 0xc3, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,c3,cc */
1901 {0xa0, 0x50, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,50,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001902 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
1903 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
1904 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1905 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1906 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1907 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1}, /* 00,1e,40,cc */
1908 {0xa0, 0x13, ZC3XX_R01F_HSYNC_2}, /* 00,1f,13,cc */
1909 {0xa0, 0x4c, ZC3XX_R020_HSYNC_3}, /* 00,20,4c,cc */
1910 {}
1911};
1912static const struct usb_action hv7131b_60HZScale[] = { /* 320x240 */
1913 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1914 {0xaa, 0x25, 0x0007}, /* 00,25,07,aa */
1915 {0xaa, 0x26, 0x00a1}, /* 00,26,a1,aa */
1916 {0xaa, 0x27, 0x0020}, /* 00,27,20,aa */
1917 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1918 {0xaa, 0x21, 0x00a0}, /* 00,21,a0,aa */
1919 {0xaa, 0x22, 0x0016}, /* 00,22,16,aa */
1920 {0xaa, 0x23, 0x0040}, /* 00,23,40,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001921 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1922 {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,4d,cc */
1923 {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,60,cc */
1924 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,01,cc */
1925 {0xa0, 0x86, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,86,cc */
1926 {0xa0, 0xa0, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,a0,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001927 {0xa0, 0x07, ZC3XX_R18C_AEFREEZE}, /* 01,8c,07,cc */
1928 {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,0f,cc */
1929 {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,18,cc */
1930 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
1931 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1932 {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,a0,cc */
1933 {0xa0, 0x16, ZC3XX_R01F_HSYNC_2}, /* 00,1f,16,cc */
1934 {0xa0, 0x40, ZC3XX_R020_HSYNC_3}, /* 00,20,40,cc */
1935 {}
1936};
1937static const struct usb_action hv7131b_NoFliker[] = { /* 640x480*/
1938 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1939 {0xaa, 0x25, 0x0003}, /* 00,25,03,aa */
1940 {0xaa, 0x26, 0x0000}, /* 00,26,00,aa */
1941 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1942 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1943 {0xaa, 0x21, 0x0010}, /* 00,21,10,aa */
1944 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
1945 {0xaa, 0x23, 0x0003}, /* 00,23,03,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001946 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1947 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,f8,cc */
1948 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,00,cc */
1949 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1950 {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,02,cc */
1951 {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,00,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001952 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1953 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1954 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
1955 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
1956 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1957 {0xa0, 0x10, ZC3XX_R01E_HSYNC_1}, /* 00,1e,10,cc */
1958 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2}, /* 00,1f,00,cc */
1959 {0xa0, 0x03, ZC3XX_R020_HSYNC_3}, /* 00,20,03,cc */
1960 {}
1961};
1962static const struct usb_action hv7131b_NoFlikerScale[] = { /* 320x240 */
1963 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1964 {0xaa, 0x25, 0x0003}, /* 00,25,03,aa */
1965 {0xaa, 0x26, 0x0000}, /* 00,26,00,aa */
1966 {0xaa, 0x27, 0x0000}, /* 00,27,00,aa */
1967 {0xaa, 0x20, 0x0000}, /* 00,20,00,aa */
1968 {0xaa, 0x21, 0x00a0}, /* 00,21,a0,aa */
1969 {0xaa, 0x22, 0x0016}, /* 00,22,16,aa */
1970 {0xaa, 0x23, 0x0040}, /* 00,23,40,aa */
Jean-Francois Moinef4f4ef72008-12-08 06:25:40 -03001971 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,2f,cc */
1972 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,f8,cc */
1973 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,00,cc */
1974 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1975 {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,02,cc */
1976 {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,00,cc */
Jean-Francois Moine13563f42008-11-06 15:35:21 -03001977 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1978 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1979 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
1980 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
1981 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0}, /* 00,1d,00,cc */
1982 {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,a0,cc */
1983 {0xa0, 0x16, ZC3XX_R01F_HSYNC_2}, /* 00,1f,16,cc */
1984 {0xa0, 0x40, ZC3XX_R020_HSYNC_3}, /* 00,20,40,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03001985 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03001986};
1987
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03001988/* from lPEPI264v.inf (hv7131b!) */
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03001989static const struct usb_action hv7131r_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001990 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1991 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
1992 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
1993 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1994 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
1995 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001996 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03001997 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001998 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1999 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2000 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2001 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2002 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2003 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2004 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2005 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2006 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2007 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2008 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2009 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002010 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2011 {0xdd, 0x00, 0x0200},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002012 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002013 {0xaa, 0x01, 0x000c},
2014 {0xaa, 0x11, 0x0000},
2015 {0xaa, 0x13, 0x0000},
2016 {0xaa, 0x14, 0x0001},
2017 {0xaa, 0x15, 0x00e8},
2018 {0xaa, 0x16, 0x0002},
2019 {0xaa, 0x17, 0x0088},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002020 {0xaa, 0x30, 0x000b},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002021 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2022 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002023 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002024 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002025 {0xa0, 0x00, 0x01ad},
2026 {0xa0, 0xc0, 0x019b},
2027 {0xa0, 0xa0, 0x019c},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002028 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2029 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2030 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2031 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2032 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002033 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002034};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002035static const struct usb_action hv7131r_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002036 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002037 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002038 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
2039 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2040 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2041 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002042 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002043 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002044 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2045 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2046 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002047 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002048 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2049 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2050 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002051 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002052 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002053 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002054 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2055 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002056 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2057 {0xdd, 0x00, 0x0200},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002058 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002059 {0xaa, 0x01, 0x000c},
2060 {0xaa, 0x11, 0x0000},
2061 {0xaa, 0x13, 0x0000},
2062 {0xaa, 0x14, 0x0001},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002063 {0xaa, 0x15, 0x00e6},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002064 {0xaa, 0x16, 0x0002},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002065 {0xaa, 0x17, 0x0086},
2066 {0xaa, 0x30, 0x000b},
2067 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002068 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002069 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002070 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002071 {0xa0, 0x00, 0x01ad},
2072 {0xa0, 0xc0, 0x019b},
2073 {0xa0, 0xa0, 0x019c},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002074 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2075 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2076 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2077 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2078 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002079 {}
2080};
2081static const struct usb_action hv7131r_50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002082 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002083 {0xa0, 0x06, ZC3XX_R190_EXPOSURELIMITHIGH},
2084 {0xa0, 0x68, ZC3XX_R191_EXPOSURELIMITMID},
2085 {0xa0, 0xa0, ZC3XX_R192_EXPOSURELIMITLOW},
2086 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2087 {0xa0, 0xea, ZC3XX_R196_ANTIFLICKERMID},
2088 {0xa0, 0x60, ZC3XX_R197_ANTIFLICKERLOW},
2089 {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2090 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2091 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2092 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2093 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2094 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2095 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2096 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2097 {}
2098};
2099static const struct usb_action hv7131r_50HZScale[] = {
2100 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2101 {0xa0, 0x0c, ZC3XX_R190_EXPOSURELIMITHIGH},
2102 {0xa0, 0xd1, ZC3XX_R191_EXPOSURELIMITMID},
2103 {0xa0, 0x40, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002104 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2105 {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID},
2106 {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002107 {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002108 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002109 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03002110 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2111 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2112 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2113 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2114 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2115 {}
2116};
2117static const struct usb_action hv7131r_60HZ[] = {
2118 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2119 {0xa0, 0x06, ZC3XX_R190_EXPOSURELIMITHIGH},
2120 {0xa0, 0x1a, ZC3XX_R191_EXPOSURELIMITMID},
2121 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},
2122 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2123 {0xa0, 0xc3, ZC3XX_R196_ANTIFLICKERMID},
2124 {0xa0, 0x50, ZC3XX_R197_ANTIFLICKERLOW},
2125 {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2126 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2127 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2128 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2129 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2130 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2131 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2132 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2133 {}
2134};
2135static const struct usb_action hv7131r_60HZScale[] = {
2136 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2137 {0xa0, 0x0c, ZC3XX_R190_EXPOSURELIMITHIGH},
2138 {0xa0, 0x35, ZC3XX_R191_EXPOSURELIMITMID},
2139 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2140 {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2141 {0xa0, 0x86, ZC3XX_R196_ANTIFLICKERMID},
2142 {0xa0, 0xa0, ZC3XX_R197_ANTIFLICKERLOW},
2143 {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2144 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2145 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2146 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2147 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2148 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2149 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2150 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2151 {}
2152};
2153static const struct usb_action hv7131r_NoFliker[] = {
2154 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2155 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},
2156 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},
2157 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2158 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2159 {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID},
2160 {0xa0, 0x58, ZC3XX_R197_ANTIFLICKERLOW},
2161 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
2162 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
2163 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
2164 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
2165 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2166 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2167 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2168 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2169 {}
2170};
2171static const struct usb_action hv7131r_NoFlikerScale[] = {
2172 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2173 {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},
2174 {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},
2175 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2176 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2177 {0xa0, 0x04, ZC3XX_R196_ANTIFLICKERMID},
2178 {0xa0, 0xb0, ZC3XX_R197_ANTIFLICKERLOW},
2179 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
2180 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
2181 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
2182 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
2183 {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2184 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2185 {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2186 {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002187 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002188};
2189
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002190static const struct usb_action icm105a_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002191 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2192 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
2193 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2194 {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2195 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2196 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2197 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2198 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2199 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2200 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2201 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2202 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2203 {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2204 {0xa0, 0x01, ZC3XX_R098_WINYSTARTLOW},
2205 {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2206 {0xa0, 0x01, ZC3XX_R09A_WINXSTARTLOW},
2207 {0xa0, 0x01, ZC3XX_R11A_FIRSTYLOW},
2208 {0xa0, 0x01, ZC3XX_R11C_FIRSTXLOW},
2209 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2210 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2211 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2212 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2213 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
2214 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2215 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2216 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2217 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002218 {0xaa, 0x01, 0x0010},
2219 {0xaa, 0x03, 0x0000},
2220 {0xaa, 0x04, 0x0001},
2221 {0xaa, 0x05, 0x0020},
2222 {0xaa, 0x06, 0x0001},
2223 {0xaa, 0x08, 0x0000},
2224 {0xaa, 0x03, 0x0001},
2225 {0xaa, 0x04, 0x0011},
2226 {0xaa, 0x05, 0x00a0},
2227 {0xaa, 0x06, 0x0001},
2228 {0xaa, 0x08, 0x0000},
2229 {0xaa, 0x03, 0x0002},
2230 {0xaa, 0x04, 0x0013},
2231 {0xaa, 0x05, 0x0020},
2232 {0xaa, 0x06, 0x0001},
2233 {0xaa, 0x08, 0x0000},
2234 {0xaa, 0x03, 0x0003},
2235 {0xaa, 0x04, 0x0015},
2236 {0xaa, 0x05, 0x0020},
2237 {0xaa, 0x06, 0x0005},
2238 {0xaa, 0x08, 0x0000},
2239 {0xaa, 0x03, 0x0004},
2240 {0xaa, 0x04, 0x0017},
2241 {0xaa, 0x05, 0x0020},
2242 {0xaa, 0x06, 0x000d},
2243 {0xaa, 0x08, 0x0000},
2244 {0xaa, 0x03, 0x0005},
2245 {0xaa, 0x04, 0x0019},
2246 {0xaa, 0x05, 0x0020},
2247 {0xaa, 0x06, 0x0005},
2248 {0xaa, 0x08, 0x0000},
2249 {0xaa, 0x03, 0x0006},
2250 {0xaa, 0x04, 0x0017},
2251 {0xaa, 0x05, 0x0026},
2252 {0xaa, 0x06, 0x0005},
2253 {0xaa, 0x08, 0x0000},
2254 {0xaa, 0x03, 0x0007},
2255 {0xaa, 0x04, 0x0019},
2256 {0xaa, 0x05, 0x0022},
2257 {0xaa, 0x06, 0x0005},
2258 {0xaa, 0x08, 0x0000},
2259 {0xaa, 0x03, 0x0008},
2260 {0xaa, 0x04, 0x0021},
2261 {0xaa, 0x05, 0x00aa},
2262 {0xaa, 0x06, 0x0005},
2263 {0xaa, 0x08, 0x0000},
2264 {0xaa, 0x03, 0x0009},
2265 {0xaa, 0x04, 0x0023},
2266 {0xaa, 0x05, 0x00aa},
2267 {0xaa, 0x06, 0x000d},
2268 {0xaa, 0x08, 0x0000},
2269 {0xaa, 0x03, 0x000a},
2270 {0xaa, 0x04, 0x0025},
2271 {0xaa, 0x05, 0x00aa},
2272 {0xaa, 0x06, 0x0005},
2273 {0xaa, 0x08, 0x0000},
2274 {0xaa, 0x03, 0x000b},
2275 {0xaa, 0x04, 0x00ec},
2276 {0xaa, 0x05, 0x002e},
2277 {0xaa, 0x06, 0x0005},
2278 {0xaa, 0x08, 0x0000},
2279 {0xaa, 0x03, 0x000c},
2280 {0xaa, 0x04, 0x00fa},
2281 {0xaa, 0x05, 0x002a},
2282 {0xaa, 0x06, 0x0005},
2283 {0xaa, 0x08, 0x0000},
2284 {0xaa, 0x07, 0x000d},
2285 {0xaa, 0x01, 0x0005},
2286 {0xaa, 0x94, 0x0002},
2287 {0xaa, 0x90, 0x0000},
2288 {0xaa, 0x91, 0x001f},
2289 {0xaa, 0x10, 0x0064},
2290 {0xaa, 0x9b, 0x00f0},
2291 {0xaa, 0x9c, 0x0002},
2292 {0xaa, 0x14, 0x001a},
2293 {0xaa, 0x20, 0x0080},
2294 {0xaa, 0x22, 0x0080},
2295 {0xaa, 0x24, 0x0080},
2296 {0xaa, 0x26, 0x0080},
2297 {0xaa, 0x00, 0x0084},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002298 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2299 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002300 {0xaa, 0xa8, 0x00c0},
2301 {0xa1, 0x01, 0x0002},
2302 {0xa1, 0x01, 0x0008},
2303 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002304 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2305 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2306 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2307 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002308 {0xa1, 0x01, 0x0008},
2309
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002310 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2311 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002312 {0xa1, 0x01, 0x01c8},
2313 {0xa1, 0x01, 0x01c9},
2314 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002315 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
2316 {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2317 {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2318 {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2319 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2320 {0xa0, 0x52, ZC3XX_R10E_RGB11},
2321 {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2322 {0xa0, 0xf7, ZC3XX_R110_RGB20},
2323 {0xa0, 0xf7, ZC3XX_R111_RGB21},
2324 {0xa0, 0x52, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002325 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002326 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2327 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002328 {0xaa, 0x0d, 0x0003},
2329 {0xaa, 0x0c, 0x008c},
2330 {0xaa, 0x0e, 0x0095},
2331 {0xaa, 0x0f, 0x0002},
2332 {0xaa, 0x1c, 0x0094},
2333 {0xaa, 0x1d, 0x0002},
2334 {0xaa, 0x20, 0x0080},
2335 {0xaa, 0x22, 0x0080},
2336 {0xaa, 0x24, 0x0080},
2337 {0xaa, 0x26, 0x0080},
2338 {0xaa, 0x00, 0x0084},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002339 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2340 {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW},
2341 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2342 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2343 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
2344 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2345 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2346 {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW},
2347 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2348 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2349 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2350 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2351 {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0},
2352 {0xa0, 0xec, ZC3XX_R01E_HSYNC_1},
2353 {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2},
2354 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2355 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2356 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN},
2357 {0xa0, 0xc0, ZC3XX_R11D_GLOBALGAIN},
2358 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002359 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002360 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2361 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2362 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2363 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002364 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002365};
2366
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002367static const struct usb_action icm105a_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002368 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2369 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
2370 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2371 {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2372 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2373 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2374 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2375 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2376 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2377 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2378 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2379 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2380 {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2381 {0xa0, 0x02, ZC3XX_R098_WINYSTARTLOW},
2382 {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2383 {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},
2384 {0xa0, 0x02, ZC3XX_R11A_FIRSTYLOW},
2385 {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},
2386 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2387 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
2388 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2389 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
2390 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2391 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2392 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2393 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2394 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002395 {0xaa, 0x01, 0x0010},
2396 {0xaa, 0x03, 0x0000},
2397 {0xaa, 0x04, 0x0001},
2398 {0xaa, 0x05, 0x0020},
2399 {0xaa, 0x06, 0x0001},
2400 {0xaa, 0x08, 0x0000},
2401 {0xaa, 0x03, 0x0001},
2402 {0xaa, 0x04, 0x0011},
2403 {0xaa, 0x05, 0x00a0},
2404 {0xaa, 0x06, 0x0001},
2405 {0xaa, 0x08, 0x0000},
2406 {0xaa, 0x03, 0x0002},
2407 {0xaa, 0x04, 0x0013},
2408 {0xaa, 0x05, 0x0020},
2409 {0xaa, 0x06, 0x0001},
2410 {0xaa, 0x08, 0x0000},
2411 {0xaa, 0x03, 0x0003},
2412 {0xaa, 0x04, 0x0015},
2413 {0xaa, 0x05, 0x0020},
2414 {0xaa, 0x06, 0x0005},
2415 {0xaa, 0x08, 0x0000},
2416 {0xaa, 0x03, 0x0004},
2417 {0xaa, 0x04, 0x0017},
2418 {0xaa, 0x05, 0x0020},
2419 {0xaa, 0x06, 0x000d},
2420 {0xaa, 0x08, 0x0000},
2421 {0xaa, 0x03, 0x0005},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002422 {0xa0, 0x04, ZC3XX_R092_I2CADDRESSSELECT},
2423 {0xa0, 0x19, ZC3XX_R093_I2CSETVALUE},
2424 {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002425 {0xa1, 0x01, 0x0091},
2426 {0xaa, 0x05, 0x0020},
2427 {0xaa, 0x06, 0x0005},
2428 {0xaa, 0x08, 0x0000},
2429 {0xaa, 0x03, 0x0006},
2430 {0xaa, 0x04, 0x0017},
2431 {0xaa, 0x05, 0x0026},
2432 {0xaa, 0x06, 0x0005},
2433 {0xaa, 0x08, 0x0000},
2434 {0xaa, 0x03, 0x0007},
2435 {0xaa, 0x04, 0x0019},
2436 {0xaa, 0x05, 0x0022},
2437 {0xaa, 0x06, 0x0005},
2438 {0xaa, 0x08, 0x0000},
2439 {0xaa, 0x03, 0x0008},
2440 {0xaa, 0x04, 0x0021},
2441 {0xaa, 0x05, 0x00aa},
2442 {0xaa, 0x06, 0x0005},
2443 {0xaa, 0x08, 0x0000},
2444 {0xaa, 0x03, 0x0009},
2445 {0xaa, 0x04, 0x0023},
2446 {0xaa, 0x05, 0x00aa},
2447 {0xaa, 0x06, 0x000d},
2448 {0xaa, 0x08, 0x0000},
2449 {0xaa, 0x03, 0x000a},
2450 {0xaa, 0x04, 0x0025},
2451 {0xaa, 0x05, 0x00aa},
2452 {0xaa, 0x06, 0x0005},
2453 {0xaa, 0x08, 0x0000},
2454 {0xaa, 0x03, 0x000b},
2455 {0xaa, 0x04, 0x00ec},
2456 {0xaa, 0x05, 0x002e},
2457 {0xaa, 0x06, 0x0005},
2458 {0xaa, 0x08, 0x0000},
2459 {0xaa, 0x03, 0x000c},
2460 {0xaa, 0x04, 0x00fa},
2461 {0xaa, 0x05, 0x002a},
2462 {0xaa, 0x06, 0x0005},
2463 {0xaa, 0x08, 0x0000},
2464 {0xaa, 0x07, 0x000d},
2465 {0xaa, 0x01, 0x0005},
2466 {0xaa, 0x94, 0x0002},
2467 {0xaa, 0x90, 0x0000},
2468 {0xaa, 0x91, 0x0010},
2469 {0xaa, 0x10, 0x0064},
2470 {0xaa, 0x9b, 0x00f0},
2471 {0xaa, 0x9c, 0x0002},
2472 {0xaa, 0x14, 0x001a},
2473 {0xaa, 0x20, 0x0080},
2474 {0xaa, 0x22, 0x0080},
2475 {0xaa, 0x24, 0x0080},
2476 {0xaa, 0x26, 0x0080},
2477 {0xaa, 0x00, 0x0084},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002478 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2479 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002480 {0xaa, 0xa8, 0x0080},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002481 {0xa0, 0x78, ZC3XX_R18D_YTARGET},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002482 {0xa1, 0x01, 0x0002},
2483 {0xa1, 0x01, 0x0008},
2484 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002485 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2486 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2487 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2488 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002489 {0xa1, 0x01, 0x0008},
2490
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002491 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
2492 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002493 {0xa1, 0x01, 0x01c8},
2494 {0xa1, 0x01, 0x01c9},
2495 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002496 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002497
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002498 {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2499 {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2500 {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2501 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2502 {0xa0, 0x52, ZC3XX_R10E_RGB11},
2503 {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2504 {0xa0, 0xf7, ZC3XX_R110_RGB20},
2505 {0xa0, 0xf7, ZC3XX_R111_RGB21},
2506 {0xa0, 0x52, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002507 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002508 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2509 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002510 {0xaa, 0x0d, 0x0003},
2511 {0xaa, 0x0c, 0x0020},
2512 {0xaa, 0x0e, 0x000e},
2513 {0xaa, 0x0f, 0x0002},
2514 {0xaa, 0x1c, 0x000d},
2515 {0xaa, 0x1d, 0x0002},
2516 {0xaa, 0x20, 0x0080},
2517 {0xaa, 0x22, 0x0080},
2518 {0xaa, 0x24, 0x0080},
2519 {0xaa, 0x26, 0x0080},
2520 {0xaa, 0x00, 0x0084},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002521 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2522 {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW},
2523 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2524 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2525 {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW},
2526 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2527 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2528 {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW},
2529 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2530 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2531 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2532 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2533 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0},
2534 {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1},
2535 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2},
2536 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2537 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2538 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002539 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002540 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2541 {0xa0, 0x40, ZC3XX_R116_RGAIN},
2542 {0xa0, 0x40, ZC3XX_R117_GGAIN},
2543 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002544 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002545};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002546static const struct usb_action icm105a_50HZScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002547 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002548 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2549 {0xaa, 0x0c, 0x0020}, /* 00,0c,20,aa */
2550 {0xaa, 0x0e, 0x000e}, /* 00,0e,0e,aa */
2551 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2552 {0xaa, 0x1c, 0x000d}, /* 00,1c,0d,aa */
2553 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2554 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2555 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2556 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2557 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2558 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002559 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2560 {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,0d,cc */
2561 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2562 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2563 {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,1a,cc */
2564 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2565 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2566 {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,4b,cc */
2567 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2568 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2569 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2570 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2571 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
2572 {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d8,cc */
2573 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2574 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002575 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002576};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002577static const struct usb_action icm105a_50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002578 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002579 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2580 {0xaa, 0x0c, 0x008c}, /* 00,0c,8c,aa */
2581 {0xaa, 0x0e, 0x0095}, /* 00,0e,95,aa */
2582 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2583 {0xaa, 0x1c, 0x0094}, /* 00,1c,94,aa */
2584 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2585 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2586 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2587 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2588 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2589 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002590 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2591 {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,94,cc */
2592 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2593 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2594 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2595 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2596 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2597 {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,84,cc */
2598 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2599 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2600 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2601 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2602 {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,e3,cc */
2603 {0xa0, 0xec, ZC3XX_R01E_HSYNC_1}, /* 00,1e,ec,cc */
2604 {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f5,cc */
2605 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2606 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2607 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002608 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002609};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002610static const struct usb_action icm105a_60HZScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002611 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002612 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2613 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2614 {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2615 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2616 {0xaa, 0x1c, 0x0008}, /* 00,1c,08,aa */
2617 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2618 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2619 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2620 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2621 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2622 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002623 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2624 {0xa0, 0x08, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,08,cc */
2625 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2626 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2627 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc */
2628 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2629 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2630 {0xa0, 0x41, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,41,cc */
2631 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2632 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2633 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2634 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2635 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2636 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2637 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2638 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002639 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002640};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002641static const struct usb_action icm105a_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002642 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002643 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2644 {0xaa, 0x0c, 0x0008}, /* 00,0c,08,aa */
2645 {0xaa, 0x0e, 0x0086}, /* 00,0e,86,aa */
2646 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2647 {0xaa, 0x1c, 0x0085}, /* 00,1c,85,aa */
2648 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2649 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2650 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2651 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2652 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2653 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002654 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2655 {0xa0, 0x85, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,85,cc */
2656 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2657 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2658 {0xa0, 0x08, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,08,cc */
2659 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2660 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2661 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,81,cc */
2662 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2663 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2664 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2665 {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2666 {0xa0, 0xc2, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c2,cc */
2667 {0xa0, 0xd6, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d6,cc */
2668 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2669 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2670 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2671 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002672 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002673};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002674static const struct usb_action icm105a_NoFlikerScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002675 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002676 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2677 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2678 {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2679 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2680 {0xaa, 0x1c, 0x0000}, /* 00,1c,00,aa */
2681 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2682 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2683 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2684 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2685 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2686 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002687 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2688 {0xa0, 0x00, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,00,cc */
2689 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2690 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2691 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2692 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2693 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2694 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2695 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2696 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2697 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2698 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2699 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2700 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2701 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2702 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002703 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002704};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002705static const struct usb_action icm105a_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002706 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002707 {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2708 {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2709 {0xaa, 0x0e, 0x0081}, /* 00,0e,81,aa */
2710 {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2711 {0xaa, 0x1c, 0x0080}, /* 00,1c,80,aa */
2712 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2713 {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2714 {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2715 {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2716 {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2717 {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002718 {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2719 {0xa0, 0x80, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,80,cc */
2720 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2721 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2722 {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2723 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2724 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2725 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2726 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2727 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2728 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2729 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2730 {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2731 {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2732 {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2733 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2734 {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2735 {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002736 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002737};
2738
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03002739static const struct usb_action mc501cb_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002740 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2741 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc */
2742 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2743 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2744 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2745 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2746 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2747 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2748 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2749 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2750 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
2751 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2752 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2753 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2754 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2755 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2756 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
2757 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2758 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
2759 {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2760 {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2761 {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2762 {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2763 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002764 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2765 {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2766 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2767 {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2768 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2769 {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2770 {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2771 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2772 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2773 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2774 {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2775 {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2776 {0xaa, 0x18, 0x00de}, /* 00,18,de,aa */
2777 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2778 {0xaa, 0x1a, 0x0086}, /* 00,1a,86,aa */
2779 {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
2780 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2781 {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
2782 {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
2783 {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
2784 {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
2785 {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
2786 {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
2787 {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
2788 {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
2789 {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
2790 {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
2791 {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
2792 {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
2793 {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
2794 {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
2795 {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
2796 {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
2797 {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
2798 {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
Jean-François Moine4e5144e2011-02-26 13:56:20 -03002799 {0xaa, 0xa0, 0x001a}, /* 00,a0,1a,aa */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002800 {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
2801 {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
2802 {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
2803 {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
2804 {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
2805 {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
2806 {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
2807 {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
2808 {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
2809 {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
2810 {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
2811 {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
2812 {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
2813 {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
2814 {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
2815 {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
2816 {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
2817 {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
2818 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2819 {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
2820 {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
2821 {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
2822 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2823 {0xaa, 0x1c, 0x0050}, /* 00,1C,50,aa */
2824 {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
2825 {0xaa, 0x3b, 0x001d}, /* 00,3b,1D,aa */
2826 {0xaa, 0x3c, 0x004c}, /* 00,3c,4C,aa */
2827 {0xaa, 0x3d, 0x0018}, /* 00,3d,18,aa */
2828 {0xaa, 0x3e, 0x006a}, /* 00,3e,6A,aa */
2829 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
2830 {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002831 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2832 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
2833 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
2834 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
2835 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
2836 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
2837 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
2838 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
2839 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002840 {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
2841 {0xaa, 0x51, 0x0027}, /* 00,51,27,aa */
2842 {0xaa, 0x52, 0x0020}, /* 00,52,20,aa */
2843 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2844 {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
2845 {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
2846 {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
2847 {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
2848 {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
2849 {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
2850
2851 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2852 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
2853 {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
2854 {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
2855 {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002856 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002857};
2858
Jean-François Moine780e3122010-10-19 04:29:10 -03002859static const struct usb_action mc501cb_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002860 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2861 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
2862 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2863 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2864 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2865 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2866 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2867 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2868 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2869 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2870 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
2871 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2872 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2873 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2874 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2875 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2876 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
2877 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2878 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
2879 {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2880 {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2881 {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2882 {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2883 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002884 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2885 {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2886 {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2887 {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2888 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2889 {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2890 {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2891 {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2892 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2893 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2894 {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2895 {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2896 {0xaa, 0x18, 0x00d8}, /* 00,18,d8,aa */
2897 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2898 {0xaa, 0x1a, 0x0088}, /* 00,1a,88,aa */
2899 {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
2900 {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2901 {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
2902 {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
2903 {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
2904 {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
2905 {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
2906 {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
2907 {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
2908 {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
2909 {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
2910 {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
2911 {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
2912 {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
2913 {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
2914 {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
2915 {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
2916 {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
2917 {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
2918 {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
Jean-François Moine4e5144e2011-02-26 13:56:20 -03002919 {0xaa, 0xa0, 0x001a}, /* 00,a0,1a,aa */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002920 {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
2921 {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
2922 {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
2923 {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
2924 {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
2925 {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
2926 {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
2927 {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
2928 {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
2929 {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
2930 {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
2931 {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
2932 {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
2933 {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
2934 {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
2935 {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
2936 {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
2937 {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
2938 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2939 {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
2940 {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
2941 {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
2942 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2943 {0xaa, 0x1c, 0x0050}, /* 00,1c,50,aa */
2944 {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
2945 {0xaa, 0x3b, 0x003a}, /* 00,3b,3A,aa */
2946 {0xaa, 0x3c, 0x0098}, /* 00,3c,98,aa */
2947 {0xaa, 0x3d, 0x0030}, /* 00,3d,30,aa */
2948 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
2949 {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
2950 {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03002951 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2952 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
2953 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
2954 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
2955 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
2956 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
2957 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
2958 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
2959 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002960 {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
2961 {0xaa, 0x51, 0x004e}, /* 00,51,4E,aa */
2962 {0xaa, 0x52, 0x0041}, /* 00,52,41,aa */
2963 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2964 {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
2965 {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
2966 {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
2967 {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
2968 {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
2969 {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002970 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002971};
2972
Jean-François Moineda751912011-04-19 14:51:15 -03002973static const struct usb_action mc501cb_50HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002974 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2975 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
2976 {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
2977 {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
2978 {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
2979 {0xaa, 0x3c, 0x004c}, /* 00,3C,4C,aa */
2980 {0xaa, 0x3d, 0x001d}, /* 00,3D,1D,aa */
2981 {0xaa, 0x3e, 0x004c}, /* 00,3E,4C,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002982 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002983};
2984
Jean-François Moineda751912011-04-19 14:51:15 -03002985static const struct usb_action mc501cb_50HZScale[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002986 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2987 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
2988 {0xaa, 0x36, 0x003a}, /* 00,36,3A,aa */
2989 {0xaa, 0x37, 0x0098}, /* 00,37,98,aa */
2990 {0xaa, 0x3b, 0x003a}, /* 00,3B,3A,aa */
2991 {0xaa, 0x3c, 0x0098}, /* 00,3C,98,aa */
2992 {0xaa, 0x3d, 0x003a}, /* 00,3D,3A,aa */
2993 {0xaa, 0x3e, 0x0098}, /* 00,3E,98,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03002994 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002995};
2996
Jean-François Moineda751912011-04-19 14:51:15 -03002997static const struct usb_action mc501cb_60HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03002998 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2999 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3000 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3001 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3002 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3003 {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3004 {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3005 {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003006 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003007};
3008
Jean-François Moineda751912011-04-19 14:51:15 -03003009static const struct usb_action mc501cb_60HZScale[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003010 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3011 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3012 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3013 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3014 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3015 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3016 {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3017 {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003018 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003019};
3020
Jean-François Moineda751912011-04-19 14:51:15 -03003021static const struct usb_action mc501cb_NoFliker[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003022 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3023 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3024 {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3025 {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3026 {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3027 {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3028 {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3029 {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003030 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003031};
3032
Jean-François Moineda751912011-04-19 14:51:15 -03003033static const struct usb_action mc501cb_NoFlikerScale[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003034 {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3035 {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3036 {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3037 {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3038 {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3039 {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3040 {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3041 {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003042 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003043};
3044
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003045/* from zs211.inf */
3046static const struct usb_action ov7620_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003047 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3048 {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, /* 00,02,40,cc */
3049 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3050 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3051 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3052 {0xa0, 0x02, ZC3XX_R083_RGAINADDR}, /* 00,83,02,cc */
3053 {0xa0, 0x01, ZC3XX_R085_BGAINADDR}, /* 00,85,01,cc */
3054 {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,80,cc */
3055 {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID}, /* 00,87,81,cc */
3056 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW}, /* 00,88,10,cc */
3057 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3058 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3059 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3060 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3061 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3062 {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
3063 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3064 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3065 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3066 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
3067 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3068 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
3069 {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
3070 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003071 {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3072 {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3073 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3074 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3075 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3076 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3077 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3078 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3079 {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3080 {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3081 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3082 {0xaa, 0x1a, 0x00f1}, /* 00,1a,f1,aa */
3083 {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3084 {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3085 {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3086 {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3087 {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3088 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3089 {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3090 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3091 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3092 {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3093 {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3094 {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3095 {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3096 {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3097 {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3098 {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003099 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3100 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3101 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3102 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003103 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003104 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3105 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3106 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3107 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3108 {0xa0, 0x68, ZC3XX_R116_RGAIN}, /* 01,16,68,cc */
3109 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
3110 {0xa0, 0x40, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,40,cc */
3111 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3112 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,50,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003113 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003114};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003115static const struct usb_action ov7620_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003116 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3117 {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT}, /* 00,02,50,cc */
3118 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3119 /* mx change? */
3120 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3121 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3122 {0xa0, 0x02, ZC3XX_R083_RGAINADDR}, /* 00,83,02,cc */
3123 {0xa0, 0x01, ZC3XX_R085_BGAINADDR}, /* 00,85,01,cc */
3124 {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,80,cc */
3125 {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID}, /* 00,87,81,cc */
3126 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW}, /* 00,88,10,cc */
3127 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3128 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3129 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3130 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3131 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3132 {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
3133 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3134 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3135 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3136 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
3137 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3138 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
3139 {0xa0, 0xd6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d6,cc */
3140 /* OV7648 00,9c,d8,cc */
3141 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003142 {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3143 {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3144 {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3145 {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3146 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3147 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3148 {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3149 {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3150 {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3151 {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3152 {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3153 {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3154 {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3155 {0xaa, 0x1a, 0x00f2}, /* 00,1a,f2,aa */
3156 {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3157 {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3158 {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3159 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3160 {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3161 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3162 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3163 {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3164 {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3165 {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3166 {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3167 {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3168 {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3169 {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003170 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3171 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3172 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3173 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3174 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3175 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3176 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3177 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3178 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3179 {0xa0, 0x68, ZC3XX_R116_RGAIN}, /* 01,16,68,cc */
3180 {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
3181 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,50,cc */
3182 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3183 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,50,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003184 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003185};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003186static const struct usb_action ov7620_50HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003187 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3188 {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
Ondrej Zary6c0e9312018-05-25 05:08:43 -04003189 /* enable 1/120s & 1/100s exposures for banding filter */
3190 {0xaa, 0x75, 0x008e},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003191 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003192 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3193 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3194 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3195 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3196 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3197 {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,83,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003198 {0xaa, 0x76, 0x0003}, /* 00,76,03,aa */
3199/* {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, * 00,02,40,cc
Jean-François Moine4e5144e2011-02-26 13:56:20 -03003200 * if mode0 (640x480) */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003201 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003202};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003203static const struct usb_action ov7620_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003204 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3205 {0xaa, 0x2b, 0x0000}, /* 00,2b,00,aa */
Ondrej Zary6c0e9312018-05-25 05:08:43 -04003206 /* enable 1/120s & 1/100s exposures for banding filter */
3207 {0xaa, 0x75, 0x008e},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003208 {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3209 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3210 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3211 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3212 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3213 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3214 {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,83,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003215 {0xaa, 0x76, 0x0003}, /* 00,76,03,aa */
3216/* {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, * 00,02,40,cc
3217 * if mode0 (640x480) */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003218/* ?? in gspca v1, it was
3219 {0xa0, 0x00, 0x0039}, * 00,00,00,dd *
3220 {0xa1, 0x01, 0x0037}, */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003221 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003222};
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003223static const struct usb_action ov7620_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003224 {0xdd, 0x00, 0x0100}, /* 00,01,00,dd */
3225 {0xaa, 0x2b, 0x0000}, /* 00,2b,00,aa */
Ondrej Zary6c0e9312018-05-25 05:08:43 -04003226 /* disable 1/120s & 1/100s exposures for banding filter */
3227 {0xaa, 0x75, 0x008a},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003228 {0xaa, 0x2d, 0x0001}, /* 00,2d,01,aa */
3229 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3230 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3231 {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3232 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3233 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3234 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,01,cc */
3235/* {0xa0, 0x44, ZC3XX_R002_CLOCKSELECT}, * 00,02,44,cc
Jean-François Moine83d1aa32010-08-04 05:11:23 -03003236 * if mode1 (320x240) */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003237/* ?? was
3238 {0xa0, 0x00, 0x0039}, * 00,00,00,dd *
3239 {0xa1, 0x01, 0x0037}, */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003240 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003241};
3242
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003243static const struct usb_action ov7630c_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003244 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3245 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3246 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3247 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3248 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3249 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3250 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3251 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3252 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3253 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3254 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3255 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3256 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3257 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003258 {0xaa, 0x12, 0x0080},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003259 {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3260 {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3261 {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3262 {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3263 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3264 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3265 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3266 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3267 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3268 {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},
3269 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003270 {0xaa, 0x12, 0x0069},
3271 {0xaa, 0x04, 0x0020},
3272 {0xaa, 0x06, 0x0050},
3273 {0xaa, 0x13, 0x0083},
3274 {0xaa, 0x14, 0x0000},
3275 {0xaa, 0x15, 0x0024},
3276 {0xaa, 0x17, 0x0018},
3277 {0xaa, 0x18, 0x00ba},
3278 {0xaa, 0x19, 0x0002},
3279 {0xaa, 0x1a, 0x00f6},
3280 {0xaa, 0x1b, 0x0002},
3281 {0xaa, 0x20, 0x00c2},
3282 {0xaa, 0x24, 0x0060},
3283 {0xaa, 0x25, 0x0040},
3284 {0xaa, 0x26, 0x0030},
3285 {0xaa, 0x27, 0x00ea},
3286 {0xaa, 0x28, 0x00a0},
3287 {0xaa, 0x21, 0x0000},
3288 {0xaa, 0x2a, 0x0081},
3289 {0xaa, 0x2b, 0x0096},
3290 {0xaa, 0x2d, 0x0094},
3291 {0xaa, 0x2f, 0x003d},
3292 {0xaa, 0x30, 0x0024},
3293 {0xaa, 0x60, 0x0000},
3294 {0xaa, 0x61, 0x0040},
3295 {0xaa, 0x68, 0x007c},
3296 {0xaa, 0x6f, 0x0015},
3297 {0xaa, 0x75, 0x0088},
3298 {0xaa, 0x77, 0x00b5},
3299 {0xaa, 0x01, 0x0060},
3300 {0xaa, 0x02, 0x0060},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003301 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3302 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3303 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3304 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3305 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003306 {0xa0, 0x00, 0x01ad},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003307 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3308 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3309 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3310 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3311 {0xa0, 0x60, ZC3XX_R116_RGAIN},
3312 {0xa0, 0x46, ZC3XX_R118_BGAIN},
3313 {0xa0, 0x04, ZC3XX_R113_RGB03},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003314/* 0x10, */
3315 {0xa1, 0x01, 0x0002},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003316 {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3317 {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3318 {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3319 {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3320 {0xa0, 0x50, ZC3XX_R10E_RGB11},
3321 {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3322 {0xa0, 0xf8, ZC3XX_R110_RGB20},
3323 {0xa0, 0xf8, ZC3XX_R111_RGB21},
3324 {0xa0, 0x50, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003325 {0xa1, 0x01, 0x0008},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003326 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
3327 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003328 {0xa1, 0x01, 0x01c8},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003329 {0xa1, 0x01, 0x01c9},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003330 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003331 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
3332 {0xa0, 0x01, ZC3XX_R120_GAMMA00}, /* gamma 2 ?*/
3333 {0xa0, 0x0c, ZC3XX_R121_GAMMA01},
3334 {0xa0, 0x1f, ZC3XX_R122_GAMMA02},
3335 {0xa0, 0x3a, ZC3XX_R123_GAMMA03},
3336 {0xa0, 0x53, ZC3XX_R124_GAMMA04},
3337 {0xa0, 0x6d, ZC3XX_R125_GAMMA05},
3338 {0xa0, 0x85, ZC3XX_R126_GAMMA06},
3339 {0xa0, 0x9c, ZC3XX_R127_GAMMA07},
3340 {0xa0, 0xb0, ZC3XX_R128_GAMMA08},
3341 {0xa0, 0xc2, ZC3XX_R129_GAMMA09},
3342 {0xa0, 0xd1, ZC3XX_R12A_GAMMA0A},
3343 {0xa0, 0xde, ZC3XX_R12B_GAMMA0B},
3344 {0xa0, 0xe9, ZC3XX_R12C_GAMMA0C},
3345 {0xa0, 0xf2, ZC3XX_R12D_GAMMA0D},
3346 {0xa0, 0xf9, ZC3XX_R12E_GAMMA0E},
3347 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3348 {0xa0, 0x05, ZC3XX_R130_GAMMA10},
3349 {0xa0, 0x0f, ZC3XX_R131_GAMMA11},
3350 {0xa0, 0x16, ZC3XX_R132_GAMMA12},
3351 {0xa0, 0x1a, ZC3XX_R133_GAMMA13},
3352 {0xa0, 0x19, ZC3XX_R134_GAMMA14},
3353 {0xa0, 0x19, ZC3XX_R135_GAMMA15},
3354 {0xa0, 0x17, ZC3XX_R136_GAMMA16},
3355 {0xa0, 0x15, ZC3XX_R137_GAMMA17},
3356 {0xa0, 0x12, ZC3XX_R138_GAMMA18},
3357 {0xa0, 0x10, ZC3XX_R139_GAMMA19},
3358 {0xa0, 0x0e, ZC3XX_R13A_GAMMA1A},
3359 {0xa0, 0x0b, ZC3XX_R13B_GAMMA1B},
3360 {0xa0, 0x09, ZC3XX_R13C_GAMMA1C},
3361 {0xa0, 0x08, ZC3XX_R13D_GAMMA1D},
3362 {0xa0, 0x06, ZC3XX_R13E_GAMMA1E},
3363 {0xa0, 0x03, ZC3XX_R13F_GAMMA1F},
3364 {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3365 {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3366 {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3367 {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3368 {0xa0, 0x50, ZC3XX_R10E_RGB11},
3369 {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3370 {0xa0, 0xf8, ZC3XX_R110_RGB20},
3371 {0xa0, 0xf8, ZC3XX_R111_RGB21},
3372 {0xa0, 0x50, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003373
3374 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003375 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003376 {0xaa, 0x10, 0x001b},
3377 {0xaa, 0x76, 0x0002},
3378 {0xaa, 0x2a, 0x0081},
3379 {0xaa, 0x2b, 0x0000},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003380 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3381 {0xa0, 0x01, ZC3XX_R191_EXPOSURELIMITMID},
3382 {0xa0, 0xb8, ZC3XX_R192_EXPOSURELIMITLOW},
3383 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3384 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3385 {0xa0, 0x37, ZC3XX_R197_ANTIFLICKERLOW},
3386 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3387 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3388 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3389 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3390 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3391 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3392 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003393 {0xaa, 0x13, 0x0083}, /* 40 */
3394 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003395 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003396 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003397};
3398
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003399static const struct usb_action ov7630c_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003400 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3401 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
3402 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3403 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3404 {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3405 {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3406 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3407 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3408 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3409 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3410 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3411 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003412
3413 {0xaa, 0x12, 0x0080},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003414 {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3415 {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3416 {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3417 {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3418 {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3419 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3420 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3421 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3422 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3423 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
3424 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003425 {0xaa, 0x12, 0x0069}, /* i2c */
3426 {0xaa, 0x04, 0x0020},
3427 {0xaa, 0x06, 0x0050},
3428 {0xaa, 0x13, 0x00c3},
3429 {0xaa, 0x14, 0x0000},
3430 {0xaa, 0x15, 0x0024},
3431 {0xaa, 0x19, 0x0003},
3432 {0xaa, 0x1a, 0x00f6},
3433 {0xaa, 0x1b, 0x0002},
3434 {0xaa, 0x20, 0x00c2},
3435 {0xaa, 0x24, 0x0060},
3436 {0xaa, 0x25, 0x0040},
3437 {0xaa, 0x26, 0x0030},
3438 {0xaa, 0x27, 0x00ea},
3439 {0xaa, 0x28, 0x00a0},
3440 {0xaa, 0x21, 0x0000},
3441 {0xaa, 0x2a, 0x0081},
3442 {0xaa, 0x2b, 0x0096},
3443 {0xaa, 0x2d, 0x0084},
3444 {0xaa, 0x2f, 0x003d},
3445 {0xaa, 0x30, 0x0024},
3446 {0xaa, 0x60, 0x0000},
3447 {0xaa, 0x61, 0x0040},
3448 {0xaa, 0x68, 0x007c},
3449 {0xaa, 0x6f, 0x0015},
3450 {0xaa, 0x75, 0x0088},
3451 {0xaa, 0x77, 0x00b5},
3452 {0xaa, 0x01, 0x0060},
3453 {0xaa, 0x02, 0x0060},
3454 {0xaa, 0x17, 0x0018},
3455 {0xaa, 0x18, 0x00ba},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003456 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3457 {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3458 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3459 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3460 {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003461 {0xa0, 0x00, 0x01ad},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003462 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3463 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3464 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3465 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3466 {0xa0, 0x60, ZC3XX_R116_RGAIN},
3467 {0xa0, 0x46, ZC3XX_R118_BGAIN},
3468 {0xa0, 0x04, ZC3XX_R113_RGB03},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003469
3470 {0xa1, 0x01, 0x0002},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003471 {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3472 {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3473 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3474 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3475 {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3476 {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3477 {0xa0, 0x00, ZC3XX_R110_RGB20},
3478 {0xa0, 0xf6, ZC3XX_R111_RGB21},
3479 {0xa0, 0x4a, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003480
3481 {0xa1, 0x01, 0x0008},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003482 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* clock ? */
3483 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00}, /* sharpness+ */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003484 {0xa1, 0x01, 0x01c8},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003485 {0xa1, 0x01, 0x01c9},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003486 {0xa1, 0x01, 0x01ca},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003487 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05}, /* sharpness- */
3488 {0xa0, 0x16, ZC3XX_R120_GAMMA00}, /* gamma ~4 */
3489 {0xa0, 0x3a, ZC3XX_R121_GAMMA01},
3490 {0xa0, 0x5b, ZC3XX_R122_GAMMA02},
3491 {0xa0, 0x7c, ZC3XX_R123_GAMMA03},
3492 {0xa0, 0x94, ZC3XX_R124_GAMMA04},
3493 {0xa0, 0xa9, ZC3XX_R125_GAMMA05},
3494 {0xa0, 0xbb, ZC3XX_R126_GAMMA06},
3495 {0xa0, 0xca, ZC3XX_R127_GAMMA07},
3496 {0xa0, 0xd7, ZC3XX_R128_GAMMA08},
3497 {0xa0, 0xe1, ZC3XX_R129_GAMMA09},
3498 {0xa0, 0xea, ZC3XX_R12A_GAMMA0A},
3499 {0xa0, 0xf1, ZC3XX_R12B_GAMMA0B},
3500 {0xa0, 0xf7, ZC3XX_R12C_GAMMA0C},
3501 {0xa0, 0xfc, ZC3XX_R12D_GAMMA0D},
3502 {0xa0, 0xff, ZC3XX_R12E_GAMMA0E},
3503 {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3504 {0xa0, 0x20, ZC3XX_R130_GAMMA10},
3505 {0xa0, 0x22, ZC3XX_R131_GAMMA11},
3506 {0xa0, 0x20, ZC3XX_R132_GAMMA12},
3507 {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
3508 {0xa0, 0x16, ZC3XX_R134_GAMMA14},
3509 {0xa0, 0x13, ZC3XX_R135_GAMMA15},
3510 {0xa0, 0x10, ZC3XX_R136_GAMMA16},
3511 {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
3512 {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
3513 {0xa0, 0x09, ZC3XX_R139_GAMMA19},
3514 {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
3515 {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
3516 {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
3517 {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
3518 {0xa0, 0x00, ZC3XX_R13E_GAMMA1E},
3519 {0xa0, 0x01, ZC3XX_R13F_GAMMA1F},
3520 {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3521 {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3522 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3523 {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3524 {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3525 {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3526 {0xa0, 0x00, ZC3XX_R110_RGB20},
3527 {0xa0, 0xf6, ZC3XX_R111_RGB21},
3528 {0xa0, 0x4a, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003529
3530 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003531 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003532 {0xaa, 0x10, 0x000d},
3533 {0xaa, 0x76, 0x0002},
3534 {0xaa, 0x2a, 0x0081},
3535 {0xaa, 0x2b, 0x0000},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003536 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3537 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},
3538 {0xa0, 0xd8, ZC3XX_R192_EXPOSURELIMITLOW},
3539 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3540 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3541 {0xa0, 0x1b, ZC3XX_R197_ANTIFLICKERLOW},
3542 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3543 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3544 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3545 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3546 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3547 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3548 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003549 {0xaa, 0x13, 0x00c3},
3550
3551 {0xa1, 0x01, 0x0180},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003552 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003553 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003554};
3555
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03003556static const struct usb_action pas106b_Initial_com[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003557/* Sream and Sensor specific */
3558 {0xa1, 0x01, 0x0010}, /* CMOSSensorSelect */
3559/* System */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003560 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
3561 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003562/* Picture size */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003563 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* ClockSelect */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003564 {0xa0, 0x03, 0x003a},
3565 {0xa0, 0x0c, 0x003b},
3566 {0xa0, 0x04, 0x0038},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003567 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003568};
3569
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003570static const struct usb_action pas106b_InitialScale[] = { /* 176x144 */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003571/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003572 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003573/* Sream and Sensor specific */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003574 {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003575/* Picture size */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003576 {0xa0, 0x00, ZC3XX_R003_FRAMEWIDTHHIGH},
3577 {0xa0, 0xb0, ZC3XX_R004_FRAMEWIDTHLOW},
3578 {0xa0, 0x00, ZC3XX_R005_FRAMEHEIGHTHIGH},
3579 {0xa0, 0x90, ZC3XX_R006_FRAMEHEIGHTLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003580/* System */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003581 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003582/* Sream and Sensor specific */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003583 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3584 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003585/* Sensor Interface */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003586 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003587/* Window inside sensor array */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003588 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3589 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3590 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3591 {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3592 {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003593/* Init the sensor */
3594 {0xaa, 0x02, 0x0004},
3595 {0xaa, 0x08, 0x0000},
3596 {0xaa, 0x09, 0x0005},
3597 {0xaa, 0x0a, 0x0002},
3598 {0xaa, 0x0b, 0x0002},
3599 {0xaa, 0x0c, 0x0005},
3600 {0xaa, 0x0d, 0x0000},
3601 {0xaa, 0x0e, 0x0002},
3602 {0xaa, 0x14, 0x0081},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03003603/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003604 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
Mauro Carvalho Chehab3e4d8f42019-02-18 14:29:03 -05003605/* Frame retrieving */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003606 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003607/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003608 {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003609/* Unknown */
3610 {0xa0, 0x00, 0x01ad},
3611/* Sharpness */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003612 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3613 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03003614/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003615 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003616/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003617 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003618/*Dead pixels */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003619 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003620/* EEPROM */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003621 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003622/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003623 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3624 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3625 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003626/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003627 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003628/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003629 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003630/*Dead pixels */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003631 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003632/* EEPROM */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003633 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003634/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003635 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3636 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3637 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003638
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003639 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3640 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3641 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3642 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3643 {0xa0, 0x58, ZC3XX_R10E_RGB11},
3644 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3645 {0xa0, 0xf4, ZC3XX_R110_RGB20},
3646 {0xa0, 0xf4, ZC3XX_R111_RGB21},
3647 {0xa0, 0x58, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003648/* Auto correction */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003649 {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3650 {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3651 {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3652 {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3653 {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3654 {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3655 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003656/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003657 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3658 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3659 {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
3660 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3661 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3662 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
3663 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
3664 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003665/* sensor on */
3666 {0xaa, 0x07, 0x00b1},
3667 {0xaa, 0x05, 0x0003},
3668 {0xaa, 0x04, 0x0001},
3669 {0xaa, 0x03, 0x003b},
3670/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003671 {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3672 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3673 {0xa0, 0xa0, ZC3XX_R11D_GLOBALGAIN},
3674 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003675/* Auto correction */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003676 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003677 {0xa1, 0x01, 0x0180}, /* AutoCorrectEnable */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003678 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003679/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003680 {0xa0, 0x40, ZC3XX_R116_RGAIN},
3681 {0xa0, 0x40, ZC3XX_R117_GGAIN},
3682 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003683 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003684};
3685
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03003686static const struct usb_action pas106b_Initial[] = { /* 352x288 */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003687/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003688 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003689/* Sream and Sensor specific */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003690 {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003691/* Picture size */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003692 {0xa0, 0x01, ZC3XX_R003_FRAMEWIDTHHIGH},
3693 {0xa0, 0x60, ZC3XX_R004_FRAMEWIDTHLOW},
3694 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3695 {0xa0, 0x20, ZC3XX_R006_FRAMEHEIGHTLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003696/* System */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003697 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003698/* Sream and Sensor specific */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003699 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3700 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003701/* Sensor Interface */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003702 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003703/* Window inside sensor array */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003704 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3705 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3706 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3707 {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3708 {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003709/* Init the sensor */
3710 {0xaa, 0x02, 0x0004},
3711 {0xaa, 0x08, 0x0000},
3712 {0xaa, 0x09, 0x0005},
3713 {0xaa, 0x0a, 0x0002},
3714 {0xaa, 0x0b, 0x0002},
3715 {0xaa, 0x0c, 0x0005},
3716 {0xaa, 0x0d, 0x0000},
3717 {0xaa, 0x0e, 0x0002},
3718 {0xaa, 0x14, 0x0081},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03003719/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003720 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
Mauro Carvalho Chehab3e4d8f42019-02-18 14:29:03 -05003721/* Frame retrieving */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003722 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003723/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003724 {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003725/* Unknown */
3726 {0xa0, 0x00, 0x01ad},
3727/* Sharpness */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003728 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3729 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03003730/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003731 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003732/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003733 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3734 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003735/*Dead pixels */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003736 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003737/* EEPROM */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003738 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003739/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003740 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3741 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3742 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003743/* Other registers */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003744 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003745/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003746 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003747/*Dead pixels */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003748 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003749/* EEPROM */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003750 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003751/* JPEG control */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003752 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3753 {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3754 {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003755
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003756 {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3757 {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3758 {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3759 {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3760 {0xa0, 0x58, ZC3XX_R10E_RGB11},
3761 {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3762 {0xa0, 0xf4, ZC3XX_R110_RGB20},
3763 {0xa0, 0xf4, ZC3XX_R111_RGB21},
3764 {0xa0, 0x58, ZC3XX_R112_RGB22},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003765/* Auto correction */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003766 {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3767 {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3768 {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3769 {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3770 {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3771 {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3772 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003773
3774/* Auto exposure and white balance */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003775 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3776 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3777 {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003778
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003779 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3780 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3781 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003782
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003783 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3784 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003785/* sensor on */
3786 {0xaa, 0x07, 0x00b1},
3787 {0xaa, 0x05, 0x0003},
3788 {0xaa, 0x04, 0x0001},
3789 {0xaa, 0x03, 0x003b},
3790/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003791 {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3792 {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003793 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003794/* Auto correction */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003795 {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003796 {0xa1, 0x01, 0x0180}, /* AutoCorrectEnable */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003797 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003798/* Gains */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03003799 {0xa0, 0x40, ZC3XX_R116_RGAIN},
3800 {0xa0, 0x40, ZC3XX_R117_GGAIN},
3801 {0xa0, 0x40, ZC3XX_R118_BGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003802
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003803 {0xa0, 0x00, 0x0007}, /* AutoCorrectEnable */
3804 {0xa0, 0xff, ZC3XX_R018_FRAMELOST}, /* Frame adjust */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003805 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003806};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03003807static const struct usb_action pas106b_50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003808 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3809 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3810 {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,54,cc */
3811 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3812 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3813 {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,87,cc */
3814 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3815 {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,30,cc */
3816 {0xaa, 0x03, 0x0021}, /* 00,03,21,aa */
3817 {0xaa, 0x04, 0x000c}, /* 00,04,0c,aa */
3818 {0xaa, 0x05, 0x0002}, /* 00,05,02,aa */
3819 {0xaa, 0x07, 0x001c}, /* 00,07,1c,aa */
3820 {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003821 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003822};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03003823static const struct usb_action pas106b_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003824 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3825 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3826 {0xa0, 0x2e, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,2e,cc */
3827 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3828 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3829 {0xa0, 0x71, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,71,cc */
3830 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3831 {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,30,cc */
3832 {0xaa, 0x03, 0x001c}, /* 00,03,1c,aa */
3833 {0xaa, 0x04, 0x0004}, /* 00,04,04,aa */
3834 {0xaa, 0x05, 0x0001}, /* 00,05,01,aa */
3835 {0xaa, 0x07, 0x00c4}, /* 00,07,c4,aa */
3836 {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003837 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003838};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03003839static const struct usb_action pas106b_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03003840 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3841 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3842 {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc */
3843 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3844 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3845 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
3846 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
3847 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
3848 {0xaa, 0x03, 0x0013}, /* 00,03,13,aa */
3849 {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3850 {0xaa, 0x05, 0x0001}, /* 00,05,01,aa */
3851 {0xaa, 0x07, 0x0030}, /* 00,07,30,aa */
3852 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03003853 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03003854};
3855
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003856/* from lvWIMv.inf 046d:08a2/:08aa 2007/06/03 */
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003857static const struct usb_action pas202b_Initial[] = { /* 640x480 */
3858 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003859 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003860 {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0e,cc */
3861 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc */
3862 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3863 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3864 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3865 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
3866 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3867 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3868 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3869 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3870 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3871 {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,03,cc */
3872 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3873 {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,03,cc */
3874 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
3875 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
3876 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
3877 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
3878 {0xaa, 0x02, 0x0002}, /* 00,02,04,aa --> 02 */
3879 {0xaa, 0x07, 0x0006}, /* 00,07,06,aa */
3880 {0xaa, 0x08, 0x0002}, /* 00,08,02,aa */
3881 {0xaa, 0x09, 0x0006}, /* 00,09,06,aa */
3882 {0xaa, 0x0a, 0x0001}, /* 00,0a,01,aa */
3883 {0xaa, 0x0b, 0x0001}, /* 00,0b,01,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003884 {0xaa, 0x0c, 0x0006},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003885 {0xaa, 0x0d, 0x0000}, /* 00,0d,00,aa */
3886 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
3887 {0xaa, 0x12, 0x0005}, /* 00,12,05,aa */
3888 {0xaa, 0x13, 0x0063}, /* 00,13,63,aa */
3889 {0xaa, 0x15, 0x0070}, /* 00,15,70,aa */
3890 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc */
3891 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3892 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3893 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3894 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3895 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3896 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3897 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3898 {0xa0, 0x70, ZC3XX_R18D_YTARGET}, /* 01,8d,70,cc */
3899 {}
3900};
3901static const struct usb_action pas202b_InitialScale[] = { /* 320x240 */
3902 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003903 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003904 {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,0e,cc */
3905 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
3906 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3907 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3908 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003909 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003910 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3911 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3912 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3913 {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3914 {0xa0, 0x08, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,08,cc */
3915 {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,02,cc */
3916 {0xa0, 0x08, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,08,cc */
3917 {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,02,cc */
3918 {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003919 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003920 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
3921 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
3922 {0xaa, 0x02, 0x0002}, /* 00,02,02,aa */
3923 {0xaa, 0x07, 0x0006}, /* 00,07,06,aa */
3924 {0xaa, 0x08, 0x0002}, /* 00,08,02,aa */
3925 {0xaa, 0x09, 0x0006}, /* 00,09,06,aa */
3926 {0xaa, 0x0a, 0x0001}, /* 00,0a,01,aa */
3927 {0xaa, 0x0b, 0x0001}, /* 00,0b,01,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003928 {0xaa, 0x0c, 0x0006},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003929 {0xaa, 0x0d, 0x0000}, /* 00,0d,00,aa */
3930 {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
3931 {0xaa, 0x12, 0x0005}, /* 00,12,05,aa */
3932 {0xaa, 0x13, 0x0063}, /* 00,13,63,aa */
3933 {0xaa, 0x15, 0x0070}, /* 00,15,70,aa */
3934 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
3935 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3936 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3937 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3938 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3939 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3940 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3941 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3942 {0xa0, 0x70, ZC3XX_R18D_YTARGET}, /* 01,8d,70,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003943 {0xa0, 0xff, ZC3XX_R097_WINYSTARTHIGH},
3944 {0xa0, 0xfe, ZC3XX_R098_WINYSTARTLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003945 {}
3946};
3947static const struct usb_action pas202b_50HZ[] = {
3948 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
3949 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
3950 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
3951 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003952 {0xaa, 0x21, 0x001b},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003953 {0xaa, 0x03, 0x0044}, /* 00,03,44,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003954 {0xaa, 0x04, 0x0008},
3955 {0xaa, 0x05, 0x001b},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003956 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
3957 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003958 {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003959 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
3960 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003961 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
3962 {0xa0, 0x1b, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003963 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3964 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3965 {0xa0, 0x4d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,4d,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003966 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
3967 {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003968 {0xa0, 0x44, ZC3XX_R01D_HSYNC_0}, /* 00,1d,44,cc */
3969 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
3970 {0xa0, 0xad, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ad,cc */
3971 {0xa0, 0xeb, ZC3XX_R020_HSYNC_3}, /* 00,20,eb,cc */
3972 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
3973 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
3974 {}
3975};
3976static const struct usb_action pas202b_50HZScale[] = {
3977 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
3978 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
3979 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003980 {0xaa, 0x20, 0x0004},
3981 {0xaa, 0x21, 0x003d},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003982 {0xaa, 0x03, 0x0041}, /* 00,03,41,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003983 {0xaa, 0x04, 0x0010},
3984 {0xaa, 0x05, 0x003d},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003985 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
3986 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003987 {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003988 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
3989 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003990 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
3991 {0xa0, 0x3d, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003992 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3993 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3994 {0xa0, 0x9b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,9b,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03003995 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
3996 {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03003997 {0xa0, 0x41, ZC3XX_R01D_HSYNC_0}, /* 00,1d,41,cc */
3998 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
3999 {0xa0, 0xad, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ad,cc */
4000 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4001 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4002 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4003 {}
4004};
4005static const struct usb_action pas202b_60HZ[] = {
4006 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4007 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4008 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4009 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
4010 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4011 {0xaa, 0x03, 0x0045}, /* 00,03,45,aa */
4012 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
4013 {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
4014 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4015 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004016 {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004017 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4018 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004019 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
4020 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004021 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4022 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4023 {0xa0, 0x40, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,40,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004024 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4025 {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004026 {0xa0, 0x45, ZC3XX_R01D_HSYNC_0}, /* 00,1d,45,cc */
4027 {0xa0, 0x8e, ZC3XX_R01E_HSYNC_1}, /* 00,1e,8e,cc */
4028 {0xa0, 0xc1, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c1,cc */
4029 {0xa0, 0xf5, ZC3XX_R020_HSYNC_3}, /* 00,20,f5,cc */
4030 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4031 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4032 {}
4033};
4034static const struct usb_action pas202b_60HZScale[] = {
4035 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4036 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4037 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004038 {0xaa, 0x20, 0x0004},
4039 {0xaa, 0x21, 0x0008},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004040 {0xaa, 0x03, 0x0042}, /* 00,03,42,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004041 {0xaa, 0x04, 0x0010},
4042 {0xaa, 0x05, 0x0008},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004043 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4044 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004045 {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004046 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc */
4047 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004048 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
4049 {0xa0, 0x08, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004050 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4051 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4052 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,81,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004053 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4054 {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004055 {0xa0, 0x42, ZC3XX_R01D_HSYNC_0}, /* 00,1d,42,cc */
4056 {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1}, /* 00,1e,6f,cc */
4057 {0xa0, 0xaf, ZC3XX_R01F_HSYNC_2}, /* 00,1f,af,cc */
4058 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4059 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4060 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4061 {}
4062};
4063static const struct usb_action pas202b_NoFliker[] = {
4064 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4065 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4066 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
4067 {0xaa, 0x20, 0x0002}, /* 00,20,02,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004068 {0xaa, 0x21, 0x0006},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004069 {0xaa, 0x03, 0x0040}, /* 00,03,40,aa */
4070 {0xaa, 0x04, 0x0008}, /* 00,04,08,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004071 {0xaa, 0x05, 0x0006},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004072 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4073 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4074 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004075 {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
4076 {0xa0, 0x06, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004077 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4078 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004079 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004080 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4081 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4082 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004083 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004084 {0xa0, 0x40, ZC3XX_R01D_HSYNC_0}, /* 00,1d,40,cc */
4085 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1}, /* 00,1e,60,cc */
4086 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2}, /* 00,1f,90,cc */
4087 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4088 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4089 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4090 {}
4091};
4092static const struct usb_action pas202b_NoFlikerScale[] = {
4093 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
4094 {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID}, /* 00,87,20,cc */
4095 {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW}, /* 00,88,21,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004096 {0xaa, 0x20, 0x0004},
4097 {0xaa, 0x21, 0x000c},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004098 {0xaa, 0x03, 0x0040}, /* 00,03,40,aa */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004099 {0xaa, 0x04, 0x0010},
4100 {0xaa, 0x05, 0x000c},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004101 {0xaa, 0x0e, 0x0001}, /* 00,0e,01,aa */
4102 {0xaa, 0x0f, 0x0000}, /* 00,0f,00,aa */
4103 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004104 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
4105 {0xa0, 0x0c, ZC3XX_R192_EXPOSURELIMITLOW},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004106 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
4107 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
4108 {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,02,cc */
4109 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
4110 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
4111 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03004112 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03004113 {0xa0, 0x40, ZC3XX_R01D_HSYNC_0}, /* 00,1d,40,cc */
4114 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1}, /* 00,1e,60,cc */
4115 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2}, /* 00,1f,90,cc */
4116 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
4117 {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID}, /* 00,87,0f,cc */
4118 {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW}, /* 00,88,0e,cc */
4119 {}
4120};
4121
Jean-François Moinea484dd92010-08-04 07:25:12 -03004122/* mt9v111 (mi0360soc) and pb0330 from vm30x.inf 0ac8:301b 07/02/13 */
4123static const struct usb_action mt9v111_1_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004124 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4125 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4126 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4127 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4128 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4129 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4130 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4131 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004132 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004133 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004134 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004135 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4136 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4137 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4138 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4139 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004140 {0xdd, 0x00, 0x0200},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004141 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004142 {0xaa, 0x01, 0x0001},
4143 {0xaa, 0x06, 0x0000},
4144 {0xaa, 0x08, 0x0483},
4145 {0xaa, 0x01, 0x0004},
4146 {0xaa, 0x08, 0x0006},
4147 {0xaa, 0x02, 0x0011},
4148 {0xaa, 0x03, 0x01e5}, /*jfm: was 01e7*/
4149 {0xaa, 0x04, 0x0285}, /*jfm: was 0287*/
4150 {0xaa, 0x07, 0x3002},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004151 {0xaa, 0x20, 0x5100},
4152 {0xaa, 0x35, 0x507f},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004153 {0xaa, 0x30, 0x0005},
4154 {0xaa, 0x31, 0x0000},
4155 {0xaa, 0x58, 0x0078},
4156 {0xaa, 0x62, 0x0411},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004157 {0xaa, 0x2b, 0x007f},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004158 {0xaa, 0x2c, 0x007f}, /*jfm: was 0030*/
4159 {0xaa, 0x2d, 0x007f}, /*jfm: was 0030*/
4160 {0xaa, 0x2e, 0x007f}, /*jfm: was 0030*/
4161 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004162 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004163 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4164 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4165 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4166 {0xa0, 0x09, 0x01ad}, /*jfm: was 00*/
4167 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4168 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4169 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4170 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4171 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004172 {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004173 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4174 {0xa0, 0x65, ZC3XX_R118_BGAIN},
4175 {}
4176};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004177static const struct usb_action mt9v111_1_InitialScale[] = { /* 320x240 */
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004178 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4179 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4180 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4181 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4182 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4183 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4184 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4185 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4186 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4187 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004188 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004189 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4190 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4191 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4192 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4193 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4194 {0xdd, 0x00, 0x0200},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004195 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004196 {0xaa, 0x01, 0x0001},
4197 {0xaa, 0x06, 0x0000},
4198 {0xaa, 0x08, 0x0483},
4199 {0xaa, 0x01, 0x0004},
4200 {0xaa, 0x08, 0x0006},
4201 {0xaa, 0x02, 0x0011},
4202 {0xaa, 0x03, 0x01e7},
4203 {0xaa, 0x04, 0x0287},
4204 {0xaa, 0x07, 0x3002},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004205 {0xaa, 0x20, 0x5100},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004206 {0xaa, 0x35, 0x007f}, /*jfm: was 0050*/
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004207 {0xaa, 0x30, 0x0005},
4208 {0xaa, 0x31, 0x0000},
4209 {0xaa, 0x58, 0x0078},
4210 {0xaa, 0x62, 0x0411},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004211 {0xaa, 0x2b, 0x007f}, /*jfm: was 28*/
4212 {0xaa, 0x2c, 0x007f}, /*jfm: was 30*/
4213 {0xaa, 0x2d, 0x007f}, /*jfm: was 30*/
4214 {0xaa, 0x2e, 0x007f}, /*jfm: was 28*/
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004215 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004216 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004217 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4218 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4219 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004220 {0xa0, 0x09, 0x01ad}, /*jfm: was 00*/
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004221 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4222 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4223 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4224 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4225 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004226 {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004227 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4228 {0xa0, 0x65, ZC3XX_R118_BGAIN},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004229 {}
4230};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004231static const struct usb_action mt9v111_1_AE50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004232 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4233 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004234 {0xbb, 0x00, 0x0562},
4235 {0xbb, 0x01, 0x09aa},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004236 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004237 {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
4238 {0xa0, 0x9b, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004239 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4240 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004241 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4242 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4243 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4244 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4245 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4246 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4247 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4248 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4249 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4250 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4251 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4252 {}
4253};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004254static const struct usb_action mt9v111_1_AE50HZScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004255 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4256 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4257 {0xbb, 0x00, 0x0509},
4258 {0xbb, 0x01, 0x0934},
4259 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4260 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4261 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4262 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4263 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4264 {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4265 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4266 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4267 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4268 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4269 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4270 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4271 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4272 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4273 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4274 {}
4275};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004276static const struct usb_action mt9v111_1_AE60HZ[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004277 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4278 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004279 {0xaa, 0x05, 0x003d},
4280 {0xaa, 0x09, 0x016e},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004281 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4282 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4283 {0xa0, 0xdd, ZC3XX_R192_EXPOSURELIMITLOW},
4284 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4285 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4286 {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
4287 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4288 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4289 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4290 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4291 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4292 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4293 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4294 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4295 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4296 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4297 {}
4298};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004299static const struct usb_action mt9v111_1_AE60HZScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004300 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4301 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4302 {0xbb, 0x00, 0x0509},
4303 {0xbb, 0x01, 0x0983},
4304 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4305 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4306 {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4307 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4308 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4309 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004310 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4311 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4312 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4313 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4314 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4315 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4316 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4317 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4318 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004319 {}
4320};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004321static const struct usb_action mt9v111_1_AENoFliker[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004322 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4323 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4324 {0xbb, 0x00, 0x0509},
4325 {0xbb, 0x01, 0x0960},
4326 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4327 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4328 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4329 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4330 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4331 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4332 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4333 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4334 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4335 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4336 {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4337 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4338 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4339 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4340 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004341 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004342 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004343};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004344static const struct usb_action mt9v111_1_AENoFlikerScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004345 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4346 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4347 {0xbb, 0x00, 0x0534},
4348 {0xbb, 0x02, 0x0960},
4349 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4350 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4351 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4352 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4353 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4354 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4355 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4356 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4357 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4358 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4359 {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4360 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4361 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4362 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4363 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4364 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4365 {}
4366};
Jean-François Moinea484dd92010-08-04 07:25:12 -03004367/* from usbvm303.inf 0ac8:303b 07/03/25 (3 - tas5130c) */
4368static const struct usb_action mt9v111_3_Initial[] = {
4369 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4370 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4371 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
Jean-François Moined581bcd2010-10-29 08:01:01 -03004372 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
Jean-François Moinea484dd92010-08-04 07:25:12 -03004373 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4374 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4375 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4376 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4377 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4378 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4379 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4380 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4381 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4382 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4383 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4384 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4385 {0xdd, 0x00, 0x0200},
4386 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4387 {0xaa, 0x01, 0x0001}, /* select IFP/SOC registers */
4388 {0xaa, 0x06, 0x0000}, /* operating mode control */
4389 {0xaa, 0x08, 0x0483}, /* output format control */
4390 /* H red first, V red or blue first,
4391 * raw Bayer, auto flicker */
4392 {0xaa, 0x01, 0x0004}, /* select sensor core registers */
4393 {0xaa, 0x08, 0x0006}, /* row start */
4394 {0xaa, 0x02, 0x0011}, /* column start */
4395 {0xaa, 0x03, 0x01e5}, /* window height - 1 */
4396 {0xaa, 0x04, 0x0285}, /* window width - 1 */
4397 {0xaa, 0x07, 0x3002}, /* output control */
4398 {0xaa, 0x20, 0x1100}, /* read mode: bits 8 & 12 (?) */
4399 {0xaa, 0x35, 0x007f}, /* global gain */
4400 {0xaa, 0x30, 0x0005},
4401 {0xaa, 0x31, 0x0000},
4402 {0xaa, 0x58, 0x0078},
4403 {0xaa, 0x62, 0x0411},
4404 {0xaa, 0x2b, 0x007f}, /* green1 gain */
4405 {0xaa, 0x2c, 0x007f}, /* blue gain */
4406 {0xaa, 0x2d, 0x007f}, /* red gain */
4407 {0xaa, 0x2e, 0x007f}, /* green2 gain */
4408 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4409 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4410 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4411 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4412 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4413 {0xa0, 0x00, 0x01ad},
4414 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4415 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4416 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4417 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4418 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4419 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
4420 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4421 {0xa0, 0x65, ZC3XX_R118_BGAIN},
4422 {}
4423};
4424static const struct usb_action mt9v111_3_InitialScale[] = {
4425 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4426 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4427 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4428 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4429 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4430 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4431 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4432 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4433 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4434 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4435 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4436 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4437 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4438 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4439 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4440 {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4441 {0xdd, 0x00, 0x0200},
4442 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4443 {0xaa, 0x01, 0x0001},
4444 {0xaa, 0x06, 0x0000},
4445 {0xaa, 0x08, 0x0483},
4446 {0xaa, 0x01, 0x0004},
4447 {0xaa, 0x08, 0x0006},
4448 {0xaa, 0x02, 0x0011},
4449 {0xaa, 0x03, 0x01e7},
4450 {0xaa, 0x04, 0x0287},
4451 {0xaa, 0x07, 0x3002},
4452 {0xaa, 0x20, 0x1100},
4453 {0xaa, 0x35, 0x007f},
4454 {0xaa, 0x30, 0x0005},
4455 {0xaa, 0x31, 0x0000},
4456 {0xaa, 0x58, 0x0078},
4457 {0xaa, 0x62, 0x0411},
4458 {0xaa, 0x2b, 0x007f},
4459 {0xaa, 0x2c, 0x007f},
4460 {0xaa, 0x2d, 0x007f},
4461 {0xaa, 0x2e, 0x007f},
4462 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4463 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4464 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4465 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4466 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4467 {0xa0, 0x00, 0x01ad},
4468 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4469 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4470 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4471 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4472 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4473 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
4474 {0xa0, 0x61, ZC3XX_R116_RGAIN},
4475 {0xa0, 0x65, ZC3XX_R118_BGAIN},
4476 {}
4477};
4478static const struct usb_action mt9v111_3_AE50HZ[] = {
4479 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4480 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4481 {0xaa, 0x05, 0x0009}, /* horizontal blanking */
4482 {0xaa, 0x09, 0x01ce}, /* shutter width */
4483 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4484 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4485 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4486 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4487 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4488 {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4489 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4490 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4491 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4492 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4493 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4494 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4495 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4496 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4497 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4498 {}
4499};
4500static const struct usb_action mt9v111_3_AE50HZScale[] = {
4501 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4502 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4503 {0xaa, 0x05, 0x0009},
4504 {0xaa, 0x09, 0x01ce},
4505 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4506 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4507 {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4508 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4509 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4510 {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4511 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4512 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4513 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4514 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4515 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4516 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4517 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4518 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4519 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4520 {}
4521};
4522static const struct usb_action mt9v111_3_AE60HZ[] = {
4523 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4524 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4525 {0xaa, 0x05, 0x0009},
4526 {0xaa, 0x09, 0x0083},
4527 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4528 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4529 {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4530 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4531 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4532 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4533 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4534 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4535 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4536 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4537 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4538 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4539 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4540 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4541 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4542 {}
4543};
4544static const struct usb_action mt9v111_3_AE60HZScale[] = {
4545 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4546 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4547 {0xaa, 0x05, 0x0009},
4548 {0xaa, 0x09, 0x0083},
4549 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4550 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4551 {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4552 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4553 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4554 {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4555 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4556 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4557 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4558 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4559 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4560 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4561 {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4562 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4563 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4564 {}
4565};
4566static const struct usb_action mt9v111_3_AENoFliker[] = {
4567 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4568 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4569 {0xaa, 0x05, 0x0034},
4570 {0xaa, 0x09, 0x0260},
4571 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4572 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4573 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4574 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4575 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4576 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4577 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4578 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4579 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4580 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4581 {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4582 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4583 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4584 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4585 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4586 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4587 {}
4588};
4589static const struct usb_action mt9v111_3_AENoFlikerScale[] = {
4590 {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4591 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4592 {0xaa, 0x05, 0x0034},
4593 {0xaa, 0x09, 0x0260},
4594 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4595 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4596 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4597 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4598 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4599 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4600 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4601 {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4602 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4603 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4604 {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4605 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4606 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4607 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4608 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4609 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4610 {}
4611};
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004612
4613static const struct usb_action pb0330_Initial[] = { /* 640x480 */
4614 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4615 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
4616 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4617 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4618 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4619 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4620 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4621 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4622 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4623 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4624 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4625 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4626 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4627 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4628 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4629 {0xdd, 0x00, 0x0200},
4630 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4631 {0xaa, 0x01, 0x0006},
4632 {0xaa, 0x02, 0x0011},
4633 {0xaa, 0x03, 0x01e5}, /*jfm: was 1e7*/
4634 {0xaa, 0x04, 0x0285}, /*jfm: was 0287*/
4635 {0xaa, 0x06, 0x0003},
4636 {0xaa, 0x07, 0x3002},
4637 {0xaa, 0x20, 0x1100},
4638 {0xaa, 0x2f, 0xf7b0},
4639 {0xaa, 0x30, 0x0005},
4640 {0xaa, 0x31, 0x0000},
4641 {0xaa, 0x34, 0x0100},
4642 {0xaa, 0x35, 0x0060},
4643 {0xaa, 0x3d, 0x068f},
4644 {0xaa, 0x40, 0x01e0},
4645 {0xaa, 0x58, 0x0078},
4646 {0xaa, 0x62, 0x0411},
4647 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4648 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4649 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4650 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4651 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4652 {0xa0, 0x09, 0x01ad}, /*jfm: was 00 */
4653 {0xa0, 0x15, 0x01ae},
4654 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4655 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4656 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4657 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4658 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4659 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /*jfm: was 6c*/
4660 {}
4661};
4662static const struct usb_action pb0330_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004663 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4664 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00 */
4665 {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4666 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4667 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4668 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4669 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4670 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4671 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4672 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4673 {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4674 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4675 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4676 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4677 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004678 {0xdd, 0x00, 0x0200},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004679 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004680 {0xaa, 0x01, 0x0006},
4681 {0xaa, 0x02, 0x0011},
4682 {0xaa, 0x03, 0x01e7},
4683 {0xaa, 0x04, 0x0287},
4684 {0xaa, 0x06, 0x0003},
4685 {0xaa, 0x07, 0x3002},
4686 {0xaa, 0x20, 0x1100},
4687 {0xaa, 0x2f, 0xf7b0},
4688 {0xaa, 0x30, 0x0005},
4689 {0xaa, 0x31, 0x0000},
4690 {0xaa, 0x34, 0x0100},
4691 {0xaa, 0x35, 0x0060},
4692 {0xaa, 0x3d, 0x068f},
4693 {0xaa, 0x40, 0x01e0},
4694 {0xaa, 0x58, 0x0078},
4695 {0xaa, 0x62, 0x0411},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004696 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4697 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4698 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4699 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4700 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004701 {0xa0, 0x09, 0x01ad},
4702 {0xa0, 0x15, 0x01ae},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004703 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4704 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4705 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4706 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4707 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004708 {0xa0, 0x78, ZC3XX_R18D_YTARGET}, /*jfm: was 6c*/
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004709 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004710};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004711static const struct usb_action pb0330_50HZ[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004712 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4713 {0xbb, 0x00, 0x055c},
4714 {0xbb, 0x01, 0x09aa},
4715 {0xbb, 0x00, 0x1001},
4716 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4717 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4718 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4719 {0xa0, 0xc4, ZC3XX_R192_EXPOSURELIMITLOW},
4720 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4721 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4722 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4723 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4724 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4725 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4726 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4727 {0xa0, 0x5c, ZC3XX_R01D_HSYNC_0},
4728 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4729 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4730 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004731 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004732};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004733static const struct usb_action pb0330_50HZScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004734 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4735 {0xbb, 0x00, 0x0566},
4736 {0xbb, 0x02, 0x09b2},
4737 {0xbb, 0x00, 0x1002},
4738 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4739 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4740 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4741 {0xa0, 0x8c, ZC3XX_R192_EXPOSURELIMITLOW},
4742 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4743 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4744 {0xa0, 0x8a, ZC3XX_R197_ANTIFLICKERLOW},
4745 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4746 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4747 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4748 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4749 {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4750 {0xa0, 0xf0, ZC3XX_R01E_HSYNC_1},
4751 {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2},
4752 {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004753 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004754};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004755static const struct usb_action pb0330_60HZ[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004756 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4757 {0xbb, 0x00, 0x0535},
4758 {0xbb, 0x01, 0x0974},
4759 {0xbb, 0x00, 0x1001},
4760 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4761 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4762 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4763 {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
4764 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4765 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4766 {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW},
4767 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4768 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4769 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4770 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4771 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4772 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4773 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4774 {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004775 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004776};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004777static const struct usb_action pb0330_60HZScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004778 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4779 {0xbb, 0x00, 0x0535},
4780 {0xbb, 0x02, 0x096c},
4781 {0xbb, 0x00, 0x1002},
4782 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4783 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4784 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4785 {0xa0, 0xc0, ZC3XX_R192_EXPOSURELIMITLOW},
4786 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4787 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4788 {0xa0, 0x7c, ZC3XX_R197_ANTIFLICKERLOW},
4789 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4790 {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4791 {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4792 {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4793 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4794 {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4795 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4796 {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004797 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004798};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004799static const struct usb_action pb0330_NoFliker[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004800 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4801 {0xbb, 0x00, 0x0509},
4802 {0xbb, 0x02, 0x0940},
4803 {0xbb, 0x00, 0x1002},
4804 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4805 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4806 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4807 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4808 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4809 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4810 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4811 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4812 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4813 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4814 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4815 {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4816 {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4817 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4818 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004819 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004820};
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03004821static const struct usb_action pb0330_NoFlikerScale[] = {
Jean-Francois Moine56205cc2009-11-04 16:38:04 -03004822 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4823 {0xbb, 0x00, 0x0535},
4824 {0xbb, 0x01, 0x0980},
4825 {0xbb, 0x00, 0x1001},
4826 {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4827 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4828 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4829 {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4830 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4831 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4832 {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4833 {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4834 {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4835 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4836 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4837 {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4838 {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4839 {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4840 {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004841 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004842};
4843
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03004844/* from oem9.inf */
4845static const struct usb_action po2030_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004846 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4847 {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT}, /* 00,02,04,cc */
4848 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
4849 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4850 {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
4851 {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
4852 {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
4853 {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
4854 {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
4855 {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
4856 {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
4857 {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
4858 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
4859 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4860 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4861 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4862 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4863 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4864 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
4865 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4866 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4867 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
4868 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
4869 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
4870 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
4871 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc */
4872 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004873 {0xaa, 0x09, 0x00ce}, /* 00,09,ce,aa */
4874 {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
4875 {0xaa, 0x0d, 0x0054}, /* 00,0d,54,aa */
4876 {0xaa, 0x0f, 0x00eb}, /* 00,0f,eb,aa */
4877 {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
4878 {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
4879 {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
4880 {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
4881 {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
4882 {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
4883 {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
4884 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
4885 {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
4886 {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
4887 {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
4888 {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
4889 {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
4890 {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
4891 {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
4892 {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
4893 {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
4894 {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
4895 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4896 {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
4897 {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
4898 {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
4899 {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
4900 {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
4901 {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
4902 {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
4903 {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
4904 {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
4905 {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
4906 {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004907 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
4908 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
4909 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4910 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004911 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004912 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4913 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4914 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4915 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4916 {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
4917 {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004918 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004919};
4920
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03004921/* from oem9.inf */
4922static const struct usb_action po2030_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004923 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4924 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
4925 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
4926 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4927 {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
4928 {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
4929 {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
4930 {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
4931 {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
4932 {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
4933 {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
4934 {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
4935 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
4936 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4937 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4938 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4939 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4940 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4941 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
4942 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4943 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
4944 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
4945 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
4946 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
4947 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
4948 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc */
4949 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004950 {0xaa, 0x09, 0x00cc}, /* 00,09,cc,aa */
4951 {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
4952 {0xaa, 0x0d, 0x0058}, /* 00,0d,58,aa */
4953 {0xaa, 0x0f, 0x00ed}, /* 00,0f,ed,aa */
4954 {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
4955 {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
4956 {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
4957 {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
4958 {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
4959 {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
4960 {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
4961 {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
4962 {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
4963 {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
4964 {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
4965 {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
4966 {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
4967 {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
4968 {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
4969 {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
4970 {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
4971 {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
4972 {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
4973 {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
4974 {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
4975 {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
4976 {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
4977 {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
4978 {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
4979 {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
4980 {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
4981 {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
4982 {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
4983 {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004984 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
4985 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
4986 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
4987 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004988 {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03004989 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
4990 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
4991 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
4992 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
4993 {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
4994 {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03004995 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004996};
4997
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03004998static const struct usb_action po2030_50HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03004999 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
5000 {0xaa, 0x1a, 0x0001}, /* 00,1a,01,aa */
5001 {0xaa, 0x1b, 0x000a}, /* 00,1b,0a,aa */
5002 {0xaa, 0x1c, 0x00b0}, /* 00,1c,b0,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005003 {0xa0, 0x05, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,05,cc */
5004 {0xa0, 0x35, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,35,cc */
5005 {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
5006 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5007 {0xa0, 0x85, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,85,cc */
5008 {0xa0, 0x58, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,58,cc */
5009 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
5010 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
5011 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
5012 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
5013 {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,22,cc */
5014 {0xa0, 0x88, ZC3XX_R18D_YTARGET}, /* 01,8d,88,cc */
5015 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc */
5016 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005017 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005018};
5019
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005020static const struct usb_action po2030_60HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005021 {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
5022 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
5023 {0xaa, 0x1b, 0x00de}, /* 00,1b,de,aa */
5024 {0xaa, 0x1c, 0x0040}, /* 00,1c,40,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005025 {0xa0, 0x08, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,08,cc */
5026 {0xa0, 0xae, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,ae,cc */
5027 {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
5028 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5029 {0xa0, 0x6f, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,6f,cc */
5030 {0xa0, 0x20, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,20,cc */
5031 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
5032 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
5033 {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
5034 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
5035 {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,22,cc */
5036 {0xa0, 0x88, ZC3XX_R18D_YTARGET}, /* 01,8d,88,cc */
5037 /* win: 01,8d,80 */
5038 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc */
5039 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005040 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005041};
5042
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005043static const struct usb_action po2030_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005044 {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005045 {0xaa, 0x8d, 0x000d}, /* 00,8d,0d,aa */
5046 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
5047 {0xaa, 0x1b, 0x0002}, /* 00,1b,02,aa */
5048 {0xaa, 0x1c, 0x0078}, /* 00,1c,78,aa */
5049 {0xaa, 0x46, 0x0000}, /* 00,46,00,aa */
5050 {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005051 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005052};
5053
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005054static const struct usb_action tas5130c_InitialScale[] = { /* 320x240 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005055 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5056 {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT},
5057 {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5058 {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5059 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5060 {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5061 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5062 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5063 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005064 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5065 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5066 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5067 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005068
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005069 {0xa0, 0x04, ZC3XX_R098_WINYSTARTLOW},
5070 {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5071 {0xa0, 0x04, ZC3XX_R11A_FIRSTYLOW},
5072 {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5073 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
5074 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5075 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
5076 {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5077 {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
5078 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5079 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03005080 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
Jean-Francois Moine013db752009-10-07 05:24:19 -03005081 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005082 {0xa0, 0x00, 0x01ad},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005083 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5084 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5085 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5086 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03005087 {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5088 {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005089 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005090};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005091static const struct usb_action tas5130c_Initial[] = { /* 640x480 */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005092 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5093 {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03005094 {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005095 {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5096 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5097 {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5098 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5099 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5100 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005101 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5102 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5103 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5104 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5105 {0xa0, 0x05, ZC3XX_R098_WINYSTARTLOW},
5106 {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5107 {0xa0, 0x05, ZC3XX_R11A_FIRSTYLOW},
5108 {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5109 {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
5110 {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5111 {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
5112 {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5113 {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
5114 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5115 {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03005116 {0xa0, 0x70, ZC3XX_R18D_YTARGET},
Jean-Francois Moine013db752009-10-07 05:24:19 -03005117 {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005118 {0xa0, 0x00, 0x01ad},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005119 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5120 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5121 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5122 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03005123 {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5124 {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005125 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005126};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005127static const struct usb_action tas5130c_50HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005128 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005129 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5130 {0xaa, 0xa4, 0x0063}, /* 00,a4,63,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005131 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5132 {0xa0, 0x63, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,63,cc */
5133 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005134 {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
5135 {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005136 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5137 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5138 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,47,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005139 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5140 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5141 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5142 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005143 {0xa0, 0xd3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,d3,cc */
5144 {0xa0, 0xda, ZC3XX_R01E_HSYNC_1}, /* 00,1e,da,cc */
5145 {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
5146 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5147 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005148 {0xa0, 0x4c, ZC3XX_R0A0_MAXXLOW},
5149 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005150 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005151};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005152static const struct usb_action tas5130c_50HZScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005153 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005154 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5155 {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005156 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5157 {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5158 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005159 {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
5160 {0xa0, 0xd0, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005161 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5162 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5163 {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005164 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5165 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5166 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5167 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005168 {0xa0, 0xf0, ZC3XX_R01D_HSYNC_0}, /* 00,1d,f0,cc */
5169 {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,f4,cc */
5170 {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f8,cc */
5171 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5172 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005173 {0xa0, 0xc0, ZC3XX_R0A0_MAXXLOW},
5174 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005175 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005176};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005177static const struct usb_action tas5130c_60HZ[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005178 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005179 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5180 {0xaa, 0xa4, 0x0036}, /* 00,a4,36,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005181 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5182 {0xa0, 0x36, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,36,cc */
5183 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005184 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5185 {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005186 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5187 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5188 {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3e,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005189 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5190 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5191 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5192 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005193 {0xa0, 0xca, ZC3XX_R01D_HSYNC_0}, /* 00,1d,ca,cc */
5194 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5195 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5196 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5197 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005198 {0xa0, 0x28, ZC3XX_R0A0_MAXXLOW},
5199 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005200 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005201};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005202static const struct usb_action tas5130c_60HZScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005203 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005204 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5205 {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005206 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5207 {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5208 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005209 {0xa0, 0x09, ZC3XX_R191_EXPOSURELIMITMID},
5210 {0xa0, 0x47, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005211 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5212 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5213 {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005214 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5215 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5216 {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5217 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005218 {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
5219 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5220 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5221 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5222 {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005223 {0xa0, 0x20, ZC3XX_R0A0_MAXXLOW},
5224 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005225 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005226};
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005227static const struct usb_action tas5130c_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005228 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005229 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5230 {0xaa, 0xa4, 0x0040}, /* 00,a4,40,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005231 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5232 {0xa0, 0x40, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,40,cc */
5233 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005234 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5235 {0xa0, 0xa0, ZC3XX_R192_EXPOSURELIMITLOW},
5236 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5237 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5238 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5239 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5240 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005241 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5242 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5243 {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5244 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5245 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5246 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5247 {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005248 {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5249 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005250 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005251};
5252
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005253static const struct usb_action tas5130c_NoFlikerScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005254 {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005255 {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5256 {0xaa, 0xa4, 0x0090}, /* 00,a4,90,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005257 {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5258 {0xa0, 0x90, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,90,cc */
5259 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005260 {0xa0, 0x0a, ZC3XX_R191_EXPOSURELIMITMID},
5261 {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
5262 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5263 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5264 {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5265 {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5266 {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005267 {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5268 {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5269 {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5270 {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5271 {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5272 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5273 {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
Jean-Francois Moine013db752009-10-07 05:24:19 -03005274 {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5275 {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005276 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005277};
5278
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005279/* from usbvm305.inf 0ac8:305b 07/06/15 (3 - tas5130c) */
5280static const struct usb_action gc0303_Initial[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005281 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc, */
5282 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, /* 00,08,02,cc, */
5283 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005284 {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005285 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc, */
5286 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc, */
5287 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc, */
5288 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc, */
5289 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5290 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc, */
5291 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc, */
5292 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc, */
5293 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc, */
5294 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc, */
5295 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc, */
5296 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc, */
5297 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e6,cc,
5298 * 6<->8 */
5299 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc,
5300 * 6<->8 */
5301 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID}, /* 00,87,10,cc, */
5302 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005303 {0xaa, 0x01, 0x0000},
5304 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa, */
5305 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005306 {0xaa, 0x1b, 0x0000},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005307 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc, */
5308 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc, */
5309 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005310 {0xaa, 0x05, 0x0010}, /* 00,05,10,aa, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005311 {0xaa, 0x0a, 0x0002},
5312 {0xaa, 0x0b, 0x0000},
5313 {0xaa, 0x0c, 0x0002},
5314 {0xaa, 0x0d, 0x0000},
5315 {0xaa, 0x0e, 0x0002},
5316 {0xaa, 0x0f, 0x0000},
5317 {0xaa, 0x10, 0x0002},
5318 {0xaa, 0x11, 0x0000},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005319 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa, */
5320 {0xaa, 0x17, 0x00e8}, /* 00,17,e6,aa, (e6 -> e8) */
5321 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa, */
5322 {0xaa, 0x19, 0x0088}, /* 00,19,86,aa, */
5323 {0xaa, 0x20, 0x0020}, /* 00,20,20,aa, */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005324 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc, */
5325 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc, */
5326 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc, */
5327 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc, */
5328 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc, */
5329 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc, */
5330 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc, */
5331 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc, */
5332 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005333 {0xa0, 0x58, ZC3XX_R1A8_DIGITALGAIN},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005334 {0xa0, 0x61, ZC3XX_R116_RGAIN}, /* 01,16,61,cc, */
5335 {0xa0, 0x65, ZC3XX_R118_BGAIN}, /* 01,18,65,cc */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005336 {0xaa, 0x1b, 0x0000},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005337 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005338};
5339
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005340static const struct usb_action gc0303_InitialScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005341 {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc, */
5342 {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, /* 00,08,02,cc, */
5343 {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005344 {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005345 {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc, */
5346 {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc, */
5347 {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc, */
5348 {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc, */
5349 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
5350 {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc, */
5351 {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc, */
5352 {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc, */
5353 {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc, */
5354 {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc, */
5355 {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc, */
5356 {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc, */
5357 {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc,
5358 * 8<->6 */
5359 {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc,
5360 * 8<->6 */
5361 {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID}, /* 00,87,10,cc, */
5362 {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005363 {0xaa, 0x01, 0x0000},
5364 {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa, */
5365 {0xaa, 0x1c, 0x0017}, /* 00,1c,17,aa, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005366 {0xaa, 0x1b, 0x0000},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005367 {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,82,cc, */
5368 {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID}, /* 00,87,83,cc, */
5369 {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW}, /* 00,88,84,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005370 {0xaa, 0x05, 0x0010}, /* 00,05,10,aa, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005371 {0xaa, 0x0a, 0x0001},
5372 {0xaa, 0x0b, 0x0000},
5373 {0xaa, 0x0c, 0x0001},
5374 {0xaa, 0x0d, 0x0000},
5375 {0xaa, 0x0e, 0x0001},
5376 {0xaa, 0x0f, 0x0000},
5377 {0xaa, 0x10, 0x0001},
5378 {0xaa, 0x11, 0x0000},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005379 {0xaa, 0x16, 0x0001}, /* 00,16,01,aa, */
5380 {0xaa, 0x17, 0x00e8}, /* 00,17,e6,aa (e6 -> e8) */
5381 {0xaa, 0x18, 0x0002}, /* 00,18,02,aa, */
5382 {0xaa, 0x19, 0x0088}, /* 00,19,88,aa, */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005383 {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,b7,cc, */
5384 {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc, */
5385 {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc, */
5386 {0xa0, 0x76, ZC3XX_R189_AWBSTATUS}, /* 01,89,76,cc, */
5387 {0xa0, 0x09, 0x01ad}, /* 01,ad,09,cc, */
5388 {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc, */
5389 {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc, */
5390 {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc, */
5391 {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005392 {0xa0, 0x58, ZC3XX_R1A8_DIGITALGAIN},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005393 {0xa0, 0x61, ZC3XX_R116_RGAIN}, /* 01,16,61,cc, */
5394 {0xa0, 0x65, ZC3XX_R118_BGAIN}, /* 01,18,65,cc */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005395 {0xaa, 0x1b, 0x0000},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005396 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005397};
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005398static const struct usb_action gc0303_50HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005399 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5400 {0xaa, 0x83, 0x0001}, /* 00,83,01,aa */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005401 {0xaa, 0x84, 0x0063},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005402 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5403 {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0d,cc, */
5404 {0xa0, 0xa8, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc, */
5405 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5406 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005407 {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,47,cc, */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005408 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5409 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5410 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005411 {0xa0, 0x48, ZC3XX_R1AA_DIGITALGAINSTEP},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005412 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5413 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5414 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5415 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5416 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5417 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005418 {0xa0, 0x7f, ZC3XX_R18D_YTARGET},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005419 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005420};
5421
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005422static const struct usb_action gc0303_50HZScale[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005423 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5424 {0xaa, 0x83, 0x0003}, /* 00,83,03,aa */
5425 {0xaa, 0x84, 0x0054}, /* 00,84,54,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005426 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5427 {0xa0, 0x0d, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,0d,cc, */
5428 {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc, */
5429 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5430 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5431 {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,8e,cc, */
5432 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5433 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5434 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005435 {0xa0, 0x48, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc, */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005436 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5437 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5438 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5439 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5440 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5441 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005442 {0xa0, 0x7f, ZC3XX_R18D_YTARGET},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005443 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005444};
5445
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005446static const struct usb_action gc0303_60HZ[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005447 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005448 {0xaa, 0x83, 0x0000},
5449 {0xaa, 0x84, 0x003b},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005450 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5451 {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,05,cc, */
5452 {0xa0, 0x88, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,88,cc, */
5453 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5454 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5455 {0xa0, 0x3b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3b,cc, */
5456 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5457 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5458 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc, */
5459 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,24,cc, */
5460 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5461 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5462 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5463 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5464 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5465 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005466 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005467 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005468};
5469
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005470static const struct usb_action gc0303_60HZScale[] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005471 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005472 {0xaa, 0x83, 0x0000},
5473 {0xaa, 0x84, 0x0076},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005474 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
5475 {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,1,0b,cc, */
5476 {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,2,10,cc, */
5477 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,5,00,cc, */
5478 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,6,00,cc, */
5479 {0xa0, 0x76, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,7,76,cc, */
5480 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,c,0e,cc, */
5481 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,f,15,cc, */
5482 {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,9,10,cc, */
5483 {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,a,24,cc, */
5484 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,d,62,cc, */
5485 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,e,90,cc, */
5486 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,f,c8,cc, */
5487 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,0,ff,cc, */
5488 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,d,58,cc, */
5489 {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005490 {0xa0, 0x80, ZC3XX_R18D_YTARGET},
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005491 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005492};
5493
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005494static const struct usb_action gc0303_NoFliker[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005495 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005496 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5497 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
5498 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005499 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,0,00,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005500 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},
5501 {0xa0, 0x48, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005502 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5503 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5504 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc, */
5505 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5506 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5507 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5508 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5509 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5510 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5511 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5512 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005513 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005514};
5515
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005516static const struct usb_action gc0303_NoFlikerScale[] = {
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005517 {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc, */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005518 {0xaa, 0x82, 0x0000}, /* 00,82,00,aa */
5519 {0xaa, 0x83, 0x0000}, /* 00,83,00,aa */
5520 {0xaa, 0x84, 0x0020}, /* 00,84,20,aa */
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005521 {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc, */
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005522 {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},
5523 {0xa0, 0x48, ZC3XX_R192_EXPOSURELIMITLOW},
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03005524 {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc, */
5525 {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc, */
5526 {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc, */
5527 {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0e,cc, */
5528 {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,15,cc, */
5529 {0xa0, 0x62, ZC3XX_R01D_HSYNC_0}, /* 00,1d,62,cc, */
5530 {0xa0, 0x90, ZC3XX_R01E_HSYNC_1}, /* 00,1e,90,cc, */
5531 {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,c8,cc, */
5532 {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc, */
5533 {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc, */
5534 {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,03,cc */
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005535 {}
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005536};
5537
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005538static u8 reg_r(struct gspca_dev *gspca_dev,
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005539 u16 index)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005540{
Jean-François Moine6d314502010-08-04 05:44:13 -03005541 int ret;
5542
5543 if (gspca_dev->usb_err < 0)
5544 return 0;
5545 ret = usb_control_msg(gspca_dev->dev,
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005546 usb_rcvctrlpipe(gspca_dev->dev, 0),
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005547 0xa1,
5548 USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5549 0x01, /* value */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005550 index, gspca_dev->usb_buf, 1,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005551 500);
Jean-François Moine6d314502010-08-04 05:44:13 -03005552 if (ret < 0) {
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005553 pr_err("reg_r err %d\n", ret);
Jean-François Moine6d314502010-08-04 05:44:13 -03005554 gspca_dev->usb_err = ret;
5555 return 0;
5556 }
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005557 return gspca_dev->usb_buf[0];
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005558}
5559
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005560static void reg_w(struct gspca_dev *gspca_dev,
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005561 u8 value,
5562 u16 index)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005563{
Jean-François Moine6d314502010-08-04 05:44:13 -03005564 int ret;
5565
5566 if (gspca_dev->usb_err < 0)
5567 return;
5568 ret = usb_control_msg(gspca_dev->dev,
5569 usb_sndctrlpipe(gspca_dev->dev, 0),
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005570 0xa0,
5571 USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5572 value, index, NULL, 0,
5573 500);
Jean-François Moine6d314502010-08-04 05:44:13 -03005574 if (ret < 0) {
Joe Perches133a9fe2011-08-21 19:56:57 -03005575 pr_err("reg_w_i err %d\n", ret);
Jean-François Moine6d314502010-08-04 05:44:13 -03005576 gspca_dev->usb_err = ret;
5577 }
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005578}
5579
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005580static u16 i2c_read(struct gspca_dev *gspca_dev,
5581 u8 reg)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005582{
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005583 u8 retbyte;
5584 u16 retval;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005585
Jean-François Moine6d314502010-08-04 05:44:13 -03005586 if (gspca_dev->usb_err < 0)
5587 return 0;
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005588 reg_w(gspca_dev, reg, 0x0092);
5589 reg_w(gspca_dev, 0x02, 0x0090); /* <- read command */
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03005590 msleep(20);
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005591 retbyte = reg_r(gspca_dev, 0x0091); /* read status */
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03005592 if (retbyte != 0x00)
Joe Perches133a9fe2011-08-21 19:56:57 -03005593 pr_err("i2c_r status error %02x\n", retbyte);
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005594 retval = reg_r(gspca_dev, 0x0095); /* read Lowbyte */
5595 retval |= reg_r(gspca_dev, 0x0096) << 8; /* read Hightbyte */
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03005596 return retval;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005597}
5598
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005599static u8 i2c_write(struct gspca_dev *gspca_dev,
5600 u8 reg,
5601 u8 valL,
5602 u8 valH)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005603{
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005604 u8 retbyte;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005605
Jean-François Moine6d314502010-08-04 05:44:13 -03005606 if (gspca_dev->usb_err < 0)
5607 return 0;
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005608 reg_w(gspca_dev, reg, 0x92);
5609 reg_w(gspca_dev, valL, 0x93);
5610 reg_w(gspca_dev, valH, 0x94);
5611 reg_w(gspca_dev, 0x01, 0x90); /* <- write command */
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03005612 msleep(1);
Jean-François Moine1b3b2122012-02-27 07:51:09 -03005613 retbyte = reg_r(gspca_dev, 0x0091); /* read status */
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03005614 if (retbyte != 0x00)
Joe Perches133a9fe2011-08-21 19:56:57 -03005615 pr_err("i2c_w status error %02x\n", retbyte);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005616 return retbyte;
5617}
5618
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005619static void usb_exchange(struct gspca_dev *gspca_dev,
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03005620 const struct usb_action *action)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005621{
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005622 while (action->req) {
5623 switch (action->req) {
5624 case 0xa0: /* write register */
Jean-François Moine6d314502010-08-04 05:44:13 -03005625 reg_w(gspca_dev, action->val, action->idx);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005626 break;
5627 case 0xa1: /* read status */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005628 reg_r(gspca_dev, action->idx);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005629 break;
5630 case 0xaa:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005631 i2c_write(gspca_dev,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005632 action->val, /* reg */
5633 action->idx & 0xff, /* valL */
5634 action->idx >> 8); /* valH */
5635 break;
Jean-Francois Moine3d221182009-01-19 15:18:44 -03005636 case 0xbb:
5637 i2c_write(gspca_dev,
5638 action->idx >> 8, /* reg */
5639 action->idx & 0xff, /* valL */
5640 action->val); /* valH */
5641 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005642 default:
5643/* case 0xdd: * delay */
Jean-François Moine7c45f2c2011-01-24 15:15:34 -03005644 msleep(action->idx);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005645 break;
5646 }
5647 action++;
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03005648 msleep(1);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005649 }
5650}
5651
5652static void setmatrix(struct gspca_dev *gspca_dev)
5653{
5654 struct sd *sd = (struct sd *) gspca_dev;
5655 int i;
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005656 const u8 *matrix;
Jean-Francois Moine3d221182009-01-19 15:18:44 -03005657 static const u8 adcm2700_matrix[9] =
Jean-Francois Moinec675e792009-01-26 05:29:06 -03005658/* {0x66, 0xed, 0xed, 0xed, 0x66, 0xed, 0xed, 0xed, 0x66}; */
5659/*ms-win*/
5660 {0x74, 0xed, 0xed, 0xed, 0x74, 0xed, 0xed, 0xed, 0x74};
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005661 static const u8 gc0305_matrix[9] =
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005662 {0x50, 0xf8, 0xf8, 0xf8, 0x50, 0xf8, 0xf8, 0xf8, 0x50};
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005663 static const u8 ov7620_matrix[9] =
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005664 {0x58, 0xf4, 0xf4, 0xf4, 0x58, 0xf4, 0xf4, 0xf4, 0x58};
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005665 static const u8 pas202b_matrix[9] =
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03005666 {0x4c, 0xf5, 0xff, 0xf9, 0x51, 0xf5, 0xfb, 0xed, 0x5f};
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005667 static const u8 po2030_matrix[9] =
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005668 {0x60, 0xf0, 0xf0, 0xf0, 0x60, 0xf0, 0xf0, 0xf0, 0x60};
Jean-Francois Moine013db752009-10-07 05:24:19 -03005669 static const u8 tas5130c_matrix[9] =
5670 {0x68, 0xec, 0xec, 0xec, 0x68, 0xec, 0xec, 0xec, 0x68};
Jean-François Moine7fbee992010-12-28 07:17:40 -03005671 static const u8 gc0303_matrix[9] =
Jean-François Moine885f3ca2011-11-30 06:48:38 -03005672 {0x6c, 0xea, 0xea, 0xea, 0x6c, 0xea, 0xea, 0xea, 0x6c};
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005673 static const u8 *matrix_tb[SENSOR_MAX] = {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005674 [SENSOR_ADCM2700] = adcm2700_matrix,
5675 [SENSOR_CS2102] = ov7620_matrix,
5676 [SENSOR_CS2102K] = NULL,
Jean-François Moine7fbee992010-12-28 07:17:40 -03005677 [SENSOR_GC0303] = gc0303_matrix,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005678 [SENSOR_GC0305] = gc0305_matrix,
Jean-François Moine4e5144e2011-02-26 13:56:20 -03005679 [SENSOR_HDCS2020] = NULL,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005680 [SENSOR_HV7131B] = NULL,
Jean-François Moine3d244062011-01-24 16:22:11 -03005681 [SENSOR_HV7131R] = po2030_matrix,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005682 [SENSOR_ICM105A] = po2030_matrix,
5683 [SENSOR_MC501CB] = NULL,
Jean-François Moinea484dd92010-08-04 07:25:12 -03005684 [SENSOR_MT9V111_1] = gc0305_matrix,
5685 [SENSOR_MT9V111_3] = gc0305_matrix,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005686 [SENSOR_OV7620] = ov7620_matrix,
5687 [SENSOR_OV7630C] = NULL,
5688 [SENSOR_PAS106] = NULL,
5689 [SENSOR_PAS202B] = pas202b_matrix,
5690 [SENSOR_PB0330] = gc0305_matrix,
5691 [SENSOR_PO2030] = po2030_matrix,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005692 [SENSOR_TAS5130C] = tas5130c_matrix,
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03005693 };
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005694
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03005695 matrix = matrix_tb[sd->sensor];
5696 if (matrix == NULL)
5697 return; /* matrix already loaded */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005698 for (i = 0; i < ARRAY_SIZE(ov7620_matrix); i++)
Jean-François Moine6d314502010-08-04 05:44:13 -03005699 reg_w(gspca_dev, matrix[i], 0x010a + i);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005700}
5701
Hans Verkuilc06ba282012-05-06 09:28:28 -03005702static void setsharpness(struct gspca_dev *gspca_dev, s32 val)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005703{
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005704 static const u8 sharpness_tb[][2] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005705 {0x02, 0x03},
5706 {0x04, 0x07},
5707 {0x08, 0x0f},
5708 {0x10, 0x1e}
5709 };
5710
Hans Verkuilc06ba282012-05-06 09:28:28 -03005711 reg_w(gspca_dev, sharpness_tb[val][0], 0x01c6);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03005712 reg_r(gspca_dev, 0x01c8);
5713 reg_r(gspca_dev, 0x01c9);
5714 reg_r(gspca_dev, 0x01ca);
Hans Verkuilc06ba282012-05-06 09:28:28 -03005715 reg_w(gspca_dev, sharpness_tb[val][1], 0x01cb);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005716}
5717
Hans Verkuilc06ba282012-05-06 09:28:28 -03005718static void setcontrast(struct gspca_dev *gspca_dev,
5719 s32 gamma, s32 brightness, s32 contrast)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005720{
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005721 const u8 *Tgamma;
Hans Verkuilc06ba282012-05-06 09:28:28 -03005722 int g, i, adj, gp1, gp2;
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005723 u8 gr[16];
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005724 static const u8 delta_b[16] = /* delta for brightness */
5725 {0x50, 0x38, 0x2d, 0x28, 0x24, 0x21, 0x1e, 0x1d,
5726 0x1d, 0x1b, 0x1b, 0x1b, 0x19, 0x18, 0x18, 0x18};
5727 static const u8 delta_c[16] = /* delta for contrast */
Jean-François Moinea8567532010-04-25 15:25:42 -03005728 {0x2c, 0x1a, 0x12, 0x0c, 0x0a, 0x06, 0x06, 0x06,
5729 0x04, 0x06, 0x04, 0x04, 0x03, 0x03, 0x02, 0x02};
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005730 static const u8 gamma_tb[6][16] = {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005731 {0x00, 0x00, 0x03, 0x0d, 0x1b, 0x2e, 0x45, 0x5f,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005732 0x79, 0x93, 0xab, 0xc1, 0xd4, 0xe5, 0xf3, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005733 {0x01, 0x0c, 0x1f, 0x3a, 0x53, 0x6d, 0x85, 0x9c,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005734 0xb0, 0xc2, 0xd1, 0xde, 0xe9, 0xf2, 0xf9, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005735 {0x04, 0x16, 0x30, 0x4e, 0x68, 0x81, 0x98, 0xac,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005736 0xbe, 0xcd, 0xda, 0xe4, 0xed, 0xf5, 0xfb, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005737 {0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005738 0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005739 {0x20, 0x4b, 0x6e, 0x8d, 0xa3, 0xb5, 0xc5, 0xd2,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005740 0xdc, 0xe5, 0xec, 0xf2, 0xf6, 0xfa, 0xfd, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005741 {0x24, 0x44, 0x64, 0x84, 0x9d, 0xb2, 0xc4, 0xd3,
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005742 0xe0, 0xeb, 0xf4, 0xff, 0xff, 0xff, 0xff, 0xff},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005743 };
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005744
Hans Verkuilc06ba282012-05-06 09:28:28 -03005745 Tgamma = gamma_tb[gamma - 1];
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005746
Hans Verkuilc06ba282012-05-06 09:28:28 -03005747 contrast -= 128; /* -128 / 127 */
5748 brightness -= 128; /* -128 / 92 */
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005749 adj = 0;
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005750 gp1 = gp2 = 0;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005751 for (i = 0; i < 16; i++) {
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005752 g = Tgamma[i] + delta_b[i] * brightness / 256
5753 - delta_c[i] * contrast / 256 - adj / 2;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005754 if (g > 0xff)
5755 g = 0xff;
Jean-François Moinea8567532010-04-25 15:25:42 -03005756 else if (g < 0)
5757 g = 0;
Jean-François Moine6d314502010-08-04 05:44:13 -03005758 reg_w(gspca_dev, g, 0x0120 + i); /* gamma */
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005759 if (contrast > 0)
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005760 adj--;
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005761 else if (contrast < 0)
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005762 adj++;
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005763 if (i > 1)
5764 gr[i - 1] = (g - gp2) / 2;
5765 else if (i != 0)
5766 gr[0] = gp1 == 0 ? 0 : (g - gp1);
5767 gp2 = gp1;
5768 gp1 = g;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005769 }
Jean-François Moinea9dfc012010-06-04 06:21:48 -03005770 gr[15] = (0xff - gp2) / 2;
Jean-Francois Moinefd180462010-01-04 15:54:59 -03005771 for (i = 0; i < 16; i++)
Jean-François Moine6d314502010-08-04 05:44:13 -03005772 reg_w(gspca_dev, gr[i], 0x0130 + i); /* gradient */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005773}
5774
Hans Verkuilc06ba282012-05-06 09:28:28 -03005775static s32 getexposure(struct gspca_dev *gspca_dev)
Jean-François Moine590f2162011-03-22 06:47:56 -03005776{
Ondrej Zary6f92c3a2018-05-25 05:08:41 -04005777 struct sd *sd = (struct sd *) gspca_dev;
5778
5779 switch (sd->sensor) {
5780 case SENSOR_HV7131R:
5781 return (i2c_read(gspca_dev, 0x25) << 9)
5782 | (i2c_read(gspca_dev, 0x26) << 1)
5783 | (i2c_read(gspca_dev, 0x27) >> 7);
5784 case SENSOR_OV7620:
5785 return i2c_read(gspca_dev, 0x10);
5786 default:
5787 return -1;
5788 }
Jean-François Moine590f2162011-03-22 06:47:56 -03005789}
5790
Hans Verkuilc06ba282012-05-06 09:28:28 -03005791static void setexposure(struct gspca_dev *gspca_dev, s32 val)
Jean-François Moine590f2162011-03-22 06:47:56 -03005792{
Ondrej Zary6f92c3a2018-05-25 05:08:41 -04005793 struct sd *sd = (struct sd *) gspca_dev;
5794
5795 switch (sd->sensor) {
5796 case SENSOR_HV7131R:
5797 i2c_write(gspca_dev, 0x25, val >> 9, 0x00);
5798 i2c_write(gspca_dev, 0x26, val >> 1, 0x00);
5799 i2c_write(gspca_dev, 0x27, val << 7, 0x00);
5800 break;
5801 case SENSOR_OV7620:
5802 i2c_write(gspca_dev, 0x10, val, 0x00);
5803 break;
5804 }
Jean-François Moine590f2162011-03-22 06:47:56 -03005805}
5806
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005807static void setquality(struct gspca_dev *gspca_dev)
5808{
5809 struct sd *sd = (struct sd *) gspca_dev;
Hans de Goede83fb2e22012-05-06 09:28:24 -03005810 jpeg_set_qual(sd->jpeg_hdr, jpeg_qual[sd->reg08 >> 1]);
Jean-François Moine30c73d42012-02-27 07:26:30 -03005811 reg_w(gspca_dev, sd->reg08, ZC3XX_R008_CLOCKSETTING);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005812}
5813
5814/* Matches the sensor's internal frame rate to the lighting frequency.
5815 * Valid frequencies are:
5816 * 50Hz, for European and Asian lighting (default)
5817 * 60Hz, for American lighting
5818 * 0 = No Fliker (for outdoore usage)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005819 */
Hans Verkuilc06ba282012-05-06 09:28:28 -03005820static void setlightfreq(struct gspca_dev *gspca_dev, s32 val)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005821{
5822 struct sd *sd = (struct sd *) gspca_dev;
5823 int i, mode;
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03005824 const struct usb_action *zc3_freq;
5825 static const struct usb_action *freq_tb[SENSOR_MAX][6] = {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005826 [SENSOR_ADCM2700] =
Jean-Francois Moinec314b532009-01-20 10:02:35 -03005827 {adcm2700_NoFliker, adcm2700_NoFliker,
5828 adcm2700_50HZ, adcm2700_50HZ,
5829 adcm2700_60HZ, adcm2700_60HZ},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005830 [SENSOR_CS2102] =
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005831 {cs2102_NoFliker, cs2102_NoFlikerScale,
5832 cs2102_50HZ, cs2102_50HZScale,
5833 cs2102_60HZ, cs2102_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005834 [SENSOR_CS2102K] =
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005835 {cs2102_NoFliker, cs2102_NoFlikerScale,
Costantino Leandro5be8b73e2008-09-09 04:32:46 -03005836 NULL, NULL, /* currently disabled */
5837 NULL, NULL},
Jean-François Moine7fbee992010-12-28 07:17:40 -03005838 [SENSOR_GC0303] =
5839 {gc0303_NoFliker, gc0303_NoFlikerScale,
5840 gc0303_50HZ, gc0303_50HZScale,
5841 gc0303_60HZ, gc0303_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005842 [SENSOR_GC0305] =
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005843 {gc0305_NoFliker, gc0305_NoFliker,
5844 gc0305_50HZ, gc0305_50HZ,
5845 gc0305_60HZ, gc0305_60HZ},
Jean-François Moine4e5144e2011-02-26 13:56:20 -03005846 [SENSOR_HDCS2020] =
5847 {hdcs2020_NoFliker, hdcs2020_NoFliker,
5848 hdcs2020_50HZ, hdcs2020_50HZ,
5849 hdcs2020_60HZ, hdcs2020_60HZ},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005850 [SENSOR_HV7131B] =
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005851 {hv7131b_NoFliker, hv7131b_NoFlikerScale,
5852 hv7131b_50HZ, hv7131b_50HZScale,
5853 hv7131b_60HZ, hv7131b_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005854 [SENSOR_HV7131R] =
Jean-François Moine2af0b4c2010-08-04 07:12:57 -03005855 {hv7131r_NoFliker, hv7131r_NoFlikerScale,
5856 hv7131r_50HZ, hv7131r_50HZScale,
5857 hv7131r_60HZ, hv7131r_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005858 [SENSOR_ICM105A] =
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005859 {icm105a_NoFliker, icm105a_NoFlikerScale,
5860 icm105a_50HZ, icm105a_50HZScale,
5861 icm105a_60HZ, icm105a_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005862 [SENSOR_MC501CB] =
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005863 {mc501cb_NoFliker, mc501cb_NoFlikerScale,
5864 mc501cb_50HZ, mc501cb_50HZScale,
5865 mc501cb_60HZ, mc501cb_60HZScale},
Jean-François Moinea484dd92010-08-04 07:25:12 -03005866 [SENSOR_MT9V111_1] =
5867 {mt9v111_1_AENoFliker, mt9v111_1_AENoFlikerScale,
5868 mt9v111_1_AE50HZ, mt9v111_1_AE50HZScale,
5869 mt9v111_1_AE60HZ, mt9v111_1_AE60HZScale},
5870 [SENSOR_MT9V111_3] =
5871 {mt9v111_3_AENoFliker, mt9v111_3_AENoFlikerScale,
5872 mt9v111_3_AE50HZ, mt9v111_3_AE50HZScale,
5873 mt9v111_3_AE60HZ, mt9v111_3_AE60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005874 [SENSOR_OV7620] =
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005875 {ov7620_NoFliker, ov7620_NoFliker,
5876 ov7620_50HZ, ov7620_50HZ,
5877 ov7620_60HZ, ov7620_60HZ},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005878 [SENSOR_OV7630C] =
Harvey Harrisonefab8212008-07-05 06:12:47 -03005879 {NULL, NULL,
5880 NULL, NULL,
5881 NULL, NULL},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005882 [SENSOR_PAS106] =
Jean-Francois Moine6a7eba22008-06-30 15:50:11 -03005883 {pas106b_NoFliker, pas106b_NoFliker,
5884 pas106b_50HZ, pas106b_50HZ,
5885 pas106b_60HZ, pas106b_60HZ},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005886 [SENSOR_PAS202B] =
Jean-François Moinea6a86f0d2010-04-25 14:57:10 -03005887 {pas202b_NoFliker, pas202b_NoFlikerScale,
5888 pas202b_50HZ, pas202b_50HZScale,
5889 pas202b_60HZ, pas202b_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005890 [SENSOR_PB0330] =
Jean-François Moinea6a86f0d2010-04-25 14:57:10 -03005891 {pb0330_NoFliker, pb0330_NoFlikerScale,
5892 pb0330_50HZ, pb0330_50HZScale,
5893 pb0330_60HZ, pb0330_60HZScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005894 [SENSOR_PO2030] =
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005895 {po2030_NoFliker, po2030_NoFliker,
5896 po2030_50HZ, po2030_50HZ,
5897 po2030_60HZ, po2030_60HZ},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005898 [SENSOR_TAS5130C] =
5899 {tas5130c_NoFliker, tas5130c_NoFlikerScale,
5900 tas5130c_50HZ, tas5130c_50HZScale,
5901 tas5130c_60HZ, tas5130c_60HZScale},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005902 };
5903
Hans Verkuilc06ba282012-05-06 09:28:28 -03005904 i = val * 2;
Jean-François Moine49fb5e62010-12-28 07:09:34 -03005905 mode = gspca_dev->cam.cam_mode[gspca_dev->curr_mode].priv;
Jean-Francois Moine1cb6d7b12010-01-08 07:06:06 -03005906 if (mode)
5907 i++; /* 320x240 */
Jean-Francois Moine47c833922010-01-07 15:59:12 -03005908 zc3_freq = freq_tb[sd->sensor][i];
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005909 if (zc3_freq == NULL)
Jean-François Moine6d314502010-08-04 05:44:13 -03005910 return;
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005911 usb_exchange(gspca_dev, zc3_freq);
5912 switch (sd->sensor) {
5913 case SENSOR_GC0305:
Hans Verkuilc06ba282012-05-06 09:28:28 -03005914 if (mode /* if 320x240 */
5915 && val == 1) /* and 50Hz */
Jean-François Moine6d314502010-08-04 05:44:13 -03005916 reg_w(gspca_dev, 0x85, 0x018d);
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005917 /* win: 0x80, 0x018d */
5918 break;
5919 case SENSOR_OV7620:
Hans Verkuilc06ba282012-05-06 09:28:28 -03005920 if (!mode) { /* if 640x480 */
5921 if (val != 0) /* and filter */
Jean-François Moine6d314502010-08-04 05:44:13 -03005922 reg_w(gspca_dev, 0x40, 0x0002);
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005923 else
Jean-François Moine6d314502010-08-04 05:44:13 -03005924 reg_w(gspca_dev, 0x44, 0x0002);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005925 }
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005926 break;
5927 case SENSOR_PAS202B:
Jean-François Moine6d314502010-08-04 05:44:13 -03005928 reg_w(gspca_dev, 0x00, 0x01a7);
Jean-François Moine83d1aa32010-08-04 05:11:23 -03005929 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005930 }
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005931}
5932
Hans Verkuilc06ba282012-05-06 09:28:28 -03005933static void setautogain(struct gspca_dev *gspca_dev, s32 val)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005934{
Ondrej Zary6f92c3a2018-05-25 05:08:41 -04005935 struct sd *sd = (struct sd *) gspca_dev;
5936
5937 if (sd->sensor == SENSOR_OV7620)
5938 i2c_write(gspca_dev, 0x13, val ? 0xa3 : 0x80, 0x00);
5939 else
5940 reg_w(gspca_dev, val ? 0x42 : 0x02, 0x0180);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03005941}
5942
Hans de Goede55db7652012-05-06 09:28:25 -03005943/*
5944 * Update the transfer parameters.
5945 * This function is executed from a work queue.
5946 */
Jean-François Moinef1801902012-02-27 07:48:32 -03005947static void transfer_update(struct work_struct *work)
5948{
5949 struct sd *sd = container_of(work, struct sd, work);
5950 struct gspca_dev *gspca_dev = &sd->gspca_dev;
5951 int change, good;
Hans de Goede55db7652012-05-06 09:28:25 -03005952 u8 reg07, reg11;
Jean-François Moinef1801902012-02-27 07:48:32 -03005953
Hans de Goede55db7652012-05-06 09:28:25 -03005954 /* reg07 gets set to 0 by sd_start before starting us */
5955 reg07 = 0;
Jean-François Moinef1801902012-02-27 07:48:32 -03005956
5957 good = 0;
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03005958 while (1) {
Jean-François Moinef1801902012-02-27 07:48:32 -03005959 msleep(100);
5960
Hans de Goede844db452012-09-09 07:30:02 -03005961 /* To protect gspca_dev->usb_buf and gspca_dev->usb_err */
Jean-François Moinef1801902012-02-27 07:48:32 -03005962 mutex_lock(&gspca_dev->usb_lock);
Hans Verkuil4ad34da2012-05-18 08:40:42 -03005963#ifdef CONFIG_PM
5964 if (gspca_dev->frozen)
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03005965 break;
Hans Verkuil4ad34da2012-05-18 08:40:42 -03005966#endif
Hans de Goede345321d2012-09-09 06:30:02 -03005967 if (!gspca_dev->present || !gspca_dev->streaming)
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03005968 break;
Hans de Goede55db7652012-05-06 09:28:25 -03005969
5970 /* Bit 0 of register 11 indicates FIFO overflow */
5971 gspca_dev->usb_err = 0;
Jean-François Moinef1801902012-02-27 07:48:32 -03005972 reg11 = reg_r(gspca_dev, 0x0011);
Hans de Goede55db7652012-05-06 09:28:25 -03005973 if (gspca_dev->usb_err)
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03005974 break;
Jean-François Moinef1801902012-02-27 07:48:32 -03005975
5976 change = reg11 & 0x01;
5977 if (change) { /* overflow */
Jean-François Moinef1801902012-02-27 07:48:32 -03005978 good = 0;
Hans de Goede55db7652012-05-06 09:28:25 -03005979
5980 if (reg07 == 0) /* Bit Rate Control not enabled? */
5981 reg07 = 0x32; /* Allow 98 bytes / unit */
5982 else if (reg07 > 2)
5983 reg07 -= 2; /* Decrease allowed bytes / unit */
5984 else
5985 change = 0;
Jean-François Moinef1801902012-02-27 07:48:32 -03005986 } else { /* no overflow */
Hans de Goede55db7652012-05-06 09:28:25 -03005987 good++;
5988 if (good >= 10) {
5989 good = 0;
5990 if (reg07) { /* BRC enabled? */
Jean-François Moinef1801902012-02-27 07:48:32 -03005991 change = 1;
Hans de Goede55db7652012-05-06 09:28:25 -03005992 if (reg07 < 0x32)
5993 reg07 += 2;
5994 else
Jean-François Moinef1801902012-02-27 07:48:32 -03005995 reg07 = 0;
Jean-François Moinef1801902012-02-27 07:48:32 -03005996 }
5997 }
5998 }
5999 if (change) {
Hans de Goede55db7652012-05-06 09:28:25 -03006000 gspca_dev->usb_err = 0;
6001 reg_w(gspca_dev, reg07, 0x0007);
6002 if (gspca_dev->usb_err)
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03006003 break;
Jean-François Moinef1801902012-02-27 07:48:32 -03006004 }
6005 mutex_unlock(&gspca_dev->usb_lock);
6006 }
Mauro Carvalho Chehab094af362015-04-28 19:49:07 -03006007
6008 /* Something went wrong. Unlock and return */
Jean-François Moinef1801902012-02-27 07:48:32 -03006009 mutex_unlock(&gspca_dev->usb_lock);
6010}
6011
Jean-François Moine6d314502010-08-04 05:44:13 -03006012static void send_unknown(struct gspca_dev *gspca_dev, int sensor)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006013{
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006014 reg_w(gspca_dev, 0x01, 0x0000); /* bridge reset */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006015 switch (sensor) {
6016 case SENSOR_PAS106:
Jean-François Moine6d314502010-08-04 05:44:13 -03006017 reg_w(gspca_dev, 0x03, 0x003a);
6018 reg_w(gspca_dev, 0x0c, 0x003b);
6019 reg_w(gspca_dev, 0x08, 0x0038);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006020 break;
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006021 case SENSOR_ADCM2700:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006022 case SENSOR_GC0305:
6023 case SENSOR_OV7620:
Jean-François Moinea484dd92010-08-04 07:25:12 -03006024 case SENSOR_MT9V111_1:
6025 case SENSOR_MT9V111_3:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006026 case SENSOR_PB0330:
6027 case SENSOR_PO2030:
Jean-François Moine6d314502010-08-04 05:44:13 -03006028 reg_w(gspca_dev, 0x0d, 0x003a);
6029 reg_w(gspca_dev, 0x02, 0x003b);
6030 reg_w(gspca_dev, 0x00, 0x0038);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006031 break;
Jean-François Moine3d244062011-01-24 16:22:11 -03006032 case SENSOR_HV7131R:
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006033 case SENSOR_PAS202B:
Jean-François Moine6d314502010-08-04 05:44:13 -03006034 reg_w(gspca_dev, 0x03, 0x003b);
6035 reg_w(gspca_dev, 0x0c, 0x003a);
6036 reg_w(gspca_dev, 0x0b, 0x0039);
Jean-François Moine3d244062011-01-24 16:22:11 -03006037 if (sensor == SENSOR_PAS202B)
6038 reg_w(gspca_dev, 0x0b, 0x0038);
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006039 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006040 }
6041}
6042
6043/* start probe 2 wires */
Jean-François Moine6d314502010-08-04 05:44:13 -03006044static void start_2wr_probe(struct gspca_dev *gspca_dev, int sensor)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006045{
Jean-François Moine6d314502010-08-04 05:44:13 -03006046 reg_w(gspca_dev, 0x01, 0x0000);
6047 reg_w(gspca_dev, sensor, 0x0010);
6048 reg_w(gspca_dev, 0x01, 0x0001);
6049 reg_w(gspca_dev, 0x03, 0x0012);
6050 reg_w(gspca_dev, 0x01, 0x0012);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006051/* msleep(2); */
6052}
6053
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006054static int sif_probe(struct gspca_dev *gspca_dev)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006055{
Jean-Francois Moine47c833922010-01-07 15:59:12 -03006056 u16 checkword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006057
Jean-François Moine6d314502010-08-04 05:44:13 -03006058 start_2wr_probe(gspca_dev, 0x0f); /* PAS106 */
6059 reg_w(gspca_dev, 0x08, 0x008d);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006060 msleep(150);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006061 checkword = ((i2c_read(gspca_dev, 0x00) & 0x0f) << 4)
6062 | ((i2c_read(gspca_dev, 0x01) & 0xf0) >> 4);
Joe Perches37d5efb2017-09-22 15:20:33 -04006063 gspca_dbg(gspca_dev, D_PROBE, "probe sif 0x%04x\n", checkword);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006064 if (checkword == 0x0007) {
Jean-François Moine6d314502010-08-04 05:44:13 -03006065 send_unknown(gspca_dev, SENSOR_PAS106);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006066 return 0x0f; /* PAS106 */
6067 }
6068 return -1;
6069}
6070
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006071static int vga_2wr_probe(struct gspca_dev *gspca_dev)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006072{
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006073 u16 retword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006074
Jean-François Moine6d314502010-08-04 05:44:13 -03006075 start_2wr_probe(gspca_dev, 0x00); /* HV7131B */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006076 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006077 retword = i2c_read(gspca_dev, 0x01);
6078 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006079 return 0x00; /* HV7131B */
6080
Jean-François Moine6d314502010-08-04 05:44:13 -03006081 start_2wr_probe(gspca_dev, 0x04); /* CS2102 */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006082 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006083 retword = i2c_read(gspca_dev, 0x01);
6084 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006085 return 0x04; /* CS2102 */
6086
Jean-François Moine6d314502010-08-04 05:44:13 -03006087 start_2wr_probe(gspca_dev, 0x06); /* OmniVision */
6088 reg_w(gspca_dev, 0x08, 0x008d);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006089 i2c_write(gspca_dev, 0x11, 0xaa, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006090 retword = i2c_read(gspca_dev, 0x11);
6091 if (retword != 0) {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006092 /* (should have returned 0xaa) --> Omnivision? */
6093 /* reg_r 0x10 -> 0x06 --> */
6094 goto ov_check;
6095 }
6096
Jean-François Moine6d314502010-08-04 05:44:13 -03006097 start_2wr_probe(gspca_dev, 0x08); /* HDCS2020 */
Jean-Francois Moine1eed40a2010-01-08 08:01:43 -03006098 i2c_write(gspca_dev, 0x1c, 0x00, 0x00);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006099 i2c_write(gspca_dev, 0x15, 0xaa, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006100 retword = i2c_read(gspca_dev, 0x15);
6101 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006102 return 0x08; /* HDCS2020 */
6103
Jean-François Moine6d314502010-08-04 05:44:13 -03006104 start_2wr_probe(gspca_dev, 0x0a); /* PB0330 */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006105 i2c_write(gspca_dev, 0x07, 0xaa, 0xaa);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006106 retword = i2c_read(gspca_dev, 0x07);
6107 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006108 return 0x0a; /* PB0330 */
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006109 retword = i2c_read(gspca_dev, 0x03);
6110 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006111 return 0x0a; /* PB0330 ?? */
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006112 retword = i2c_read(gspca_dev, 0x04);
6113 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006114 return 0x0a; /* PB0330 ?? */
6115
Jean-François Moine6d314502010-08-04 05:44:13 -03006116 start_2wr_probe(gspca_dev, 0x0c); /* ICM105A */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006117 i2c_write(gspca_dev, 0x01, 0x11, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006118 retword = i2c_read(gspca_dev, 0x01);
6119 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006120 return 0x0c; /* ICM105A */
6121
Jean-François Moine6d314502010-08-04 05:44:13 -03006122 start_2wr_probe(gspca_dev, 0x0e); /* PAS202BCB */
6123 reg_w(gspca_dev, 0x08, 0x008d);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006124 i2c_write(gspca_dev, 0x03, 0xaa, 0x00);
Jean-Francois Moine721ecbc2009-10-20 05:25:16 -03006125 msleep(50);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006126 retword = i2c_read(gspca_dev, 0x03);
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006127 if (retword != 0) {
Jean-François Moine6d314502010-08-04 05:44:13 -03006128 send_unknown(gspca_dev, SENSOR_PAS202B);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006129 return 0x0e; /* PAS202BCB */
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006130 }
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006131
Jean-François Moine6d314502010-08-04 05:44:13 -03006132 start_2wr_probe(gspca_dev, 0x02); /* TAS5130C */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006133 i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006134 retword = i2c_read(gspca_dev, 0x01);
6135 if (retword != 0)
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03006136 return 0x02; /* TAS5130C */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006137ov_check:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006138 reg_r(gspca_dev, 0x0010); /* ?? */
6139 reg_r(gspca_dev, 0x0010);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006140
Jean-François Moine6d314502010-08-04 05:44:13 -03006141 reg_w(gspca_dev, 0x01, 0x0000);
6142 reg_w(gspca_dev, 0x01, 0x0001);
6143 reg_w(gspca_dev, 0x06, 0x0010); /* OmniVision */
6144 reg_w(gspca_dev, 0xa1, 0x008b);
6145 reg_w(gspca_dev, 0x08, 0x008d);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006146 msleep(500);
Jean-François Moine6d314502010-08-04 05:44:13 -03006147 reg_w(gspca_dev, 0x01, 0x0012);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006148 i2c_write(gspca_dev, 0x12, 0x80, 0x00); /* sensor reset */
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006149 retword = i2c_read(gspca_dev, 0x0a) << 8;
6150 retword |= i2c_read(gspca_dev, 0x0b);
Joe Perches37d5efb2017-09-22 15:20:33 -04006151 gspca_dbg(gspca_dev, D_PROBE, "probe 2wr ov vga 0x%04x\n", retword);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006152 switch (retword) {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006153 case 0x7631: /* OV7630C */
Jean-François Moine6d314502010-08-04 05:44:13 -03006154 reg_w(gspca_dev, 0x06, 0x0010);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006155 break;
6156 case 0x7620: /* OV7620 */
6157 case 0x7648: /* OV7648 */
6158 break;
6159 default:
6160 return -1; /* not OmniVision */
6161 }
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006162 return retword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006163}
6164
6165struct sensor_by_chipset_revision {
Jean-Francois Moine47c833922010-01-07 15:59:12 -03006166 u16 revision;
6167 u8 internal_sensor_id;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006168};
6169static const struct sensor_by_chipset_revision chipset_revision_sensor[] = {
Jean-Francois Moine013db752009-10-07 05:24:19 -03006170 {0xc000, 0x12}, /* TAS5130C */
Jean-François Moinea484dd92010-08-04 07:25:12 -03006171 {0xc001, 0x13}, /* MT9V111 */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006172 {0xe001, 0x13},
6173 {0x8001, 0x13},
6174 {0x8000, 0x14}, /* CS2102K */
Jean-François Moinea484dd92010-08-04 07:25:12 -03006175 {0x8400, 0x15}, /* MT9V111 */
Luis Maia658604e2009-12-15 13:40:44 -03006176 {0xe400, 0x15},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006177};
6178
6179static int vga_3wr_probe(struct gspca_dev *gspca_dev)
6180{
6181 struct sd *sd = (struct sd *) gspca_dev;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006182 int i;
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006183 u16 retword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006184
6185/*fixme: lack of 8b=b3 (11,12)-> 10, 8b=e0 (14,15,16)-> 12 found in gspcav1*/
Jean-François Moine6d314502010-08-04 05:44:13 -03006186 reg_w(gspca_dev, 0x02, 0x0010);
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03006187 reg_r(gspca_dev, 0x0010);
Jean-François Moine6d314502010-08-04 05:44:13 -03006188 reg_w(gspca_dev, 0x01, 0x0000);
6189 reg_w(gspca_dev, 0x00, 0x0010);
6190 reg_w(gspca_dev, 0x01, 0x0001);
6191 reg_w(gspca_dev, 0x91, 0x008b);
6192 reg_w(gspca_dev, 0x03, 0x0012);
6193 reg_w(gspca_dev, 0x01, 0x0012);
6194 reg_w(gspca_dev, 0x05, 0x0012);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006195 retword = i2c_read(gspca_dev, 0x14);
6196 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006197 return 0x11; /* HV7131R */
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006198 retword = i2c_read(gspca_dev, 0x15);
6199 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006200 return 0x11; /* HV7131R */
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006201 retword = i2c_read(gspca_dev, 0x16);
6202 if (retword != 0)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006203 return 0x11; /* HV7131R */
6204
Jean-François Moine6d314502010-08-04 05:44:13 -03006205 reg_w(gspca_dev, 0x02, 0x0010);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006206 retword = reg_r(gspca_dev, 0x000b) << 8;
6207 retword |= reg_r(gspca_dev, 0x000a);
Joe Perches37d5efb2017-09-22 15:20:33 -04006208 gspca_dbg(gspca_dev, D_PROBE, "probe 3wr vga 1 0x%04x\n", retword);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006209 reg_r(gspca_dev, 0x0010);
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006210 if ((retword & 0xff00) == 0x6400)
6211 return 0x02; /* TAS5130C */
6212 for (i = 0; i < ARRAY_SIZE(chipset_revision_sensor); i++) {
6213 if (chipset_revision_sensor[i].revision == retword) {
6214 sd->chip_revision = retword;
Jean-François Moine6d314502010-08-04 05:44:13 -03006215 send_unknown(gspca_dev, SENSOR_PB0330);
Jean-François Moine780e3122010-10-19 04:29:10 -03006216 return chipset_revision_sensor[i].internal_sensor_id;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006217 }
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006218 }
6219
Jean-François Moine6d314502010-08-04 05:44:13 -03006220 reg_w(gspca_dev, 0x01, 0x0000); /* check PB0330 */
6221 reg_w(gspca_dev, 0x01, 0x0001);
6222 reg_w(gspca_dev, 0xdd, 0x008b);
6223 reg_w(gspca_dev, 0x0a, 0x0010);
6224 reg_w(gspca_dev, 0x03, 0x0012);
6225 reg_w(gspca_dev, 0x01, 0x0012);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006226 retword = i2c_read(gspca_dev, 0x00);
6227 if (retword != 0) {
Joe Perches37d5efb2017-09-22 15:20:33 -04006228 gspca_dbg(gspca_dev, D_PROBE, "probe 3wr vga type 0a\n");
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03006229 return 0x0a; /* PB0330 */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006230 }
6231
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006232 /* probe gc0303 / gc0305 */
Jean-François Moine6d314502010-08-04 05:44:13 -03006233 reg_w(gspca_dev, 0x01, 0x0000);
6234 reg_w(gspca_dev, 0x01, 0x0001);
6235 reg_w(gspca_dev, 0x98, 0x008b);
6236 reg_w(gspca_dev, 0x01, 0x0010);
6237 reg_w(gspca_dev, 0x03, 0x0012);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006238 msleep(2);
Jean-François Moine6d314502010-08-04 05:44:13 -03006239 reg_w(gspca_dev, 0x01, 0x0012);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006240 retword = i2c_read(gspca_dev, 0x00);
6241 if (retword != 0) {
Joe Perches37d5efb2017-09-22 15:20:33 -04006242 gspca_dbg(gspca_dev, D_PROBE, "probe 3wr vga type %02x\n",
6243 retword);
Jean-François Moine7fbee992010-12-28 07:17:40 -03006244 if (retword == 0x0011) /* gc0303 */
6245 return 0x0303;
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006246 if (retword == 0x0029) /* gc0305 */
Jean-François Moine6d314502010-08-04 05:44:13 -03006247 send_unknown(gspca_dev, SENSOR_GC0305);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006248 return retword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006249 }
6250
Jean-François Moine6d314502010-08-04 05:44:13 -03006251 reg_w(gspca_dev, 0x01, 0x0000); /* check OmniVision */
6252 reg_w(gspca_dev, 0x01, 0x0001);
6253 reg_w(gspca_dev, 0xa1, 0x008b);
6254 reg_w(gspca_dev, 0x08, 0x008d);
6255 reg_w(gspca_dev, 0x06, 0x0010);
6256 reg_w(gspca_dev, 0x01, 0x0012);
6257 reg_w(gspca_dev, 0x05, 0x0012);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006258 if (i2c_read(gspca_dev, 0x1c) == 0x007f /* OV7610 - manufacturer ID */
6259 && i2c_read(gspca_dev, 0x1d) == 0x00a2) {
Jean-François Moine6d314502010-08-04 05:44:13 -03006260 send_unknown(gspca_dev, SENSOR_OV7620);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006261 return 0x06; /* OmniVision confirm ? */
6262 }
6263
Jean-François Moine6d314502010-08-04 05:44:13 -03006264 reg_w(gspca_dev, 0x01, 0x0000);
6265 reg_w(gspca_dev, 0x00, 0x0002);
6266 reg_w(gspca_dev, 0x01, 0x0010);
6267 reg_w(gspca_dev, 0x01, 0x0001);
6268 reg_w(gspca_dev, 0xee, 0x008b);
6269 reg_w(gspca_dev, 0x03, 0x0012);
6270 reg_w(gspca_dev, 0x01, 0x0012);
6271 reg_w(gspca_dev, 0x05, 0x0012);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006272 retword = i2c_read(gspca_dev, 0x00) << 8; /* ID 0 */
6273 retword |= i2c_read(gspca_dev, 0x01); /* ID 1 */
Joe Perches37d5efb2017-09-22 15:20:33 -04006274 gspca_dbg(gspca_dev, D_PROBE, "probe 3wr vga 2 0x%04x\n", retword);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006275 if (retword == 0x2030) {
Jean-François Moinebd62bbc2011-05-17 05:08:59 -03006276 u8 retbyte;
6277
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006278 retbyte = i2c_read(gspca_dev, 0x02); /* revision number */
Joe Perches37d5efb2017-09-22 15:20:33 -04006279 gspca_dbg(gspca_dev, D_PROBE, "sensor PO2030 rev 0x%02x\n",
6280 retbyte);
Theodore Kilgorec93396e2013-02-04 13:17:55 -03006281
Jean-François Moine6d314502010-08-04 05:44:13 -03006282 send_unknown(gspca_dev, SENSOR_PO2030);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006283 return retword;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006284 }
6285
Jean-François Moine6d314502010-08-04 05:44:13 -03006286 reg_w(gspca_dev, 0x01, 0x0000);
6287 reg_w(gspca_dev, 0x0a, 0x0010);
6288 reg_w(gspca_dev, 0xd3, 0x008b);
6289 reg_w(gspca_dev, 0x01, 0x0001);
6290 reg_w(gspca_dev, 0x03, 0x0012);
6291 reg_w(gspca_dev, 0x01, 0x0012);
6292 reg_w(gspca_dev, 0x05, 0x0012);
6293 reg_w(gspca_dev, 0xd3, 0x008b);
Jean-Francois Moine3ab67ba2009-01-08 09:38:45 -03006294 retword = i2c_read(gspca_dev, 0x01);
6295 if (retword != 0) {
Joe Perches37d5efb2017-09-22 15:20:33 -04006296 gspca_dbg(gspca_dev, D_PROBE, "probe 3wr vga type 0a ? ret: %04x\n",
6297 retword);
Jean-Francois Moine881cd412009-04-05 04:01:13 -03006298 return 0x16; /* adcm2700 (6100/6200) */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006299 }
6300 return -1;
6301}
6302
6303static int zcxx_probeSensor(struct gspca_dev *gspca_dev)
6304{
6305 struct sd *sd = (struct sd *) gspca_dev;
Jean-Francois Moine603538a2009-02-19 15:38:31 -03006306 int sensor;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006307
6308 switch (sd->sensor) {
6309 case SENSOR_MC501CB:
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03006310 return -1; /* don't probe */
Jean-François Moine7fbee992010-12-28 07:17:40 -03006311 case SENSOR_GC0303:
Hans de Goede346623422008-09-03 16:47:28 -03006312 /* may probe but with no write in reg 0x0010 */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006313 return -1; /* don't probe */
Hans de Goede346623422008-09-03 16:47:28 -03006314 case SENSOR_PAS106:
6315 sensor = sif_probe(gspca_dev);
6316 if (sensor >= 0)
6317 return sensor;
6318 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006319 }
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006320 sensor = vga_2wr_probe(gspca_dev);
Jean-Francois Moine603538a2009-02-19 15:38:31 -03006321 if (sensor >= 0)
Hans de Goede346623422008-09-03 16:47:28 -03006322 return sensor;
Jean-Francois Moine603538a2009-02-19 15:38:31 -03006323 return vga_3wr_probe(gspca_dev);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006324}
6325
6326/* this function is called at probe time */
6327static int sd_config(struct gspca_dev *gspca_dev,
6328 const struct usb_device_id *id)
6329{
6330 struct sd *sd = (struct sd *) gspca_dev;
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006331
Jean-François Moinea484dd92010-08-04 07:25:12 -03006332 if (id->idProduct == 0x301b)
6333 sd->bridge = BRIDGE_ZC301;
6334 else
6335 sd->bridge = BRIDGE_ZC303;
6336
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006337 /* define some sensors from the vendor/product */
6338 sd->sensor = id->driver_info;
6339
Jean-François Moine30c73d42012-02-27 07:26:30 -03006340 sd->reg08 = REG08_DEF;
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006341
Jean-François Moinef1801902012-02-27 07:48:32 -03006342 INIT_WORK(&sd->work, transfer_update);
6343
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006344 return 0;
6345}
6346
Hans Verkuilc06ba282012-05-06 09:28:28 -03006347static int zcxx_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006348{
Hans de Goedea8a47862012-05-09 11:19:00 -03006349 struct gspca_dev *gspca_dev =
6350 container_of(ctrl->handler, struct gspca_dev, ctrl_handler);
6351 struct sd *sd = (struct sd *)gspca_dev;
Hans Verkuilc06ba282012-05-06 09:28:28 -03006352
6353 switch (ctrl->id) {
6354 case V4L2_CID_AUTOGAIN:
6355 gspca_dev->usb_err = 0;
6356 if (ctrl->val && sd->exposure && gspca_dev->streaming)
6357 sd->exposure->val = getexposure(gspca_dev);
6358 return gspca_dev->usb_err;
6359 }
6360 return -EINVAL;
6361}
6362
6363static int zcxx_s_ctrl(struct v4l2_ctrl *ctrl)
6364{
Hans de Goedea8a47862012-05-09 11:19:00 -03006365 struct gspca_dev *gspca_dev =
6366 container_of(ctrl->handler, struct gspca_dev, ctrl_handler);
6367 struct sd *sd = (struct sd *)gspca_dev;
Hans Verkuilc06ba282012-05-06 09:28:28 -03006368 int i, qual;
6369
6370 gspca_dev->usb_err = 0;
6371
6372 if (ctrl->id == V4L2_CID_JPEG_COMPRESSION_QUALITY) {
6373 qual = sd->reg08 >> 1;
6374
6375 for (i = 0; i < ARRAY_SIZE(jpeg_qual); i++) {
6376 if (ctrl->val <= jpeg_qual[i])
6377 break;
6378 }
Mauro Carvalho Chehabb036f1c2015-04-28 19:39:53 -03006379 if (i == ARRAY_SIZE(jpeg_qual) || (i > 0 && i == qual && ctrl->val < jpeg_qual[i]))
Hans Verkuilc06ba282012-05-06 09:28:28 -03006380 i--;
6381
6382 /* With high quality settings we need max bandwidth */
6383 if (i >= 2 && gspca_dev->streaming &&
6384 !gspca_dev->cam.needs_full_bandwidth)
6385 return -EBUSY;
6386
6387 sd->reg08 = (i << 1) | 1;
6388 ctrl->val = jpeg_qual[i];
6389 }
6390
6391 if (!gspca_dev->streaming)
6392 return 0;
6393
6394 switch (ctrl->id) {
6395 /* gamma/brightness/contrast cluster */
6396 case V4L2_CID_GAMMA:
6397 setcontrast(gspca_dev, sd->gamma->val,
6398 sd->brightness->val, sd->contrast->val);
6399 break;
6400 /* autogain/exposure cluster */
6401 case V4L2_CID_AUTOGAIN:
6402 setautogain(gspca_dev, ctrl->val);
6403 if (!gspca_dev->usb_err && !ctrl->val && sd->exposure)
6404 setexposure(gspca_dev, sd->exposure->val);
6405 break;
6406 case V4L2_CID_POWER_LINE_FREQUENCY:
6407 setlightfreq(gspca_dev, ctrl->val);
6408 break;
6409 case V4L2_CID_SHARPNESS:
6410 setsharpness(gspca_dev, ctrl->val);
6411 break;
6412 case V4L2_CID_JPEG_COMPRESSION_QUALITY:
6413 setquality(gspca_dev);
6414 break;
6415 }
6416 return gspca_dev->usb_err;
6417}
6418
6419static const struct v4l2_ctrl_ops zcxx_ctrl_ops = {
6420 .g_volatile_ctrl = zcxx_g_volatile_ctrl,
6421 .s_ctrl = zcxx_s_ctrl,
6422};
6423
6424static int sd_init_controls(struct gspca_dev *gspca_dev)
6425{
6426 struct sd *sd = (struct sd *)gspca_dev;
Hans de Goedea8a47862012-05-09 11:19:00 -03006427 struct v4l2_ctrl_handler *hdl = &gspca_dev->ctrl_handler;
Jean-Francois Moine47c833922010-01-07 15:59:12 -03006428 static const u8 gamma[SENSOR_MAX] = {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006429 [SENSOR_ADCM2700] = 4,
6430 [SENSOR_CS2102] = 4,
6431 [SENSOR_CS2102K] = 5,
Jean-François Moine7fbee992010-12-28 07:17:40 -03006432 [SENSOR_GC0303] = 3,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006433 [SENSOR_GC0305] = 4,
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006434 [SENSOR_HDCS2020] = 4,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006435 [SENSOR_HV7131B] = 4,
6436 [SENSOR_HV7131R] = 4,
6437 [SENSOR_ICM105A] = 4,
6438 [SENSOR_MC501CB] = 4,
Jean-François Moinea484dd92010-08-04 07:25:12 -03006439 [SENSOR_MT9V111_1] = 4,
6440 [SENSOR_MT9V111_3] = 4,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006441 [SENSOR_OV7620] = 3,
6442 [SENSOR_OV7630C] = 4,
6443 [SENSOR_PAS106] = 4,
6444 [SENSOR_PAS202B] = 4,
6445 [SENSOR_PB0330] = 4,
6446 [SENSOR_PO2030] = 4,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006447 [SENSOR_TAS5130C] = 3,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006448 };
Hans Verkuilc06ba282012-05-06 09:28:28 -03006449
6450 gspca_dev->vdev.ctrl_handler = hdl;
6451 v4l2_ctrl_handler_init(hdl, 8);
6452 sd->brightness = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6453 V4L2_CID_BRIGHTNESS, 0, 255, 1, 128);
6454 sd->contrast = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6455 V4L2_CID_CONTRAST, 0, 255, 1, 128);
6456 sd->gamma = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6457 V4L2_CID_GAMMA, 1, 6, 1, gamma[sd->sensor]);
6458 if (sd->sensor == SENSOR_HV7131R)
6459 sd->exposure = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6460 V4L2_CID_EXPOSURE, 0x30d, 0x493e, 1, 0x927);
Ondrej Zary6f92c3a2018-05-25 05:08:41 -04006461 else if (sd->sensor == SENSOR_OV7620)
6462 sd->exposure = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6463 V4L2_CID_EXPOSURE, 0, 255, 1, 0x41);
Hans Verkuilc06ba282012-05-06 09:28:28 -03006464 sd->autogain = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6465 V4L2_CID_AUTOGAIN, 0, 1, 1, 1);
6466 if (sd->sensor != SENSOR_OV7630C)
6467 sd->plfreq = v4l2_ctrl_new_std_menu(hdl, &zcxx_ctrl_ops,
6468 V4L2_CID_POWER_LINE_FREQUENCY,
6469 V4L2_CID_POWER_LINE_FREQUENCY_60HZ, 0,
6470 V4L2_CID_POWER_LINE_FREQUENCY_DISABLED);
6471 sd->sharpness = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6472 V4L2_CID_SHARPNESS, 0, 3, 1,
6473 sd->sensor == SENSOR_PO2030 ? 0 : 2);
6474 sd->jpegqual = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops,
6475 V4L2_CID_JPEG_COMPRESSION_QUALITY,
6476 jpeg_qual[0], jpeg_qual[ARRAY_SIZE(jpeg_qual) - 1], 1,
6477 jpeg_qual[REG08_DEF >> 1]);
6478 if (hdl->error) {
6479 pr_err("Could not initialize controls\n");
6480 return hdl->error;
6481 }
6482 v4l2_ctrl_cluster(3, &sd->gamma);
Ondrej Zary6f92c3a2018-05-25 05:08:41 -04006483 if (sd->sensor == SENSOR_HV7131R || sd->sensor == SENSOR_OV7620)
Hans Verkuilc06ba282012-05-06 09:28:28 -03006484 v4l2_ctrl_auto_cluster(2, &sd->autogain, 0, true);
6485 return 0;
6486}
6487
6488/* this function is called at probe and resume time */
6489static int sd_init(struct gspca_dev *gspca_dev)
6490{
6491 struct sd *sd = (struct sd *) gspca_dev;
6492 struct cam *cam;
6493 int sensor;
Hans de Goede9919fe82010-01-13 07:12:28 -03006494 static const u8 mode_tb[SENSOR_MAX] = {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006495 [SENSOR_ADCM2700] = 2,
6496 [SENSOR_CS2102] = 1,
6497 [SENSOR_CS2102K] = 1,
Jean-François Moine7fbee992010-12-28 07:17:40 -03006498 [SENSOR_GC0303] = 1,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006499 [SENSOR_GC0305] = 1,
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006500 [SENSOR_HDCS2020] = 1,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006501 [SENSOR_HV7131B] = 1,
6502 [SENSOR_HV7131R] = 1,
6503 [SENSOR_ICM105A] = 1,
6504 [SENSOR_MC501CB] = 2,
Jean-François Moinea484dd92010-08-04 07:25:12 -03006505 [SENSOR_MT9V111_1] = 1,
6506 [SENSOR_MT9V111_3] = 1,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006507 [SENSOR_OV7620] = 2,
6508 [SENSOR_OV7630C] = 1,
6509 [SENSOR_PAS106] = 0,
6510 [SENSOR_PAS202B] = 1,
6511 [SENSOR_PB0330] = 1,
6512 [SENSOR_PO2030] = 1,
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006513 [SENSOR_TAS5130C] = 1,
Hans de Goede9919fe82010-01-13 07:12:28 -03006514 };
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006515
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006516 sensor = zcxx_probeSensor(gspca_dev);
6517 if (sensor >= 0)
Joe Perches37d5efb2017-09-22 15:20:33 -04006518 gspca_dbg(gspca_dev, D_PROBE, "probe sensor -> %04x\n", sensor);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006519 if ((unsigned) force_sensor < SENSOR_MAX) {
6520 sd->sensor = force_sensor;
Joe Perches37d5efb2017-09-22 15:20:33 -04006521 gspca_dbg(gspca_dev, D_PROBE, "sensor forced to %d\n",
6522 force_sensor);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006523 } else {
6524 switch (sensor) {
6525 case -1:
6526 switch (sd->sensor) {
6527 case SENSOR_MC501CB:
Joe Perches37d5efb2017-09-22 15:20:33 -04006528 gspca_dbg(gspca_dev, D_PROBE, "Sensor MC501CB\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006529 break;
Jean-François Moine7fbee992010-12-28 07:17:40 -03006530 case SENSOR_GC0303:
Joe Perches37d5efb2017-09-22 15:20:33 -04006531 gspca_dbg(gspca_dev, D_PROBE, "Sensor GC0303\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006532 break;
6533 default:
Joe Perches133a9fe2011-08-21 19:56:57 -03006534 pr_warn("Unknown sensor - set to TAS5130C\n");
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006535 sd->sensor = SENSOR_TAS5130C;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006536 }
6537 break;
6538 case 0:
Jean-Francois Moined754a6c2009-12-20 05:07:10 -03006539 /* check the sensor type */
6540 sensor = i2c_read(gspca_dev, 0x00);
Joe Perches37d5efb2017-09-22 15:20:33 -04006541 gspca_dbg(gspca_dev, D_PROBE, "Sensor hv7131 type %d\n",
6542 sensor);
Jean-Francois Moined754a6c2009-12-20 05:07:10 -03006543 switch (sensor) {
6544 case 0: /* hv7131b */
6545 case 1: /* hv7131e */
Joe Perches37d5efb2017-09-22 15:20:33 -04006546 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor HV7131B\n");
Jean-Francois Moined754a6c2009-12-20 05:07:10 -03006547 sd->sensor = SENSOR_HV7131B;
6548 break;
6549 default:
6550/* case 2: * hv7131r */
Joe Perches37d5efb2017-09-22 15:20:33 -04006551 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor HV7131R\n");
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006552 sd->sensor = SENSOR_HV7131R;
Jean-Francois Moined754a6c2009-12-20 05:07:10 -03006553 break;
6554 }
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006555 break;
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03006556 case 0x02:
Joe Perches37d5efb2017-09-22 15:20:33 -04006557 gspca_dbg(gspca_dev, D_PROBE, "Sensor TAS5130C\n");
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006558 sd->sensor = SENSOR_TAS5130C;
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03006559 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006560 case 0x04:
Joe Perches37d5efb2017-09-22 15:20:33 -04006561 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor CS2102\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006562 sd->sensor = SENSOR_CS2102;
6563 break;
6564 case 0x08:
Joe Perches37d5efb2017-09-22 15:20:33 -04006565 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor HDCS2020\n");
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006566 sd->sensor = SENSOR_HDCS2020;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006567 break;
6568 case 0x0a:
Joe Perches37d5efb2017-09-22 15:20:33 -04006569 gspca_dbg(gspca_dev, D_PROBE,
6570 "Find Sensor PB0330. Chip revision %x\n",
6571 sd->chip_revision);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006572 sd->sensor = SENSOR_PB0330;
6573 break;
6574 case 0x0c:
Joe Perches37d5efb2017-09-22 15:20:33 -04006575 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor ICM105A\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006576 sd->sensor = SENSOR_ICM105A;
6577 break;
6578 case 0x0e:
Joe Perches37d5efb2017-09-22 15:20:33 -04006579 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor PAS202B\n");
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006580 sd->sensor = SENSOR_PAS202B;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006581 break;
6582 case 0x0f:
Joe Perches37d5efb2017-09-22 15:20:33 -04006583 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor PAS106\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006584 sd->sensor = SENSOR_PAS106;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006585 break;
6586 case 0x10:
6587 case 0x12:
Joe Perches37d5efb2017-09-22 15:20:33 -04006588 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor TAS5130C\n");
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006589 sd->sensor = SENSOR_TAS5130C;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006590 break;
6591 case 0x11:
Joe Perches37d5efb2017-09-22 15:20:33 -04006592 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor HV7131R\n");
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006593 sd->sensor = SENSOR_HV7131R;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006594 break;
6595 case 0x13:
Jean-François Moinea484dd92010-08-04 07:25:12 -03006596 case 0x15:
Joe Perches37d5efb2017-09-22 15:20:33 -04006597 gspca_dbg(gspca_dev, D_PROBE,
6598 "Sensor MT9V111. Chip revision %04x\n",
6599 sd->chip_revision);
Jean-François Moinea484dd92010-08-04 07:25:12 -03006600 sd->sensor = sd->bridge == BRIDGE_ZC301
6601 ? SENSOR_MT9V111_1
6602 : SENSOR_MT9V111_3;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006603 break;
6604 case 0x14:
Joe Perches37d5efb2017-09-22 15:20:33 -04006605 gspca_dbg(gspca_dev, D_PROBE,
6606 "Find Sensor CS2102K?. Chip revision %x\n",
6607 sd->chip_revision);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006608 sd->sensor = SENSOR_CS2102K;
6609 break;
Jean-Francois Moine5be2b092009-01-20 05:12:34 -03006610 case 0x16:
Joe Perches37d5efb2017-09-22 15:20:33 -04006611 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor ADCM2700\n");
Jean-Francois Moine5be2b092009-01-20 05:12:34 -03006612 sd->sensor = SENSOR_ADCM2700;
6613 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006614 case 0x29:
Joe Perches37d5efb2017-09-22 15:20:33 -04006615 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor GC0305\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006616 sd->sensor = SENSOR_GC0305;
6617 break;
Jean-François Moine7fbee992010-12-28 07:17:40 -03006618 case 0x0303:
Joe Perches37d5efb2017-09-22 15:20:33 -04006619 gspca_dbg(gspca_dev, D_PROBE, "Sensor GC0303\n");
Jean-François Moine7fbee992010-12-28 07:17:40 -03006620 sd->sensor = SENSOR_GC0303;
Jean-Francois Moine63fc4a02008-07-21 05:42:17 -03006621 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006622 case 0x2030:
Joe Perches37d5efb2017-09-22 15:20:33 -04006623 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor PO2030\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006624 sd->sensor = SENSOR_PO2030;
6625 break;
6626 case 0x7620:
Joe Perches37d5efb2017-09-22 15:20:33 -04006627 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor OV7620\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006628 sd->sensor = SENSOR_OV7620;
6629 break;
Jean-Francois Moinee2d750f2009-02-19 15:41:28 -03006630 case 0x7631:
Joe Perches37d5efb2017-09-22 15:20:33 -04006631 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor OV7630C\n");
Jean-Francois Moinee2d750f2009-02-19 15:41:28 -03006632 sd->sensor = SENSOR_OV7630C;
6633 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006634 case 0x7648:
Joe Perches37d5efb2017-09-22 15:20:33 -04006635 gspca_dbg(gspca_dev, D_PROBE, "Find Sensor OV7648\n");
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006636 sd->sensor = SENSOR_OV7620; /* same sensor (?) */
6637 break;
6638 default:
Joe Perches133a9fe2011-08-21 19:56:57 -03006639 pr_err("Unknown sensor %04x\n", sensor);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006640 return -EINVAL;
6641 }
6642 }
6643 if (sensor < 0x20) {
6644 if (sensor == -1 || sensor == 0x10 || sensor == 0x12)
Jean-François Moine6d314502010-08-04 05:44:13 -03006645 reg_w(gspca_dev, 0x02, 0x0010);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006646 reg_r(gspca_dev, 0x0010);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006647 }
6648
6649 cam = &gspca_dev->cam;
Hans de Goede9919fe82010-01-13 07:12:28 -03006650 switch (mode_tb[sd->sensor]) {
6651 case 0:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006652 cam->cam_mode = sif_mode;
Jean-Francois Moinec41492c2008-07-07 08:31:16 -03006653 cam->nmodes = ARRAY_SIZE(sif_mode);
Hans de Goede9919fe82010-01-13 07:12:28 -03006654 break;
6655 case 1:
6656 cam->cam_mode = vga_mode;
6657 cam->nmodes = ARRAY_SIZE(vga_mode);
6658 break;
6659 default:
6660/* case 2: */
6661 cam->cam_mode = broken_vga_mode;
6662 cam->nmodes = ARRAY_SIZE(broken_vga_mode);
6663 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006664 }
Jean-François Moine49fb5e62010-12-28 07:09:34 -03006665
Jean-Francois Moine77880ba32010-01-08 08:04:21 -03006666 /* switch off the led */
Jean-François Moine6d314502010-08-04 05:44:13 -03006667 reg_w(gspca_dev, 0x01, 0x0000);
Jean-François Moinec39da6a2010-08-04 06:07:23 -03006668 return gspca_dev->usb_err;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006669}
6670
Hans de Goede55db7652012-05-06 09:28:25 -03006671static int sd_pre_start(struct gspca_dev *gspca_dev)
6672{
6673 struct sd *sd = (struct sd *) gspca_dev;
6674 gspca_dev->cam.needs_full_bandwidth = (sd->reg08 >= 4) ? 1 : 0;
6675 return 0;
6676}
6677
Jean-Francois Moine72ab97c2008-09-20 06:39:08 -03006678static int sd_start(struct gspca_dev *gspca_dev)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006679{
6680 struct sd *sd = (struct sd *) gspca_dev;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006681 int mode;
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03006682 static const struct usb_action *init_tb[SENSOR_MAX][2] = {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006683 [SENSOR_ADCM2700] =
6684 {adcm2700_Initial, adcm2700_InitialScale},
6685 [SENSOR_CS2102] =
6686 {cs2102_Initial, cs2102_InitialScale},
6687 [SENSOR_CS2102K] =
6688 {cs2102K_Initial, cs2102K_InitialScale},
Jean-François Moine7fbee992010-12-28 07:17:40 -03006689 [SENSOR_GC0303] =
6690 {gc0303_Initial, gc0303_InitialScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006691 [SENSOR_GC0305] =
6692 {gc0305_Initial, gc0305_InitialScale},
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006693 [SENSOR_HDCS2020] =
6694 {hdcs2020_Initial, hdcs2020_InitialScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006695 [SENSOR_HV7131B] =
6696 {hv7131b_Initial, hv7131b_InitialScale},
6697 [SENSOR_HV7131R] =
6698 {hv7131r_Initial, hv7131r_InitialScale},
6699 [SENSOR_ICM105A] =
6700 {icm105a_Initial, icm105a_InitialScale},
6701 [SENSOR_MC501CB] =
6702 {mc501cb_Initial, mc501cb_InitialScale},
Jean-François Moinea484dd92010-08-04 07:25:12 -03006703 [SENSOR_MT9V111_1] =
6704 {mt9v111_1_Initial, mt9v111_1_InitialScale},
6705 [SENSOR_MT9V111_3] =
6706 {mt9v111_3_Initial, mt9v111_3_InitialScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006707 [SENSOR_OV7620] =
6708 {ov7620_Initial, ov7620_InitialScale},
6709 [SENSOR_OV7630C] =
6710 {ov7630c_Initial, ov7630c_InitialScale},
6711 [SENSOR_PAS106] =
6712 {pas106b_Initial, pas106b_InitialScale},
6713 [SENSOR_PAS202B] =
6714 {pas202b_Initial, pas202b_InitialScale},
6715 [SENSOR_PB0330] =
6716 {pb0330_Initial, pb0330_InitialScale},
6717 [SENSOR_PO2030] =
6718 {po2030_Initial, po2030_InitialScale},
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006719 [SENSOR_TAS5130C] =
6720 {tas5130c_Initial, tas5130c_InitialScale},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006721 };
6722
Jean-Francois Moine71cb2762009-03-03 05:33:41 -03006723 /* create the JPEG header */
Ondrej Zary1966bc22013-08-30 17:54:23 -03006724 jpeg_define(sd->jpeg_hdr, gspca_dev->pixfmt.height,
6725 gspca_dev->pixfmt.width,
Jean-Francois Moine71cb2762009-03-03 05:33:41 -03006726 0x21); /* JPEG 422 */
Jean-Francois Moine71cb2762009-03-03 05:33:41 -03006727
Jean-Francois Moine50924512010-01-08 08:08:12 -03006728 mode = gspca_dev->cam.cam_mode[gspca_dev->curr_mode].priv;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006729 switch (sd->sensor) {
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006730 case SENSOR_HV7131R:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006731 zcxx_probeSensor(gspca_dev);
6732 break;
6733 case SENSOR_PAS106:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006734 usb_exchange(gspca_dev, pas106b_Initial_com);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006735 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006736 }
Jean-Francois Moine50924512010-01-08 08:08:12 -03006737 usb_exchange(gspca_dev, init_tb[sd->sensor][mode]);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006738
6739 switch (sd->sensor) {
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006740 case SENSOR_ADCM2700:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006741 case SENSOR_GC0305:
6742 case SENSOR_OV7620:
6743 case SENSOR_PO2030:
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006744 case SENSOR_TAS5130C:
Jean-François Moine7fbee992010-12-28 07:17:40 -03006745 case SENSOR_GC0303:
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006746/* msleep(100); * ?? */
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006747 reg_r(gspca_dev, 0x0002); /* --> 0x40 */
Jean-François Moine6d314502010-08-04 05:44:13 -03006748 reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6749 reg_w(gspca_dev, 0x15, 0x01ae);
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006750 if (sd->sensor == SENSOR_TAS5130C)
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03006751 break;
Jean-François Moine6d314502010-08-04 05:44:13 -03006752 reg_w(gspca_dev, 0x0d, 0x003a);
6753 reg_w(gspca_dev, 0x02, 0x003b);
6754 reg_w(gspca_dev, 0x00, 0x0038);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006755 break;
Jean-François Moine3d244062011-01-24 16:22:11 -03006756 case SENSOR_HV7131R:
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006757 case SENSOR_PAS202B:
Jean-François Moine6d314502010-08-04 05:44:13 -03006758 reg_w(gspca_dev, 0x03, 0x003b);
6759 reg_w(gspca_dev, 0x0c, 0x003a);
6760 reg_w(gspca_dev, 0x0b, 0x0039);
Jean-François Moine3d244062011-01-24 16:22:11 -03006761 if (sd->sensor == SENSOR_HV7131R)
6762 reg_w(gspca_dev, 0x50, ZC3XX_R11D_GLOBALGAIN);
Jean-Francois Moine38719d42010-01-04 16:09:47 -03006763 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006764 }
6765
6766 setmatrix(gspca_dev);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006767 switch (sd->sensor) {
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006768 case SENSOR_ADCM2700:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006769 case SENSOR_OV7620:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006770 reg_r(gspca_dev, 0x0008);
Jean-François Moine6d314502010-08-04 05:44:13 -03006771 reg_w(gspca_dev, 0x00, 0x0008);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006772 break;
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006773 case SENSOR_PAS202B:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006774 case SENSOR_GC0305:
Jean-François Moine3d244062011-01-24 16:22:11 -03006775 case SENSOR_HV7131R:
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006776 case SENSOR_TAS5130C:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006777 reg_r(gspca_dev, 0x0008);
Mauro Carvalho Chehab3e4d8f42019-02-18 14:29:03 -05006778 /* fall through */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006779 case SENSOR_PO2030:
Jean-François Moine6d314502010-08-04 05:44:13 -03006780 reg_w(gspca_dev, 0x03, 0x0008);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006781 break;
6782 }
Hans Verkuilc06ba282012-05-06 09:28:28 -03006783 setsharpness(gspca_dev, v4l2_ctrl_g_ctrl(sd->sharpness));
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006784
6785 /* set the gamma tables when not set */
6786 switch (sd->sensor) {
Jean-Francois Moine1d763312009-09-18 05:36:24 -03006787 case SENSOR_CS2102K: /* gamma set in xxx_Initial */
Jean-François Moine4e5144e2011-02-26 13:56:20 -03006788 case SENSOR_HDCS2020:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006789 case SENSOR_OV7630C:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006790 break;
6791 default:
Hans Verkuilc06ba282012-05-06 09:28:28 -03006792 setcontrast(gspca_dev, v4l2_ctrl_g_ctrl(sd->gamma),
6793 v4l2_ctrl_g_ctrl(sd->brightness),
6794 v4l2_ctrl_g_ctrl(sd->contrast));
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006795 break;
6796 }
6797 setmatrix(gspca_dev); /* one more time? */
6798 switch (sd->sensor) {
6799 case SENSOR_OV7620:
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006800 case SENSOR_PAS202B:
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006801 reg_r(gspca_dev, 0x0180); /* from win */
Jean-François Moine6d314502010-08-04 05:44:13 -03006802 reg_w(gspca_dev, 0x00, 0x0180);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006803 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006804 }
Jean-François Moine30c73d42012-02-27 07:26:30 -03006805 setquality(gspca_dev);
Hans de Goede55db7652012-05-06 09:28:25 -03006806 /* Start with BRC disabled, transfer_update will enable it if needed */
6807 reg_w(gspca_dev, 0x00, 0x0007);
Hans Verkuilc06ba282012-05-06 09:28:28 -03006808 if (sd->plfreq)
6809 setlightfreq(gspca_dev, v4l2_ctrl_g_ctrl(sd->plfreq));
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006810
6811 switch (sd->sensor) {
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006812 case SENSOR_ADCM2700:
Jean-François Moine6d314502010-08-04 05:44:13 -03006813 reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6814 reg_w(gspca_dev, 0x15, 0x01ae);
6815 reg_w(gspca_dev, 0x02, 0x0180);
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006816 /* ms-win + */
Jean-François Moine6d314502010-08-04 05:44:13 -03006817 reg_w(gspca_dev, 0x40, 0x0117);
Jean-Francois Moine3d221182009-01-19 15:18:44 -03006818 break;
Jean-François Moine3d244062011-01-24 16:22:11 -03006819 case SENSOR_HV7131R:
Hans Verkuilc06ba282012-05-06 09:28:28 -03006820 setexposure(gspca_dev, v4l2_ctrl_g_ctrl(sd->exposure));
Jean-François Moine3d244062011-01-24 16:22:11 -03006821 reg_w(gspca_dev, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN);
6822 break;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006823 case SENSOR_GC0305:
Jean-François Moine83d1aa32010-08-04 05:11:23 -03006824 case SENSOR_TAS5130C:
Jean-François Moine6d314502010-08-04 05:44:13 -03006825 reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6826 reg_w(gspca_dev, 0x15, 0x01ae);
Mauro Carvalho Chehab3e4d8f42019-02-18 14:29:03 -05006827 /* fall through */
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006828 case SENSOR_PAS202B:
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006829 case SENSOR_PO2030:
Jean-François Moine780e3122010-10-19 04:29:10 -03006830/* reg_w(gspca_dev, 0x40, ZC3XX_R117_GGAIN); in win traces */
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006831 reg_r(gspca_dev, 0x0180);
6832 break;
6833 case SENSOR_OV7620:
Jean-François Moine6d314502010-08-04 05:44:13 -03006834 reg_w(gspca_dev, 0x09, 0x01ad);
6835 reg_w(gspca_dev, 0x15, 0x01ae);
Jean-Francois Moine7320d6b2008-12-08 06:41:04 -03006836 i2c_read(gspca_dev, 0x13); /*fixme: returns 0xa3 */
6837 i2c_write(gspca_dev, 0x13, 0xa3, 0x00);
Jean-François Moine780e3122010-10-19 04:29:10 -03006838 /*fixme: returned value to send? */
Jean-François Moine6d314502010-08-04 05:44:13 -03006839 reg_w(gspca_dev, 0x40, 0x0117);
Jean-Francois Moine739570b2008-07-14 09:38:29 -03006840 reg_r(gspca_dev, 0x0180);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006841 break;
6842 }
6843
Hans Verkuilc06ba282012-05-06 09:28:28 -03006844 setautogain(gspca_dev, v4l2_ctrl_g_ctrl(sd->autogain));
Jean-François Moinef1801902012-02-27 07:48:32 -03006845
Hans de Goede55db7652012-05-06 09:28:25 -03006846 if (gspca_dev->usb_err < 0)
6847 return gspca_dev->usb_err;
Jean-François Moinef1801902012-02-27 07:48:32 -03006848
Hans de Goede55db7652012-05-06 09:28:25 -03006849 /* Start the transfer parameters update thread */
Bhaktipriya Shridharf7cf0362016-07-09 04:52:29 -03006850 schedule_work(&sd->work);
Hans de Goede55db7652012-05-06 09:28:25 -03006851
6852 return 0;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006853}
6854
Hans de Goede844db452012-09-09 07:30:02 -03006855/* called on streamoff with alt==0 and on disconnect */
6856/* the usb_lock is held at entry - restore on exit */
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006857static void sd_stop0(struct gspca_dev *gspca_dev)
6858{
6859 struct sd *sd = (struct sd *) gspca_dev;
6860
Bhaktipriya Shridharf7cf0362016-07-09 04:52:29 -03006861 mutex_unlock(&gspca_dev->usb_lock);
6862 flush_work(&sd->work);
6863 mutex_lock(&gspca_dev->usb_lock);
Hans de Goede345321d2012-09-09 06:30:02 -03006864 if (!gspca_dev->present)
Jean-Francois Moine98522a72008-11-18 06:33:08 -03006865 return;
Jean-François Moine6d314502010-08-04 05:44:13 -03006866 send_unknown(gspca_dev, sd->sensor);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006867}
6868
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006869static void sd_pkt_scan(struct gspca_dev *gspca_dev,
Jean-Francois Moine76dd2722009-11-13 09:21:03 -03006870 u8 *data,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006871 int len)
6872{
Jean-Francois Moine71cb2762009-03-03 05:33:41 -03006873 struct sd *sd = (struct sd *) gspca_dev;
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006874
Jean-François Moinea5ecdfb2011-01-24 16:31:58 -03006875 /* check the JPEG end of frame */
6876 if (len >= 3
6877 && data[len - 3] == 0xff && data[len - 2] == 0xd9) {
6878/*fixme: what does the last byte mean?*/
Jean-Francois Moine76dd2722009-11-13 09:21:03 -03006879 gspca_frame_add(gspca_dev, LAST_PACKET,
Jean-François Moinea5ecdfb2011-01-24 16:31:58 -03006880 data, len - 1);
6881 return;
6882 }
6883
6884 /* check the JPEG start of a frame */
6885 if (data[0] == 0xff && data[1] == 0xd8) {
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006886 /* put the JPEG header in the new frame */
Jean-Francois Moine76dd2722009-11-13 09:21:03 -03006887 gspca_frame_add(gspca_dev, FIRST_PACKET,
Jean-Francois Moine71cb2762009-03-03 05:33:41 -03006888 sd->jpeg_hdr, JPEG_HDR_SZ);
6889
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006890 /* remove the webcam's header:
6891 * ff d8 ff fe 00 0e 00 00 ss ss 00 01 ww ww hh hh pp pp
6892 * - 'ss ss' is the frame sequence number (BE)
Jean-François Moine780e3122010-10-19 04:29:10 -03006893 * - 'ww ww' and 'hh hh' are the window dimensions (BE)
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006894 * - 'pp pp' is the packet sequence number (BE)
6895 */
6896 data += 18;
6897 len -= 18;
6898 }
Jean-Francois Moine76dd2722009-11-13 09:21:03 -03006899 gspca_frame_add(gspca_dev, INTER_PACKET, data, len);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006900}
6901
Jean-François Moinecd7f98f2012-03-16 06:47:23 -03006902static int sd_set_jcomp(struct gspca_dev *gspca_dev,
Hans Verkuild88aab52012-09-17 05:05:25 -03006903 const struct v4l2_jpegcompression *jcomp)
Jean-François Moinecd7f98f2012-03-16 06:47:23 -03006904{
6905 struct sd *sd = (struct sd *) gspca_dev;
6906
Hans Verkuild88aab52012-09-17 05:05:25 -03006907 return v4l2_ctrl_s_ctrl(sd->jpegqual, jcomp->quality);
Jean-Francois Moine77ac0ba2009-03-02 06:40:52 -03006908}
6909
6910static int sd_get_jcomp(struct gspca_dev *gspca_dev,
6911 struct v4l2_jpegcompression *jcomp)
6912{
6913 struct sd *sd = (struct sd *) gspca_dev;
6914
6915 memset(jcomp, 0, sizeof *jcomp);
Hans Verkuilc06ba282012-05-06 09:28:28 -03006916 jcomp->quality = v4l2_ctrl_g_ctrl(sd->jpegqual);
Jean-Francois Moine77ac0ba2009-03-02 06:40:52 -03006917 jcomp->jpeg_markers = V4L2_JPEG_MARKER_DHT
6918 | V4L2_JPEG_MARKER_DQT;
6919 return 0;
6920}
6921
Peter Senna Tschudin78f968f2013-01-24 19:29:13 -03006922#if IS_ENABLED(CONFIG_INPUT)
Hans de Goede1a3510262010-01-29 11:05:25 -03006923static int sd_int_pkt_scan(struct gspca_dev *gspca_dev,
6924 u8 *data, /* interrupt packet data */
Jonathan McCrohanf58c91c2013-10-20 21:34:01 -03006925 int len) /* interrupt packet length */
Hans de Goede1a3510262010-01-29 11:05:25 -03006926{
6927 if (len == 8 && data[4] == 1) {
6928 input_report_key(gspca_dev->input_dev, KEY_CAMERA, 1);
6929 input_sync(gspca_dev->input_dev);
6930 input_report_key(gspca_dev->input_dev, KEY_CAMERA, 0);
6931 input_sync(gspca_dev->input_dev);
6932 }
6933
6934 return 0;
6935}
6936#endif
6937
Jean-Francois Moinea5ae2062008-07-04 11:16:16 -03006938static const struct sd_desc sd_desc = {
Jean-François Moine0b74e2c2012-02-27 08:26:05 -03006939 .name = KBUILD_MODNAME,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006940 .config = sd_config,
Jean-Francois Moine012d6b02008-09-03 17:12:16 -03006941 .init = sd_init,
Hans Verkuilc06ba282012-05-06 09:28:28 -03006942 .init_controls = sd_init_controls,
Hans de Goede55db7652012-05-06 09:28:25 -03006943 .isoc_init = sd_pre_start,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006944 .start = sd_start,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006945 .stop0 = sd_stop0,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006946 .pkt_scan = sd_pkt_scan,
Jean-Francois Moine77ac0ba2009-03-02 06:40:52 -03006947 .get_jcomp = sd_get_jcomp,
6948 .set_jcomp = sd_set_jcomp,
Peter Senna Tschudin78f968f2013-01-24 19:29:13 -03006949#if IS_ENABLED(CONFIG_INPUT)
Hans de Goede1a3510262010-01-29 11:05:25 -03006950 .int_pkt_scan = sd_int_pkt_scan,
6951#endif
Jean-Francois Moined43fa322008-06-12 10:58:58 -03006952};
6953
Jean-François Moine95c967c2011-01-13 05:20:29 -03006954static const struct usb_device_id device_table[] = {
Wolfram Sange1771292011-09-23 04:47:58 -03006955 {USB_DEVICE(0x03f0, 0x1b07)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006956 {USB_DEVICE(0x041e, 0x041e)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006957 {USB_DEVICE(0x041e, 0x4017)},
Hans de Goeded6db35e2008-09-03 17:12:13 -03006958 {USB_DEVICE(0x041e, 0x401c), .driver_info = SENSOR_PAS106},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006959 {USB_DEVICE(0x041e, 0x401e)},
6960 {USB_DEVICE(0x041e, 0x401f)},
Hans de Goede222a07f2008-09-03 17:12:20 -03006961 {USB_DEVICE(0x041e, 0x4022)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006962 {USB_DEVICE(0x041e, 0x4029)},
Hans de Goeded6db35e2008-09-03 17:12:13 -03006963 {USB_DEVICE(0x041e, 0x4034), .driver_info = SENSOR_PAS106},
6964 {USB_DEVICE(0x041e, 0x4035), .driver_info = SENSOR_PAS106},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006965 {USB_DEVICE(0x041e, 0x4036)},
6966 {USB_DEVICE(0x041e, 0x403a)},
Jean-François Moine7fbee992010-12-28 07:17:40 -03006967 {USB_DEVICE(0x041e, 0x4051), .driver_info = SENSOR_GC0303},
6968 {USB_DEVICE(0x041e, 0x4053), .driver_info = SENSOR_GC0303},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006969 {USB_DEVICE(0x0458, 0x7007)},
6970 {USB_DEVICE(0x0458, 0x700c)},
6971 {USB_DEVICE(0x0458, 0x700f)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006972 {USB_DEVICE(0x0461, 0x0a00)},
Fabio Rossi88a40cf2008-12-26 14:41:48 -03006973 {USB_DEVICE(0x046d, 0x089d), .driver_info = SENSOR_MC501CB},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006974 {USB_DEVICE(0x046d, 0x08a0)},
6975 {USB_DEVICE(0x046d, 0x08a1)},
6976 {USB_DEVICE(0x046d, 0x08a2)},
6977 {USB_DEVICE(0x046d, 0x08a3)},
6978 {USB_DEVICE(0x046d, 0x08a6)},
6979 {USB_DEVICE(0x046d, 0x08a7)},
6980 {USB_DEVICE(0x046d, 0x08a9)},
6981 {USB_DEVICE(0x046d, 0x08aa)},
6982 {USB_DEVICE(0x046d, 0x08ac)},
6983 {USB_DEVICE(0x046d, 0x08ad)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006984 {USB_DEVICE(0x046d, 0x08ae)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006985 {USB_DEVICE(0x046d, 0x08af)},
6986 {USB_DEVICE(0x046d, 0x08b9)},
6987 {USB_DEVICE(0x046d, 0x08d7)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006988 {USB_DEVICE(0x046d, 0x08d8)},
Jean-François Moine7d55a842010-12-28 07:02:32 -03006989 {USB_DEVICE(0x046d, 0x08d9)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006990 {USB_DEVICE(0x046d, 0x08da)},
Hans de Goeded6db35e2008-09-03 17:12:13 -03006991 {USB_DEVICE(0x046d, 0x08dd), .driver_info = SENSOR_MC501CB},
6992 {USB_DEVICE(0x0471, 0x0325), .driver_info = SENSOR_PAS106},
6993 {USB_DEVICE(0x0471, 0x0326), .driver_info = SENSOR_PAS106},
6994 {USB_DEVICE(0x0471, 0x032d), .driver_info = SENSOR_PAS106},
6995 {USB_DEVICE(0x0471, 0x032e), .driver_info = SENSOR_PAS106},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006996 {USB_DEVICE(0x055f, 0xc005)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006997 {USB_DEVICE(0x055f, 0xd003)},
6998 {USB_DEVICE(0x055f, 0xd004)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03006999 {USB_DEVICE(0x0698, 0x2003)},
Hans de Goede222a07f2008-09-03 17:12:20 -03007000 {USB_DEVICE(0x0ac8, 0x0301), .driver_info = SENSOR_PAS106},
Douglas Schilling Landgrafd99819d2009-03-26 05:10:55 -03007001 {USB_DEVICE(0x0ac8, 0x0302), .driver_info = SENSOR_PAS106},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03007002 {USB_DEVICE(0x0ac8, 0x301b)},
7003 {USB_DEVICE(0x0ac8, 0x303b)},
Jean-Francois Moine7bd330b42009-12-02 06:06:03 -03007004 {USB_DEVICE(0x0ac8, 0x305b)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03007005 {USB_DEVICE(0x0ac8, 0x307b)},
7006 {USB_DEVICE(0x10fd, 0x0128)},
Hans de Goede222a07f2008-09-03 17:12:20 -03007007 {USB_DEVICE(0x10fd, 0x804d)},
Jean-Francois Moine9d64fdb2008-07-25 08:53:03 -03007008 {USB_DEVICE(0x10fd, 0x8050)},
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007009 {} /* end of entry */
7010};
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007011MODULE_DEVICE_TABLE(usb, device_table);
7012
7013/* -- device connect -- */
7014static int sd_probe(struct usb_interface *intf,
7015 const struct usb_device_id *id)
7016{
7017 return gspca_dev_probe(intf, id, &sd_desc, sizeof(struct sd),
7018 THIS_MODULE);
7019}
7020
7021/* USB driver */
7022static struct usb_driver sd_driver = {
Jean-François Moine0b74e2c2012-02-27 08:26:05 -03007023 .name = KBUILD_MODNAME,
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007024 .id_table = device_table,
7025 .probe = sd_probe,
7026 .disconnect = gspca_disconnect,
Jean-Francois Moine6a709742008-09-03 16:48:10 -03007027#ifdef CONFIG_PM
7028 .suspend = gspca_suspend,
7029 .resume = gspca_resume,
Hans Verkuilc06ba282012-05-06 09:28:28 -03007030 .reset_resume = gspca_resume,
Jean-Francois Moine6a709742008-09-03 16:48:10 -03007031#endif
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007032};
7033
Greg Kroah-Hartmanecb3b2b2011-11-18 09:46:12 -08007034module_usb_driver(sd_driver);
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007035
Jean-Francois Moined43fa322008-06-12 10:58:58 -03007036module_param(force_sensor, int, 0644);
7037MODULE_PARM_DESC(force_sensor,
7038 "Force sensor. Only for experts!!!");