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