V4L/DVB (9866): gspca - vc032x: V and H flips added for sensors ov7660 and 7670.
[safe/jmp/linux-2.6] / drivers / media / video / gspca / vc032x.c
1 /*
2  *              Z-star vc0321 library
3  *              Copyright (C) 2006 Koninski Artur takeshi87@o2.pl
4  *              Copyright (C) 2006 Michel Xhaard
5  *
6  * V4L2 by Jean-Francois Moine <http://moinejf.free.fr>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21  */
22
23 #define MODULE_NAME "vc032x"
24
25 #include "gspca.h"
26
27 MODULE_AUTHOR("Michel Xhaard <mxhaard@users.sourceforge.net>");
28 MODULE_DESCRIPTION("GSPCA/VC032X USB Camera Driver");
29 MODULE_LICENSE("GPL");
30
31 /* specific webcam descriptor */
32 struct sd {
33         struct gspca_dev gspca_dev;     /* !! must be the first item */
34
35         __u8 autogain;
36         __u8 hflip;
37         __u8 vflip;
38         __u8 lightfreq;
39
40         char qindex;
41         char bridge;
42 #define BRIDGE_VC0321 0
43 #define BRIDGE_VC0323 1
44         char sensor;
45 #define SENSOR_HV7131R 0
46 #define SENSOR_MI0360 1
47 #define SENSOR_MI1320 2
48 #define SENSOR_MI1310_SOC 3
49 #define SENSOR_OV7660 4
50 #define SENSOR_OV7670 5
51 #define SENSOR_PO3130NC 6
52 };
53
54 /* V4L2 controls supported by the driver */
55 static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val);
56 static int sd_getautogain(struct gspca_dev *gspca_dev, __s32 *val);
57 static int sd_sethflip(struct gspca_dev *gspca_dev, __s32 val);
58 static int sd_gethflip(struct gspca_dev *gspca_dev, __s32 *val);
59 static int sd_setvflip(struct gspca_dev *gspca_dev, __s32 val);
60 static int sd_getvflip(struct gspca_dev *gspca_dev, __s32 *val);
61 static int sd_setfreq(struct gspca_dev *gspca_dev, __s32 val);
62 static int sd_getfreq(struct gspca_dev *gspca_dev, __s32 *val);
63
64 static struct ctrl sd_ctrls[] = {
65         {
66             {
67                 .id      = V4L2_CID_AUTOGAIN,
68                 .type    = V4L2_CTRL_TYPE_BOOLEAN,
69                 .name    = "Auto Gain",
70                 .minimum = 0,
71                 .maximum = 1,
72                 .step    = 1,
73 #define AUTOGAIN_DEF 1
74                 .default_value = AUTOGAIN_DEF,
75             },
76             .set = sd_setautogain,
77             .get = sd_getautogain,
78         },
79 /* next 2 controls work with ov7660 and ov7670 only */
80 #define HFLIP_IDX 1
81         {
82             {
83                 .id      = V4L2_CID_HFLIP,
84                 .type    = V4L2_CTRL_TYPE_BOOLEAN,
85                 .name    = "Mirror",
86                 .minimum = 0,
87                 .maximum = 1,
88                 .step    = 1,
89 #define HFLIP_DEF 0
90                 .default_value = HFLIP_DEF,
91             },
92             .set = sd_sethflip,
93             .get = sd_gethflip,
94         },
95 #define VFLIP_IDX 2
96         {
97             {
98                 .id      = V4L2_CID_VFLIP,
99                 .type    = V4L2_CTRL_TYPE_BOOLEAN,
100                 .name    = "Vflip",
101                 .minimum = 0,
102                 .maximum = 1,
103                 .step    = 1,
104 #define VFLIP_DEF 0
105                 .default_value = VFLIP_DEF,
106             },
107             .set = sd_setvflip,
108             .get = sd_getvflip,
109         },
110 #define LIGHTFREQ_IDX 3
111         {
112             {
113                 .id      = V4L2_CID_POWER_LINE_FREQUENCY,
114                 .type    = V4L2_CTRL_TYPE_MENU,
115                 .name    = "Light frequency filter",
116                 .minimum = 0,
117                 .maximum = 2,   /* 0: No, 1: 50Hz, 2:60Hz */
118                 .step    = 1,
119 #define FREQ_DEF 1
120                 .default_value = FREQ_DEF,
121             },
122             .set = sd_setfreq,
123             .get = sd_getfreq,
124         },
125 };
126
127 static struct v4l2_pix_format vc0321_mode[] = {
128         {320, 240, V4L2_PIX_FMT_YVYU, V4L2_FIELD_NONE,
129                 .bytesperline = 320,
130                 .sizeimage = 320 * 240 * 2,
131                 .colorspace = V4L2_COLORSPACE_SRGB,
132                 .priv = 1},
133         {640, 480, V4L2_PIX_FMT_YVYU, V4L2_FIELD_NONE,
134                 .bytesperline = 640,
135                 .sizeimage = 640 * 480 * 2,
136                 .colorspace = V4L2_COLORSPACE_SRGB,
137                 .priv = 0},
138 };
139 static struct v4l2_pix_format vc0323_mode[] = {
140         {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
141                 .bytesperline = 320,
142                 .sizeimage = 320 * 240 * 3 / 8 + 590,
143                 .colorspace = V4L2_COLORSPACE_JPEG,
144                 .priv = 1},
145         {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
146                 .bytesperline = 640,
147                 .sizeimage = 640 * 480 * 3 / 8 + 590,
148                 .colorspace = V4L2_COLORSPACE_JPEG,
149                 .priv = 0},
150 };
151
152 /* OV7660/7670 registers */
153 #define OV7660_REG_MVFP 0x1e
154 #define OV7660_MVFP_MIRROR      0x20
155 #define OV7660_MVFP_VFLIP       0x10
156
157 static const __u8 mi0360_matrix[9] = {
158         0x50, 0xf8, 0xf8, 0xf5, 0x50, 0xfb, 0xff, 0xf1, 0x50
159 };
160
161 static const __u8 mi0360_initVGA_JPG[][4] = {
162         {0xb0, 0x03, 0x19, 0xcc},
163         {0xb0, 0x04, 0x02, 0xcc},
164         {0xb3, 0x00, 0x24, 0xcc},
165         {0xb3, 0x00, 0x25, 0xcc},
166         {0xb3, 0x08, 0x01, 0xcc},
167         {0xb3, 0x09, 0x0c, 0xcc},
168         {0xb3, 0x05, 0x01, 0xcc},
169         {0xb3, 0x06, 0x03, 0xcc},
170         {0xb3, 0x03, 0x0a, 0xcc},
171         {0xb3, 0x20, 0x00, 0xcc},
172         {0xb3, 0x21, 0x00, 0xcc},
173         {0xb3, 0x22, 0x01, 0xcc},
174         {0xb3, 0x23, 0xe0, 0xcc},
175         {0xb3, 0x04, 0x05, 0xcc},
176         {0xb3, 0x14, 0x00, 0xcc},
177         {0xb3, 0x15, 0x00, 0xcc},
178         {0xb3, 0x16, 0x02, 0xcc},
179         {0xb3, 0x17, 0x7f, 0xcc},
180         {0xb3, 0x35, 0xdd, 0xcc},
181         {0xb3, 0x34, 0x02, 0xcc},
182         {0xb3, 0x00, 0x25, 0xcc},
183         {0xbc, 0x00, 0x71, 0xcc},
184         {0xb8, 0x00, 0x13, 0xcc},
185         {0xb8, 0x27, 0x20, 0xcc},
186         {0xb8, 0x2c, 0x50, 0xcc},
187         {0xb8, 0x2d, 0xf8, 0xcc},
188         {0xb8, 0x2e, 0xf8, 0xcc},
189         {0xb8, 0x2f, 0xf8, 0xcc},
190         {0xb8, 0x30, 0x50, 0xcc},
191         {0xb8, 0x31, 0xf8, 0xcc},
192         {0xb8, 0x32, 0xf8, 0xcc},
193         {0xb8, 0x33, 0xf8, 0xcc},
194         {0xb8, 0x34, 0x50, 0xcc},
195         {0xb8, 0x35, 0x00, 0xcc},
196         {0xb8, 0x36, 0x00, 0xcc},
197         {0xb8, 0x37, 0x00, 0xcc},
198         {0xb8, 0x01, 0x79, 0xcc},
199         {0xb8, 0x08, 0xe0, 0xcc},
200         {0xb3, 0x01, 0x41, 0xcc},
201         {0xb8, 0x01, 0x79, 0xcc},
202         {0xb8, 0x14, 0x18, 0xcc},
203         {0xb8, 0xb2, 0x0a, 0xcc},
204         {0xb8, 0xb4, 0x0a, 0xcc},
205         {0xb8, 0xb5, 0x0a, 0xcc},
206         {0xb8, 0xfe, 0x00, 0xcc},
207         {0xb8, 0xff, 0x28, 0xcc},
208         {0xb9, 0x00, 0x28, 0xcc},
209         {0xb9, 0x01, 0x28, 0xcc},
210         {0xb9, 0x02, 0x28, 0xcc},
211         {0xb9, 0x03, 0x00, 0xcc},
212         {0xb9, 0x04, 0x00, 0xcc},
213         {0xb9, 0x05, 0x3c, 0xcc},
214         {0xb9, 0x06, 0x3c, 0xcc},
215         {0xb9, 0x07, 0x3c, 0xcc},
216         {0xb9, 0x08, 0x3c, 0xcc},
217         {0xb8, 0x8e, 0x00, 0xcc},
218         {0xb8, 0x8f, 0xff, 0xcc},
219         {0xb8, 0x81, 0x09, 0xcc},
220         {0x31, 0x00, 0x00, 0xbb},
221         {0x09, 0x01, 0xc7, 0xbb},
222         {0x34, 0x01, 0x00, 0xbb},
223         {0x2b, 0x00, 0x28, 0xbb},
224         {0x2c, 0x00, 0x30, 0xbb},
225         {0x2d, 0x00, 0x30, 0xbb},
226         {0x2e, 0x00, 0x28, 0xbb},
227         {0x62, 0x04, 0x11, 0xbb},
228         {0x03, 0x01, 0xe0, 0xbb},
229         {0x2c, 0x00, 0x2c, 0xbb},
230         {0x20, 0xd0, 0x00, 0xbb},
231         {0x01, 0x00, 0x08, 0xbb},
232         {0x06, 0x00, 0x10, 0xbb},
233         {0x05, 0x00, 0x20, 0xbb},
234         {0x20, 0x00, 0x00, 0xbb},
235         {0xb6, 0x00, 0x00, 0xcc},
236         {0xb6, 0x03, 0x02, 0xcc},
237         {0xb6, 0x02, 0x80, 0xcc},
238         {0xb6, 0x05, 0x01, 0xcc},
239         {0xb6, 0x04, 0xe0, 0xcc},
240         {0xb6, 0x12, 0x78, 0xcc},
241         {0xb6, 0x18, 0x02, 0xcc},
242         {0xb6, 0x17, 0x58, 0xcc},
243         {0xb6, 0x16, 0x00, 0xcc},
244         {0xb6, 0x22, 0x12, 0xcc},
245         {0xb6, 0x23, 0x0b, 0xcc},
246         {0xb3, 0x02, 0x02, 0xcc},
247         {0xbf, 0xc0, 0x39, 0xcc},
248         {0xbf, 0xc1, 0x04, 0xcc},
249         {0xbf, 0xcc, 0x10, 0xcc},
250         {0xb9, 0x12, 0x00, 0xcc},
251         {0xb9, 0x13, 0x0a, 0xcc},
252         {0xb9, 0x14, 0x0a, 0xcc},
253         {0xb9, 0x15, 0x0a, 0xcc},
254         {0xb9, 0x16, 0x0a, 0xcc},
255         {0xb9, 0x18, 0x00, 0xcc},
256         {0xb9, 0x19, 0x0f, 0xcc},
257         {0xb9, 0x1a, 0x0f, 0xcc},
258         {0xb9, 0x1b, 0x0f, 0xcc},
259         {0xb9, 0x1c, 0x0f, 0xcc},
260         {0xb8, 0x8e, 0x00, 0xcc},
261         {0xb8, 0x8f, 0xff, 0xcc},
262         {0xb6, 0x12, 0xf8, 0xcc},
263         {0xb8, 0x0c, 0x20, 0xcc},
264         {0xb8, 0x0d, 0x70, 0xcc},
265         {0xb6, 0x13, 0x13, 0xcc},
266         {0x35, 0x00, 0x60, 0xbb},
267         {0xb3, 0x5c, 0x01, 0xcc},
268         {}
269 };
270 static const __u8 mi0360_initQVGA_JPG[][4] = {
271         {0xb0, 0x03, 0x19, 0xcc},
272         {0xb0, 0x04, 0x02, 0xcc},
273         {0xb3, 0x00, 0x24, 0xcc},
274         {0xb3, 0x00, 0x25, 0xcc},
275         {0xb3, 0x08, 0x01, 0xcc},
276         {0xb3, 0x09, 0x0c, 0xcc},
277         {0xb3, 0x05, 0x01, 0xcc},
278         {0xb3, 0x06, 0x03, 0xcc},
279         {0xb3, 0x03, 0x0a, 0xcc},
280         {0xb3, 0x20, 0x00, 0xcc},
281         {0xb3, 0x21, 0x00, 0xcc},
282         {0xb3, 0x22, 0x01, 0xcc},
283         {0xb3, 0x23, 0xe0, 0xcc},
284         {0xb3, 0x04, 0x05, 0xcc},
285         {0xb3, 0x14, 0x00, 0xcc},
286         {0xb3, 0x15, 0x00, 0xcc},
287         {0xb3, 0x16, 0x02, 0xcc},
288         {0xb3, 0x17, 0x7f, 0xcc},
289         {0xb3, 0x35, 0xdd, 0xcc},
290         {0xb3, 0x34, 0x02, 0xcc},
291         {0xb3, 0x00, 0x25, 0xcc},
292         {0xbc, 0x00, 0xd1, 0xcc},
293         {0xb8, 0x00, 0x13, 0xcc},
294         {0xb8, 0x27, 0x20, 0xcc},
295         {0xb8, 0x2c, 0x50, 0xcc},
296         {0xb8, 0x2d, 0xf8, 0xcc},
297         {0xb8, 0x2e, 0xf8, 0xcc},
298         {0xb8, 0x2f, 0xf8, 0xcc},
299         {0xb8, 0x30, 0x50, 0xcc},
300         {0xb8, 0x31, 0xf8, 0xcc},
301         {0xb8, 0x32, 0xf8, 0xcc},
302         {0xb8, 0x33, 0xf8, 0xcc},
303         {0xb8, 0x34, 0x50, 0xcc},
304         {0xb8, 0x35, 0x00, 0xcc},
305         {0xb8, 0x36, 0x00, 0xcc},
306         {0xb8, 0x37, 0x00, 0xcc},
307         {0xb8, 0x01, 0x79, 0xcc},
308         {0xb8, 0x08, 0xe0, 0xcc},
309         {0xb3, 0x01, 0x41, 0xcc},
310         {0xb8, 0x01, 0x79, 0xcc},
311         {0xb8, 0x14, 0x18, 0xcc},
312         {0xb8, 0xb2, 0x0a, 0xcc},
313         {0xb8, 0xb4, 0x0a, 0xcc},
314         {0xb8, 0xb5, 0x0a, 0xcc},
315         {0xb8, 0xfe, 0x00, 0xcc},
316         {0xb8, 0xff, 0x28, 0xcc},
317         {0xb9, 0x00, 0x28, 0xcc},
318         {0xb9, 0x01, 0x28, 0xcc},
319         {0xb9, 0x02, 0x28, 0xcc},
320         {0xb9, 0x03, 0x00, 0xcc},
321         {0xb9, 0x04, 0x00, 0xcc},
322         {0xb9, 0x05, 0x3c, 0xcc},
323         {0xb9, 0x06, 0x3c, 0xcc},
324         {0xb9, 0x07, 0x3c, 0xcc},
325         {0xb9, 0x08, 0x3c, 0xcc},
326         {0xb8, 0x8e, 0x00, 0xcc},
327         {0xb8, 0x8f, 0xff, 0xcc},
328         {0xb8, 0x81, 0x09, 0xcc},
329         {0x31, 0x00, 0x00, 0xbb},
330         {0x09, 0x01, 0xc7, 0xbb},
331         {0x34, 0x01, 0x00, 0xbb},
332         {0x2b, 0x00, 0x28, 0xbb},
333         {0x2c, 0x00, 0x30, 0xbb},
334         {0x2d, 0x00, 0x30, 0xbb},
335         {0x2e, 0x00, 0x28, 0xbb},
336         {0x62, 0x04, 0x11, 0xbb},
337         {0x03, 0x01, 0xe0, 0xbb},
338         {0x2c, 0x00, 0x2c, 0xbb},
339         {0x20, 0xd0, 0x00, 0xbb},
340         {0x01, 0x00, 0x08, 0xbb},
341         {0x06, 0x00, 0x10, 0xbb},
342         {0x05, 0x00, 0x20, 0xbb},
343         {0x20, 0x00, 0x00, 0xbb},
344         {0xb6, 0x00, 0x00, 0xcc},
345         {0xb6, 0x03, 0x01, 0xcc},
346         {0xb6, 0x02, 0x40, 0xcc},
347         {0xb6, 0x05, 0x00, 0xcc},
348         {0xb6, 0x04, 0xf0, 0xcc},
349         {0xb6, 0x12, 0x78, 0xcc},
350         {0xb6, 0x18, 0x00, 0xcc},
351         {0xb6, 0x17, 0x96, 0xcc},
352         {0xb6, 0x16, 0x00, 0xcc},
353         {0xb6, 0x22, 0x12, 0xcc},
354         {0xb6, 0x23, 0x0b, 0xcc},
355         {0xb3, 0x02, 0x02, 0xcc},
356         {0xbf, 0xc0, 0x39, 0xcc},
357         {0xbf, 0xc1, 0x04, 0xcc},
358         {0xbf, 0xcc, 0x10, 0xcc},
359         {0xb9, 0x12, 0x00, 0xcc},
360         {0xb9, 0x13, 0x0a, 0xcc},
361         {0xb9, 0x14, 0x0a, 0xcc},
362         {0xb9, 0x15, 0x0a, 0xcc},
363         {0xb9, 0x16, 0x0a, 0xcc},
364         {0xb9, 0x18, 0x00, 0xcc},
365         {0xb9, 0x19, 0x0f, 0xcc},
366         {0xb9, 0x1a, 0x0f, 0xcc},
367         {0xb9, 0x1b, 0x0f, 0xcc},
368         {0xb9, 0x1c, 0x0f, 0xcc},
369         {0xb8, 0x8e, 0x00, 0xcc},
370         {0xb8, 0x8f, 0xff, 0xcc},
371         {0xb6, 0x12, 0xf8, 0xcc},
372         {0xb6, 0x13, 0x13, 0xcc},
373         {0xbc, 0x02, 0x18, 0xcc},
374         {0xbc, 0x03, 0x50, 0xcc},
375         {0xbc, 0x04, 0x18, 0xcc},
376         {0xbc, 0x05, 0x00, 0xcc},
377         {0xbc, 0x06, 0x00, 0xcc},
378         {0xbc, 0x08, 0x30, 0xcc},
379         {0xbc, 0x09, 0x40, 0xcc},
380         {0xbc, 0x0a, 0x10, 0xcc},
381         {0xb8, 0x0c, 0x20, 0xcc},
382         {0xb8, 0x0d, 0x70, 0xcc},
383         {0xbc, 0x0b, 0x00, 0xcc},
384         {0xbc, 0x0c, 0x00, 0xcc},
385         {0x35, 0x00, 0xef, 0xbb},
386         {0xb3, 0x5c, 0x01, 0xcc},
387         {}
388 };
389
390 static const __u8 mi1310_socinitVGA_JPG[][4] = {
391         {0xb0, 0x03, 0x19, 0xcc},
392         {0xb0, 0x04, 0x02, 0xcc},
393         {0xb3, 0x00, 0x64, 0xcc},
394         {0xb3, 0x00, 0x65, 0xcc},
395         {0xb3, 0x05, 0x00, 0xcc},
396         {0xb3, 0x06, 0x00, 0xcc},
397         {0xb3, 0x08, 0x01, 0xcc},
398         {0xb3, 0x09, 0x0c, 0xcc},
399         {0xb3, 0x34, 0x02, 0xcc},
400         {0xb3, 0x35, 0xdd, 0xcc},
401         {0xb3, 0x02, 0x00, 0xcc},
402         {0xb3, 0x03, 0x0a, 0xcc},
403         {0xb3, 0x04, 0x05, 0xcc},
404         {0xb3, 0x20, 0x00, 0xcc},
405         {0xb3, 0x21, 0x00, 0xcc},
406         {0xb3, 0x22, 0x03, 0xcc},
407         {0xb3, 0x23, 0xc0, 0xcc},
408         {0xb3, 0x14, 0x00, 0xcc},
409         {0xb3, 0x15, 0x00, 0xcc},
410         {0xb3, 0x16, 0x04, 0xcc},
411         {0xb3, 0x17, 0xff, 0xcc},
412         {0xb3, 0x00, 0x65, 0xcc},
413         {0xb8, 0x00, 0x00, 0xcc},
414         {0xbc, 0x00, 0xd0, 0xcc},
415         {0xbc, 0x01, 0x01, 0xcc},
416         {0xf0, 0x00, 0x02, 0xbb},
417         {0xc8, 0x9f, 0x0b, 0xbb},
418         {0x5b, 0x00, 0x01, 0xbb},
419         {0x2f, 0xde, 0x20, 0xbb},
420         {0xf0, 0x00, 0x00, 0xbb},
421         {0x20, 0x03, 0x02, 0xbb},
422         {0xf0, 0x00, 0x01, 0xbb},
423         {0x05, 0x00, 0x07, 0xbb},
424         {0x34, 0x00, 0x00, 0xbb},
425         {0x35, 0xff, 0x00, 0xbb},
426         {0xdc, 0x07, 0x02, 0xbb},
427         {0xdd, 0x3c, 0x18, 0xbb},
428         {0xde, 0x92, 0x6d, 0xbb},
429         {0xdf, 0xcd, 0xb1, 0xbb},
430         {0xe0, 0xff, 0xe7, 0xbb},
431         {0x06, 0xf0, 0x0d, 0xbb},
432         {0x06, 0x70, 0x0e, 0xbb},
433         {0x4c, 0x00, 0x01, 0xbb},
434         {0x4d, 0x00, 0x01, 0xbb},
435         {0xf0, 0x00, 0x02, 0xbb},
436         {0x2e, 0x0c, 0x55, 0xbb},
437         {0x21, 0xb6, 0x6e, 0xbb},
438         {0x36, 0x30, 0x10, 0xbb},
439         {0x37, 0x00, 0xc1, 0xbb},
440         {0xf0, 0x00, 0x00, 0xbb},
441         {0x07, 0x00, 0x84, 0xbb},
442         {0x08, 0x02, 0x4a, 0xbb},
443         {0x05, 0x01, 0x10, 0xbb},
444         {0x06, 0x00, 0x39, 0xbb},
445         {0xf0, 0x00, 0x02, 0xbb},
446         {0x58, 0x02, 0x67, 0xbb},
447         {0x57, 0x02, 0x00, 0xbb},
448         {0x5a, 0x02, 0x67, 0xbb},
449         {0x59, 0x02, 0x00, 0xbb},
450         {0x5c, 0x12, 0x0d, 0xbb},
451         {0x5d, 0x16, 0x11, 0xbb},
452         {0x39, 0x06, 0x18, 0xbb},
453         {0x3a, 0x06, 0x18, 0xbb},
454         {0x3b, 0x06, 0x18, 0xbb},
455         {0x3c, 0x06, 0x18, 0xbb},
456         {0x64, 0x7b, 0x5b, 0xbb},
457         {0xf0, 0x00, 0x02, 0xbb},
458         {0x36, 0x30, 0x10, 0xbb},
459         {0x37, 0x00, 0xc0, 0xbb},
460         {0xbc, 0x0e, 0x00, 0xcc},
461         {0xbc, 0x0f, 0x05, 0xcc},
462         {0xbc, 0x10, 0xc0, 0xcc},
463         {0xbc, 0x11, 0x03, 0xcc},
464         {0xb6, 0x00, 0x00, 0xcc},
465         {0xb6, 0x03, 0x02, 0xcc},
466         {0xb6, 0x02, 0x80, 0xcc},
467         {0xb6, 0x05, 0x01, 0xcc},
468         {0xb6, 0x04, 0xe0, 0xcc},
469         {0xb6, 0x12, 0xf8, 0xcc},
470         {0xb6, 0x13, 0x25, 0xcc},
471         {0xb6, 0x18, 0x02, 0xcc},
472         {0xb6, 0x17, 0x58, 0xcc},
473         {0xb6, 0x16, 0x00, 0xcc},
474         {0xb6, 0x22, 0x12, 0xcc},
475         {0xb6, 0x23, 0x0b, 0xcc},
476         {0xbf, 0xc0, 0x39, 0xcc},
477         {0xbf, 0xc1, 0x04, 0xcc},
478         {0xbf, 0xcc, 0x00, 0xcc},
479         {0xbc, 0x02, 0x18, 0xcc},
480         {0xbc, 0x03, 0x50, 0xcc},
481         {0xbc, 0x04, 0x18, 0xcc},
482         {0xbc, 0x05, 0x00, 0xcc},
483         {0xbc, 0x06, 0x00, 0xcc},
484         {0xbc, 0x08, 0x30, 0xcc},
485         {0xbc, 0x09, 0x40, 0xcc},
486         {0xbc, 0x0a, 0x10, 0xcc},
487         {0xbc, 0x0b, 0x00, 0xcc},
488         {0xbc, 0x0c, 0x00, 0xcc},
489         {0xb3, 0x5c, 0x01, 0xcc},
490         {0xf0, 0x00, 0x01, 0xbb},
491         {0x80, 0x00, 0x03, 0xbb},
492         {0x81, 0xc7, 0x14, 0xbb},
493         {0x82, 0xeb, 0xe8, 0xbb},
494         {0x83, 0xfe, 0xf4, 0xbb},
495         {0x84, 0xcd, 0x10, 0xbb},
496         {0x85, 0xf3, 0xee, 0xbb},
497         {0x86, 0xff, 0xf1, 0xbb},
498         {0x87, 0xcd, 0x10, 0xbb},
499         {0x88, 0xf3, 0xee, 0xbb},
500         {0x89, 0x01, 0xf1, 0xbb},
501         {0x8a, 0xe5, 0x17, 0xbb},
502         {0x8b, 0xe8, 0xe2, 0xbb},
503         {0x8c, 0xf7, 0xed, 0xbb},
504         {0x8d, 0x00, 0xff, 0xbb},
505         {0x8e, 0xec, 0x10, 0xbb},
506         {0x8f, 0xf0, 0xed, 0xbb},
507         {0x90, 0xf9, 0xf2, 0xbb},
508         {0x91, 0x00, 0x00, 0xbb},
509         {0x92, 0xe9, 0x0d, 0xbb},
510         {0x93, 0xf4, 0xf2, 0xbb},
511         {0x94, 0xfb, 0xf5, 0xbb},
512         {0x95, 0x00, 0xff, 0xbb},
513         {0xb6, 0x0f, 0x08, 0xbb},
514         {0xb7, 0x3d, 0x16, 0xbb},
515         {0xb8, 0x0c, 0x04, 0xbb},
516         {0xb9, 0x1c, 0x07, 0xbb},
517         {0xba, 0x0a, 0x03, 0xbb},
518         {0xbb, 0x1b, 0x09, 0xbb},
519         {0xbc, 0x17, 0x0d, 0xbb},
520         {0xbd, 0x23, 0x1d, 0xbb},
521         {0xbe, 0x00, 0x28, 0xbb},
522         {0xbf, 0x11, 0x09, 0xbb},
523         {0xc0, 0x16, 0x15, 0xbb},
524         {0xc1, 0x00, 0x1b, 0xbb},
525         {0xc2, 0x0e, 0x07, 0xbb},
526         {0xc3, 0x14, 0x10, 0xbb},
527         {0xc4, 0x00, 0x17, 0xbb},
528         {0x06, 0x74, 0x8e, 0xbb},
529         {0xf0, 0x00, 0x01, 0xbb},
530         {0x06, 0xf4, 0x8e, 0xbb},
531         {0x00, 0x00, 0x50, 0xdd},
532         {0x06, 0x74, 0x8e, 0xbb},
533         {0xf0, 0x00, 0x02, 0xbb},
534         {0x24, 0x50, 0x20, 0xbb},
535         {0xf0, 0x00, 0x02, 0xbb},
536         {0x34, 0x0c, 0x50, 0xbb},
537         {0xb3, 0x01, 0x41, 0xcc},
538         {0xf0, 0x00, 0x00, 0xbb},
539         {0x03, 0x03, 0xc0, 0xbb},
540         {},
541 };
542 static const __u8 mi1310_socinitQVGA_JPG[][4] = {
543         {0xb0, 0x03, 0x19, 0xcc},       {0xb0, 0x04, 0x02, 0xcc},
544         {0xb3, 0x00, 0x64, 0xcc},       {0xb3, 0x00, 0x65, 0xcc},
545         {0xb3, 0x05, 0x00, 0xcc},       {0xb3, 0x06, 0x00, 0xcc},
546         {0xb3, 0x08, 0x01, 0xcc},       {0xb3, 0x09, 0x0c, 0xcc},
547         {0xb3, 0x34, 0x02, 0xcc},       {0xb3, 0x35, 0xdd, 0xcc},
548         {0xb3, 0x02, 0x00, 0xcc},       {0xb3, 0x03, 0x0a, 0xcc},
549         {0xb3, 0x04, 0x05, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
550         {0xb3, 0x21, 0x00, 0xcc},       {0xb3, 0x22, 0x03, 0xcc},
551         {0xb3, 0x23, 0xc0, 0xcc},       {0xb3, 0x14, 0x00, 0xcc},
552         {0xb3, 0x15, 0x00, 0xcc},       {0xb3, 0x16, 0x04, 0xcc},
553         {0xb3, 0x17, 0xff, 0xcc},       {0xb3, 0x00, 0x65, 0xcc},
554         {0xb8, 0x00, 0x00, 0xcc},       {0xbc, 0x00, 0xf0, 0xcc},
555         {0xbc, 0x01, 0x01, 0xcc},       {0xf0, 0x00, 0x02, 0xbb},
556         {0xc8, 0x9f, 0x0b, 0xbb},       {0x5b, 0x00, 0x01, 0xbb},
557         {0x2f, 0xde, 0x20, 0xbb},       {0xf0, 0x00, 0x00, 0xbb},
558         {0x20, 0x03, 0x02, 0xbb},       {0xf0, 0x00, 0x01, 0xbb},
559         {0x05, 0x00, 0x07, 0xbb},       {0x34, 0x00, 0x00, 0xbb},
560         {0x35, 0xff, 0x00, 0xbb},       {0xdc, 0x07, 0x02, 0xbb},
561         {0xdd, 0x3c, 0x18, 0xbb},       {0xde, 0x92, 0x6d, 0xbb},
562         {0xdf, 0xcd, 0xb1, 0xbb},       {0xe0, 0xff, 0xe7, 0xbb},
563         {0x06, 0xf0, 0x0d, 0xbb},       {0x06, 0x70, 0x0e, 0xbb},
564         {0x4c, 0x00, 0x01, 0xbb},       {0x4d, 0x00, 0x01, 0xbb},
565         {0xf0, 0x00, 0x02, 0xbb},       {0x2e, 0x0c, 0x55, 0xbb},
566         {0x21, 0xb6, 0x6e, 0xbb},       {0x36, 0x30, 0x10, 0xbb},
567         {0x37, 0x00, 0xc1, 0xbb},       {0xf0, 0x00, 0x00, 0xbb},
568         {0x07, 0x00, 0x84, 0xbb},       {0x08, 0x02, 0x4a, 0xbb},
569         {0x05, 0x01, 0x10, 0xbb},       {0x06, 0x00, 0x39, 0xbb},
570         {0xf0, 0x00, 0x02, 0xbb},       {0x58, 0x02, 0x67, 0xbb},
571         {0x57, 0x02, 0x00, 0xbb},       {0x5a, 0x02, 0x67, 0xbb},
572         {0x59, 0x02, 0x00, 0xbb},       {0x5c, 0x12, 0x0d, 0xbb},
573         {0x5d, 0x16, 0x11, 0xbb},       {0x39, 0x06, 0x18, 0xbb},
574         {0x3a, 0x06, 0x18, 0xbb},       {0x3b, 0x06, 0x18, 0xbb},
575         {0x3c, 0x06, 0x18, 0xbb},       {0x64, 0x7b, 0x5b, 0xbb},
576         {0xf0, 0x00, 0x02, 0xbb},       {0x36, 0x30, 0x10, 0xbb},
577         {0x37, 0x00, 0xc0, 0xbb},       {0xbc, 0x0e, 0x00, 0xcc},
578         {0xbc, 0x0f, 0x05, 0xcc},       {0xbc, 0x10, 0xc0, 0xcc},
579         {0xbc, 0x11, 0x03, 0xcc},       {0xb6, 0x00, 0x00, 0xcc},
580         {0xb6, 0x03, 0x01, 0xcc},       {0xb6, 0x02, 0x40, 0xcc},
581         {0xb6, 0x05, 0x00, 0xcc},       {0xb6, 0x04, 0xf0, 0xcc},
582         {0xb6, 0x12, 0xf8, 0xcc},       {0xb6, 0x13, 0x25, 0xcc},
583         {0xb6, 0x18, 0x00, 0xcc},       {0xb6, 0x17, 0x96, 0xcc},
584         {0xb6, 0x16, 0x00, 0xcc},       {0xb6, 0x22, 0x12, 0xcc},
585         {0xb6, 0x23, 0x0b, 0xcc},       {0xbf, 0xc0, 0x39, 0xcc},
586         {0xbf, 0xc1, 0x04, 0xcc},       {0xbf, 0xcc, 0x00, 0xcc},
587         {0xb3, 0x5c, 0x01, 0xcc},       {0xf0, 0x00, 0x01, 0xbb},
588         {0x80, 0x00, 0x03, 0xbb},       {0x81, 0xc7, 0x14, 0xbb},
589         {0x82, 0xeb, 0xe8, 0xbb},       {0x83, 0xfe, 0xf4, 0xbb},
590         {0x84, 0xcd, 0x10, 0xbb},       {0x85, 0xf3, 0xee, 0xbb},
591         {0x86, 0xff, 0xf1, 0xbb},       {0x87, 0xcd, 0x10, 0xbb},
592         {0x88, 0xf3, 0xee, 0xbb},       {0x89, 0x01, 0xf1, 0xbb},
593         {0x8a, 0xe5, 0x17, 0xbb},       {0x8b, 0xe8, 0xe2, 0xbb},
594         {0x8c, 0xf7, 0xed, 0xbb},       {0x8d, 0x00, 0xff, 0xbb},
595         {0x8e, 0xec, 0x10, 0xbb},       {0x8f, 0xf0, 0xed, 0xbb},
596         {0x90, 0xf9, 0xf2, 0xbb},       {0x91, 0x00, 0x00, 0xbb},
597         {0x92, 0xe9, 0x0d, 0xbb},       {0x93, 0xf4, 0xf2, 0xbb},
598         {0x94, 0xfb, 0xf5, 0xbb},       {0x95, 0x00, 0xff, 0xbb},
599         {0xb6, 0x0f, 0x08, 0xbb},       {0xb7, 0x3d, 0x16, 0xbb},
600         {0xb8, 0x0c, 0x04, 0xbb},       {0xb9, 0x1c, 0x07, 0xbb},
601         {0xba, 0x0a, 0x03, 0xbb},       {0xbb, 0x1b, 0x09, 0xbb},
602         {0xbc, 0x17, 0x0d, 0xbb},       {0xbd, 0x23, 0x1d, 0xbb},
603         {0xbe, 0x00, 0x28, 0xbb},       {0xbf, 0x11, 0x09, 0xbb},
604         {0xc0, 0x16, 0x15, 0xbb},       {0xc1, 0x00, 0x1b, 0xbb},
605         {0xc2, 0x0e, 0x07, 0xbb},       {0xc3, 0x14, 0x10, 0xbb},
606         {0xc4, 0x00, 0x17, 0xbb},       {0x06, 0x74, 0x8e, 0xbb},
607         {0xf0, 0x00, 0x01, 0xbb},       {0x06, 0xf4, 0x8e, 0xbb},
608         {0x00, 0x00, 0x50, 0xdd},       {0x06, 0x74, 0x8e, 0xbb},
609         {0xf0, 0x00, 0x02, 0xbb},       {0x24, 0x50, 0x20, 0xbb},
610         {0xf0, 0x00, 0x02, 0xbb},       {0x34, 0x0c, 0x50, 0xbb},
611         {0xb3, 0x01, 0x41, 0xcc},       {0xf0, 0x00, 0x00, 0xbb},
612         {0x03, 0x03, 0xc0, 0xbb},
613         {},
614 };
615
616 static const __u8 mi1320_gamma[17] = {
617         0x00, 0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
618         0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff
619 };
620 static const __u8 mi1320_matrix[9] = {
621         0x54, 0xda, 0x06, 0xf1, 0x50, 0xf4, 0xf7, 0xea, 0x52
622 };
623 static const __u8 mi1320_initVGA_data[][4] = {
624         {0xb3, 0x01, 0x01, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
625         {0xb0, 0x03, 0x19, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
626         {0xb0, 0x04, 0x02, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
627         {0xb3, 0x00, 0x64, 0xcc},       {0xb3, 0x00, 0x65, 0xcc},
628         {0xb0, 0x16, 0x03, 0xcc},       {0xb3, 0x05, 0x00, 0xcc},
629         {0xb3, 0x06, 0x00, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
630         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x34, 0x02, 0xcc},
631         {0xb3, 0x35, 0xc8, 0xcc},       {0xb3, 0x02, 0x00, 0xcc},
632         {0xb3, 0x03, 0x0a, 0xcc},       {0xb3, 0x04, 0x05, 0xcc},
633         {0xb3, 0x20, 0x00, 0xcc},       {0xb3, 0x21, 0x00, 0xcc},
634         {0xb3, 0x22, 0x03, 0xcc},       {0xb3, 0x23, 0xc0, 0xcc},
635         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
636         {0xb3, 0x16, 0x04, 0xcc},       {0xb3, 0x17, 0xff, 0xcc},
637         {0xb3, 0x00, 0x67, 0xcc},       {0xbc, 0x00, 0xd0, 0xcc},
638         {0xbc, 0x01, 0x01, 0xcc},       {0xf0, 0x00, 0x00, 0xbb},
639         {0x0d, 0x00, 0x09, 0xbb},       {0x00, 0x01, 0x00, 0xdd},
640         {0x0d, 0x00, 0x08, 0xbb},       {0xf0, 0x00, 0x01, 0xbb},
641         {0xa1, 0x05, 0x00, 0xbb},       {0xa4, 0x03, 0xc0, 0xbb},
642         {0xf0, 0x00, 0x02, 0xbb},       {0x00, 0x00, 0x10, 0xdd},
643         {0xc8, 0x9f, 0x0b, 0xbb},       {0x00, 0x00, 0x10, 0xdd},
644         {0xf0, 0x00, 0x00, 0xbb},       {0x00, 0x00, 0x10, 0xdd},
645         {0x20, 0x01, 0x00, 0xbb},       {0x00, 0x00, 0x10, 0xdd},
646         {0xf0, 0x00, 0x01, 0xbb},       {0x9d, 0x3c, 0xa0, 0xbb},
647         {0x47, 0x30, 0x30, 0xbb},       {0xf0, 0x00, 0x00, 0xbb},
648         {0x0a, 0x80, 0x11, 0xbb},       {0x35, 0x00, 0x22, 0xbb},
649         {0xf0, 0x00, 0x02, 0xbb},       {0x9d, 0xc5, 0x05, 0xbb},
650         {0xdc, 0x0f, 0xfc, 0xbb},       {0xf0, 0x00, 0x01, 0xbb},
651         {0x06, 0x74, 0x0e, 0xbb},       {0x80, 0x00, 0x06, 0xbb},
652         {0x81, 0x04, 0x00, 0xbb},       {0x82, 0x01, 0x02, 0xbb},
653         {0x83, 0x03, 0x02, 0xbb},       {0x84, 0x05, 0x00, 0xbb},
654         {0x85, 0x01, 0x00, 0xbb},       {0x86, 0x03, 0x02, 0xbb},
655         {0x87, 0x05, 0x00, 0xbb},       {0x88, 0x01, 0x00, 0xbb},
656         {0x89, 0x02, 0x02, 0xbb},       {0x8a, 0xfd, 0x04, 0xbb},
657         {0x8b, 0xfc, 0xfd, 0xbb},       {0x8c, 0xff, 0xfd, 0xbb},
658         {0x8d, 0x00, 0x00, 0xbb},       {0x8e, 0xfe, 0x05, 0xbb},
659         {0x8f, 0xfc, 0xfd, 0xbb},       {0x90, 0xfe, 0xfd, 0xbb},
660         {0x91, 0x00, 0x00, 0xbb},       {0x92, 0xfe, 0x03, 0xbb},
661         {0x93, 0xfd, 0xfe, 0xbb},       {0x94, 0xff, 0xfd, 0xbb},
662         {0x95, 0x00, 0x00, 0xbb},       {0xb6, 0x07, 0x05, 0xbb},
663         {0xb7, 0x13, 0x06, 0xbb},       {0xb8, 0x08, 0x06, 0xbb},
664         {0xb9, 0x14, 0x08, 0xbb},       {0xba, 0x06, 0x05, 0xbb},
665         {0xbb, 0x13, 0x06, 0xbb},       {0xbc, 0x03, 0x01, 0xbb},
666         {0xbd, 0x03, 0x04, 0xbb},       {0xbe, 0x00, 0x02, 0xbb},
667         {0xbf, 0x03, 0x01, 0xbb},       {0xc0, 0x02, 0x04, 0xbb},
668         {0xc1, 0x00, 0x04, 0xbb},       {0xc2, 0x02, 0x01, 0xbb},
669         {0xc3, 0x01, 0x03, 0xbb},       {0xc4, 0x00, 0x04, 0xbb},
670         {0xf0, 0x00, 0x00, 0xbb},       {0x05, 0x01, 0x13, 0xbb},
671         {0x06, 0x00, 0x11, 0xbb},       {0x07, 0x00, 0x85, 0xbb},
672         {0x08, 0x00, 0x27, 0xbb},       {0x20, 0x01, 0x03, 0xbb},
673         {0x21, 0x80, 0x00, 0xbb},       {0x22, 0x0d, 0x0f, 0xbb},
674         {0x24, 0x80, 0x00, 0xbb},       {0x59, 0x00, 0xff, 0xbb},
675         {0xf0, 0x00, 0x02, 0xbb},       {0x39, 0x03, 0x0d, 0xbb},
676         {0x3a, 0x06, 0x1b, 0xbb},       {0x3b, 0x00, 0x95, 0xbb},
677         {0x3c, 0x04, 0xdb, 0xbb},       {0x57, 0x02, 0x00, 0xbb},
678         {0x58, 0x02, 0x66, 0xbb},       {0x59, 0x00, 0xff, 0xbb},
679         {0x5a, 0x01, 0x33, 0xbb},       {0x5c, 0x12, 0x0d, 0xbb},
680         {0x5d, 0x16, 0x11, 0xbb},       {0x64, 0x5e, 0x1c, 0xbb},
681         {0xf0, 0x00, 0x02, 0xbb},       {0x2f, 0xd1, 0x00, 0xbb},
682         {0x5b, 0x00, 0x01, 0xbb},       {0xf0, 0x00, 0x02, 0xbb},
683         {0x36, 0x68, 0x10, 0xbb},       {0x00, 0x00, 0x30, 0xdd},
684         {0x37, 0x82, 0x00, 0xbb},       {0xbc, 0x0e, 0x00, 0xcc},
685         {0xbc, 0x0f, 0x05, 0xcc},       {0xbc, 0x10, 0xc0, 0xcc},
686         {0xbc, 0x11, 0x03, 0xcc},       {0xb6, 0x00, 0x00, 0xcc},
687         {0xb6, 0x03, 0x05, 0xcc},       {0xb6, 0x02, 0x00, 0xcc},
688         {0xb6, 0x05, 0x04, 0xcc},       {0xb6, 0x04, 0x00, 0xcc},
689         {0xb6, 0x12, 0xf8, 0xcc},       {0xb6, 0x13, 0x29, 0xcc},
690         {0xb6, 0x18, 0x0a, 0xcc},       {0xb6, 0x17, 0x00, 0xcc},
691         {0xb6, 0x16, 0x00, 0xcc},       {0xb6, 0x22, 0x12, 0xcc},
692         {0xb6, 0x23, 0x0b, 0xcc},       {0xbf, 0xc0, 0x26, 0xcc},
693         {0xbf, 0xc1, 0x02, 0xcc},       {0xbf, 0xcc, 0x04, 0xcc},
694         {0xbc, 0x02, 0x18, 0xcc},       {0xbc, 0x03, 0x50, 0xcc},
695         {0xbc, 0x04, 0x18, 0xcc},       {0xbc, 0x05, 0x00, 0xcc},
696         {0xbc, 0x06, 0x00, 0xcc},       {0xbc, 0x08, 0x30, 0xcc},
697         {0xbc, 0x09, 0x40, 0xcc},       {0xbc, 0x0a, 0x10, 0xcc},
698         {0xbc, 0x0b, 0x00, 0xcc},       {0xbc, 0x0c, 0x00, 0xcc},
699         {0xb3, 0x5c, 0x01, 0xcc},       {0xb3, 0x01, 0x41, 0xcc},
700         {}
701 };
702 static const __u8 mi1320_initQVGA_data[][4] = {
703         {0xb3, 0x01, 0x01, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
704         {0xb0, 0x03, 0x19, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
705         {0xb0, 0x04, 0x02, 0xcc},       {0x00, 0x00, 0x33, 0xdd},
706         {0xb3, 0x00, 0x64, 0xcc},       {0xb3, 0x00, 0x65, 0xcc},
707         {0xb0, 0x16, 0x03, 0xcc},       {0xb3, 0x05, 0x01, 0xcc},
708         {0xb3, 0x06, 0x01, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
709         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x34, 0x02, 0xcc},
710         {0xb3, 0x35, 0xc8, 0xcc},       {0xb3, 0x02, 0x00, 0xcc},
711         {0xb3, 0x03, 0x0a, 0xcc},       {0xb3, 0x04, 0x05, 0xcc},
712         {0xb3, 0x20, 0x00, 0xcc},       {0xb3, 0x21, 0x00, 0xcc},
713         {0xb3, 0x22, 0x01, 0xcc},       {0xb3, 0x23, 0xe0, 0xcc},
714         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
715         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
716         {0xb3, 0x00, 0x65, 0xcc},       {0xb8, 0x00, 0x00, 0xcc},
717         {0xbc, 0x00, 0xd0, 0xcc},       {0xbc, 0x01, 0x01, 0xcc},
718         {0xf0, 0x00, 0x00, 0xbb},       {0x0d, 0x00, 0x09, 0xbb},
719         {0x00, 0x01, 0x00, 0xdd},       {0x0d, 0x00, 0x08, 0xbb},
720         {0xf0, 0x00, 0x00, 0xbb},       {0x02, 0x00, 0x64, 0xbb},
721         {0x05, 0x01, 0x78, 0xbb},       {0x06, 0x00, 0x11, 0xbb},
722         {0x07, 0x01, 0x42, 0xbb},       {0x08, 0x00, 0x11, 0xbb},
723         {0x20, 0x01, 0x00, 0xbb},       {0x21, 0x80, 0x00, 0xbb},
724         {0x22, 0x0d, 0x0f, 0xbb},       {0x24, 0x80, 0x00, 0xbb},
725         {0x59, 0x00, 0xff, 0xbb},       {0xf0, 0x00, 0x01, 0xbb},
726         {0x9d, 0x3c, 0xa0, 0xbb},       {0x47, 0x30, 0x30, 0xbb},
727         {0xf0, 0x00, 0x00, 0xbb},       {0x0a, 0x80, 0x11, 0xbb},
728         {0x35, 0x00, 0x22, 0xbb},       {0xf0, 0x00, 0x02, 0xbb},
729         {0x9d, 0xc5, 0x05, 0xbb},       {0xdc, 0x0f, 0xfc, 0xbb},
730         {0xf0, 0x00, 0x01, 0xbb},       {0x06, 0x74, 0x0e, 0xbb},
731         {0x80, 0x00, 0x06, 0xbb},       {0x81, 0x04, 0x00, 0xbb},
732         {0x82, 0x01, 0x02, 0xbb},       {0x83, 0x03, 0x02, 0xbb},
733         {0x84, 0x05, 0x00, 0xbb},       {0x85, 0x01, 0x00, 0xbb},
734         {0x86, 0x03, 0x02, 0xbb},       {0x87, 0x05, 0x00, 0xbb},
735         {0x88, 0x01, 0x00, 0xbb},       {0x89, 0x02, 0x02, 0xbb},
736         {0x8a, 0xfd, 0x04, 0xbb},       {0x8b, 0xfc, 0xfd, 0xbb},
737         {0x8c, 0xff, 0xfd, 0xbb},       {0x8d, 0x00, 0x00, 0xbb},
738         {0x8e, 0xfe, 0x05, 0xbb},       {0x8f, 0xfc, 0xfd, 0xbb},
739         {0x90, 0xfe, 0xfd, 0xbb},       {0x91, 0x00, 0x00, 0xbb},
740         {0x92, 0xfe, 0x03, 0xbb},       {0x93, 0xfd, 0xfe, 0xbb},
741         {0x94, 0xff, 0xfd, 0xbb},       {0x95, 0x00, 0x00, 0xbb},
742         {0xb6, 0x07, 0x05, 0xbb},       {0xb7, 0x13, 0x06, 0xbb},
743         {0xb8, 0x08, 0x06, 0xbb},       {0xb9, 0x14, 0x08, 0xbb},
744         {0xba, 0x06, 0x05, 0xbb},       {0xbb, 0x13, 0x06, 0xbb},
745         {0xbc, 0x03, 0x01, 0xbb},       {0xbd, 0x03, 0x04, 0xbb},
746         {0xbe, 0x00, 0x02, 0xbb},       {0xbf, 0x03, 0x01, 0xbb},
747         {0xc0, 0x02, 0x04, 0xbb},       {0xc1, 0x00, 0x04, 0xbb},
748         {0xc2, 0x02, 0x01, 0xbb},       {0xc3, 0x01, 0x03, 0xbb},
749         {0xc4, 0x00, 0x04, 0xbb},       {0xf0, 0x00, 0x02, 0xbb},
750         {0xc8, 0x00, 0x00, 0xbb},       {0x2e, 0x00, 0x00, 0xbb},
751         {0x2e, 0x0c, 0x5b, 0xbb},       {0x2f, 0xd1, 0x00, 0xbb},
752         {0x39, 0x03, 0xca, 0xbb},       {0x3a, 0x06, 0x80, 0xbb},
753         {0x3b, 0x01, 0x52, 0xbb},       {0x3c, 0x05, 0x40, 0xbb},
754         {0x57, 0x01, 0x9c, 0xbb},       {0x58, 0x01, 0xee, 0xbb},
755         {0x59, 0x00, 0xf0, 0xbb},       {0x5a, 0x01, 0x20, 0xbb},
756         {0x5c, 0x1d, 0x17, 0xbb},       {0x5d, 0x22, 0x1c, 0xbb},
757         {0x64, 0x1e, 0x1c, 0xbb},       {0x5b, 0x00, 0x01, 0xbb},
758         {0xf0, 0x00, 0x02, 0xbb},       {0x36, 0x68, 0x10, 0xbb},
759         {0x00, 0x00, 0x30, 0xdd},       {0x37, 0x81, 0x00, 0xbb},
760         {0xbc, 0x02, 0x18, 0xcc},       {0xbc, 0x03, 0x50, 0xcc},
761         {0xbc, 0x04, 0x18, 0xcc},       {0xbc, 0x05, 0x00, 0xcc},
762         {0xbc, 0x06, 0x00, 0xcc},       {0xbc, 0x08, 0x30, 0xcc},
763         {0xbc, 0x09, 0x40, 0xcc},       {0xbc, 0x0a, 0x10, 0xcc},
764         {0xbc, 0x0b, 0x00, 0xcc},       {0xbc, 0x0c, 0x00, 0xcc},
765         {0xbf, 0xc0, 0x26, 0xcc},       {0xbf, 0xc1, 0x02, 0xcc},
766         {0xbf, 0xcc, 0x04, 0xcc},       {0xb3, 0x5c, 0x01, 0xcc},
767         {0xb3, 0x01, 0x41, 0xcc},
768         {}
769 };
770
771 static const __u8 po3130_gamma[17] = {
772         0x00, 0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
773         0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff
774 };
775 static const __u8 po3130_matrix[9] = {
776         0x5f, 0xec, 0xf5, 0xf1, 0x5a, 0xf5, 0xf1, 0xec, 0x63
777 };
778
779 static const __u8 po3130_initVGA_data[][4] = {
780         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
781         {0x00, 0x00, 0x50, 0xdd},       {0xb0, 0x03, 0x01, 0xcc},
782         {0xb3, 0x00, 0x04, 0xcc},       {0xb3, 0x00, 0x24, 0xcc},
783         {0xb3, 0x00, 0x25, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
784         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x05, 0x00, 0xcc},
785         {0xb3, 0x06, 0x01, 0xcc},       {0xb3, 0x03, 0x1a, 0xcc},
786         {0xb3, 0x04, 0x15, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
787         {0xb3, 0x21, 0x00, 0xcc},       {0xb3, 0x22, 0x01, 0xcc},
788         {0xb3, 0x23, 0xe8, 0xcc},       {0xb8, 0x08, 0xe8, 0xcc},
789         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
790         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
791         {0xb3, 0x34, 0x01, 0xcc},       {0xb3, 0x35, 0xf6, 0xcc},
792         {0xb3, 0x00, 0x27, 0xcc},       {0xbc, 0x00, 0x71, 0xcc},
793         {0xb8, 0x00, 0x21, 0xcc},       {0xb8, 0x27, 0x20, 0xcc},
794         {0xb8, 0x01, 0x79, 0xcc},       {0xb8, 0x81, 0x09, 0xcc},
795         {0xb8, 0x2c, 0x50, 0xcc},       {0xb8, 0x2d, 0xf8, 0xcc},
796         {0xb8, 0x2e, 0xf8, 0xcc},       {0xb8, 0x2f, 0xf8, 0xcc},
797         {0xb8, 0x30, 0x50, 0xcc},       {0xb8, 0x31, 0xf8, 0xcc},
798         {0xb8, 0x32, 0xf8, 0xcc},       {0xb8, 0x33, 0xf8, 0xcc},
799         {0xb8, 0x34, 0x50, 0xcc},       {0xb8, 0x35, 0x00, 0xcc},
800         {0xb8, 0x36, 0x00, 0xcc},       {0xb8, 0x37, 0x00, 0xcc},
801         {0x00, 0x1e, 0xc6, 0xaa},       {0x00, 0x20, 0x44, 0xaa},
802         {0x00, 0xad, 0x02, 0xaa},       {0x00, 0xae, 0x2c, 0xaa},
803         {0x00, 0x12, 0x08, 0xaa},       {0x00, 0x17, 0x41, 0xaa},
804         {0x00, 0x19, 0x41, 0xaa},       {0x00, 0x1e, 0x06, 0xaa},
805         {0x00, 0x21, 0x00, 0xaa},       {0x00, 0x36, 0xc0, 0xaa},
806         {0x00, 0x37, 0xc8, 0xaa},       {0x00, 0x3b, 0x36, 0xaa},
807         {0x00, 0x4b, 0xfe, 0xaa},       {0x00, 0x51, 0x1c, 0xaa},
808         {0x00, 0x52, 0x01, 0xaa},       {0x00, 0x55, 0x0a, 0xaa},
809         {0x00, 0x59, 0x02, 0xaa},       {0x00, 0x5a, 0x04, 0xaa},
810         {0x00, 0x5c, 0x10, 0xaa},       {0x00, 0x5d, 0x10, 0xaa},
811         {0x00, 0x5e, 0x10, 0xaa},       {0x00, 0x5f, 0x10, 0xaa},
812         {0x00, 0x61, 0x00, 0xaa},       {0x00, 0x62, 0x18, 0xaa},
813         {0x00, 0x63, 0x30, 0xaa},       {0x00, 0x70, 0x68, 0xaa},
814         {0x00, 0x80, 0x71, 0xaa},       {0x00, 0x81, 0x08, 0xaa},
815         {0x00, 0x82, 0x00, 0xaa},       {0x00, 0x83, 0x55, 0xaa},
816         {0x00, 0x84, 0x06, 0xaa},       {0x00, 0x85, 0x06, 0xaa},
817         {0x00, 0x86, 0x13, 0xaa},       {0x00, 0x87, 0x18, 0xaa},
818         {0x00, 0xaa, 0x3f, 0xaa},       {0x00, 0xab, 0x44, 0xaa},
819         {0x00, 0xb0, 0x68, 0xaa},       {0x00, 0xb5, 0x10, 0xaa},
820         {0x00, 0xb8, 0x20, 0xaa},       {0x00, 0xb9, 0xa0, 0xaa},
821         {0x00, 0xbc, 0x04, 0xaa},       {0x00, 0x8b, 0x40, 0xaa},
822         {0x00, 0x8c, 0x91, 0xaa},       {0x00, 0x8d, 0x8f, 0xaa},
823         {0x00, 0x8e, 0x91, 0xaa},       {0x00, 0x8f, 0x43, 0xaa},
824         {0x00, 0x90, 0x92, 0xaa},       {0x00, 0x91, 0x89, 0xaa},
825         {0x00, 0x92, 0x9d, 0xaa},       {0x00, 0x93, 0x46, 0xaa},
826         {0x00, 0xd6, 0x22, 0xaa},       {0x00, 0x73, 0x00, 0xaa},
827         {0x00, 0x74, 0x10, 0xaa},       {0x00, 0x75, 0x20, 0xaa},
828         {0x00, 0x76, 0x2b, 0xaa},       {0x00, 0x77, 0x36, 0xaa},
829         {0x00, 0x78, 0x49, 0xaa},       {0x00, 0x79, 0x5a, 0xaa},
830         {0x00, 0x7a, 0x7f, 0xaa},       {0x00, 0x7b, 0x9b, 0xaa},
831         {0x00, 0x7c, 0xba, 0xaa},       {0x00, 0x7d, 0xd4, 0xaa},
832         {0x00, 0x7e, 0xea, 0xaa},       {0x00, 0xd6, 0x62, 0xaa},
833         {0x00, 0x73, 0x00, 0xaa},       {0x00, 0x74, 0x10, 0xaa},
834         {0x00, 0x75, 0x20, 0xaa},       {0x00, 0x76, 0x2b, 0xaa},
835         {0x00, 0x77, 0x36, 0xaa},       {0x00, 0x78, 0x49, 0xaa},
836         {0x00, 0x79, 0x5a, 0xaa},       {0x00, 0x7a, 0x7f, 0xaa},
837         {0x00, 0x7b, 0x9b, 0xaa},       {0x00, 0x7c, 0xba, 0xaa},
838         {0x00, 0x7d, 0xd4, 0xaa},       {0x00, 0x7e, 0xea, 0xaa},
839         {0x00, 0xd6, 0xa2, 0xaa},       {0x00, 0x73, 0x00, 0xaa},
840         {0x00, 0x74, 0x10, 0xaa},       {0x00, 0x75, 0x20, 0xaa},
841         {0x00, 0x76, 0x2b, 0xaa},       {0x00, 0x77, 0x36, 0xaa},
842         {0x00, 0x78, 0x49, 0xaa},       {0x00, 0x79, 0x5a, 0xaa},
843         {0x00, 0x7a, 0x7f, 0xaa},       {0x00, 0x7b, 0x9b, 0xaa},
844         {0x00, 0x7c, 0xba, 0xaa},       {0x00, 0x7d, 0xd4, 0xaa},
845         {0x00, 0x7e, 0xea, 0xaa},
846         {0x00, 0x4c, 0x07, 0xaa},
847         {0x00, 0x4b, 0xe0, 0xaa},       {0x00, 0x4e, 0x77, 0xaa},
848         {0x00, 0x59, 0x02, 0xaa},       {0x00, 0x4d, 0x0a, 0xaa},
849 /*      {0x00, 0xd1, 0x00, 0xaa},       {0x00, 0x20, 0xc4, 0xaa},
850         {0xb8, 0x8e, 0x00, 0xcc},       {0xb8, 0x8f, 0xff, 0xcc}, */
851         {0x00, 0xd1, 0x3c, 0xaa},       {0x00, 0x20, 0xc4, 0xaa},
852         {0xb8, 0x8e, 0x00, 0xcc},       {0xb8, 0x8f, 0xff, 0xcc},
853         {0xb8, 0xfe, 0x00, 0xcc},       {0xb8, 0xff, 0x28, 0xcc},
854         {0xb9, 0x00, 0x28, 0xcc},       {0xb9, 0x01, 0x28, 0xcc},
855         {0xb9, 0x02, 0x28, 0xcc},       {0xb9, 0x03, 0x00, 0xcc},
856         {0xb9, 0x04, 0x00, 0xcc},       {0xb9, 0x05, 0x3c, 0xcc},
857         {0xb9, 0x06, 0x3c, 0xcc},       {0xb9, 0x07, 0x3c, 0xcc},
858         {0xb9, 0x08, 0x3c, 0xcc},       {0x00, 0x05, 0x00, 0xaa},
859         {0xb3, 0x5c, 0x00, 0xcc},       {0xb3, 0x01, 0x41, 0xcc},
860         {}
861 };
862 static const __u8 po3130_rundata[][4] = {
863         {0x00, 0x47, 0x45, 0xaa},       {0x00, 0x48, 0x9b, 0xaa},
864         {0x00, 0x49, 0x3a, 0xaa},       {0x00, 0x4a, 0x01, 0xaa},
865         {0x00, 0x44, 0x40, 0xaa},
866 /*      {0x00, 0xd5, 0x7c, 0xaa}, */
867         {0x00, 0xad, 0x04, 0xaa},       {0x00, 0xae, 0x00, 0xaa},
868         {0x00, 0xb0, 0x78, 0xaa},       {0x00, 0x98, 0x02, 0xaa},
869         {0x00, 0x94, 0x25, 0xaa},       {0x00, 0x95, 0x25, 0xaa},
870         {0x00, 0x59, 0x68, 0xaa},       {0x00, 0x44, 0x20, 0xaa},
871         {0x00, 0x17, 0x50, 0xaa},       {0x00, 0x19, 0x50, 0xaa},
872         {0x00, 0xd1, 0x3c, 0xaa},       {0x00, 0xd1, 0x3c, 0xaa},
873         {0x00, 0x1e, 0x06, 0xaa},       {0x00, 0x1e, 0x06, 0xaa},
874         {}
875 };
876
877 static const __u8 po3130_initQVGA_data[][4] = {
878         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
879         {0x00, 0x00, 0x50, 0xdd},       {0xb0, 0x03, 0x09, 0xcc},
880         {0xb3, 0x00, 0x04, 0xcc},       {0xb3, 0x00, 0x24, 0xcc},
881         {0xb3, 0x00, 0x25, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
882         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x05, 0x00, 0xcc},
883         {0xb3, 0x06, 0x01, 0xcc},       {0xb3, 0x03, 0x1a, 0xcc},
884         {0xb3, 0x04, 0x15, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
885         {0xb3, 0x21, 0x00, 0xcc},       {0xb3, 0x22, 0x01, 0xcc},
886         {0xb3, 0x23, 0xe0, 0xcc},       {0xb8, 0x08, 0xe0, 0xcc},
887         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
888         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
889         {0xb3, 0x34, 0x01, 0xcc},       {0xb3, 0x35, 0xf6, 0xcc},
890         {0xb3, 0x00, 0x27, 0xcc},       {0xbc, 0x00, 0xd1, 0xcc},
891         {0xb8, 0x00, 0x21, 0xcc},       {0xb8, 0x27, 0x20, 0xcc},
892         {0xb8, 0x01, 0x79, 0xcc},       {0xb8, 0x81, 0x09, 0xcc},
893         {0xb8, 0x2c, 0x50, 0xcc},       {0xb8, 0x2d, 0xf8, 0xcc},
894         {0xb8, 0x2e, 0xf8, 0xcc},       {0xb8, 0x2f, 0xf8, 0xcc},
895         {0xb8, 0x30, 0x50, 0xcc},       {0xb8, 0x31, 0xf8, 0xcc},
896         {0xb8, 0x32, 0xf8, 0xcc},       {0xb8, 0x33, 0xf8, 0xcc},
897         {0xb8, 0x34, 0x50, 0xcc},       {0xb8, 0x35, 0x00, 0xcc},
898         {0xb8, 0x36, 0x00, 0xcc},       {0xb8, 0x37, 0x00, 0xcc},
899         {0x00, 0x1e, 0xc6, 0xaa},       {0x00, 0x20, 0x44, 0xaa},
900         {0x00, 0xad, 0x02, 0xaa},       {0x00, 0xae, 0x2c, 0xaa},
901         {0x00, 0x12, 0x08, 0xaa},       {0x00, 0x17, 0x41, 0xaa},
902         {0x00, 0x19, 0x41, 0xaa},       {0x00, 0x1e, 0x06, 0xaa},
903         {0x00, 0x21, 0x00, 0xaa},       {0x00, 0x36, 0xc0, 0xaa},
904         {0x00, 0x37, 0xc8, 0xaa},       {0x00, 0x3b, 0x36, 0xaa},
905         {0x00, 0x4b, 0xfe, 0xaa},       {0x00, 0x51, 0x1c, 0xaa},
906         {0x00, 0x52, 0x01, 0xaa},       {0x00, 0x55, 0x0a, 0xaa},
907         {0x00, 0x59, 0x6f, 0xaa},       {0x00, 0x5a, 0x04, 0xaa},
908         {0x00, 0x5c, 0x10, 0xaa},       {0x00, 0x5d, 0x10, 0xaa},
909         {0x00, 0x5e, 0x10, 0xaa},       {0x00, 0x5f, 0x10, 0xaa},
910         {0x00, 0x61, 0x00, 0xaa},       {0x00, 0x62, 0x18, 0xaa},
911         {0x00, 0x63, 0x30, 0xaa},       {0x00, 0x70, 0x68, 0xaa},
912         {0x00, 0x80, 0x71, 0xaa},       {0x00, 0x81, 0x08, 0xaa},
913         {0x00, 0x82, 0x00, 0xaa},       {0x00, 0x83, 0x55, 0xaa},
914         {0x00, 0x84, 0x06, 0xaa},       {0x00, 0x85, 0x06, 0xaa},
915         {0x00, 0x86, 0x13, 0xaa},       {0x00, 0x87, 0x18, 0xaa},
916         {0x00, 0xaa, 0x3f, 0xaa},       {0x00, 0xab, 0x44, 0xaa},
917         {0x00, 0xb0, 0x68, 0xaa},       {0x00, 0xb5, 0x10, 0xaa},
918         {0x00, 0xb8, 0x20, 0xaa},       {0x00, 0xb9, 0xa0, 0xaa},
919         {0x00, 0xbc, 0x04, 0xaa},       {0x00, 0x8b, 0x40, 0xaa},
920         {0x00, 0x8c, 0x91, 0xaa},       {0x00, 0x8d, 0x8f, 0xaa},
921         {0x00, 0x8e, 0x91, 0xaa},       {0x00, 0x8f, 0x43, 0xaa},
922         {0x00, 0x90, 0x92, 0xaa},       {0x00, 0x91, 0x89, 0xaa},
923         {0x00, 0x92, 0x9d, 0xaa},       {0x00, 0x93, 0x46, 0xaa},
924         {0x00, 0xd6, 0x22, 0xaa},       {0x00, 0x73, 0x00, 0xaa},
925         {0x00, 0x74, 0x10, 0xaa},       {0x00, 0x75, 0x20, 0xaa},
926         {0x00, 0x76, 0x2b, 0xaa},       {0x00, 0x77, 0x36, 0xaa},
927         {0x00, 0x78, 0x49, 0xaa},       {0x00, 0x79, 0x5a, 0xaa},
928         {0x00, 0x7a, 0x7f, 0xaa},       {0x00, 0x7b, 0x9b, 0xaa},
929         {0x00, 0x7c, 0xba, 0xaa},       {0x00, 0x7d, 0xd4, 0xaa},
930         {0x00, 0x7e, 0xea, 0xaa},       {0x00, 0xd6, 0x62, 0xaa},
931         {0x00, 0x73, 0x00, 0xaa},       {0x00, 0x74, 0x10, 0xaa},
932         {0x00, 0x75, 0x20, 0xaa},       {0x00, 0x76, 0x2b, 0xaa},
933         {0x00, 0x77, 0x36, 0xaa},       {0x00, 0x78, 0x49, 0xaa},
934         {0x00, 0x79, 0x5a, 0xaa},       {0x00, 0x7a, 0x7f, 0xaa},
935         {0x00, 0x7b, 0x9b, 0xaa},       {0x00, 0x7c, 0xba, 0xaa},
936         {0x00, 0x7d, 0xd4, 0xaa},       {0x00, 0x7e, 0xea, 0xaa},
937         {0x00, 0xd6, 0xa2, 0xaa},       {0x00, 0x73, 0x00, 0xaa},
938         {0x00, 0x74, 0x10, 0xaa},       {0x00, 0x75, 0x20, 0xaa},
939         {0x00, 0x76, 0x2b, 0xaa},       {0x00, 0x77, 0x36, 0xaa},
940         {0x00, 0x78, 0x49, 0xaa},       {0x00, 0x79, 0x5a, 0xaa},
941         {0x00, 0x7a, 0x7f, 0xaa},       {0x00, 0x7b, 0x9b, 0xaa},
942         {0x00, 0x7c, 0xba, 0xaa},       {0x00, 0x7d, 0xd4, 0xaa},
943         {0x00, 0x7e, 0xea, 0xaa},       {0x00, 0x4c, 0x07, 0xaa},
944         {0x00, 0x4b, 0xe0, 0xaa},       {0x00, 0x4e, 0x77, 0xaa},
945         {0x00, 0x59, 0x66, 0xaa},       {0x00, 0x4d, 0x0a, 0xaa},
946         {0x00, 0xd1, 0x00, 0xaa},       {0x00, 0x20, 0xc4, 0xaa},
947         {0xb8, 0x8e, 0x00, 0xcc},       {0xb8, 0x8f, 0xff, 0xcc},
948         {0xb8, 0xfe, 0x00, 0xcc},       {0xb8, 0xff, 0x28, 0xcc},
949         {0xb9, 0x00, 0x28, 0xcc},       {0xb9, 0x01, 0x28, 0xcc},
950         {0xb9, 0x02, 0x28, 0xcc},       {0xb9, 0x03, 0x00, 0xcc},
951         {0xb9, 0x04, 0x00, 0xcc},       {0xb9, 0x05, 0x3c, 0xcc},
952         {0xb9, 0x06, 0x3c, 0xcc},       {0xb9, 0x07, 0x3c, 0xcc},
953         {0xb9, 0x08, 0x3c, 0xcc},       {0xbc, 0x02, 0x18, 0xcc},
954         {0xbc, 0x03, 0x50, 0xcc},       {0xbc, 0x04, 0x18, 0xcc},
955         {0xbc, 0x05, 0x00, 0xcc},       {0xbc, 0x06, 0x00, 0xcc},
956         {0xbc, 0x08, 0x30, 0xcc},       {0xbc, 0x09, 0x40, 0xcc},
957         {0xbc, 0x0a, 0x10, 0xcc},       {0xbc, 0x0b, 0x00, 0xcc},
958         {0xbc, 0x0c, 0x00, 0xcc},       {0x00, 0x05, 0x00, 0xaa},
959         {0xb3, 0x5c, 0x00, 0xcc},       {0xb3, 0x01, 0x41, 0xcc},
960         {}
961 };
962
963 static const __u8 hv7131r_gamma[17] = {
964 /*      0x00, 0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
965  *      0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff */
966         0x04, 0x1a, 0x36, 0x55, 0x6f, 0x87, 0x9d, 0xb0, 0xc1,
967         0xcf, 0xda, 0xe4, 0xec, 0xf3, 0xf8, 0xfd, 0xff
968 };
969 static const __u8 hv7131r_matrix[9] = {
970         0x5f, 0xec, 0xf5, 0xf1, 0x5a, 0xf5, 0xf1, 0xec, 0x63
971 };
972 static const __u8 hv7131r_initVGA_data[][4] = {
973         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
974         {0x00, 0x00, 0x50, 0xdd},       {0xb0, 0x03, 0x01, 0xcc},
975         {0xb3, 0x00, 0x24, 0xcc},
976         {0xb3, 0x00, 0x25, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
977         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x05, 0x00, 0xcc},
978         {0xb3, 0x06, 0x01, 0xcc},
979         {0xb3, 0x01, 0x45, 0xcc},       {0xb3, 0x03, 0x0b, 0xcc},
980         {0xb3, 0x04, 0x05, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
981         {0xb3, 0x21, 0x00, 0xcc},
982         {0xb3, 0x22, 0x01, 0xcc},       {0xb3, 0x23, 0xe0, 0xcc},
983         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
984         {0xb3, 0x16, 0x02, 0xcc},
985         {0xb3, 0x17, 0x7f, 0xcc},       {0xb3, 0x34, 0x01, 0xcc},
986         {0xb3, 0x35, 0x91, 0xcc},       {0xb3, 0x00, 0x27, 0xcc},
987         {0xbc, 0x00, 0x73, 0xcc},
988         {0xb8, 0x00, 0x23, 0xcc},       {0x00, 0x01, 0x0c, 0xaa},
989         {0x00, 0x14, 0x01, 0xaa},       {0x00, 0x15, 0xe6, 0xaa},
990         {0x00, 0x16, 0x02, 0xaa},
991         {0x00, 0x17, 0x86, 0xaa},       {0x00, 0x23, 0x00, 0xaa},
992         {0x00, 0x25, 0x09, 0xaa},       {0x00, 0x26, 0x27, 0xaa},
993         {0x00, 0x27, 0xc0, 0xaa},
994         {0xb8, 0x2c, 0x60, 0xcc},       {0xb8, 0x2d, 0xf8, 0xcc},
995         {0xb8, 0x2e, 0xf8, 0xcc},       {0xb8, 0x2f, 0xf8, 0xcc},
996         {0xb8, 0x30, 0x50, 0xcc},
997         {0xb8, 0x31, 0xf8, 0xcc},       {0xb8, 0x32, 0xf8, 0xcc},
998         {0xb8, 0x33, 0xf8, 0xcc},       {0xb8, 0x34, 0x65, 0xcc},
999         {0xb8, 0x35, 0x00, 0xcc},
1000         {0xb8, 0x36, 0x00, 0xcc},       {0xb8, 0x37, 0x00, 0xcc},
1001         {0xb8, 0x27, 0x20, 0xcc},       {0xb8, 0x01, 0x7d, 0xcc},
1002         {0xb8, 0x81, 0x09, 0xcc},
1003         {0xb3, 0x01, 0x41, 0xcc},       {0xb8, 0xfe, 0x00, 0xcc},
1004         {0xb8, 0xff, 0x28, 0xcc},       {0xb9, 0x00, 0x28, 0xcc},
1005         {0xb9, 0x01, 0x28, 0xcc},
1006         {0xb9, 0x02, 0x28, 0xcc},       {0xb9, 0x03, 0x00, 0xcc},
1007         {0xb9, 0x04, 0x00, 0xcc},       {0xb9, 0x05, 0x3c, 0xcc},
1008         {0xb9, 0x06, 0x3c, 0xcc},
1009         {0xb9, 0x07, 0x3c, 0xcc},       {0xb9, 0x08, 0x3c, 0xcc},
1010         {0xb8, 0x8e, 0x00, 0xcc},       {0xb8, 0x8f, 0xff, 0xcc},
1011         {0x00, 0x30, 0x18, 0xaa},
1012         {}
1013 };
1014
1015 static const __u8 hv7131r_initQVGA_data[][4] = {
1016         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
1017         {0x00, 0x00, 0x50, 0xdd},       {0xb0, 0x03, 0x01, 0xcc},
1018         {0xb3, 0x00, 0x24, 0xcc},
1019         {0xb3, 0x00, 0x25, 0xcc},       {0xb3, 0x08, 0x01, 0xcc},
1020         {0xb3, 0x09, 0x0c, 0xcc},       {0xb3, 0x05, 0x00, 0xcc},
1021         {0xb3, 0x06, 0x01, 0xcc},
1022         {0xb3, 0x03, 0x0b, 0xcc},       {0xb3, 0x04, 0x05, 0xcc},
1023         {0xb3, 0x20, 0x00, 0xcc},       {0xb3, 0x21, 0x00, 0xcc},
1024         {0xb3, 0x22, 0x01, 0xcc},
1025         {0xb3, 0x23, 0xe0, 0xcc},       {0xb3, 0x14, 0x00, 0xcc},
1026         {0xb3, 0x15, 0x00, 0xcc},       {0xb3, 0x16, 0x02, 0xcc},
1027         {0xb3, 0x17, 0x7f, 0xcc},
1028         {0xb3, 0x34, 0x01, 0xcc},       {0xb3, 0x35, 0x91, 0xcc},
1029         {0xb3, 0x00, 0x27, 0xcc},       {0xbc, 0x00, 0xd1, 0xcc},
1030         {0xb8, 0x00, 0x21, 0xcc},
1031         {0x00, 0x01, 0x0c, 0xaa},       {0x00, 0x14, 0x01, 0xaa},
1032         {0x00, 0x15, 0xe6, 0xaa},       {0x00, 0x16, 0x02, 0xaa},
1033         {0x00, 0x17, 0x86, 0xaa},
1034         {0x00, 0x23, 0x00, 0xaa},       {0x00, 0x25, 0x01, 0xaa},
1035         {0x00, 0x26, 0xd4, 0xaa},       {0x00, 0x27, 0xc0, 0xaa},
1036         {0xbc, 0x02, 0x08, 0xcc},
1037         {0xbc, 0x03, 0x70, 0xcc},       {0xbc, 0x04, 0x08, 0xcc},
1038         {0xbc, 0x05, 0x00, 0xcc},       {0xbc, 0x06, 0x00, 0xcc},
1039         {0xbc, 0x08, 0x3c, 0xcc},
1040         {0xbc, 0x09, 0x40, 0xcc},       {0xbc, 0x0a, 0x04, 0xcc},
1041         {0xbc, 0x0b, 0x00, 0xcc},       {0xbc, 0x0c, 0x00, 0xcc},
1042         {0xb8, 0xfe, 0x02, 0xcc},
1043         {0xb8, 0xff, 0x07, 0xcc},       {0xb9, 0x00, 0x14, 0xcc},
1044         {0xb9, 0x01, 0x14, 0xcc},       {0xb9, 0x02, 0x14, 0xcc},
1045         {0xb9, 0x03, 0x00, 0xcc},
1046         {0xb9, 0x04, 0x02, 0xcc},       {0xb9, 0x05, 0x05, 0xcc},
1047         {0xb9, 0x06, 0x0f, 0xcc},       {0xb9, 0x07, 0x0f, 0xcc},
1048         {0xb9, 0x08, 0x0f, 0xcc},
1049         {0xb8, 0x2c, 0x60, 0xcc},       {0xb8, 0x2d, 0xf8, 0xcc},
1050         {0xb8, 0x2e, 0xf8, 0xcc},       {0xb8, 0x2f, 0xf8, 0xcc},
1051         {0xb8, 0x30, 0x50, 0xcc},
1052         {0xb8, 0x31, 0xf8, 0xcc},       {0xb8, 0x32, 0xf8, 0xcc},
1053         {0xb8, 0x33, 0xf8, 0xcc},
1054         {0xb8, 0x34, 0x65, 0xcc},       {0xb8, 0x35, 0x00, 0xcc},
1055         {0xb8, 0x36, 0x00, 0xcc},       {0xb8, 0x37, 0x00, 0xcc},
1056         {0xb8, 0x27, 0x20, 0xcc},
1057         {0xb8, 0x01, 0x7d, 0xcc},       {0xb8, 0x81, 0x09, 0xcc},
1058         {0xb3, 0x01, 0x41, 0xcc},       {0xb8, 0xfe, 0x00, 0xcc},
1059         {0xb8, 0xff, 0x28, 0xcc},
1060         {0xb9, 0x00, 0x28, 0xcc},       {0xb9, 0x01, 0x28, 0xcc},
1061         {0xb9, 0x02, 0x28, 0xcc},       {0xb9, 0x03, 0x00, 0xcc},
1062         {0xb9, 0x04, 0x00, 0xcc},
1063         {0xb9, 0x05, 0x3c, 0xcc},       {0xb9, 0x06, 0x3c, 0xcc},
1064         {0xb9, 0x07, 0x3c, 0xcc},       {0xb9, 0x08, 0x3c, 0xcc},
1065         {0xb8, 0x8e, 0x00, 0xcc},
1066         {0xb8, 0x8f, 0xff, 0xcc},       {0x00, 0x30, 0x18, 0xaa},
1067         {}
1068 };
1069
1070 static const __u8 ov7660_gamma[17] = {
1071         0x00, 0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
1072         0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff
1073 };
1074 static const __u8 ov7660_matrix[9] = {
1075         0x5a, 0xf0, 0xf6, 0xf3, 0x57, 0xf6, 0xf3, 0xef, 0x62
1076 };
1077 static const __u8 ov7660_initVGA_data[][4] = {
1078         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
1079         {0x00, 0x00, 0x50, 0xdd},
1080         {0xb0, 0x03, 0x01, 0xcc},
1081         {0xb3, 0x00, 0x21, 0xcc},       {0xb3, 0x00, 0x26, 0xcc},
1082         {0xb3, 0x05, 0x01, 0xcc},
1083         {0xb3, 0x06, 0x03, 0xcc},
1084         {0xb3, 0x03, 0x1f, 0xcc},       {0xb3, 0x04, 0x05, 0xcc},
1085         {0xb3, 0x05, 0x00, 0xcc},
1086         {0xb3, 0x06, 0x01, 0xcc},
1087         {0xb3, 0x15, 0x00, 0xcc},/* 0xb315  <-0 href startl */
1088         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
1089         {0xb3, 0x21, 0x00, 0xcc},
1090         {0xb3, 0x23, 0xe0, 0xcc},       {0xb3, 0x1d, 0x01, 0xcc},
1091         {0xb3, 0x1f, 0x02, 0xcc},
1092         {0xb3, 0x34, 0x01, 0xcc},
1093         {0xb3, 0x35, 0xa1, 0xcc},       {0xb3, 0x00, 0x26, 0xcc},
1094         {0xb8, 0x00, 0x33, 0xcc}, /* 13 */
1095         {0xb8, 0x01, 0x7d, 0xcc},
1096         {0xbc, 0x00, 0x73, 0xcc},       {0xb8, 0x81, 0x09, 0xcc},
1097         {0xb8, 0x27, 0x20, 0xcc},
1098         {0xb8, 0x8f, 0x50, 0xcc},
1099         {0x00, 0x01, 0x80, 0xaa},       {0x00, 0x02, 0x80, 0xaa},
1100         {0x00, 0x12, 0x80, 0xaa},
1101         {0x00, 0x12, 0x05, 0xaa},
1102         {0x00, 0x1e, 0x01, 0xaa},       /* MVFP */
1103         {0x00, 0x3d, 0x40, 0xaa}, /* 0x3d <-40 gamma 01 */
1104         {0x00, 0x41, 0x00, 0xaa}, /* edge 00 */
1105         {0x00, 0x0d, 0x48, 0xaa},       {0x00, 0x0e, 0x04, 0xaa},
1106         {0x00, 0x13, 0xa7, 0xaa},
1107         {0x00, 0x40, 0xc1, 0xaa},       {0x00, 0x35, 0x00, 0xaa},
1108         {0x00, 0x36, 0x00, 0xaa},
1109         {0x00, 0x3c, 0x68, 0xaa},       {0x00, 0x1b, 0x05, 0xaa},
1110         {0x00, 0x39, 0x43, 0xaa},
1111         {0x00, 0x8d, 0xcf, 0xaa},
1112         {0x00, 0x8b, 0xcc, 0xaa},       {0x00, 0x8c, 0xcc, 0xaa},
1113         {0x00, 0x0f, 0x62, 0xaa},
1114         {0x00, 0x35, 0x84, 0xaa},
1115         {0x00, 0x3b, 0x08, 0xaa}, /* 0 * Nightframe 1/4 + 50Hz -> 0xC8 */
1116         {0x00, 0x3a, 0x00, 0xaa}, /* mx change yuyv format 00, 04, 01; 08, 0c*/
1117         {0x00, 0x14, 0x2a, 0xaa}, /* agc ampli */
1118         {0x00, 0x9e, 0x40, 0xaa},       {0xb8, 0x8f, 0x50, 0xcc},
1119         {0x00, 0x01, 0x80, 0xaa},
1120         {0x00, 0x02, 0x80, 0xaa},
1121         {0xb8, 0xfe, 0x00, 0xcc},       {0xb8, 0xff, 0x28, 0xcc},
1122         {0xb9, 0x00, 0x28, 0xcc},
1123         {0xb9, 0x01, 0x28, 0xcc},       {0xb9, 0x02, 0x28, 0xcc},
1124         {0xb9, 0x03, 0x00, 0xcc},
1125         {0xb9, 0x04, 0x00, 0xcc},
1126         {0xb9, 0x05, 0x3c, 0xcc},       {0xb9, 0x06, 0x3c, 0xcc},
1127         {0xb9, 0x07, 0x3c, 0xcc},
1128         {0xb9, 0x08, 0x3c, 0xcc},
1129
1130         {0xb8, 0x8e, 0x00, 0xcc},       {0xb8, 0x8f, 0xff, 0xcc},
1131
1132         {0x00, 0x29, 0x3c, 0xaa},       {0xb3, 0x01, 0x45, 0xcc},
1133         {}
1134 };
1135 static const __u8 ov7660_initQVGA_data[][4] = {
1136         {0xb0, 0x4d, 0x00, 0xcc},       {0xb3, 0x01, 0x01, 0xcc},
1137         {0x00, 0x00, 0x50, 0xdd},       {0xb0, 0x03, 0x01, 0xcc},
1138         {0xb3, 0x00, 0x21, 0xcc},       {0xb3, 0x00, 0x26, 0xcc},
1139         {0xb3, 0x05, 0x01, 0xcc},       {0xb3, 0x06, 0x03, 0xcc},
1140         {0xb3, 0x03, 0x1f, 0xcc},       {0xb3, 0x04, 0x05, 0xcc},
1141         {0xb3, 0x05, 0x00, 0xcc},       {0xb3, 0x06, 0x01, 0xcc},
1142         {0xb3, 0x15, 0x00, 0xcc},/* 0xb315  <-0 href startl */
1143         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
1144         {0xb3, 0x21, 0x00, 0xcc},
1145         {0xb3, 0x23, 0xe0, 0xcc},       {0xb3, 0x1d, 0x01, 0xcc},
1146         {0xb3, 0x1f, 0x02, 0xcc},       {0xb3, 0x34, 0x01, 0xcc},
1147         {0xb3, 0x35, 0xa1, 0xcc},       {0xb3, 0x00, 0x26, 0xcc},
1148         {0xb8, 0x00, 0x33, 0xcc}, /* 13 */
1149         {0xb8, 0x01, 0x7d, 0xcc},
1150 /* sizer */
1151         {0xbc, 0x00, 0xd3, 0xcc},
1152         {0xb8, 0x81, 0x09, 0xcc},       {0xb8, 0x81, 0x09, 0xcc},
1153         {0xb8, 0x27, 0x20, 0xcc},       {0xb8, 0x8f, 0x50, 0xcc},
1154         {0x00, 0x01, 0x80, 0xaa},       {0x00, 0x02, 0x80, 0xaa},
1155         {0x00, 0x12, 0x80, 0xaa},       {0x00, 0x12, 0x05, 0xaa},
1156         {0x00, 0x1e, 0x01, 0xaa},       /* MVFP */
1157         {0x00, 0x3d, 0x40, 0xaa}, /* 0x3d <-40 gamma 01 */
1158         {0x00, 0x41, 0x00, 0xaa}, /* edge 00 */
1159         {0x00, 0x0d, 0x48, 0xaa},       {0x00, 0x0e, 0x04, 0xaa},
1160         {0x00, 0x13, 0xa7, 0xaa},
1161         {0x00, 0x40, 0xc1, 0xaa},       {0x00, 0x35, 0x00, 0xaa},
1162         {0x00, 0x36, 0x00, 0xaa},
1163         {0x00, 0x3c, 0x68, 0xaa},       {0x00, 0x1b, 0x05, 0xaa},
1164         {0x00, 0x39, 0x43, 0xaa},       {0x00, 0x8d, 0xcf, 0xaa},
1165         {0x00, 0x8b, 0xcc, 0xaa},       {0x00, 0x8c, 0xcc, 0xaa},
1166         {0x00, 0x0f, 0x62, 0xaa},       {0x00, 0x35, 0x84, 0xaa},
1167         {0x00, 0x3b, 0x08, 0xaa}, /* 0  * Nightframe 1/4 + 50Hz -> 0xC8 */
1168         {0x00, 0x3a, 0x00, 0xaa}, /* mx change yuyv format 00, 04, 01; 08, 0c*/
1169         {0x00, 0x14, 0x2a, 0xaa}, /* agc ampli */
1170         {0x00, 0x9e, 0x40, 0xaa},       {0xb8, 0x8f, 0x50, 0xcc},
1171         {0x00, 0x01, 0x80, 0xaa},
1172         {0x00, 0x02, 0x80, 0xaa},
1173 /* sizer filters */
1174         {0xbc, 0x02, 0x08, 0xcc},
1175         {0xbc, 0x03, 0x70, 0xcc},
1176         {0xb8, 0x35, 0x00, 0xcc},
1177         {0xb8, 0x36, 0x00, 0xcc},
1178         {0xb8, 0x37, 0x00, 0xcc},
1179         {0xbc, 0x04, 0x08, 0xcc},
1180         {0xbc, 0x05, 0x00, 0xcc},
1181         {0xbc, 0x06, 0x00, 0xcc},
1182         {0xbc, 0x08, 0x3c, 0xcc},
1183         {0xbc, 0x09, 0x40, 0xcc},
1184         {0xbc, 0x0a, 0x04, 0xcc},
1185         {0xbc, 0x0b, 0x00, 0xcc},
1186         {0xbc, 0x0c, 0x00, 0xcc},
1187 /* */
1188         {0xb8, 0xfe, 0x00, 0xcc},
1189         {0xb8, 0xff, 0x28, 0xcc},
1190 /* */
1191         {0xb9, 0x00, 0x28, 0xcc},       {0xb9, 0x01, 0x28, 0xcc},
1192         {0xb9, 0x02, 0x28, 0xcc},       {0xb9, 0x03, 0x00, 0xcc},
1193         {0xb9, 0x04, 0x00, 0xcc},       {0xb9, 0x05, 0x3c, 0xcc},
1194         {0xb9, 0x06, 0x3c, 0xcc},       {0xb9, 0x07, 0x3c, 0xcc},
1195         {0xb9, 0x08, 0x3c, 0xcc},
1196 /* */
1197         {0xb8, 0x8e, 0x00, 0xcc},
1198         {0xb8, 0x8f, 0xff, 0xcc}, /* ff */
1199         {0x00, 0x29, 0x3c, 0xaa},
1200         {0xb3, 0x01, 0x45, 0xcc}, /* 45 */
1201         {}
1202 };
1203
1204 static const __u8 ov7660_50HZ[][4] = {
1205         {0x00, 0x3b, 0x08, 0xaa},
1206         {0x00, 0x9d, 0x40, 0xaa},
1207         {0x00, 0x13, 0xa7, 0xaa},
1208         {}
1209 };
1210
1211 static const __u8 ov7660_60HZ[][4] = {
1212         {0x00, 0x3b, 0x00, 0xaa},
1213         {0x00, 0x9e, 0x40, 0xaa},
1214         {0x00, 0x13, 0xa7, 0xaa},
1215         {}
1216 };
1217
1218 static const __u8 ov7660_NoFliker[][4] = {
1219         {0x00, 0x13, 0x87, 0xaa},
1220         {}
1221 };
1222
1223 static const __u8 ov7670_initVGA_JPG[][4] = {
1224         {0xb3, 0x01, 0x05, 0xcc},
1225         {0x00, 0x00, 0x30, 0xdd},       {0xb0, 0x03, 0x19, 0xcc},
1226         {0x00, 0x00, 0x10, 0xdd},
1227         {0xb0, 0x04, 0x02, 0xcc},       {0x00, 0x00, 0x10, 0xdd},
1228         {0xb3, 0x00, 0x66, 0xcc},       {0xb3, 0x00, 0x67, 0xcc},
1229         {0xb3, 0x35, 0xa1, 0xcc},       {0xb3, 0x34, 0x01, 0xcc},
1230         {0xb3, 0x05, 0x01, 0xcc},       {0xb3, 0x06, 0x01, 0xcc},
1231         {0xb3, 0x08, 0x01, 0xcc},       {0xb3, 0x09, 0x0c, 0xcc},
1232         {0xb3, 0x02, 0x02, 0xcc},       {0xb3, 0x03, 0x1f, 0xcc},
1233         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
1234         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
1235         {0xb3, 0x04, 0x05, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
1236         {0xb3, 0x21, 0x00, 0xcc},       {0xb3, 0x22, 0x01, 0xcc},
1237         {0xb3, 0x23, 0xe0, 0xcc},       {0xbc, 0x00, 0x41, 0xcc},
1238         {0xbc, 0x01, 0x01, 0xcc},       {0x00, 0x12, 0x80, 0xaa},
1239         {0x00, 0x00, 0x20, 0xdd},       {0x00, 0x12, 0x00, 0xaa},
1240         {0x00, 0x11, 0x40, 0xaa},       {0x00, 0x6b, 0x0a, 0xaa},
1241         {0x00, 0x3a, 0x04, 0xaa},       {0x00, 0x40, 0xc0, 0xaa},
1242         {0x00, 0x8c, 0x00, 0xaa},       {0x00, 0x7a, 0x29, 0xaa},
1243         {0x00, 0x7b, 0x0e, 0xaa},       {0x00, 0x7c, 0x1a, 0xaa},
1244         {0x00, 0x7d, 0x31, 0xaa},       {0x00, 0x7e, 0x53, 0xaa},
1245         {0x00, 0x7f, 0x60, 0xaa},       {0x00, 0x80, 0x6b, 0xaa},
1246         {0x00, 0x81, 0x73, 0xaa},       {0x00, 0x82, 0x7b, 0xaa},
1247         {0x00, 0x83, 0x82, 0xaa},       {0x00, 0x84, 0x89, 0xaa},
1248         {0x00, 0x85, 0x96, 0xaa},       {0x00, 0x86, 0xa1, 0xaa},
1249         {0x00, 0x87, 0xb7, 0xaa},       {0x00, 0x88, 0xcc, 0xaa},
1250         {0x00, 0x89, 0xe1, 0xaa},       {0x00, 0x13, 0xe0, 0xaa},
1251         {0x00, 0x00, 0x00, 0xaa},       {0x00, 0x10, 0x00, 0xaa},
1252         {0x00, 0x0d, 0x40, 0xaa},       {0x00, 0x14, 0x28, 0xaa},
1253         {0x00, 0xa5, 0x05, 0xaa},       {0x00, 0xab, 0x07, 0xaa},
1254         {0x00, 0x24, 0x95, 0xaa},       {0x00, 0x25, 0x33, 0xaa},
1255         {0x00, 0x26, 0xe3, 0xaa},       {0x00, 0x9f, 0x88, 0xaa},
1256         {0x00, 0xa0, 0x78, 0xaa},       {0x00, 0x55, 0x90, 0xaa},
1257         {0x00, 0xa1, 0x03, 0xaa},       {0x00, 0xa6, 0xe0, 0xaa},
1258         {0x00, 0xa7, 0xd8, 0xaa},       {0x00, 0xa8, 0xf0, 0xaa},
1259         {0x00, 0xa9, 0x90, 0xaa},       {0x00, 0xaa, 0x14, 0xaa},
1260         {0x00, 0x13, 0xe5, 0xaa},       {0x00, 0x0e, 0x61, 0xaa},
1261         {0x00, 0x0f, 0x4b, 0xaa},       {0x00, 0x16, 0x02, 0xaa},
1262         {0x00, 0x1e, 0x07, 0xaa},       /* MVFP */
1263         {0x00, 0x21, 0x02, 0xaa},
1264         {0x00, 0x22, 0x91, 0xaa},       {0x00, 0x29, 0x07, 0xaa},
1265         {0x00, 0x33, 0x0b, 0xaa},       {0x00, 0x35, 0x0b, 0xaa},
1266         {0x00, 0x37, 0x1d, 0xaa},       {0x00, 0x38, 0x71, 0xaa},
1267         {0x00, 0x39, 0x2a, 0xaa},       {0x00, 0x3c, 0x78, 0xaa},
1268         {0x00, 0x4d, 0x40, 0xaa},       {0x00, 0x4e, 0x20, 0xaa},
1269         {0x00, 0x74, 0x19, 0xaa},       {0x00, 0x8d, 0x4f, 0xaa},
1270         {0x00, 0x8e, 0x00, 0xaa},       {0x00, 0x8f, 0x00, 0xaa},
1271         {0x00, 0x90, 0x00, 0xaa},       {0x00, 0x91, 0x00, 0xaa},
1272         {0x00, 0x96, 0x00, 0xaa},       {0x00, 0x9a, 0x80, 0xaa},
1273         {0x00, 0xb0, 0x84, 0xaa},       {0x00, 0xb1, 0x0c, 0xaa},
1274         {0x00, 0xb2, 0x0e, 0xaa},       {0x00, 0xb3, 0x82, 0xaa},
1275         {0x00, 0xb8, 0x0a, 0xaa},       {0x00, 0x43, 0x14, 0xaa},
1276         {0x00, 0x44, 0xf0, 0xaa},       {0x00, 0x45, 0x45, 0xaa},
1277         {0x00, 0x46, 0x63, 0xaa},       {0x00, 0x47, 0x2d, 0xaa},
1278         {0x00, 0x48, 0x46, 0xaa},       {0x00, 0x59, 0x88, 0xaa},
1279         {0x00, 0x5a, 0xa0, 0xaa},       {0x00, 0x5b, 0xc6, 0xaa},
1280         {0x00, 0x5c, 0x7d, 0xaa},       {0x00, 0x5d, 0x5f, 0xaa},
1281         {0x00, 0x5e, 0x19, 0xaa},       {0x00, 0x6c, 0x0a, 0xaa},
1282         {0x00, 0x6d, 0x55, 0xaa},       {0x00, 0x6e, 0x11, 0xaa},
1283         {0x00, 0x6f, 0x9e, 0xaa},       {0x00, 0x69, 0x00, 0xaa},
1284         {0x00, 0x6a, 0x40, 0xaa},       {0x00, 0x01, 0x40, 0xaa},
1285         {0x00, 0x02, 0x40, 0xaa},       {0x00, 0x13, 0xe7, 0xaa},
1286         {0x00, 0x5f, 0xf0, 0xaa},       {0x00, 0x60, 0xf0, 0xaa},
1287         {0x00, 0x61, 0xf0, 0xaa},       {0x00, 0x27, 0xa0, 0xaa},
1288         {0x00, 0x28, 0x80, 0xaa},       {0x00, 0x2c, 0x90, 0xaa},
1289         {0x00, 0x4f, 0x66, 0xaa},       {0x00, 0x50, 0x66, 0xaa},
1290         {0x00, 0x51, 0x00, 0xaa},       {0x00, 0x52, 0x22, 0xaa},
1291         {0x00, 0x53, 0x5e, 0xaa},       {0x00, 0x54, 0x80, 0xaa},
1292         {0x00, 0x58, 0x9e, 0xaa},       {0x00, 0x41, 0x08, 0xaa},
1293         {0x00, 0x3f, 0x00, 0xaa},       {0x00, 0x75, 0x85, 0xaa},
1294         {0x00, 0x76, 0xe1, 0xaa},       {0x00, 0x4c, 0x00, 0xaa},
1295         {0x00, 0x77, 0x0a, 0xaa},       {0x00, 0x3d, 0x88, 0xaa},
1296         {0x00, 0x4b, 0x09, 0xaa},       {0x00, 0xc9, 0x60, 0xaa},
1297         {0x00, 0x41, 0x38, 0xaa},       {0x00, 0x62, 0x30, 0xaa},
1298         {0x00, 0x63, 0x30, 0xaa},       {0x00, 0x64, 0x08, 0xaa},
1299         {0x00, 0x94, 0x07, 0xaa},       {0x00, 0x95, 0x0b, 0xaa},
1300         {0x00, 0x65, 0x00, 0xaa},       {0x00, 0x66, 0x05, 0xaa},
1301         {0x00, 0x56, 0x50, 0xaa},       {0x00, 0x34, 0x11, 0xaa},
1302         {0x00, 0xa4, 0x88, 0xaa},       {0x00, 0x96, 0x00, 0xaa},
1303         {0x00, 0x97, 0x30, 0xaa},       {0x00, 0x98, 0x20, 0xaa},
1304         {0x00, 0x99, 0x30, 0xaa},       {0x00, 0x9a, 0x84, 0xaa},
1305         {0x00, 0x9b, 0x29, 0xaa},       {0x00, 0x9c, 0x03, 0xaa},
1306         {0x00, 0x78, 0x04, 0xaa},       {0x00, 0x79, 0x01, 0xaa},
1307         {0x00, 0xc8, 0xf0, 0xaa},       {0x00, 0x79, 0x0f, 0xaa},
1308         {0x00, 0xc8, 0x00, 0xaa},       {0x00, 0x79, 0x10, 0xaa},
1309         {0x00, 0xc8, 0x7e, 0xaa},       {0x00, 0x79, 0x0a, 0xaa},
1310         {0x00, 0xc8, 0x80, 0xaa},       {0x00, 0x79, 0x0b, 0xaa},
1311         {0x00, 0xc8, 0x01, 0xaa},       {0x00, 0x79, 0x0c, 0xaa},
1312         {0x00, 0xc8, 0x0f, 0xaa},       {0x00, 0x79, 0x0d, 0xaa},
1313         {0x00, 0xc8, 0x20, 0xaa},       {0x00, 0x79, 0x09, 0xaa},
1314         {0x00, 0xc8, 0x80, 0xaa},       {0x00, 0x79, 0x02, 0xaa},
1315         {0x00, 0xc8, 0xc0, 0xaa},       {0x00, 0x79, 0x03, 0xaa},
1316         {0x00, 0xc8, 0x40, 0xaa},       {0x00, 0x79, 0x05, 0xaa},
1317         {0x00, 0xc8, 0x30, 0xaa},       {0x00, 0x79, 0x26, 0xaa},
1318         {0x00, 0x11, 0x40, 0xaa},       {0x00, 0x3a, 0x04, 0xaa},
1319         {0x00, 0x12, 0x00, 0xaa},       {0x00, 0x40, 0xc0, 0xaa},
1320         {0x00, 0x8c, 0x00, 0xaa},       {0x00, 0x17, 0x14, 0xaa},
1321         {0x00, 0x18, 0x02, 0xaa},       {0x00, 0x32, 0x92, 0xaa},
1322         {0x00, 0x19, 0x02, 0xaa},       {0x00, 0x1a, 0x7a, 0xaa},
1323         {0x00, 0x03, 0x0a, 0xaa},       {0x00, 0x0c, 0x00, 0xaa},
1324         {0x00, 0x3e, 0x00, 0xaa},       {0x00, 0x70, 0x3a, 0xaa},
1325         {0x00, 0x71, 0x35, 0xaa},       {0x00, 0x72, 0x11, 0xaa},
1326         {0x00, 0x73, 0xf0, 0xaa},       {0x00, 0xa2, 0x02, 0xaa},
1327         {0x00, 0xb1, 0x00, 0xaa},       {0x00, 0xb1, 0x0c, 0xaa},
1328         {0x00, 0x1e, 0x37, 0xaa},       /* MVFP */
1329         {0x00, 0xaa, 0x14, 0xaa},
1330         {0x00, 0x24, 0x80, 0xaa},       {0x00, 0x25, 0x74, 0xaa},
1331         {0x00, 0x26, 0xd3, 0xaa},       {0x00, 0x0d, 0x00, 0xaa},
1332         {0x00, 0x14, 0x18, 0xaa},       {0x00, 0x9d, 0x99, 0xaa},
1333         {0x00, 0x9e, 0x7f, 0xaa},       {0x00, 0x64, 0x08, 0xaa},
1334         {0x00, 0x94, 0x07, 0xaa},       {0x00, 0x95, 0x06, 0xaa},
1335         {0x00, 0x66, 0x05, 0xaa},       {0x00, 0x41, 0x08, 0xaa},
1336         {0x00, 0x3f, 0x00, 0xaa},       {0x00, 0x75, 0x07, 0xaa},
1337         {0x00, 0x76, 0xe1, 0xaa},       {0x00, 0x4c, 0x00, 0xaa},
1338         {0x00, 0x77, 0x00, 0xaa},       {0x00, 0x3d, 0xc2, 0xaa},
1339         {0x00, 0x4b, 0x09, 0xaa},       {0x00, 0xc9, 0x60, 0xaa},
1340         {0x00, 0x41, 0x38, 0xaa},       {0xb6, 0x00, 0x00, 0xcc},
1341         {0xb6, 0x03, 0x02, 0xcc},       {0xb6, 0x02, 0x80, 0xcc},
1342         {0xb6, 0x05, 0x01, 0xcc},       {0xb6, 0x04, 0xe0, 0xcc},
1343         {0xb6, 0x12, 0xf8, 0xcc},       {0xb6, 0x13, 0x13, 0xcc},
1344         {0xb6, 0x18, 0x02, 0xcc},       {0xb6, 0x17, 0x58, 0xcc},
1345         {0xb6, 0x16, 0x00, 0xcc},       {0xb6, 0x22, 0x12, 0xcc},
1346         {0xb6, 0x23, 0x0b, 0xcc},       {0xbf, 0xc0, 0x39, 0xcc},
1347         {0xbf, 0xc1, 0x04, 0xcc},       {0xbf, 0xcc, 0x00, 0xcc},
1348         {0xb3, 0x5c, 0x01, 0xcc},       {0xb3, 0x01, 0x45, 0xcc},
1349         {0x00, 0x77, 0x05, 0xaa},
1350         {},
1351 };
1352
1353 static const __u8 ov7670_initQVGA_JPG[][4] = {
1354         {0xb3, 0x01, 0x05, 0xcc},       {0x00, 0x00, 0x30, 0xdd},
1355         {0xb0, 0x03, 0x19, 0xcc},       {0x00, 0x00, 0x10, 0xdd},
1356         {0xb0, 0x04, 0x02, 0xcc},       {0x00, 0x00, 0x10, 0xdd},
1357         {0xb3, 0x00, 0x66, 0xcc},       {0xb3, 0x00, 0x67, 0xcc},
1358         {0xb3, 0x35, 0xa1, 0xcc},       {0xb3, 0x34, 0x01, 0xcc},
1359         {0xb3, 0x05, 0x01, 0xcc},       {0xb3, 0x06, 0x01, 0xcc},
1360         {0xb3, 0x08, 0x01, 0xcc},       {0xb3, 0x09, 0x0c, 0xcc},
1361         {0xb3, 0x02, 0x02, 0xcc},       {0xb3, 0x03, 0x1f, 0xcc},
1362         {0xb3, 0x14, 0x00, 0xcc},       {0xb3, 0x15, 0x00, 0xcc},
1363         {0xb3, 0x16, 0x02, 0xcc},       {0xb3, 0x17, 0x7f, 0xcc},
1364         {0xb3, 0x04, 0x05, 0xcc},       {0xb3, 0x20, 0x00, 0xcc},
1365         {0xb3, 0x21, 0x00, 0xcc},       {0xb3, 0x22, 0x01, 0xcc},
1366         {0xb3, 0x23, 0xe0, 0xcc},       {0xbc, 0x00, 0xd1, 0xcc},
1367         {0xbc, 0x01, 0x01, 0xcc},       {0x00, 0x12, 0x80, 0xaa},
1368         {0x00, 0x00, 0x20, 0xdd},       {0x00, 0x12, 0x00, 0xaa},
1369         {0x00, 0x11, 0x40, 0xaa},       {0x00, 0x6b, 0x0a, 0xaa},
1370         {0x00, 0x3a, 0x04, 0xaa},       {0x00, 0x40, 0xc0, 0xaa},
1371         {0x00, 0x8c, 0x00, 0xaa},       {0x00, 0x7a, 0x29, 0xaa},
1372         {0x00, 0x7b, 0x0e, 0xaa},       {0x00, 0x7c, 0x1a, 0xaa},
1373         {0x00, 0x7d, 0x31, 0xaa},       {0x00, 0x7e, 0x53, 0xaa},
1374         {0x00, 0x7f, 0x60, 0xaa},       {0x00, 0x80, 0x6b, 0xaa},
1375         {0x00, 0x81, 0x73, 0xaa},       {0x00, 0x82, 0x7b, 0xaa},
1376         {0x00, 0x83, 0x82, 0xaa},       {0x00, 0x84, 0x89, 0xaa},
1377         {0x00, 0x85, 0x96, 0xaa},       {0x00, 0x86, 0xa1, 0xaa},
1378         {0x00, 0x87, 0xb7, 0xaa},       {0x00, 0x88, 0xcc, 0xaa},
1379         {0x00, 0x89, 0xe1, 0xaa},       {0x00, 0x13, 0xe0, 0xaa},
1380         {0x00, 0x00, 0x00, 0xaa},       {0x00, 0x10, 0x00, 0xaa},
1381         {0x00, 0x0d, 0x40, 0xaa},       {0x00, 0x14, 0x28, 0xaa},
1382         {0x00, 0xa5, 0x05, 0xaa},       {0x00, 0xab, 0x07, 0xaa},
1383         {0x00, 0x24, 0x95, 0xaa},       {0x00, 0x25, 0x33, 0xaa},
1384         {0x00, 0x26, 0xe3, 0xaa},       {0x00, 0x9f, 0x88, 0xaa},
1385         {0x00, 0xa0, 0x78, 0xaa},       {0x00, 0x55, 0x90, 0xaa},
1386         {0x00, 0xa1, 0x03, 0xaa},       {0x00, 0xa6, 0xe0, 0xaa},
1387         {0x00, 0xa7, 0xd8, 0xaa},       {0x00, 0xa8, 0xf0, 0xaa},
1388         {0x00, 0xa9, 0x90, 0xaa},       {0x00, 0xaa, 0x14, 0xaa},
1389         {0x00, 0x13, 0xe5, 0xaa},       {0x00, 0x0e, 0x61, 0xaa},
1390         {0x00, 0x0f, 0x4b, 0xaa},       {0x00, 0x16, 0x02, 0xaa},
1391         {0x00, 0x1e, 0x07, 0xaa},       /* MVFP */
1392         {0x00, 0x21, 0x02, 0xaa},
1393         {0x00, 0x22, 0x91, 0xaa},       {0x00, 0x29, 0x07, 0xaa},
1394         {0x00, 0x33, 0x0b, 0xaa},       {0x00, 0x35, 0x0b, 0xaa},
1395         {0x00, 0x37, 0x1d, 0xaa},       {0x00, 0x38, 0x71, 0xaa},
1396         {0x00, 0x39, 0x2a, 0xaa},       {0x00, 0x3c, 0x78, 0xaa},
1397         {0x00, 0x4d, 0x40, 0xaa},       {0x00, 0x4e, 0x20, 0xaa},
1398         {0x00, 0x74, 0x19, 0xaa},       {0x00, 0x8d, 0x4f, 0xaa},
1399         {0x00, 0x8e, 0x00, 0xaa},       {0x00, 0x8f, 0x00, 0xaa},
1400         {0x00, 0x90, 0x00, 0xaa},       {0x00, 0x91, 0x00, 0xaa},
1401         {0x00, 0x96, 0x00, 0xaa},       {0x00, 0x9a, 0x80, 0xaa},
1402         {0x00, 0xb0, 0x84, 0xaa},       {0x00, 0xb1, 0x0c, 0xaa},
1403         {0x00, 0xb2, 0x0e, 0xaa},       {0x00, 0xb3, 0x82, 0xaa},
1404         {0x00, 0xb8, 0x0a, 0xaa},       {0x00, 0x43, 0x14, 0xaa},
1405         {0x00, 0x44, 0xf0, 0xaa},       {0x00, 0x45, 0x45, 0xaa},
1406         {0x00, 0x46, 0x63, 0xaa},       {0x00, 0x47, 0x2d, 0xaa},
1407         {0x00, 0x48, 0x46, 0xaa},       {0x00, 0x59, 0x88, 0xaa},
1408         {0x00, 0x5a, 0xa0, 0xaa},       {0x00, 0x5b, 0xc6, 0xaa},
1409         {0x00, 0x5c, 0x7d, 0xaa},       {0x00, 0x5d, 0x5f, 0xaa},
1410         {0x00, 0x5e, 0x19, 0xaa},       {0x00, 0x6c, 0x0a, 0xaa},
1411         {0x00, 0x6d, 0x55, 0xaa},       {0x00, 0x6e, 0x11, 0xaa},
1412         {0x00, 0x6f, 0x9e, 0xaa},       {0x00, 0x69, 0x00, 0xaa},
1413         {0x00, 0x6a, 0x40, 0xaa},       {0x00, 0x01, 0x40, 0xaa},
1414         {0x00, 0x02, 0x40, 0xaa},       {0x00, 0x13, 0xe7, 0xaa},
1415         {0x00, 0x5f, 0xf0, 0xaa},       {0x00, 0x60, 0xf0, 0xaa},
1416         {0x00, 0x61, 0xf0, 0xaa},       {0x00, 0x27, 0xa0, 0xaa},
1417         {0x00, 0x28, 0x80, 0xaa},       {0x00, 0x2c, 0x90, 0xaa},
1418         {0x00, 0x4f, 0x66, 0xaa},       {0x00, 0x50, 0x66, 0xaa},
1419         {0x00, 0x51, 0x00, 0xaa},       {0x00, 0x52, 0x22, 0xaa},
1420         {0x00, 0x53, 0x5e, 0xaa},       {0x00, 0x54, 0x80, 0xaa},
1421         {0x00, 0x58, 0x9e, 0xaa},       {0x00, 0x41, 0x08, 0xaa},
1422         {0x00, 0x3f, 0x00, 0xaa},       {0x00, 0x75, 0x85, 0xaa},
1423         {0x00, 0x76, 0xe1, 0xaa},       {0x00, 0x4c, 0x00, 0xaa},
1424         {0x00, 0x77, 0x0a, 0xaa},       {0x00, 0x3d, 0x88, 0xaa},
1425         {0x00, 0x4b, 0x09, 0xaa},       {0x00, 0xc9, 0x60, 0xaa},
1426         {0x00, 0x41, 0x38, 0xaa},       {0x00, 0x62, 0x30, 0xaa},
1427         {0x00, 0x63, 0x30, 0xaa},       {0x00, 0x64, 0x08, 0xaa},
1428         {0x00, 0x94, 0x07, 0xaa},       {0x00, 0x95, 0x0b, 0xaa},
1429         {0x00, 0x65, 0x00, 0xaa},       {0x00, 0x66, 0x05, 0xaa},
1430         {0x00, 0x56, 0x50, 0xaa},       {0x00, 0x34, 0x11, 0xaa},
1431         {0x00, 0xa4, 0x88, 0xaa},       {0x00, 0x96, 0x00, 0xaa},
1432         {0x00, 0x97, 0x30, 0xaa},       {0x00, 0x98, 0x20, 0xaa},
1433         {0x00, 0x99, 0x30, 0xaa},       {0x00, 0x9a, 0x84, 0xaa},
1434         {0x00, 0x9b, 0x29, 0xaa},       {0x00, 0x9c, 0x03, 0xaa},
1435         {0x00, 0x78, 0x04, 0xaa},       {0x00, 0x79, 0x01, 0xaa},
1436         {0x00, 0xc8, 0xf0, 0xaa},       {0x00, 0x79, 0x0f, 0xaa},
1437         {0x00, 0xc8, 0x00, 0xaa},       {0x00, 0x79, 0x10, 0xaa},
1438         {0x00, 0xc8, 0x7e, 0xaa},       {0x00, 0x79, 0x0a, 0xaa},
1439         {0x00, 0xc8, 0x80, 0xaa},       {0x00, 0x79, 0x0b, 0xaa},
1440         {0x00, 0xc8, 0x01, 0xaa},       {0x00, 0x79, 0x0c, 0xaa},
1441         {0x00, 0xc8, 0x0f, 0xaa},       {0x00, 0x79, 0x0d, 0xaa},
1442         {0x00, 0xc8, 0x20, 0xaa},       {0x00, 0x79, 0x09, 0xaa},
1443         {0x00, 0xc8, 0x80, 0xaa},       {0x00, 0x79, 0x02, 0xaa},
1444         {0x00, 0xc8, 0xc0, 0xaa},       {0x00, 0x79, 0x03, 0xaa},
1445         {0x00, 0xc8, 0x40, 0xaa},       {0x00, 0x79, 0x05, 0xaa},
1446         {0x00, 0xc8, 0x30, 0xaa},       {0x00, 0x79, 0x26, 0xaa},
1447         {0x00, 0x11, 0x40, 0xaa},       {0x00, 0x3a, 0x04, 0xaa},
1448         {0x00, 0x12, 0x00, 0xaa},       {0x00, 0x40, 0xc0, 0xaa},
1449         {0x00, 0x8c, 0x00, 0xaa},       {0x00, 0x17, 0x14, 0xaa},
1450         {0x00, 0x18, 0x02, 0xaa},       {0x00, 0x32, 0x92, 0xaa},
1451         {0x00, 0x19, 0x02, 0xaa},       {0x00, 0x1a, 0x7a, 0xaa},
1452         {0x00, 0x03, 0x0a, 0xaa},       {0x00, 0x0c, 0x00, 0xaa},
1453         {0x00, 0x3e, 0x00, 0xaa},       {0x00, 0x70, 0x3a, 0xaa},
1454         {0x00, 0x71, 0x35, 0xaa},       {0x00, 0x72, 0x11, 0xaa},
1455         {0x00, 0x73, 0xf0, 0xaa},       {0x00, 0xa2, 0x02, 0xaa},
1456         {0x00, 0xb1, 0x00, 0xaa},       {0x00, 0xb1, 0x0c, 0xaa},
1457         {0x00, 0x1e, 0x37, 0xaa},       /* MVFP */
1458         {0x00, 0xaa, 0x14, 0xaa},
1459         {0x00, 0x24, 0x80, 0xaa},       {0x00, 0x25, 0x74, 0xaa},
1460         {0x00, 0x26, 0xd3, 0xaa},       {0x00, 0x0d, 0x00, 0xaa},
1461         {0x00, 0x14, 0x18, 0xaa},       {0x00, 0x9d, 0x99, 0xaa},
1462         {0x00, 0x9e, 0x7f, 0xaa},       {0x00, 0x64, 0x08, 0xaa},
1463         {0x00, 0x94, 0x07, 0xaa},       {0x00, 0x95, 0x06, 0xaa},
1464         {0x00, 0x66, 0x05, 0xaa},       {0x00, 0x41, 0x08, 0xaa},
1465         {0x00, 0x3f, 0x00, 0xaa},       {0x00, 0x75, 0x07, 0xaa},
1466         {0x00, 0x76, 0xe1, 0xaa},       {0x00, 0x4c, 0x00, 0xaa},
1467         {0x00, 0x77, 0x00, 0xaa},       {0x00, 0x3d, 0xc2, 0xaa},
1468         {0x00, 0x4b, 0x09, 0xaa},       {0x00, 0xc9, 0x60, 0xaa},
1469         {0x00, 0x41, 0x38, 0xaa},       {0xb6, 0x00, 0x00, 0xcc},
1470         {0xb6, 0x03, 0x01, 0xcc},       {0xb6, 0x02, 0x40, 0xcc},
1471         {0xb6, 0x05, 0x00, 0xcc},       {0xb6, 0x04, 0xf0, 0xcc},
1472         {0xb6, 0x12, 0xf8, 0xcc},       {0xb6, 0x13, 0x21, 0xcc},
1473         {0xb6, 0x18, 0x00, 0xcc},       {0xb6, 0x17, 0x96, 0xcc},
1474         {0xb6, 0x16, 0x00, 0xcc},       {0xb6, 0x22, 0x12, 0xcc},
1475         {0xb6, 0x23, 0x0b, 0xcc},       {0xbf, 0xc0, 0x39, 0xcc},
1476         {0xbf, 0xc1, 0x04, 0xcc},       {0xbf, 0xcc, 0x00, 0xcc},
1477         {0xbc, 0x02, 0x18, 0xcc},       {0xbc, 0x03, 0x50, 0xcc},
1478         {0xbc, 0x04, 0x18, 0xcc},       {0xbc, 0x05, 0x00, 0xcc},
1479         {0xbc, 0x06, 0x00, 0xcc},       {0xbc, 0x08, 0x30, 0xcc},
1480         {0xbc, 0x09, 0x40, 0xcc},       {0xbc, 0x0a, 0x10, 0xcc},
1481         {0xbc, 0x0b, 0x00, 0xcc},       {0xbc, 0x0c, 0x00, 0xcc},
1482         {0xb3, 0x5c, 0x01, 0xcc},       {0xb3, 0x01, 0x45, 0xcc},
1483         {0x00, 0x77, 0x05, 0xaa },
1484         {},
1485 };
1486 struct sensor_info {
1487         int sensorId;
1488         __u8 I2cAdd;
1489         __u8 IdAdd;
1490         __u16 VpId;
1491         __u8 m1;
1492         __u8 m2;
1493         __u8 op;
1494         };
1495
1496 static const struct sensor_info sensor_info_data[] = {
1497 /*      sensorId,         I2cAdd,       IdAdd,  VpId,  m1,    m2,  op */
1498         {SENSOR_HV7131R,    0x80 | 0x11, 0x00, 0x0209, 0x24, 0x25, 0x01},
1499         {SENSOR_OV7660,     0x80 | 0x21, 0x0a, 0x7660, 0x26, 0x26, 0x05},
1500         {SENSOR_PO3130NC,   0x80 | 0x76, 0x00, 0x3130, 0x24, 0x25, 0x01},
1501         {SENSOR_MI1320,     0x80 | 0xc8, 0x00, 0x148c, 0x64, 0x65, 0x01},
1502         {SENSOR_OV7670,     0x80 | 0x21, 0x0a, 0x7673, 0x66, 0x67, 0x05},
1503         {SENSOR_MI1310_SOC, 0x80 | 0x5d, 0x00, 0x143a, 0x24, 0x25, 0x01},
1504 /* (tested in vc032x_probe_sensor) */
1505 /*      {SENSOR_MI0360,     0x80 | 0x5d, 0x00, 0x8243, 0x24, 0x25, 0x01}, */
1506 };
1507
1508 /* read 'len' bytes in gspca_dev->usb_buf */
1509 static void reg_r(struct gspca_dev *gspca_dev,
1510                   __u16 req,
1511                   __u16 index,
1512                   __u16 len)
1513 {
1514         usb_control_msg(gspca_dev->dev,
1515                         usb_rcvctrlpipe(gspca_dev->dev, 0),
1516                         req,
1517                         USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
1518                         1,                      /* value */
1519                         index, gspca_dev->usb_buf, len,
1520                         500);
1521 }
1522
1523 static void reg_w(struct usb_device *dev,
1524                             __u16 req,
1525                             __u16 value,
1526                             __u16 index)
1527 {
1528         usb_control_msg(dev,
1529                         usb_sndctrlpipe(dev, 0),
1530                         req,
1531                         USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
1532                         value, index, NULL, 0,
1533                         500);
1534 }
1535
1536 static void read_sensor_register(struct gspca_dev *gspca_dev,
1537                                 __u16 address, __u16 *value)
1538 {
1539         struct usb_device *dev = gspca_dev->dev;
1540         __u8 ldata, mdata, hdata;
1541         int retry = 50;
1542
1543         *value = 0;
1544
1545         reg_r(gspca_dev, 0xa1, 0xb33f, 1);
1546         /*PDEBUG(D_PROBE, " I2c Bus Busy Wait  0x%02X ", tmpvalue); */
1547         if (!(gspca_dev->usb_buf[0] & 0x02)) {
1548                 PDEBUG(D_ERR, "I2c Bus Busy Wait %d",
1549                         gspca_dev->usb_buf[0] & 0x02);
1550                 return;
1551         }
1552         reg_w(dev, 0xa0, address, 0xb33a);
1553         reg_w(dev, 0xa0, 0x02, 0xb339);
1554
1555         reg_r(gspca_dev, 0xa1, 0xb33b, 1);
1556         while (retry-- && gspca_dev->usb_buf[0]) {
1557                 reg_r(gspca_dev, 0xa1, 0xb33b, 1);
1558 /*              PDEBUG(D_PROBE, "Read again 0xb33b %d", tmpvalue); */
1559                 msleep(1);
1560         }
1561         reg_r(gspca_dev, 0xa1, 0xb33e, 1);
1562         ldata = gspca_dev->usb_buf[0];
1563         reg_r(gspca_dev, 0xa1, 0xb33d, 1);
1564         mdata = gspca_dev->usb_buf[0];
1565         reg_r(gspca_dev, 0xa1, 0xb33c, 1);
1566         hdata = gspca_dev->usb_buf[0];
1567         PDEBUG(D_PROBE, "Read Sensor %02x%02x %02x",
1568                 hdata, mdata, ldata);
1569         reg_r(gspca_dev, 0xa1, 0xb334, 1);
1570         if (gspca_dev->usb_buf[0] == 0x02)
1571                 *value = (hdata << 8) + mdata;
1572         else
1573                 *value = hdata;
1574 }
1575
1576 static int vc032x_probe_sensor(struct gspca_dev *gspca_dev)
1577 {
1578         struct usb_device *dev = gspca_dev->dev;
1579         int i;
1580         __u16 value;
1581         const struct sensor_info *ptsensor_info;
1582
1583         reg_r(gspca_dev, 0xa1, 0xbfcf, 1);
1584         PDEBUG(D_PROBE, "check sensor header %02x", gspca_dev->usb_buf[0]);
1585         for (i = 0; i < ARRAY_SIZE(sensor_info_data); i++) {
1586                 ptsensor_info = &sensor_info_data[i];
1587                 reg_w(dev, 0xa0, 0x02, 0xb334);
1588                 reg_w(dev, 0xa0, ptsensor_info->m1, 0xb300);
1589                 reg_w(dev, 0xa0, ptsensor_info->m2, 0xb300);
1590                 reg_w(dev, 0xa0, 0x01, 0xb308);
1591                 reg_w(dev, 0xa0, 0x0c, 0xb309);
1592                 reg_w(dev, 0xa0, ptsensor_info->I2cAdd, 0xb335);
1593                 reg_w(dev, 0xa0, ptsensor_info->op, 0xb301);
1594                 read_sensor_register(gspca_dev, ptsensor_info->IdAdd, &value);
1595                 if (value == ptsensor_info->VpId)
1596                         return ptsensor_info->sensorId;
1597
1598                 /* special case for MI0360 */
1599                 if (ptsensor_info->sensorId == SENSOR_MI1310_SOC
1600                     && value == 0x8243)
1601                         return ptsensor_info->sensorId;
1602         }
1603         return -1;
1604 }
1605
1606 static __u8 i2c_write(struct gspca_dev *gspca_dev,
1607                         __u8 reg, const __u8 *val, __u8 size)
1608 {
1609         struct usb_device *dev = gspca_dev->dev;
1610
1611         if (size > 3 || size < 1)
1612                 return -EINVAL;
1613         reg_r(gspca_dev, 0xa1, 0xb33f, 1);
1614         reg_w(dev, 0xa0, size, 0xb334);
1615         reg_w(dev, 0xa0, reg, 0xb33a);
1616         switch (size) {
1617         case 1:
1618                 reg_w(dev, 0xa0, val[0], 0xb336);
1619                 break;
1620         case 2:
1621                 reg_w(dev, 0xa0, val[0], 0xb336);
1622                 reg_w(dev, 0xa0, val[1], 0xb337);
1623                 break;
1624         case 3:
1625                 reg_w(dev, 0xa0, val[0], 0xb336);
1626                 reg_w(dev, 0xa0, val[1], 0xb337);
1627                 reg_w(dev, 0xa0, val[2], 0xb338);
1628                 break;
1629         default:
1630                 reg_w(dev, 0xa0, 0x01, 0xb334);
1631                 return -EINVAL;
1632         }
1633         reg_w(dev, 0xa0, 0x01, 0xb339);
1634         reg_r(gspca_dev, 0xa1, 0xb33b, 1);
1635         return gspca_dev->usb_buf[0] == 0;
1636 }
1637
1638 static void put_tab_to_reg(struct gspca_dev *gspca_dev,
1639                         const __u8 *tab, __u8 tabsize, __u16 addr)
1640 {
1641         int j;
1642         __u16 ad = addr;
1643
1644         for (j = 0; j < tabsize; j++)
1645                 reg_w(gspca_dev->dev, 0xa0, tab[j], ad++);
1646 }
1647
1648 static void usb_exchange(struct gspca_dev *gspca_dev,
1649                         const __u8 data[][4])
1650 {
1651         struct usb_device *dev = gspca_dev->dev;
1652         int i = 0;
1653
1654         for (;;) {
1655                 switch (data[i][3]) {
1656                 default:
1657                         return;
1658                 case 0xcc:                      /* normal write */
1659                         reg_w(dev, 0xa0, data[i][2],
1660                                         ((data[i][0])<<8) | data[i][1]);
1661                         break;
1662                 case 0xaa:                      /* i2c op */
1663                         i2c_write(gspca_dev, data[i][1], &data[i][2], 1);
1664                         break;
1665                 case 0xbb:                      /* i2c op */
1666                         i2c_write(gspca_dev, data[i][0], &data[i][1], 2);
1667                         break;
1668                 case 0xdd:
1669                         msleep(data[i][2] + 10);
1670                         break;
1671                 }
1672                 i++;
1673         }
1674         /*not reached*/
1675 }
1676
1677 /*
1678  "GammaT"=hex:04,17,31,4f,6a,83,99,ad,bf,ce,da,e5,ee,f5,fb,ff,ff
1679  "MatrixT"=hex:60,f9,e5,e7,50,05,f3,e6,66
1680  */
1681
1682 static void vc0321_reset(struct gspca_dev *gspca_dev)
1683 {
1684         reg_w(gspca_dev->dev, 0xa0, 0x00, 0xb04d);
1685         reg_w(gspca_dev->dev, 0xa0, 0x01, 0xb301);
1686         msleep(100);
1687         reg_w(gspca_dev->dev, 0xa0, 0x01, 0xb003);
1688         msleep(100);
1689 }
1690
1691 /* this function is called at probe time */
1692 static int sd_config(struct gspca_dev *gspca_dev,
1693                         const struct usb_device_id *id)
1694 {
1695         struct sd *sd = (struct sd *) gspca_dev;
1696         struct usb_device *dev = gspca_dev->dev;
1697         struct cam *cam;
1698         int sensor;
1699
1700         cam = &gspca_dev->cam;
1701         cam->epaddr = 0x02;
1702         sd->bridge = id->driver_info;
1703
1704         vc0321_reset(gspca_dev);
1705         sensor = vc032x_probe_sensor(gspca_dev);
1706         switch (sensor) {
1707         case -1:
1708                 PDEBUG(D_PROBE, "Unknown sensor...");
1709                 return -EINVAL;
1710         case SENSOR_HV7131R:
1711                 PDEBUG(D_PROBE, "Find Sensor HV7131R");
1712                 break;
1713         case SENSOR_MI0360:
1714                 PDEBUG(D_PROBE, "Find Sensor MI0360");
1715                 sd->bridge = BRIDGE_VC0323;
1716                 break;
1717         case SENSOR_MI1310_SOC:
1718                 PDEBUG(D_PROBE, "Find Sensor MI1310_SOC");
1719                 break;
1720         case SENSOR_MI1320:
1721                 PDEBUG(D_PROBE, "Find Sensor MI1320");
1722                 break;
1723         case SENSOR_OV7660:
1724                 PDEBUG(D_PROBE, "Find Sensor OV7660");
1725                 break;
1726         case SENSOR_OV7670:
1727                 PDEBUG(D_PROBE, "Find Sensor OV7670");
1728                 break;
1729         case SENSOR_PO3130NC:
1730                 PDEBUG(D_PROBE, "Find Sensor PO3130NC");
1731                 break;
1732         }
1733         sd->sensor = sensor;
1734
1735         if (sd->bridge == BRIDGE_VC0321) {
1736                 cam->cam_mode = vc0321_mode;
1737                 cam->nmodes = ARRAY_SIZE(vc0321_mode);
1738         } else {
1739                 cam->cam_mode = vc0323_mode;
1740                 cam->nmodes = ARRAY_SIZE(vc0323_mode);
1741         }
1742
1743         sd->qindex = 7;
1744         sd->hflip = HFLIP_DEF;
1745         sd->vflip = VFLIP_DEF;
1746         if (sd->sensor == SENSOR_OV7670) {
1747                 sd->hflip = 1;
1748                 sd->vflip = 1;
1749         }
1750         sd->autogain = AUTOGAIN_DEF;
1751         sd->lightfreq = FREQ_DEF;
1752         if (sd->sensor != SENSOR_OV7670)
1753                 gspca_dev->ctrl_dis = (1 << LIGHTFREQ_IDX);
1754         switch (sd->sensor) {
1755         case SENSOR_OV7660:
1756         case SENSOR_OV7670:
1757                 break;
1758         default:
1759                 gspca_dev->ctrl_dis = (1 << HFLIP_IDX)
1760                                         | (1 << VFLIP_IDX);
1761                 break;
1762         }
1763
1764         if (sd->bridge == BRIDGE_VC0321) {
1765                 reg_r(gspca_dev, 0x8a, 0, 3);
1766                 reg_w(dev, 0x87, 0x00, 0x0f0f);
1767
1768                 reg_r(gspca_dev, 0x8b, 0, 3);
1769                 reg_w(dev, 0x88, 0x00, 0x0202);
1770         }
1771         return 0;
1772 }
1773
1774 /* this function is called at probe and time */
1775 static int sd_init(struct gspca_dev *gspca_dev)
1776 {
1777         return 0;
1778 }
1779
1780 static void setquality(struct gspca_dev *gspca_dev)
1781 {
1782 }
1783
1784 /* for OV7660 and OV7670 only */
1785 static void sethvflip(struct gspca_dev *gspca_dev)
1786 {
1787         struct sd *sd = (struct sd *) gspca_dev;
1788         __u8 data;
1789
1790         switch (sd->sensor) {
1791         case SENSOR_OV7660:
1792                 data = 1;
1793                 break;
1794         case SENSOR_OV7670:
1795                 data = 7;
1796                 break;
1797         default:
1798                 return;
1799         }
1800         data |= OV7660_MVFP_MIRROR * sd->hflip
1801                 | OV7660_MVFP_VFLIP * sd->vflip;
1802         i2c_write(gspca_dev, OV7660_REG_MVFP, &data, 1);
1803 }
1804
1805 static void setautogain(struct gspca_dev *gspca_dev)
1806 {
1807 }
1808
1809 static void setlightfreq(struct gspca_dev *gspca_dev)
1810 {
1811         struct sd *sd = (struct sd *) gspca_dev;
1812         static const __u8 (*ov7660_freq_tb[3])[4] =
1813                 {ov7660_NoFliker, ov7660_50HZ, ov7660_60HZ};
1814
1815         if (sd->sensor != SENSOR_OV7660)
1816                 return;
1817         usb_exchange(gspca_dev, ov7660_freq_tb[sd->lightfreq]);
1818 }
1819
1820 static int sd_start(struct gspca_dev *gspca_dev)
1821 {
1822         struct sd *sd = (struct sd *) gspca_dev;
1823         const __u8 *GammaT = NULL;
1824         const __u8 *MatrixT = NULL;
1825         int mode;
1826
1827         /* Assume start use the good resolution from gspca_dev->mode */
1828         if (sd->bridge == BRIDGE_VC0321) {
1829                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xbfec);
1830                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xbfed);
1831                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xbfee);
1832                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xbfef);
1833         }
1834
1835         mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv;
1836         switch (sd->sensor) {
1837         case SENSOR_HV7131R:
1838                 GammaT = hv7131r_gamma;
1839                 MatrixT = hv7131r_matrix;
1840                 if (mode) {
1841                         /* 320x240 */
1842                         usb_exchange(gspca_dev, hv7131r_initQVGA_data);
1843                 } else {
1844                         /* 640x480 */
1845                         usb_exchange(gspca_dev, hv7131r_initVGA_data);
1846                 }
1847                 break;
1848         case SENSOR_OV7660:
1849                 GammaT = ov7660_gamma;
1850                 MatrixT = ov7660_matrix;
1851                 if (mode) {
1852                         /* 320x240 */
1853                         usb_exchange(gspca_dev, ov7660_initQVGA_data);
1854                 } else {
1855                         /* 640x480 */
1856                         usb_exchange(gspca_dev, ov7660_initVGA_data);
1857                 }
1858                 break;
1859         case SENSOR_OV7670:
1860                 /*GammaT = ov7660_gamma; */
1861                 /*MatrixT = ov7660_matrix; */
1862                 if (mode) {
1863                         /* 320x240 */
1864                         usb_exchange(gspca_dev, ov7670_initQVGA_JPG);
1865                 } else {
1866                         /* 640x480 */
1867                         usb_exchange(gspca_dev, ov7670_initVGA_JPG);
1868                 }
1869                 break;
1870         case SENSOR_MI0360:
1871                 GammaT = mi1320_gamma;
1872                 MatrixT = mi0360_matrix;
1873                 if (mode) {
1874                         /* 320x240 */
1875                         usb_exchange(gspca_dev, mi0360_initQVGA_JPG);
1876                 } else {
1877                         /* 640x480 */
1878                         usb_exchange(gspca_dev, mi0360_initVGA_JPG);
1879                 }
1880                 break;
1881         case SENSOR_MI1310_SOC:
1882                 if (mode) {
1883                         /* 320x240 */
1884                         usb_exchange(gspca_dev, mi1310_socinitQVGA_JPG);
1885                 } else {
1886                         /* 640x480 */
1887                         usb_exchange(gspca_dev, mi1310_socinitVGA_JPG);
1888                 }
1889                 break;
1890         case SENSOR_MI1320:
1891                 GammaT = mi1320_gamma;
1892                 MatrixT = mi1320_matrix;
1893                 if (mode) {
1894                         /* 320x240 */
1895                         usb_exchange(gspca_dev, mi1320_initQVGA_data);
1896                 } else {
1897                         /* 640x480 */
1898                         usb_exchange(gspca_dev, mi1320_initVGA_data);
1899                 }
1900                 break;
1901         case SENSOR_PO3130NC:
1902                 GammaT = po3130_gamma;
1903                 MatrixT = po3130_matrix;
1904                 if (mode) {
1905                         /* 320x240 */
1906                         usb_exchange(gspca_dev, po3130_initQVGA_data);
1907                 } else {
1908                         /* 640x480 */
1909                         usb_exchange(gspca_dev, po3130_initVGA_data);
1910                 }
1911                 usb_exchange(gspca_dev, po3130_rundata);
1912                 break;
1913         default:
1914                 PDEBUG(D_PROBE, "Damned !! no sensor found Bye");
1915                 return -EMEDIUMTYPE;
1916         }
1917         if (GammaT && MatrixT) {
1918                 put_tab_to_reg(gspca_dev, GammaT, 17, 0xb84a);
1919                 put_tab_to_reg(gspca_dev, GammaT, 17, 0xb85b);
1920                 put_tab_to_reg(gspca_dev, GammaT, 17, 0xb86c);
1921                 put_tab_to_reg(gspca_dev, MatrixT, 9, 0xb82c);
1922
1923                 /* Seem SHARPNESS */
1924                 /*
1925                 reg_w(gspca_dev->dev, 0xa0, 0x80, 0xb80a);
1926                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xb80b);
1927                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xb80e);
1928                 */
1929                 /* all 0x40 ??? do nothing
1930                 reg_w(gspca_dev->dev, 0xa0, 0x40, 0xb822);
1931                 reg_w(gspca_dev->dev, 0xa0, 0x40, 0xb823);
1932                 reg_w(gspca_dev->dev, 0xa0, 0x40, 0xb824);
1933                 */
1934                 /* Only works for HV7131R ??
1935                 reg_r (gspca_dev, 0xa1, 0xb881, 1);
1936                 reg_w(gspca_dev->dev, 0xa0, 0xfe01, 0xb881);
1937                 reg_w(gspca_dev->dev, 0xa0, 0x79, 0xb801);
1938                 */
1939                 /* only hv7131r et ov7660
1940                 reg_w(gspca_dev->dev, 0xa0, 0x20, 0xb827);
1941                 reg_w(gspca_dev->dev, 0xa0, 0xff, 0xb826); * ISP_GAIN 80
1942                 reg_w(gspca_dev->dev, 0xa0, 0x23, 0xb800); * ISP CTRL_BAS
1943                 */
1944                 /* set the led on 0x0892 0x0896 */
1945                 reg_w(gspca_dev->dev, 0x89, 0xffff, 0xfdff);
1946                 msleep(100);
1947                 setquality(gspca_dev);
1948                 sethvflip(gspca_dev);
1949                 setautogain(gspca_dev);
1950                 setlightfreq(gspca_dev);
1951         }
1952         return 0;
1953 }
1954
1955 static void sd_stopN(struct gspca_dev *gspca_dev)
1956 {
1957         struct usb_device *dev = gspca_dev->dev;
1958
1959         reg_w(dev, 0x89, 0xffff, 0xffff);
1960         reg_w(dev, 0xa0, 0x01, 0xb301);
1961         reg_w(dev, 0xa0, 0x09, 0xb003);
1962 }
1963
1964 /* called on streamoff with alt 0 and on disconnect */
1965 static void sd_stop0(struct gspca_dev *gspca_dev)
1966 {
1967         struct usb_device *dev = gspca_dev->dev;
1968
1969         if (!gspca_dev->present)
1970                 return;
1971         reg_w(dev, 0x89, 0xffff, 0xffff);
1972 }
1973
1974 static void sd_pkt_scan(struct gspca_dev *gspca_dev,
1975                         struct gspca_frame *frame,      /* target */
1976                         __u8 *data,                     /* isoc packet */
1977                         int len)                        /* iso pkt length */
1978 {
1979         struct sd *sd = (struct sd *) gspca_dev;
1980
1981         if (data[0] == 0xff && data[1] == 0xd8) {
1982                 PDEBUG(D_PACK,
1983                         "vc032x header packet found len %d", len);
1984                 frame = gspca_frame_add(gspca_dev, LAST_PACKET, frame,
1985                                                 data, 0);
1986                 if (sd->bridge == BRIDGE_VC0321) {
1987 #define VCHDRSZ 46
1988                         data += VCHDRSZ;
1989                         len -= VCHDRSZ;
1990 #undef VCHDRSZ
1991                 }
1992                 gspca_frame_add(gspca_dev, FIRST_PACKET, frame,
1993                                 data, len);
1994                 return;
1995         }
1996         gspca_frame_add(gspca_dev, INTER_PACKET, frame, data, len);
1997 }
1998
1999 static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val)
2000 {
2001         struct sd *sd = (struct sd *) gspca_dev;
2002
2003         sd->autogain = val;
2004         if (gspca_dev->streaming)
2005                 setautogain(gspca_dev);
2006         return 0;
2007 }
2008
2009 static int sd_getautogain(struct gspca_dev *gspca_dev, __s32 *val)
2010 {
2011         struct sd *sd = (struct sd *) gspca_dev;
2012
2013         *val = sd->autogain;
2014         return 0;
2015 }
2016
2017 static int sd_sethflip(struct gspca_dev *gspca_dev, __s32 val)
2018 {
2019         struct sd *sd = (struct sd *) gspca_dev;
2020
2021         sd->hflip = val;
2022         if (gspca_dev->streaming)
2023                 sethvflip(gspca_dev);
2024         return 0;
2025 }
2026
2027 static int sd_gethflip(struct gspca_dev *gspca_dev, __s32 *val)
2028 {
2029         struct sd *sd = (struct sd *) gspca_dev;
2030
2031         *val = sd->hflip;
2032         return 0;
2033 }
2034
2035 static int sd_setvflip(struct gspca_dev *gspca_dev, __s32 val)
2036 {
2037         struct sd *sd = (struct sd *) gspca_dev;
2038
2039         sd->vflip = val;
2040         if (gspca_dev->streaming)
2041                 sethvflip(gspca_dev);
2042         return 0;
2043 }
2044
2045 static int sd_getvflip(struct gspca_dev *gspca_dev, __s32 *val)
2046 {
2047         struct sd *sd = (struct sd *) gspca_dev;
2048
2049         *val = sd->vflip;
2050         return 0;
2051 }
2052
2053 static int sd_setfreq(struct gspca_dev *gspca_dev, __s32 val)
2054 {
2055         struct sd *sd = (struct sd *) gspca_dev;
2056
2057         sd->lightfreq = val;
2058         if (gspca_dev->streaming)
2059                 setlightfreq(gspca_dev);
2060         return 0;
2061 }
2062
2063 static int sd_getfreq(struct gspca_dev *gspca_dev, __s32 *val)
2064 {
2065         struct sd *sd = (struct sd *) gspca_dev;
2066
2067         *val = sd->lightfreq;
2068         return 0;
2069 }
2070
2071 static int sd_querymenu(struct gspca_dev *gspca_dev,
2072                         struct v4l2_querymenu *menu)
2073 {
2074         switch (menu->id) {
2075         case V4L2_CID_POWER_LINE_FREQUENCY:
2076                 switch (menu->index) {
2077                 case 0:         /* V4L2_CID_POWER_LINE_FREQUENCY_DISABLED */
2078                         strcpy((char *) menu->name, "NoFliker");
2079                         return 0;
2080                 case 1:         /* V4L2_CID_POWER_LINE_FREQUENCY_50HZ */
2081                         strcpy((char *) menu->name, "50 Hz");
2082                         return 0;
2083                 case 2:         /* V4L2_CID_POWER_LINE_FREQUENCY_60HZ */
2084                         strcpy((char *) menu->name, "60 Hz");
2085                         return 0;
2086                 }
2087                 break;
2088         }
2089         return -EINVAL;
2090 }
2091
2092 /* sub-driver description */
2093 static const struct sd_desc sd_desc = {
2094         .name = MODULE_NAME,
2095         .ctrls = sd_ctrls,
2096         .nctrls = ARRAY_SIZE(sd_ctrls),
2097         .config = sd_config,
2098         .init = sd_init,
2099         .start = sd_start,
2100         .stopN = sd_stopN,
2101         .stop0 = sd_stop0,
2102         .pkt_scan = sd_pkt_scan,
2103         .querymenu = sd_querymenu,
2104 };
2105
2106 /* -- module initialisation -- */
2107 static const __devinitdata struct usb_device_id device_table[] = {
2108         {USB_DEVICE(0x046d, 0x0892), .driver_info = BRIDGE_VC0321},
2109         {USB_DEVICE(0x046d, 0x0896), .driver_info = BRIDGE_VC0321},
2110         {USB_DEVICE(0x0ac8, 0x0321), .driver_info = BRIDGE_VC0321},
2111         {USB_DEVICE(0x0ac8, 0x0323), .driver_info = BRIDGE_VC0323},
2112         {USB_DEVICE(0x0ac8, 0x0328), .driver_info = BRIDGE_VC0321},
2113         {USB_DEVICE(0x0ac8, 0xc001), .driver_info = BRIDGE_VC0321},
2114         {USB_DEVICE(0x0ac8, 0xc002), .driver_info = BRIDGE_VC0321},
2115         {USB_DEVICE(0x17ef, 0x4802), .driver_info = BRIDGE_VC0323},
2116         {}
2117 };
2118 MODULE_DEVICE_TABLE(usb, device_table);
2119
2120 /* -- device connect -- */
2121 static int sd_probe(struct usb_interface *intf,
2122                         const struct usb_device_id *id)
2123 {
2124         return gspca_dev_probe(intf, id, &sd_desc, sizeof(struct sd),
2125                                 THIS_MODULE);
2126 }
2127
2128 static struct usb_driver sd_driver = {
2129         .name = MODULE_NAME,
2130         .id_table = device_table,
2131         .probe = sd_probe,
2132         .disconnect = gspca_disconnect,
2133 #ifdef CONFIG_PM
2134         .suspend = gspca_suspend,
2135         .resume = gspca_resume,
2136 #endif
2137 };
2138
2139 /* -- module insert / remove -- */
2140 static int __init sd_mod_init(void)
2141 {
2142         if (usb_register(&sd_driver) < 0)
2143                 return -1;
2144         PDEBUG(D_PROBE, "registered");
2145         return 0;
2146 }
2147 static void __exit sd_mod_exit(void)
2148 {
2149         usb_deregister(&sd_driver);
2150         PDEBUG(D_PROBE, "deregistered");
2151 }
2152
2153 module_init(sd_mod_init);
2154 module_exit(sd_mod_exit);