1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * vehicle sensor nvp6324
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (C) 2020 Rockchip Electronics Co.Ltd
6*4882a593Smuzhiyun * Authors:
7*4882a593Smuzhiyun * wpzz <randy.wang@rock-chips.com>
8*4882a593Smuzhiyun *
9*4882a593Smuzhiyun */
10*4882a593Smuzhiyun
11*4882a593Smuzhiyun #include <linux/init.h>
12*4882a593Smuzhiyun #include <linux/module.h>
13*4882a593Smuzhiyun #include <linux/kernel.h>
14*4882a593Smuzhiyun #include <linux/delay.h>
15*4882a593Smuzhiyun #include <linux/sched.h>
16*4882a593Smuzhiyun #include <linux/errno.h>
17*4882a593Smuzhiyun #include <linux/sysctl.h>
18*4882a593Smuzhiyun #include <linux/interrupt.h>
19*4882a593Smuzhiyun #include <linux/platform_device.h>
20*4882a593Smuzhiyun #include <linux/proc_fs.h>
21*4882a593Smuzhiyun #include <linux/suspend.h>
22*4882a593Smuzhiyun #include <linux/delay.h>
23*4882a593Smuzhiyun #include <linux/io.h>
24*4882a593Smuzhiyun #include <linux/irq.h>
25*4882a593Smuzhiyun #include <linux/uaccess.h>
26*4882a593Smuzhiyun #include <linux/of_gpio.h>
27*4882a593Smuzhiyun #include <linux/of_irq.h>
28*4882a593Smuzhiyun #include "vehicle_cfg.h"
29*4882a593Smuzhiyun #include "vehicle_main.h"
30*4882a593Smuzhiyun #include "vehicle_ad.h"
31*4882a593Smuzhiyun #include "vehicle_ad_nvp6324.h"
32*4882a593Smuzhiyun
33*4882a593Smuzhiyun enum {
34*4882a593Smuzhiyun CVSTD_720P60 = 0,
35*4882a593Smuzhiyun CVSTD_720P50,
36*4882a593Smuzhiyun CVSTD_1080P30,
37*4882a593Smuzhiyun CVSTD_1080P25,
38*4882a593Smuzhiyun CVSTD_720P30,
39*4882a593Smuzhiyun CVSTD_720P25,
40*4882a593Smuzhiyun CVSTD_SVGAP30,
41*4882a593Smuzhiyun CVSTD_SD,
42*4882a593Smuzhiyun CVSTD_NTSC,
43*4882a593Smuzhiyun CVSTD_PAL
44*4882a593Smuzhiyun };
45*4882a593Smuzhiyun
46*4882a593Smuzhiyun enum {
47*4882a593Smuzhiyun FORCE_PAL_WIDTH = 960,
48*4882a593Smuzhiyun FORCE_PAL_HEIGHT = 576,
49*4882a593Smuzhiyun FORCE_NTSC_WIDTH = 960,
50*4882a593Smuzhiyun FORCE_NTSC_HEIGHT = 480,
51*4882a593Smuzhiyun FORCE_SVGA_WIDTH = 800,
52*4882a593Smuzhiyun FORCE_SVGA_HEIGHT = 600,
53*4882a593Smuzhiyun FORCE_720P_WIDTH = 1280,
54*4882a593Smuzhiyun FORCE_720P_HEIGHT = 720,
55*4882a593Smuzhiyun FORCE_1080P_WIDTH = 1920,
56*4882a593Smuzhiyun FORCE_1080P_HEIGHT = 1080,
57*4882a593Smuzhiyun FORCE_CIF_OUTPUT_FORMAT = CIF_OUTPUT_FORMAT_420,
58*4882a593Smuzhiyun };
59*4882a593Smuzhiyun
60*4882a593Smuzhiyun enum {
61*4882a593Smuzhiyun VIDEO_UNPLUG,
62*4882a593Smuzhiyun VIDEO_IN,
63*4882a593Smuzhiyun VIDEO_LOCKED,
64*4882a593Smuzhiyun VIDEO_UNLOCK
65*4882a593Smuzhiyun };
66*4882a593Smuzhiyun
67*4882a593Smuzhiyun #define JAGUAR1_LINK_FREQ_320M 320000000UL
68*4882a593Smuzhiyun #define JAGUAR1_LINK_FREQ_640M 640000000UL
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun static struct vehicle_ad_dev *nvp6324_g_addev;
71*4882a593Smuzhiyun static int cvstd_mode = CVSTD_1080P25;
72*4882a593Smuzhiyun //static int cvstd_old = CVSTD_720P25;
73*4882a593Smuzhiyun static int cvstd_old = CVSTD_NTSC;
74*4882a593Smuzhiyun
75*4882a593Smuzhiyun //static int cvstd_sd = CVSTD_NTSC;
76*4882a593Smuzhiyun static int cvstd_state = VIDEO_UNPLUG;
77*4882a593Smuzhiyun static int cvstd_old_state = VIDEO_UNLOCK;
78*4882a593Smuzhiyun static int video_mode;
79*4882a593Smuzhiyun static int video_old;
80*4882a593Smuzhiyun
81*4882a593Smuzhiyun static bool g_nvp6324_streaming;
82*4882a593Smuzhiyun
83*4882a593Smuzhiyun #define SENSOR_REGISTER_LEN 1 /* sensor register address bytes*/
84*4882a593Smuzhiyun #define SENSOR_VALUE_LEN 1 /* sensor register value bytes*/
85*4882a593Smuzhiyun #define JAGUAR1_CHIP_ID 0xB0
86*4882a593Smuzhiyun
87*4882a593Smuzhiyun struct rk_sensor_reg {
88*4882a593Smuzhiyun unsigned int reg;
89*4882a593Smuzhiyun unsigned int val;
90*4882a593Smuzhiyun };
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun #define SENSOR_CHANNEL_REG 0x41
93*4882a593Smuzhiyun
94*4882a593Smuzhiyun #define SEQCMD_END 0xFF000000
95*4882a593Smuzhiyun #define SensorEnd {SEQCMD_END, 0x00}
96*4882a593Smuzhiyun
97*4882a593Smuzhiyun #define SENSOR_ID(_msb, _lsb) ((_msb) << 8 | (_lsb))
98*4882a593Smuzhiyun
99*4882a593Smuzhiyun /* NTSC Preview resolution setting*/
100*4882a593Smuzhiyun static struct rk_sensor_reg sensor_preview_data_ntsc_30hz[] = {
101*4882a593Smuzhiyun {0xff, 0x04},
102*4882a593Smuzhiyun {0xa0, 0x24},
103*4882a593Smuzhiyun {0xa1, 0x24},
104*4882a593Smuzhiyun {0xa2, 0x24},
105*4882a593Smuzhiyun {0xa3, 0x24},
106*4882a593Smuzhiyun {0xa4, 0x24},
107*4882a593Smuzhiyun {0xa5, 0x24},
108*4882a593Smuzhiyun {0xa6, 0x24},
109*4882a593Smuzhiyun {0xa7, 0x24},
110*4882a593Smuzhiyun {0xa8, 0x24},
111*4882a593Smuzhiyun {0xa9, 0x24},
112*4882a593Smuzhiyun {0xaa, 0x24},
113*4882a593Smuzhiyun {0xab, 0x24},
114*4882a593Smuzhiyun {0xac, 0x24},
115*4882a593Smuzhiyun {0xad, 0x24},
116*4882a593Smuzhiyun {0xae, 0x24},
117*4882a593Smuzhiyun {0xaf, 0x24},
118*4882a593Smuzhiyun {0xb0, 0x24},
119*4882a593Smuzhiyun {0xb1, 0x24},
120*4882a593Smuzhiyun {0xb2, 0x24},
121*4882a593Smuzhiyun {0xb3, 0x24},
122*4882a593Smuzhiyun {0xb4, 0x24},
123*4882a593Smuzhiyun {0xb5, 0x24},
124*4882a593Smuzhiyun {0xb6, 0x24},
125*4882a593Smuzhiyun {0xb7, 0x24},
126*4882a593Smuzhiyun {0xb8, 0x24},
127*4882a593Smuzhiyun {0xb9, 0x24},
128*4882a593Smuzhiyun {0xba, 0x24},
129*4882a593Smuzhiyun {0xbb, 0x24},
130*4882a593Smuzhiyun {0xbc, 0x24},
131*4882a593Smuzhiyun {0xbd, 0x24},
132*4882a593Smuzhiyun {0xbe, 0x24},
133*4882a593Smuzhiyun {0xbf, 0x24},
134*4882a593Smuzhiyun {0xc0, 0x24},
135*4882a593Smuzhiyun {0xc1, 0x24},
136*4882a593Smuzhiyun {0xc2, 0x24},
137*4882a593Smuzhiyun {0xc3, 0x24},
138*4882a593Smuzhiyun {0xff, 0x21},
139*4882a593Smuzhiyun {0x07, 0x80},
140*4882a593Smuzhiyun {0x07, 0x00},
141*4882a593Smuzhiyun {0xff, 0x0A},
142*4882a593Smuzhiyun {0x77, 0x8F},
143*4882a593Smuzhiyun {0xF7, 0x8F},
144*4882a593Smuzhiyun {0xff, 0x0B},
145*4882a593Smuzhiyun {0x77, 0x8F},
146*4882a593Smuzhiyun {0xF7, 0x8F},
147*4882a593Smuzhiyun
148*4882a593Smuzhiyun {0xFF, 0x21},
149*4882a593Smuzhiyun {0x40, 0xAC},
150*4882a593Smuzhiyun {0x41, 0x10},
151*4882a593Smuzhiyun {0x42, 0x03},
152*4882a593Smuzhiyun {0x43, 0x43},
153*4882a593Smuzhiyun {0x11, 0x04},
154*4882a593Smuzhiyun {0x10, 0x0A},
155*4882a593Smuzhiyun {0x12, 0x06},
156*4882a593Smuzhiyun {0x13, 0x09},
157*4882a593Smuzhiyun {0x17, 0x01},
158*4882a593Smuzhiyun {0x18, 0x0D},
159*4882a593Smuzhiyun {0x15, 0x04},
160*4882a593Smuzhiyun {0x14, 0x16},
161*4882a593Smuzhiyun {0x16, 0x05},
162*4882a593Smuzhiyun {0x19, 0x05},
163*4882a593Smuzhiyun {0x1A, 0x0A},
164*4882a593Smuzhiyun {0x1B, 0x08},
165*4882a593Smuzhiyun {0x1C, 0x07},
166*4882a593Smuzhiyun {0x44, 0x00},
167*4882a593Smuzhiyun {0x49, 0xF3},
168*4882a593Smuzhiyun {0x49, 0xF0},
169*4882a593Smuzhiyun {0x44, 0x02},
170*4882a593Smuzhiyun {0x08, 0x40}, //0x40:non-continue;0x48:continuous
171*4882a593Smuzhiyun {0x0F, 0x01},
172*4882a593Smuzhiyun {0x38, 0x1E},
173*4882a593Smuzhiyun {0x39, 0x1E},
174*4882a593Smuzhiyun {0x3A, 0x1E},
175*4882a593Smuzhiyun {0x3B, 0x1E},
176*4882a593Smuzhiyun {0x07, 0x0f}, //0x07:2lane;0x0f:4lane
177*4882a593Smuzhiyun {0x2D, 0x01}, //0x00:2lane;0x01:4lane
178*4882a593Smuzhiyun {0x45, 0x02},
179*4882a593Smuzhiyun {0xFF, 0x13},
180*4882a593Smuzhiyun {0x30, 0x00},
181*4882a593Smuzhiyun {0x31, 0x00},
182*4882a593Smuzhiyun {0x32, 0x00},
183*4882a593Smuzhiyun
184*4882a593Smuzhiyun {0xFF, 0x00},
185*4882a593Smuzhiyun {0x00, 0x00},
186*4882a593Smuzhiyun {0x01, 0x00},
187*4882a593Smuzhiyun {0x02, 0x00},
188*4882a593Smuzhiyun {0x03, 0x00},
189*4882a593Smuzhiyun {0x04, 0x0e}, //sd_mode
190*4882a593Smuzhiyun {0x05, 0x0e},
191*4882a593Smuzhiyun {0x06, 0x0e},
192*4882a593Smuzhiyun {0x07, 0x0e},
193*4882a593Smuzhiyun {0x08, 0x00}, //ahd_mode
194*4882a593Smuzhiyun {0x09, 0x00},
195*4882a593Smuzhiyun {0x0a, 0x00},
196*4882a593Smuzhiyun {0x0b, 0x00},
197*4882a593Smuzhiyun {0x0c, 0x00},
198*4882a593Smuzhiyun {0x0d, 0x00},
199*4882a593Smuzhiyun {0x0e, 0x00},
200*4882a593Smuzhiyun {0x0f, 0x00},
201*4882a593Smuzhiyun {0x10, 0xa0}, //video_format
202*4882a593Smuzhiyun {0x11, 0xa0},
203*4882a593Smuzhiyun {0x12, 0xa0},
204*4882a593Smuzhiyun {0x13, 0xa0},
205*4882a593Smuzhiyun {0x14, 0x00},
206*4882a593Smuzhiyun {0x15, 0x00},
207*4882a593Smuzhiyun {0x16, 0x00},
208*4882a593Smuzhiyun {0x17, 0x00},
209*4882a593Smuzhiyun {0x18, 0x13},
210*4882a593Smuzhiyun {0x19, 0x13},
211*4882a593Smuzhiyun {0x1a, 0x13},
212*4882a593Smuzhiyun {0x1b, 0x13},
213*4882a593Smuzhiyun {0x1c, 0x1a},
214*4882a593Smuzhiyun {0x1d, 0x1a},
215*4882a593Smuzhiyun {0x1e, 0x1a},
216*4882a593Smuzhiyun {0x1f, 0x1a},
217*4882a593Smuzhiyun {0x20, 0x00},
218*4882a593Smuzhiyun {0x21, 0x00},
219*4882a593Smuzhiyun {0x22, 0x00},
220*4882a593Smuzhiyun {0x23, 0x00},
221*4882a593Smuzhiyun {0x24, 0x90}, //contrast
222*4882a593Smuzhiyun {0x25, 0x90},
223*4882a593Smuzhiyun {0x26, 0x90},
224*4882a593Smuzhiyun {0x27, 0x90},
225*4882a593Smuzhiyun {0x28, 0x90}, //black_level
226*4882a593Smuzhiyun {0x29, 0x90},
227*4882a593Smuzhiyun {0x2a, 0x90},
228*4882a593Smuzhiyun {0x2b, 0x90},
229*4882a593Smuzhiyun {0x30, 0x00}, //y_peaking_mode
230*4882a593Smuzhiyun {0x31, 0x00},
231*4882a593Smuzhiyun {0x32, 0x00},
232*4882a593Smuzhiyun {0x33, 0x00},
233*4882a593Smuzhiyun {0x34, 0x08}, //y_fir_mode
234*4882a593Smuzhiyun {0x35, 0x08},
235*4882a593Smuzhiyun {0x36, 0x08},
236*4882a593Smuzhiyun {0x37, 0x08},
237*4882a593Smuzhiyun {0x40, 0x00},
238*4882a593Smuzhiyun {0x41, 0x00},
239*4882a593Smuzhiyun {0x42, 0x00},
240*4882a593Smuzhiyun {0x43, 0x00},
241*4882a593Smuzhiyun {0x44, 0x00},
242*4882a593Smuzhiyun {0x45, 0x00},
243*4882a593Smuzhiyun {0x46, 0x00},
244*4882a593Smuzhiyun {0x47, 0x00},
245*4882a593Smuzhiyun {0x48, 0x00},
246*4882a593Smuzhiyun {0x49, 0x00},
247*4882a593Smuzhiyun {0x4a, 0x00},
248*4882a593Smuzhiyun {0x4b, 0x00},
249*4882a593Smuzhiyun {0x4c, 0xfe},
250*4882a593Smuzhiyun {0x4d, 0xfe},
251*4882a593Smuzhiyun {0x4e, 0xfe},
252*4882a593Smuzhiyun {0x4f, 0xfe},
253*4882a593Smuzhiyun {0x50, 0xfb},
254*4882a593Smuzhiyun {0x51, 0xfb},
255*4882a593Smuzhiyun {0x52, 0xfb},
256*4882a593Smuzhiyun {0x53, 0xfb},
257*4882a593Smuzhiyun {0x58, 0x80},
258*4882a593Smuzhiyun {0x59, 0x80},
259*4882a593Smuzhiyun {0x5a, 0x80},
260*4882a593Smuzhiyun {0x5b, 0x80},
261*4882a593Smuzhiyun {0x5c, 0x82}, //pal_cm_off
262*4882a593Smuzhiyun {0x5d, 0x82},
263*4882a593Smuzhiyun {0x5e, 0x82},
264*4882a593Smuzhiyun {0x5f, 0x82},
265*4882a593Smuzhiyun {0x60, 0x10},
266*4882a593Smuzhiyun {0x61, 0x10},
267*4882a593Smuzhiyun {0x62, 0x10},
268*4882a593Smuzhiyun {0x63, 0x10},
269*4882a593Smuzhiyun {0x64, 0x18}, //y_delay
270*4882a593Smuzhiyun {0x65, 0x18},
271*4882a593Smuzhiyun {0x66, 0x18},
272*4882a593Smuzhiyun {0x67, 0x18},
273*4882a593Smuzhiyun {0x68, 0x70}, //h_delay_a //h_delay_lsb
274*4882a593Smuzhiyun {0x69, 0x70},
275*4882a593Smuzhiyun {0x6a, 0x70},
276*4882a593Smuzhiyun {0x6b, 0x70},
277*4882a593Smuzhiyun {0x6c, 0x00},
278*4882a593Smuzhiyun {0x6d, 0x00},
279*4882a593Smuzhiyun {0x6e, 0x00},
280*4882a593Smuzhiyun {0x6f, 0x00},
281*4882a593Smuzhiyun {0x70, 0x9e}, //v_crop_start
282*4882a593Smuzhiyun {0x71, 0x9e},
283*4882a593Smuzhiyun {0x72, 0x9e},
284*4882a593Smuzhiyun {0x73, 0x9e},
285*4882a593Smuzhiyun {0x78, 0xc0},
286*4882a593Smuzhiyun {0x79, 0xc0},
287*4882a593Smuzhiyun {0x7a, 0xc0},
288*4882a593Smuzhiyun {0x7b, 0xc0},
289*4882a593Smuzhiyun
290*4882a593Smuzhiyun {0xFF, 0x01},
291*4882a593Smuzhiyun {0x7C, 0x00},
292*4882a593Smuzhiyun {0x84, 0x04},
293*4882a593Smuzhiyun {0x85, 0x04},
294*4882a593Smuzhiyun {0x86, 0x04},
295*4882a593Smuzhiyun {0x87, 0x04},
296*4882a593Smuzhiyun {0x88, 0x01},
297*4882a593Smuzhiyun {0x89, 0x01},
298*4882a593Smuzhiyun {0x8a, 0x01},
299*4882a593Smuzhiyun {0x8b, 0x01},
300*4882a593Smuzhiyun {0x8c, 0x02},
301*4882a593Smuzhiyun {0x8d, 0x02},
302*4882a593Smuzhiyun {0x8e, 0x02},
303*4882a593Smuzhiyun {0x8f, 0x02},
304*4882a593Smuzhiyun {0xEC, 0x00},
305*4882a593Smuzhiyun {0xED, 0x00},
306*4882a593Smuzhiyun {0xEE, 0x00},
307*4882a593Smuzhiyun {0xEF, 0x00},
308*4882a593Smuzhiyun
309*4882a593Smuzhiyun {0xFF, 0x05},
310*4882a593Smuzhiyun {0x00, 0xd0},
311*4882a593Smuzhiyun {0x01, 0x2c},
312*4882a593Smuzhiyun {0x05, 0x20}, //d_agc_option
313*4882a593Smuzhiyun {0x1d, 0x0c},
314*4882a593Smuzhiyun {0x21, 0x20}, //sub contrast
315*4882a593Smuzhiyun {0x24, 0x2a},
316*4882a593Smuzhiyun {0x25, 0xdc}, //fsc_lock_mode
317*4882a593Smuzhiyun {0x26, 0x40},
318*4882a593Smuzhiyun {0x27, 0x57},
319*4882a593Smuzhiyun {0x28, 0x80}, //s_point
320*4882a593Smuzhiyun {0x2b, 0xc0}, //saturation_b
321*4882a593Smuzhiyun {0x31, 0x82},
322*4882a593Smuzhiyun {0x32, 0x10},
323*4882a593Smuzhiyun {0x38, 0x00},
324*4882a593Smuzhiyun {0x47, 0x04},
325*4882a593Smuzhiyun {0x50, 0x84},
326*4882a593Smuzhiyun {0x53, 0x04},
327*4882a593Smuzhiyun {0x57, 0x00},
328*4882a593Smuzhiyun {0x58, 0x77},
329*4882a593Smuzhiyun {0x59, 0x00},
330*4882a593Smuzhiyun {0x5C, 0x78},
331*4882a593Smuzhiyun {0x5F, 0x00},
332*4882a593Smuzhiyun {0x62, 0x20},
333*4882a593Smuzhiyun {0x64, 0x01},
334*4882a593Smuzhiyun {0x65, 0x00},
335*4882a593Smuzhiyun {0x69, 0x00},
336*4882a593Smuzhiyun {0x6E, 0x00}, //VBLK_EXT_EN
337*4882a593Smuzhiyun {0x6F, 0x00}, //VBLK_EXT_[7:0]
338*4882a593Smuzhiyun {0x90, 0x01}, //comb_mode
339*4882a593Smuzhiyun {0x92, 0x00},
340*4882a593Smuzhiyun {0x94, 0x00},
341*4882a593Smuzhiyun {0x95, 0x00},
342*4882a593Smuzhiyun {0xa9, 0x00},
343*4882a593Smuzhiyun {0xb5, 0x00},
344*4882a593Smuzhiyun {0xb7, 0xfc},
345*4882a593Smuzhiyun {0xb8, 0xb8},
346*4882a593Smuzhiyun {0xb9, 0x72},
347*4882a593Smuzhiyun {0xbb, 0x0f},
348*4882a593Smuzhiyun {0xd1, 0x30}, //burst_dec_c
349*4882a593Smuzhiyun {0xd5, 0x80},
350*4882a593Smuzhiyun
351*4882a593Smuzhiyun {0xFF, 0x09},
352*4882a593Smuzhiyun {0x40, 0x00},
353*4882a593Smuzhiyun {0x41, 0x00},
354*4882a593Smuzhiyun {0x42, 0x00},
355*4882a593Smuzhiyun {0x43, 0x00},
356*4882a593Smuzhiyun {0x44, 0x00},
357*4882a593Smuzhiyun {0x45, 0x00},
358*4882a593Smuzhiyun {0x46, 0x00},
359*4882a593Smuzhiyun {0x47, 0x00},
360*4882a593Smuzhiyun {0x50, 0x30},
361*4882a593Smuzhiyun {0x51, 0x6f},
362*4882a593Smuzhiyun {0x52, 0x67},
363*4882a593Smuzhiyun {0x53, 0x48},
364*4882a593Smuzhiyun {0x54, 0x30},
365*4882a593Smuzhiyun {0x55, 0x6f},
366*4882a593Smuzhiyun {0x56, 0x67},
367*4882a593Smuzhiyun {0x57, 0x48},
368*4882a593Smuzhiyun {0x58, 0x30},
369*4882a593Smuzhiyun {0x59, 0x6f},
370*4882a593Smuzhiyun {0x5a, 0x67},
371*4882a593Smuzhiyun {0x5b, 0x48},
372*4882a593Smuzhiyun {0x5c, 0x30},
373*4882a593Smuzhiyun {0x5d, 0x6f},
374*4882a593Smuzhiyun {0x5e, 0x67},
375*4882a593Smuzhiyun {0x5f, 0x48},
376*4882a593Smuzhiyun {0x96, 0x10},
377*4882a593Smuzhiyun {0x97, 0x10},
378*4882a593Smuzhiyun {0x98, 0x00},
379*4882a593Smuzhiyun {0x99, 0x00},
380*4882a593Smuzhiyun {0x9a, 0x00},
381*4882a593Smuzhiyun {0x9b, 0x00},
382*4882a593Smuzhiyun {0x9c, 0x00},
383*4882a593Smuzhiyun {0x9d, 0x00},
384*4882a593Smuzhiyun {0x9e, 0x00},
385*4882a593Smuzhiyun {0xb6, 0x10},
386*4882a593Smuzhiyun {0xb7, 0x10},
387*4882a593Smuzhiyun {0xb8, 0x00},
388*4882a593Smuzhiyun {0xb9, 0x00},
389*4882a593Smuzhiyun {0xba, 0x00},
390*4882a593Smuzhiyun {0xbb, 0x00},
391*4882a593Smuzhiyun {0xbc, 0x00},
392*4882a593Smuzhiyun {0xbd, 0x00},
393*4882a593Smuzhiyun {0xbe, 0x00},
394*4882a593Smuzhiyun {0xd6, 0x10},
395*4882a593Smuzhiyun {0xd7, 0x10},
396*4882a593Smuzhiyun {0xd8, 0x00},
397*4882a593Smuzhiyun {0xd9, 0x00},
398*4882a593Smuzhiyun {0xda, 0x00},
399*4882a593Smuzhiyun {0xdb, 0x00},
400*4882a593Smuzhiyun {0xdc, 0x00},
401*4882a593Smuzhiyun {0xdd, 0x00},
402*4882a593Smuzhiyun {0xde, 0x00},
403*4882a593Smuzhiyun {0xf6, 0x10},
404*4882a593Smuzhiyun {0xf7, 0x10},
405*4882a593Smuzhiyun {0xf8, 0x00},
406*4882a593Smuzhiyun {0xf9, 0x00},
407*4882a593Smuzhiyun {0xfa, 0x00},
408*4882a593Smuzhiyun {0xfb, 0x00},
409*4882a593Smuzhiyun {0xfc, 0x00},
410*4882a593Smuzhiyun {0xfd, 0x00},
411*4882a593Smuzhiyun {0xfe, 0x00},
412*4882a593Smuzhiyun
413*4882a593Smuzhiyun {0xff, 0x0a},
414*4882a593Smuzhiyun {0x3d, 0x00},
415*4882a593Smuzhiyun {0x3c, 0x00},
416*4882a593Smuzhiyun {0x30, 0xac},
417*4882a593Smuzhiyun {0x31, 0x78},
418*4882a593Smuzhiyun {0x32, 0x17},
419*4882a593Smuzhiyun {0x33, 0xc1},
420*4882a593Smuzhiyun {0x34, 0x40},
421*4882a593Smuzhiyun {0x35, 0x00},
422*4882a593Smuzhiyun {0x36, 0xc3},
423*4882a593Smuzhiyun {0x37, 0x0a},
424*4882a593Smuzhiyun {0x38, 0x00},
425*4882a593Smuzhiyun {0x39, 0x02},
426*4882a593Smuzhiyun {0x3a, 0x00},
427*4882a593Smuzhiyun {0x3b, 0xb2},
428*4882a593Smuzhiyun {0x25, 0x10},
429*4882a593Smuzhiyun {0x27, 0x1e},
430*4882a593Smuzhiyun {0xbd, 0x00},
431*4882a593Smuzhiyun {0xbc, 0x00},
432*4882a593Smuzhiyun {0xb0, 0xac},
433*4882a593Smuzhiyun {0xb1, 0x78},
434*4882a593Smuzhiyun {0xb2, 0x17},
435*4882a593Smuzhiyun {0xb3, 0xc1},
436*4882a593Smuzhiyun {0xb4, 0x40},
437*4882a593Smuzhiyun {0xb5, 0x00},
438*4882a593Smuzhiyun {0xb6, 0xc3},
439*4882a593Smuzhiyun {0xb7, 0x0a},
440*4882a593Smuzhiyun {0xb8, 0x00},
441*4882a593Smuzhiyun {0xb9, 0x02},
442*4882a593Smuzhiyun {0xba, 0x00},
443*4882a593Smuzhiyun {0xbb, 0xb2},
444*4882a593Smuzhiyun {0xa5, 0x10},
445*4882a593Smuzhiyun {0xa7, 0x1e},
446*4882a593Smuzhiyun
447*4882a593Smuzhiyun {0xff, 0x0b},
448*4882a593Smuzhiyun {0x3d, 0x00},
449*4882a593Smuzhiyun {0x3c, 0x00},
450*4882a593Smuzhiyun {0x30, 0xac},
451*4882a593Smuzhiyun {0x31, 0x78},
452*4882a593Smuzhiyun {0x32, 0x17},
453*4882a593Smuzhiyun {0x33, 0xc1},
454*4882a593Smuzhiyun {0x34, 0x40},
455*4882a593Smuzhiyun {0x35, 0x00},
456*4882a593Smuzhiyun {0x36, 0xc3},
457*4882a593Smuzhiyun {0x37, 0x0a},
458*4882a593Smuzhiyun {0x38, 0x00},
459*4882a593Smuzhiyun {0x39, 0x02},
460*4882a593Smuzhiyun {0x3a, 0x00},
461*4882a593Smuzhiyun {0x3b, 0xb2},
462*4882a593Smuzhiyun {0x25, 0x10},
463*4882a593Smuzhiyun {0x27, 0x1e},
464*4882a593Smuzhiyun {0xbd, 0x00},
465*4882a593Smuzhiyun {0xbc, 0x00},
466*4882a593Smuzhiyun {0xb0, 0xac},
467*4882a593Smuzhiyun {0xb1, 0x78},
468*4882a593Smuzhiyun {0xb2, 0x17},
469*4882a593Smuzhiyun {0xb3, 0xc1},
470*4882a593Smuzhiyun {0xb4, 0x40},
471*4882a593Smuzhiyun {0xb5, 0x00},
472*4882a593Smuzhiyun {0xb6, 0xc3},
473*4882a593Smuzhiyun {0xb7, 0x0a},
474*4882a593Smuzhiyun {0xb8, 0x00},
475*4882a593Smuzhiyun {0xb9, 0x02},
476*4882a593Smuzhiyun {0xba, 0x00},
477*4882a593Smuzhiyun {0xbb, 0xb2},
478*4882a593Smuzhiyun {0xa5, 0x10},
479*4882a593Smuzhiyun {0xa7, 0x1e},
480*4882a593Smuzhiyun
481*4882a593Smuzhiyun {0xFF, 0x21},
482*4882a593Smuzhiyun {0x3E, 0x00},
483*4882a593Smuzhiyun {0x3F, 0x00},
484*4882a593Smuzhiyun {0xFF, 0x20},
485*4882a593Smuzhiyun {0x01, 0xaa}, //0x00:1/1;0x55:1/2;0xaa:1/4
486*4882a593Smuzhiyun {0x00, 0x00},
487*4882a593Smuzhiyun {0x40, 0x01},
488*4882a593Smuzhiyun {0x0F, 0x00},
489*4882a593Smuzhiyun {0x0D, 0x01}, //0x01:4lane;0x00:2lane
490*4882a593Smuzhiyun {0x40, 0x00},
491*4882a593Smuzhiyun {0x00, 0xff}, //0xff:ch1/2/3/4 0x33:ch1/2 0x11:ch1
492*4882a593Smuzhiyun
493*4882a593Smuzhiyun {0xFF, 0x01},
494*4882a593Smuzhiyun {0xC8, 0x00},
495*4882a593Smuzhiyun {0xC9, 0x00},
496*4882a593Smuzhiyun {0xCA, 0x00},
497*4882a593Smuzhiyun {0xCB, 0x00},
498*4882a593Smuzhiyun
499*4882a593Smuzhiyun //pattern enabled
500*4882a593Smuzhiyun {0xFF, 0x00},
501*4882a593Smuzhiyun {0x1C, 0x1A},
502*4882a593Smuzhiyun {0x1D, 0x1A},
503*4882a593Smuzhiyun {0x1E, 0x1A},
504*4882a593Smuzhiyun {0x1F, 0x1A},
505*4882a593Smuzhiyun
506*4882a593Smuzhiyun {0xFF, 0x05},
507*4882a593Smuzhiyun {0x6A, 0x80},
508*4882a593Smuzhiyun {0xFF, 0x06},
509*4882a593Smuzhiyun {0x6A, 0x80},
510*4882a593Smuzhiyun {0xFF, 0x07},
511*4882a593Smuzhiyun {0x6A, 0x80},
512*4882a593Smuzhiyun {0xFF, 0x08},
513*4882a593Smuzhiyun {0x6A, 0x80},
514*4882a593Smuzhiyun {0xFF, 0x21}, //add frame num
515*4882a593Smuzhiyun {0x3E, 0x11}, //1 : Fix to 1 for Odd Field, 2 for Even Field
516*4882a593Smuzhiyun {0x3F, 0x11}, //1 : Fix to 1 for Odd Field, 2 for Even Field
517*4882a593Smuzhiyun SensorEnd
518*4882a593Smuzhiyun };
519*4882a593Smuzhiyun
520*4882a593Smuzhiyun /* Pal Preview resolution setting*/
521*4882a593Smuzhiyun static struct rk_sensor_reg sensor_preview_data_pal_25hz[] = {
522*4882a593Smuzhiyun {0xff, 0x04},
523*4882a593Smuzhiyun {0xa0, 0x24},
524*4882a593Smuzhiyun {0xa1, 0x24},
525*4882a593Smuzhiyun {0xa2, 0x24},
526*4882a593Smuzhiyun {0xa3, 0x24},
527*4882a593Smuzhiyun {0xa4, 0x24},
528*4882a593Smuzhiyun {0xa5, 0x24},
529*4882a593Smuzhiyun {0xa6, 0x24},
530*4882a593Smuzhiyun {0xa7, 0x24},
531*4882a593Smuzhiyun {0xa8, 0x24},
532*4882a593Smuzhiyun {0xa9, 0x24},
533*4882a593Smuzhiyun {0xaa, 0x24},
534*4882a593Smuzhiyun {0xab, 0x24},
535*4882a593Smuzhiyun {0xac, 0x24},
536*4882a593Smuzhiyun {0xad, 0x24},
537*4882a593Smuzhiyun {0xae, 0x24},
538*4882a593Smuzhiyun {0xaf, 0x24},
539*4882a593Smuzhiyun {0xb0, 0x24},
540*4882a593Smuzhiyun {0xb1, 0x24},
541*4882a593Smuzhiyun {0xb2, 0x24},
542*4882a593Smuzhiyun {0xb3, 0x24},
543*4882a593Smuzhiyun {0xb4, 0x24},
544*4882a593Smuzhiyun {0xb5, 0x24},
545*4882a593Smuzhiyun {0xb6, 0x24},
546*4882a593Smuzhiyun {0xb7, 0x24},
547*4882a593Smuzhiyun {0xb8, 0x24},
548*4882a593Smuzhiyun {0xb9, 0x24},
549*4882a593Smuzhiyun {0xba, 0x24},
550*4882a593Smuzhiyun {0xbb, 0x24},
551*4882a593Smuzhiyun {0xbc, 0x24},
552*4882a593Smuzhiyun {0xbd, 0x24},
553*4882a593Smuzhiyun {0xbe, 0x24},
554*4882a593Smuzhiyun {0xbf, 0x24},
555*4882a593Smuzhiyun {0xc0, 0x24},
556*4882a593Smuzhiyun {0xc1, 0x24},
557*4882a593Smuzhiyun {0xc2, 0x24},
558*4882a593Smuzhiyun {0xc3, 0x24},
559*4882a593Smuzhiyun {0xff, 0x21},
560*4882a593Smuzhiyun {0x07, 0x80},
561*4882a593Smuzhiyun {0x07, 0x00},
562*4882a593Smuzhiyun {0xff, 0x0A},
563*4882a593Smuzhiyun {0x77, 0x8F},
564*4882a593Smuzhiyun {0xF7, 0x8F},
565*4882a593Smuzhiyun {0xff, 0x0B},
566*4882a593Smuzhiyun {0x77, 0x8F},
567*4882a593Smuzhiyun {0xF7, 0x8F},
568*4882a593Smuzhiyun
569*4882a593Smuzhiyun {0xFF, 0x21},
570*4882a593Smuzhiyun {0x40, 0xAC},
571*4882a593Smuzhiyun {0x41, 0x10},
572*4882a593Smuzhiyun {0x42, 0x03},
573*4882a593Smuzhiyun {0x43, 0x43},
574*4882a593Smuzhiyun {0x11, 0x04},
575*4882a593Smuzhiyun {0x10, 0x0A},
576*4882a593Smuzhiyun {0x12, 0x06},
577*4882a593Smuzhiyun {0x13, 0x09},
578*4882a593Smuzhiyun {0x17, 0x01},
579*4882a593Smuzhiyun {0x18, 0x0D},
580*4882a593Smuzhiyun {0x15, 0x04},
581*4882a593Smuzhiyun {0x14, 0x16},
582*4882a593Smuzhiyun {0x16, 0x05},
583*4882a593Smuzhiyun {0x19, 0x05},
584*4882a593Smuzhiyun {0x1A, 0x0A},
585*4882a593Smuzhiyun {0x1B, 0x08},
586*4882a593Smuzhiyun {0x1C, 0x07},
587*4882a593Smuzhiyun {0x44, 0x00},
588*4882a593Smuzhiyun {0x49, 0xF3},
589*4882a593Smuzhiyun {0x49, 0xF0},
590*4882a593Smuzhiyun {0x44, 0x02},
591*4882a593Smuzhiyun {0x08, 0x40}, //0x40:non-continue;0x48:continuous
592*4882a593Smuzhiyun {0x0F, 0x01},
593*4882a593Smuzhiyun {0x38, 0x1E},
594*4882a593Smuzhiyun {0x39, 0x1E},
595*4882a593Smuzhiyun {0x3A, 0x1E},
596*4882a593Smuzhiyun {0x3B, 0x1E},
597*4882a593Smuzhiyun {0x07, 0x0f}, //0x07:2lane;0x0f:4lane
598*4882a593Smuzhiyun {0x2D, 0x01}, //0x00:2lane;0x01:4lane
599*4882a593Smuzhiyun {0x45, 0x02},
600*4882a593Smuzhiyun {0xFF, 0x13},
601*4882a593Smuzhiyun {0x30, 0x00},
602*4882a593Smuzhiyun {0x31, 0x00},
603*4882a593Smuzhiyun {0x32, 0x00},
604*4882a593Smuzhiyun
605*4882a593Smuzhiyun {0xFF, 0x00},
606*4882a593Smuzhiyun {0x00, 0x00},
607*4882a593Smuzhiyun {0x01, 0x00},
608*4882a593Smuzhiyun {0x02, 0x00},
609*4882a593Smuzhiyun {0x03, 0x00},
610*4882a593Smuzhiyun {0x04, 0x0f}, //sd_mode
611*4882a593Smuzhiyun {0x05, 0x0f},
612*4882a593Smuzhiyun {0x06, 0x0f},
613*4882a593Smuzhiyun {0x07, 0x0f},
614*4882a593Smuzhiyun {0x08, 0x00}, //ahd_mode
615*4882a593Smuzhiyun {0x09, 0x00},
616*4882a593Smuzhiyun {0x0a, 0x00},
617*4882a593Smuzhiyun {0x0b, 0x00},
618*4882a593Smuzhiyun {0x0c, 0x00},
619*4882a593Smuzhiyun {0x0d, 0x00},
620*4882a593Smuzhiyun {0x0e, 0x00},
621*4882a593Smuzhiyun {0x0f, 0x00},
622*4882a593Smuzhiyun {0x10, 0xdd}, //video_format
623*4882a593Smuzhiyun {0x11, 0xdd},
624*4882a593Smuzhiyun {0x12, 0xdd},
625*4882a593Smuzhiyun {0x13, 0xdd},
626*4882a593Smuzhiyun {0x14, 0x00},
627*4882a593Smuzhiyun {0x15, 0x00},
628*4882a593Smuzhiyun {0x16, 0x00},
629*4882a593Smuzhiyun {0x17, 0x00},
630*4882a593Smuzhiyun {0x18, 0x13},
631*4882a593Smuzhiyun {0x19, 0x13},
632*4882a593Smuzhiyun {0x1a, 0x13},
633*4882a593Smuzhiyun {0x1b, 0x13},
634*4882a593Smuzhiyun {0x1c, 0x1a},
635*4882a593Smuzhiyun {0x1d, 0x1a},
636*4882a593Smuzhiyun {0x1e, 0x1a},
637*4882a593Smuzhiyun {0x1f, 0x1a},
638*4882a593Smuzhiyun {0x20, 0x00},
639*4882a593Smuzhiyun {0x21, 0x00},
640*4882a593Smuzhiyun {0x22, 0x00},
641*4882a593Smuzhiyun {0x23, 0x00},
642*4882a593Smuzhiyun {0x24, 0x90}, //contrast
643*4882a593Smuzhiyun {0x25, 0x90},
644*4882a593Smuzhiyun {0x26, 0x90},
645*4882a593Smuzhiyun {0x27, 0x90},
646*4882a593Smuzhiyun {0x28, 0x90}, //black_level
647*4882a593Smuzhiyun {0x29, 0x90},
648*4882a593Smuzhiyun {0x2a, 0x90},
649*4882a593Smuzhiyun {0x2b, 0x90},
650*4882a593Smuzhiyun {0x30, 0x00}, //y_peaking_mode
651*4882a593Smuzhiyun {0x31, 0x00},
652*4882a593Smuzhiyun {0x32, 0x00},
653*4882a593Smuzhiyun {0x33, 0x00},
654*4882a593Smuzhiyun {0x34, 0x08}, //y_fir_mode
655*4882a593Smuzhiyun {0x35, 0x08},
656*4882a593Smuzhiyun {0x36, 0x08},
657*4882a593Smuzhiyun {0x37, 0x08},
658*4882a593Smuzhiyun {0x40, 0x00},
659*4882a593Smuzhiyun {0x41, 0x00},
660*4882a593Smuzhiyun {0x42, 0x00},
661*4882a593Smuzhiyun {0x43, 0x00},
662*4882a593Smuzhiyun {0x44, 0x00},
663*4882a593Smuzhiyun {0x45, 0x00},
664*4882a593Smuzhiyun {0x46, 0x00},
665*4882a593Smuzhiyun {0x47, 0x00},
666*4882a593Smuzhiyun {0x48, 0x00},
667*4882a593Smuzhiyun {0x49, 0x00},
668*4882a593Smuzhiyun {0x4a, 0x00},
669*4882a593Smuzhiyun {0x4b, 0x00},
670*4882a593Smuzhiyun {0x4c, 0xfe},
671*4882a593Smuzhiyun {0x4d, 0xfe},
672*4882a593Smuzhiyun {0x4e, 0xfe},
673*4882a593Smuzhiyun {0x4f, 0xfe},
674*4882a593Smuzhiyun {0x50, 0xfb},
675*4882a593Smuzhiyun {0x51, 0xfb},
676*4882a593Smuzhiyun {0x52, 0xfb},
677*4882a593Smuzhiyun {0x53, 0xfb},
678*4882a593Smuzhiyun {0x58, 0x80},
679*4882a593Smuzhiyun {0x59, 0x80},
680*4882a593Smuzhiyun {0x5a, 0x80},
681*4882a593Smuzhiyun {0x5b, 0x80},
682*4882a593Smuzhiyun {0x5c, 0x82}, //pal_cm_off
683*4882a593Smuzhiyun {0x5d, 0x82},
684*4882a593Smuzhiyun {0x5e, 0x82},
685*4882a593Smuzhiyun {0x5f, 0x82},
686*4882a593Smuzhiyun {0x60, 0x10},
687*4882a593Smuzhiyun {0x61, 0x10},
688*4882a593Smuzhiyun {0x62, 0x10},
689*4882a593Smuzhiyun {0x63, 0x10},
690*4882a593Smuzhiyun {0x64, 0x07}, //y_delay
691*4882a593Smuzhiyun {0x65, 0x07},
692*4882a593Smuzhiyun {0x66, 0x07},
693*4882a593Smuzhiyun {0x67, 0x07},
694*4882a593Smuzhiyun {0x68, 0x68}, //h_delay_a //h_delay_lsb
695*4882a593Smuzhiyun {0x69, 0x68},
696*4882a593Smuzhiyun {0x6a, 0x68},
697*4882a593Smuzhiyun {0x6b, 0x68},
698*4882a593Smuzhiyun {0x6c, 0x00},
699*4882a593Smuzhiyun {0x6d, 0x00},
700*4882a593Smuzhiyun {0x6e, 0x00},
701*4882a593Smuzhiyun {0x6f, 0x00},
702*4882a593Smuzhiyun {0x70, 0x3f}, //v_crop_start
703*4882a593Smuzhiyun {0x71, 0x3f},
704*4882a593Smuzhiyun {0x72, 0x3f},
705*4882a593Smuzhiyun {0x73, 0x3f},
706*4882a593Smuzhiyun {0x78, 0x21},
707*4882a593Smuzhiyun {0x79, 0x21},
708*4882a593Smuzhiyun {0x7a, 0x21},
709*4882a593Smuzhiyun {0x7b, 0x21},
710*4882a593Smuzhiyun
711*4882a593Smuzhiyun {0xFF, 0x01},
712*4882a593Smuzhiyun {0x7C, 0x00},
713*4882a593Smuzhiyun {0x84, 0x04},
714*4882a593Smuzhiyun {0x85, 0x04},
715*4882a593Smuzhiyun {0x86, 0x04},
716*4882a593Smuzhiyun {0x87, 0x04},
717*4882a593Smuzhiyun {0x88, 0x01},
718*4882a593Smuzhiyun {0x89, 0x01},
719*4882a593Smuzhiyun {0x8a, 0x01},
720*4882a593Smuzhiyun {0x8b, 0x01},
721*4882a593Smuzhiyun {0x8c, 0x02},
722*4882a593Smuzhiyun {0x8d, 0x02},
723*4882a593Smuzhiyun {0x8e, 0x02},
724*4882a593Smuzhiyun {0x8f, 0x02},
725*4882a593Smuzhiyun {0xEC, 0x00},
726*4882a593Smuzhiyun {0xED, 0x00},
727*4882a593Smuzhiyun {0xEE, 0x00},
728*4882a593Smuzhiyun {0xEF, 0x00},
729*4882a593Smuzhiyun
730*4882a593Smuzhiyun {0xFF, 0x05},
731*4882a593Smuzhiyun {0x00, 0xd0},
732*4882a593Smuzhiyun {0x01, 0x2c},
733*4882a593Smuzhiyun {0x05, 0x20}, //d_agc_option
734*4882a593Smuzhiyun {0x1d, 0x0c},
735*4882a593Smuzhiyun {0x21, 0x20}, //sub contrast
736*4882a593Smuzhiyun {0x24, 0x2a},
737*4882a593Smuzhiyun {0x25, 0xcc}, //fsc_lock_mode
738*4882a593Smuzhiyun {0x26, 0x40},
739*4882a593Smuzhiyun {0x27, 0x57},
740*4882a593Smuzhiyun {0x28, 0x80}, //s_point
741*4882a593Smuzhiyun {0x2b, 0xc0}, //saturation_b
742*4882a593Smuzhiyun {0x31, 0x02},
743*4882a593Smuzhiyun {0x32, 0x10},
744*4882a593Smuzhiyun {0x38, 0x00},
745*4882a593Smuzhiyun {0x47, 0xEE},
746*4882a593Smuzhiyun {0x50, 0xc6},
747*4882a593Smuzhiyun {0x53, 0x04},
748*4882a593Smuzhiyun {0x57, 0x00},
749*4882a593Smuzhiyun {0x58, 0x77},
750*4882a593Smuzhiyun {0x59, 0x00},
751*4882a593Smuzhiyun {0x5C, 0x78},
752*4882a593Smuzhiyun {0x5F, 0x00},
753*4882a593Smuzhiyun {0x62, 0x20},
754*4882a593Smuzhiyun {0x64, 0x01},
755*4882a593Smuzhiyun {0x65, 0x00},
756*4882a593Smuzhiyun {0x69, 0x00},
757*4882a593Smuzhiyun {0x6E, 0x00}, //VBLK_EXT_EN
758*4882a593Smuzhiyun {0x6F, 0x00}, //VBLK_EXT_[7:0]
759*4882a593Smuzhiyun {0x90, 0x0d}, //comb_mode
760*4882a593Smuzhiyun {0x92, 0x00},
761*4882a593Smuzhiyun {0x94, 0x00},
762*4882a593Smuzhiyun {0x95, 0x00},
763*4882a593Smuzhiyun {0xa9, 0x00},
764*4882a593Smuzhiyun {0xb5, 0x00},
765*4882a593Smuzhiyun {0xb7, 0xfc},
766*4882a593Smuzhiyun {0xb8, 0xb8},
767*4882a593Smuzhiyun {0xb9, 0x72},
768*4882a593Smuzhiyun {0xbb, 0x0f},
769*4882a593Smuzhiyun {0xd1, 0x30}, //burst_dec_c
770*4882a593Smuzhiyun {0xd5, 0x80},
771*4882a593Smuzhiyun
772*4882a593Smuzhiyun {0xFF, 0x09},
773*4882a593Smuzhiyun {0x40, 0x00},
774*4882a593Smuzhiyun {0x41, 0x00},
775*4882a593Smuzhiyun {0x42, 0x00},
776*4882a593Smuzhiyun {0x43, 0x00},
777*4882a593Smuzhiyun {0x44, 0x00},
778*4882a593Smuzhiyun {0x45, 0x00},
779*4882a593Smuzhiyun {0x46, 0x00},
780*4882a593Smuzhiyun {0x47, 0x00},
781*4882a593Smuzhiyun {0x50, 0x30},
782*4882a593Smuzhiyun {0x51, 0x6f},
783*4882a593Smuzhiyun {0x52, 0x67},
784*4882a593Smuzhiyun {0x53, 0x48},
785*4882a593Smuzhiyun {0x54, 0x30},
786*4882a593Smuzhiyun {0x55, 0x6f},
787*4882a593Smuzhiyun {0x56, 0x67},
788*4882a593Smuzhiyun {0x57, 0x48},
789*4882a593Smuzhiyun {0x58, 0x30},
790*4882a593Smuzhiyun {0x59, 0x6f},
791*4882a593Smuzhiyun {0x5a, 0x67},
792*4882a593Smuzhiyun {0x5b, 0x48},
793*4882a593Smuzhiyun {0x5c, 0x30},
794*4882a593Smuzhiyun {0x5d, 0x6f},
795*4882a593Smuzhiyun {0x5e, 0x67},
796*4882a593Smuzhiyun {0x5f, 0x48},
797*4882a593Smuzhiyun {0x96, 0x10},
798*4882a593Smuzhiyun {0x97, 0x10},
799*4882a593Smuzhiyun {0x98, 0x00},
800*4882a593Smuzhiyun {0x99, 0x00},
801*4882a593Smuzhiyun {0x9a, 0x00},
802*4882a593Smuzhiyun {0x9b, 0x00},
803*4882a593Smuzhiyun {0x9c, 0x00},
804*4882a593Smuzhiyun {0x9d, 0x00},
805*4882a593Smuzhiyun {0x9e, 0x00},
806*4882a593Smuzhiyun {0xb6, 0x10},
807*4882a593Smuzhiyun {0xb7, 0x10},
808*4882a593Smuzhiyun {0xb8, 0x00},
809*4882a593Smuzhiyun {0xb9, 0x00},
810*4882a593Smuzhiyun {0xba, 0x00},
811*4882a593Smuzhiyun {0xbb, 0x00},
812*4882a593Smuzhiyun {0xbc, 0x00},
813*4882a593Smuzhiyun {0xbd, 0x00},
814*4882a593Smuzhiyun {0xbe, 0x00},
815*4882a593Smuzhiyun {0xd6, 0x10},
816*4882a593Smuzhiyun {0xd7, 0x10},
817*4882a593Smuzhiyun {0xd8, 0x00},
818*4882a593Smuzhiyun {0xd9, 0x00},
819*4882a593Smuzhiyun {0xda, 0x00},
820*4882a593Smuzhiyun {0xdb, 0x00},
821*4882a593Smuzhiyun {0xdc, 0x00},
822*4882a593Smuzhiyun {0xdd, 0x00},
823*4882a593Smuzhiyun {0xde, 0x00},
824*4882a593Smuzhiyun {0xf6, 0x10},
825*4882a593Smuzhiyun {0xf7, 0x10},
826*4882a593Smuzhiyun {0xf8, 0x00},
827*4882a593Smuzhiyun {0xf9, 0x00},
828*4882a593Smuzhiyun {0xfa, 0x00},
829*4882a593Smuzhiyun {0xfb, 0x00},
830*4882a593Smuzhiyun {0xfc, 0x00},
831*4882a593Smuzhiyun {0xfd, 0x00},
832*4882a593Smuzhiyun {0xfe, 0x00},
833*4882a593Smuzhiyun
834*4882a593Smuzhiyun {0xff, 0x0a},
835*4882a593Smuzhiyun {0x3d, 0x00},
836*4882a593Smuzhiyun {0x3c, 0x00},
837*4882a593Smuzhiyun {0x30, 0xac},
838*4882a593Smuzhiyun {0x31, 0x78},
839*4882a593Smuzhiyun {0x32, 0x17},
840*4882a593Smuzhiyun {0x33, 0xc1},
841*4882a593Smuzhiyun {0x34, 0x40},
842*4882a593Smuzhiyun {0x35, 0x00},
843*4882a593Smuzhiyun {0x36, 0xc3},
844*4882a593Smuzhiyun {0x37, 0x0a},
845*4882a593Smuzhiyun {0x38, 0x00},
846*4882a593Smuzhiyun {0x39, 0x02},
847*4882a593Smuzhiyun {0x3a, 0x00},
848*4882a593Smuzhiyun {0x3b, 0xb2},
849*4882a593Smuzhiyun {0x25, 0x10},
850*4882a593Smuzhiyun {0x27, 0x1e},
851*4882a593Smuzhiyun {0xbd, 0x00},
852*4882a593Smuzhiyun {0xbc, 0x00},
853*4882a593Smuzhiyun {0xb0, 0xac},
854*4882a593Smuzhiyun {0xb1, 0x78},
855*4882a593Smuzhiyun {0xb2, 0x17},
856*4882a593Smuzhiyun {0xb3, 0xc1},
857*4882a593Smuzhiyun {0xb4, 0x40},
858*4882a593Smuzhiyun {0xb5, 0x00},
859*4882a593Smuzhiyun {0xb6, 0xc3},
860*4882a593Smuzhiyun {0xb7, 0x0a},
861*4882a593Smuzhiyun {0xb8, 0x00},
862*4882a593Smuzhiyun {0xb9, 0x02},
863*4882a593Smuzhiyun {0xba, 0x00},
864*4882a593Smuzhiyun {0xbb, 0xb2},
865*4882a593Smuzhiyun {0xa5, 0x10},
866*4882a593Smuzhiyun {0xa7, 0x1e},
867*4882a593Smuzhiyun
868*4882a593Smuzhiyun {0xff, 0x0b},
869*4882a593Smuzhiyun {0x3d, 0x00},
870*4882a593Smuzhiyun {0x3c, 0x00},
871*4882a593Smuzhiyun {0x30, 0xac},
872*4882a593Smuzhiyun {0x31, 0x78},
873*4882a593Smuzhiyun {0x32, 0x17},
874*4882a593Smuzhiyun {0x33, 0xc1},
875*4882a593Smuzhiyun {0x34, 0x40},
876*4882a593Smuzhiyun {0x35, 0x00},
877*4882a593Smuzhiyun {0x36, 0xc3},
878*4882a593Smuzhiyun {0x37, 0x0a},
879*4882a593Smuzhiyun {0x38, 0x00},
880*4882a593Smuzhiyun {0x39, 0x02},
881*4882a593Smuzhiyun {0x3a, 0x00},
882*4882a593Smuzhiyun {0x3b, 0xb2},
883*4882a593Smuzhiyun {0x25, 0x10},
884*4882a593Smuzhiyun {0x27, 0x1e},
885*4882a593Smuzhiyun {0xbd, 0x00},
886*4882a593Smuzhiyun {0xbc, 0x00},
887*4882a593Smuzhiyun {0xb0, 0xac},
888*4882a593Smuzhiyun {0xb1, 0x78},
889*4882a593Smuzhiyun {0xb2, 0x17},
890*4882a593Smuzhiyun {0xb3, 0xc1},
891*4882a593Smuzhiyun {0xb4, 0x40},
892*4882a593Smuzhiyun {0xb5, 0x00},
893*4882a593Smuzhiyun {0xb6, 0xc3},
894*4882a593Smuzhiyun {0xb7, 0x0a},
895*4882a593Smuzhiyun {0xb8, 0x00},
896*4882a593Smuzhiyun {0xb9, 0x02},
897*4882a593Smuzhiyun {0xba, 0x00},
898*4882a593Smuzhiyun {0xbb, 0xb2},
899*4882a593Smuzhiyun {0xa5, 0x10},
900*4882a593Smuzhiyun {0xa7, 0x1e},
901*4882a593Smuzhiyun
902*4882a593Smuzhiyun {0xFF, 0x21},
903*4882a593Smuzhiyun {0x3E, 0x00},
904*4882a593Smuzhiyun {0x3F, 0x00},
905*4882a593Smuzhiyun {0xFF, 0x20},
906*4882a593Smuzhiyun {0x01, 0xaa}, //0x00:1/1;0x55:1/2;0xaa:1/4
907*4882a593Smuzhiyun {0x00, 0x00},
908*4882a593Smuzhiyun {0x40, 0x01},
909*4882a593Smuzhiyun {0x0F, 0x00},
910*4882a593Smuzhiyun {0x0D, 0x01}, //0x01:4lane;0x00:2lane
911*4882a593Smuzhiyun {0x40, 0x00},
912*4882a593Smuzhiyun {0x00, 0xff}, //0xff:ch1/2/3/4 0x33:ch1/2 0x11:ch1
913*4882a593Smuzhiyun
914*4882a593Smuzhiyun {0xFF, 0x01},
915*4882a593Smuzhiyun {0xC8, 0x00},
916*4882a593Smuzhiyun {0xC9, 0x00},
917*4882a593Smuzhiyun {0xCA, 0x00},
918*4882a593Smuzhiyun {0xCB, 0x00},
919*4882a593Smuzhiyun
920*4882a593Smuzhiyun //pattern enabled
921*4882a593Smuzhiyun {0xFF, 0x00},
922*4882a593Smuzhiyun {0x1C, 0x1A},
923*4882a593Smuzhiyun {0x1D, 0x1A},
924*4882a593Smuzhiyun {0x1E, 0x1A},
925*4882a593Smuzhiyun {0x1F, 0x1A},
926*4882a593Smuzhiyun
927*4882a593Smuzhiyun {0xFF, 0x05},
928*4882a593Smuzhiyun {0x6A, 0x80},
929*4882a593Smuzhiyun {0xFF, 0x06},
930*4882a593Smuzhiyun {0x6A, 0x80},
931*4882a593Smuzhiyun {0xFF, 0x07},
932*4882a593Smuzhiyun {0x6A, 0x80},
933*4882a593Smuzhiyun {0xFF, 0x08},
934*4882a593Smuzhiyun {0x6A, 0x80},
935*4882a593Smuzhiyun {0xFF, 0x21}, //add frame num
936*4882a593Smuzhiyun {0x3E, 0x11}, //1 : Fix to 1 for Odd Field, 2 for Even Field
937*4882a593Smuzhiyun {0x3F, 0x11}, //1 : Fix to 1 for Odd Field, 2 for Even Field
938*4882a593Smuzhiyun SensorEnd
939*4882a593Smuzhiyun };
940*4882a593Smuzhiyun
941*4882a593Smuzhiyun /* 720p Preview resolution setting*/
942*4882a593Smuzhiyun static struct rk_sensor_reg sensor_preview_data_720p_25hz[] = {
943*4882a593Smuzhiyun {0xff, 0x04},
944*4882a593Smuzhiyun {0xa0, 0x24},
945*4882a593Smuzhiyun {0xa1, 0x24},
946*4882a593Smuzhiyun {0xa2, 0x24},
947*4882a593Smuzhiyun {0xa3, 0x24},
948*4882a593Smuzhiyun {0xa4, 0x24},
949*4882a593Smuzhiyun {0xa5, 0x24},
950*4882a593Smuzhiyun {0xa6, 0x24},
951*4882a593Smuzhiyun {0xa7, 0x24},
952*4882a593Smuzhiyun {0xa8, 0x24},
953*4882a593Smuzhiyun {0xa9, 0x24},
954*4882a593Smuzhiyun {0xaa, 0x24},
955*4882a593Smuzhiyun {0xab, 0x24},
956*4882a593Smuzhiyun {0xac, 0x24},
957*4882a593Smuzhiyun {0xad, 0x24},
958*4882a593Smuzhiyun {0xae, 0x24},
959*4882a593Smuzhiyun {0xaf, 0x24},
960*4882a593Smuzhiyun {0xb0, 0x24},
961*4882a593Smuzhiyun {0xb1, 0x24},
962*4882a593Smuzhiyun {0xb2, 0x24},
963*4882a593Smuzhiyun {0xb3, 0x24},
964*4882a593Smuzhiyun {0xb4, 0x24},
965*4882a593Smuzhiyun {0xb5, 0x24},
966*4882a593Smuzhiyun {0xb6, 0x24},
967*4882a593Smuzhiyun {0xb7, 0x24},
968*4882a593Smuzhiyun {0xb8, 0x24},
969*4882a593Smuzhiyun {0xb9, 0x24},
970*4882a593Smuzhiyun {0xba, 0x24},
971*4882a593Smuzhiyun {0xbb, 0x24},
972*4882a593Smuzhiyun {0xbc, 0x24},
973*4882a593Smuzhiyun {0xbd, 0x24},
974*4882a593Smuzhiyun {0xbe, 0x24},
975*4882a593Smuzhiyun {0xbf, 0x24},
976*4882a593Smuzhiyun {0xc0, 0x24},
977*4882a593Smuzhiyun {0xc1, 0x24},
978*4882a593Smuzhiyun {0xc2, 0x24},
979*4882a593Smuzhiyun {0xc3, 0x24},
980*4882a593Smuzhiyun {0xff, 0x21},
981*4882a593Smuzhiyun {0x07, 0x80},
982*4882a593Smuzhiyun {0x07, 0x00},
983*4882a593Smuzhiyun {0xff, 0x0A},
984*4882a593Smuzhiyun {0x77, 0x8F},
985*4882a593Smuzhiyun {0xF7, 0x8F},
986*4882a593Smuzhiyun {0xff, 0x0B},
987*4882a593Smuzhiyun {0x77, 0x8F},
988*4882a593Smuzhiyun {0xF7, 0x8F},
989*4882a593Smuzhiyun {0xFF, 0x21},
990*4882a593Smuzhiyun {0x40, 0xAC},
991*4882a593Smuzhiyun {0x41, 0x10},
992*4882a593Smuzhiyun {0x42, 0x03},
993*4882a593Smuzhiyun {0x43, 0x43},
994*4882a593Smuzhiyun {0x11, 0x04},
995*4882a593Smuzhiyun {0x10, 0x0A},
996*4882a593Smuzhiyun {0x12, 0x06},
997*4882a593Smuzhiyun {0x13, 0x09},
998*4882a593Smuzhiyun {0x17, 0x01},
999*4882a593Smuzhiyun {0x18, 0x0D},
1000*4882a593Smuzhiyun {0x15, 0x04},
1001*4882a593Smuzhiyun {0x14, 0x16},
1002*4882a593Smuzhiyun {0x16, 0x05},
1003*4882a593Smuzhiyun {0x19, 0x05},
1004*4882a593Smuzhiyun {0x1A, 0x0A},
1005*4882a593Smuzhiyun {0x1B, 0x08},
1006*4882a593Smuzhiyun {0x1C, 0x07},
1007*4882a593Smuzhiyun {0x44, 0x00},
1008*4882a593Smuzhiyun {0x49, 0xF3},
1009*4882a593Smuzhiyun {0x49, 0xF0},
1010*4882a593Smuzhiyun {0x44, 0x02},
1011*4882a593Smuzhiyun {0x08, 0x40}, //0x40:non-continue;0x48:continuous
1012*4882a593Smuzhiyun {0x0F, 0x01},
1013*4882a593Smuzhiyun {0x38, 0x1E},
1014*4882a593Smuzhiyun {0x39, 0x1E},
1015*4882a593Smuzhiyun {0x3A, 0x1E},
1016*4882a593Smuzhiyun {0x3B, 0x1E},
1017*4882a593Smuzhiyun {0x07, 0x0f}, //0x07:2lane;0x0f:4lane
1018*4882a593Smuzhiyun {0x2D, 0x01}, //0x00:2lane;0x01:4lane
1019*4882a593Smuzhiyun {0x45, 0x02},
1020*4882a593Smuzhiyun {0xFF, 0x13},
1021*4882a593Smuzhiyun {0x30, 0x00},
1022*4882a593Smuzhiyun {0x31, 0x00},
1023*4882a593Smuzhiyun {0x32, 0x00},
1024*4882a593Smuzhiyun {0xFF, 0x00},
1025*4882a593Smuzhiyun {0x00, 0x00},
1026*4882a593Smuzhiyun {0x01, 0x00},
1027*4882a593Smuzhiyun {0x02, 0x00},
1028*4882a593Smuzhiyun {0x03, 0x00},
1029*4882a593Smuzhiyun {0x04, 0x00}, //sd_mode
1030*4882a593Smuzhiyun {0x05, 0x00},
1031*4882a593Smuzhiyun {0x06, 0x00},
1032*4882a593Smuzhiyun {0x07, 0x00},
1033*4882a593Smuzhiyun {0x08, 0x0d}, //ahd_mode
1034*4882a593Smuzhiyun {0x09, 0x0d},
1035*4882a593Smuzhiyun {0x0a, 0x0d},
1036*4882a593Smuzhiyun {0x0b, 0x0d},
1037*4882a593Smuzhiyun {0x0c, 0x00},
1038*4882a593Smuzhiyun {0x0d, 0x00},
1039*4882a593Smuzhiyun {0x0e, 0x00},
1040*4882a593Smuzhiyun {0x0f, 0x00},
1041*4882a593Smuzhiyun {0x10, 0x20}, //video_format
1042*4882a593Smuzhiyun {0x11, 0x20},
1043*4882a593Smuzhiyun {0x12, 0x20},
1044*4882a593Smuzhiyun {0x13, 0x20},
1045*4882a593Smuzhiyun {0x14, 0x00},
1046*4882a593Smuzhiyun {0x15, 0x00},
1047*4882a593Smuzhiyun {0x16, 0x00},
1048*4882a593Smuzhiyun {0x17, 0x00},
1049*4882a593Smuzhiyun {0x18, 0x13},
1050*4882a593Smuzhiyun {0x19, 0x13},
1051*4882a593Smuzhiyun {0x1a, 0x13},
1052*4882a593Smuzhiyun {0x1b, 0x13},
1053*4882a593Smuzhiyun {0x1c, 0x1a},
1054*4882a593Smuzhiyun {0x1d, 0x1a},
1055*4882a593Smuzhiyun {0x1e, 0x1a},
1056*4882a593Smuzhiyun {0x1f, 0x1a},
1057*4882a593Smuzhiyun {0x20, 0x00},
1058*4882a593Smuzhiyun {0x21, 0x00},
1059*4882a593Smuzhiyun {0x22, 0x00},
1060*4882a593Smuzhiyun {0x23, 0x00},
1061*4882a593Smuzhiyun {0x24, 0x88}, //contrast
1062*4882a593Smuzhiyun {0x25, 0x88},
1063*4882a593Smuzhiyun {0x26, 0x88},
1064*4882a593Smuzhiyun {0x27, 0x88},
1065*4882a593Smuzhiyun {0x28, 0x84}, //black_level
1066*4882a593Smuzhiyun {0x29, 0x84},
1067*4882a593Smuzhiyun {0x2a, 0x84},
1068*4882a593Smuzhiyun {0x2b, 0x84},
1069*4882a593Smuzhiyun {0x30, 0x03}, //y_peaking_mode
1070*4882a593Smuzhiyun {0x31, 0x03},
1071*4882a593Smuzhiyun {0x32, 0x03},
1072*4882a593Smuzhiyun {0x33, 0x03},
1073*4882a593Smuzhiyun {0x34, 0x0f}, //y_fir_mode
1074*4882a593Smuzhiyun {0x35, 0x0f},
1075*4882a593Smuzhiyun {0x36, 0x0f},
1076*4882a593Smuzhiyun {0x37, 0x0f},
1077*4882a593Smuzhiyun {0x40, 0x00},
1078*4882a593Smuzhiyun {0x41, 0x00},
1079*4882a593Smuzhiyun {0x42, 0x00},
1080*4882a593Smuzhiyun {0x43, 0x00},
1081*4882a593Smuzhiyun {0x44, 0x00},
1082*4882a593Smuzhiyun {0x45, 0x00},
1083*4882a593Smuzhiyun {0x46, 0x00},
1084*4882a593Smuzhiyun {0x47, 0x00},
1085*4882a593Smuzhiyun {0x48, 0x00},
1086*4882a593Smuzhiyun {0x49, 0x00},
1087*4882a593Smuzhiyun {0x4a, 0x00},
1088*4882a593Smuzhiyun {0x4b, 0x00},
1089*4882a593Smuzhiyun {0x4c, 0x00},
1090*4882a593Smuzhiyun {0x4d, 0x00},
1091*4882a593Smuzhiyun {0x4e, 0x00},
1092*4882a593Smuzhiyun {0x4f, 0x00},
1093*4882a593Smuzhiyun {0x50, 0x00},
1094*4882a593Smuzhiyun {0x51, 0x00},
1095*4882a593Smuzhiyun {0x52, 0x00},
1096*4882a593Smuzhiyun {0x53, 0x00},
1097*4882a593Smuzhiyun {0x58, 0x80},
1098*4882a593Smuzhiyun {0x59, 0x80},
1099*4882a593Smuzhiyun {0x5a, 0x80},
1100*4882a593Smuzhiyun {0x5b, 0x80},
1101*4882a593Smuzhiyun {0x5c, 0x82}, //pal_cm_off
1102*4882a593Smuzhiyun {0x5d, 0x82},
1103*4882a593Smuzhiyun {0x5e, 0x82},
1104*4882a593Smuzhiyun {0x5f, 0x82},
1105*4882a593Smuzhiyun {0x60, 0x10},
1106*4882a593Smuzhiyun {0x61, 0x10},
1107*4882a593Smuzhiyun {0x62, 0x10},
1108*4882a593Smuzhiyun {0x63, 0x10},
1109*4882a593Smuzhiyun {0x64, 0x05}, //y_delay
1110*4882a593Smuzhiyun {0x65, 0x05},
1111*4882a593Smuzhiyun {0x66, 0x05},
1112*4882a593Smuzhiyun {0x67, 0x05},
1113*4882a593Smuzhiyun {0x68, 0x43}, //h_delay_a //h_delay_lsb
1114*4882a593Smuzhiyun {0x69, 0x43},
1115*4882a593Smuzhiyun {0x6a, 0x43},
1116*4882a593Smuzhiyun {0x6b, 0x43},
1117*4882a593Smuzhiyun {0x6c, 0x00},
1118*4882a593Smuzhiyun {0x6d, 0x00},
1119*4882a593Smuzhiyun {0x6e, 0x00},
1120*4882a593Smuzhiyun {0x6f, 0x00},
1121*4882a593Smuzhiyun {0x78, 0x21},
1122*4882a593Smuzhiyun {0x79, 0x21},
1123*4882a593Smuzhiyun {0x7a, 0x21},
1124*4882a593Smuzhiyun {0x7b, 0x21},
1125*4882a593Smuzhiyun {0xFF, 0x01},
1126*4882a593Smuzhiyun {0x7C, 0x00},
1127*4882a593Smuzhiyun {0x84, 0x04},
1128*4882a593Smuzhiyun {0x85, 0x04},
1129*4882a593Smuzhiyun {0x86, 0x04},
1130*4882a593Smuzhiyun {0x87, 0x04},
1131*4882a593Smuzhiyun {0x88, 0x01},
1132*4882a593Smuzhiyun {0x89, 0x01},
1133*4882a593Smuzhiyun {0x8a, 0x01},
1134*4882a593Smuzhiyun {0x8b, 0x01},
1135*4882a593Smuzhiyun {0x8c, 0x02},
1136*4882a593Smuzhiyun {0x8d, 0x02},
1137*4882a593Smuzhiyun {0x8e, 0x02},
1138*4882a593Smuzhiyun {0x8f, 0x02},
1139*4882a593Smuzhiyun {0xEC, 0x00},
1140*4882a593Smuzhiyun {0xED, 0x00},
1141*4882a593Smuzhiyun {0xEE, 0x00},
1142*4882a593Smuzhiyun {0xEF, 0x00},
1143*4882a593Smuzhiyun {0xFF, 0x05},
1144*4882a593Smuzhiyun {0x00, 0xd0},
1145*4882a593Smuzhiyun {0x01, 0x2c},
1146*4882a593Smuzhiyun {0x05, 0x24}, //d_agc_option
1147*4882a593Smuzhiyun {0x1d, 0x0c},
1148*4882a593Smuzhiyun {0x24, 0x2a},
1149*4882a593Smuzhiyun {0x25, 0xdc}, //fsc_lock_mode
1150*4882a593Smuzhiyun {0x26, 0x40},
1151*4882a593Smuzhiyun {0x27, 0x57},
1152*4882a593Smuzhiyun {0x28, 0x80}, //s_point
1153*4882a593Smuzhiyun {0x2b, 0xa8}, //saturation_b
1154*4882a593Smuzhiyun {0x31, 0x82},
1155*4882a593Smuzhiyun {0x32, 0x10},
1156*4882a593Smuzhiyun {0x38, 0x00}, //burst_dec_b
1157*4882a593Smuzhiyun {0x47, 0xEE},
1158*4882a593Smuzhiyun {0x50, 0xc6},
1159*4882a593Smuzhiyun {0x53, 0x00},
1160*4882a593Smuzhiyun {0x57, 0x00},
1161*4882a593Smuzhiyun {0x58, 0x77},
1162*4882a593Smuzhiyun {0x59, 0x00},
1163*4882a593Smuzhiyun {0x5C, 0x78},
1164*4882a593Smuzhiyun {0x5F, 0x00},
1165*4882a593Smuzhiyun {0x62, 0x20},
1166*4882a593Smuzhiyun {0x64, 0x00},
1167*4882a593Smuzhiyun {0x65, 0x00},
1168*4882a593Smuzhiyun {0x69, 0x00},
1169*4882a593Smuzhiyun {0x6E, 0x00}, //VBLK_EXT_EN
1170*4882a593Smuzhiyun {0x6F, 0x00}, //VBLK_EXT_[7:0]
1171*4882a593Smuzhiyun {0x90, 0x01}, //comb_mode
1172*4882a593Smuzhiyun {0x92, 0x00},
1173*4882a593Smuzhiyun {0x94, 0x00},
1174*4882a593Smuzhiyun {0x95, 0x00},
1175*4882a593Smuzhiyun {0xa9, 0x00},
1176*4882a593Smuzhiyun {0xb5, 0x80},
1177*4882a593Smuzhiyun {0xb7, 0xfc},
1178*4882a593Smuzhiyun {0xb8, 0x39},
1179*4882a593Smuzhiyun {0xb9, 0x72},
1180*4882a593Smuzhiyun {0xbb, 0x0f},
1181*4882a593Smuzhiyun {0xd1, 0x30}, //burst_dec_c
1182*4882a593Smuzhiyun {0xd5, 0x80},
1183*4882a593Smuzhiyun {0xFF, 0x09},
1184*4882a593Smuzhiyun {0x40, 0x00},
1185*4882a593Smuzhiyun {0x41, 0x00},
1186*4882a593Smuzhiyun {0x42, 0x00},
1187*4882a593Smuzhiyun {0x43, 0x00},
1188*4882a593Smuzhiyun {0x44, 0x00},
1189*4882a593Smuzhiyun {0x45, 0x00},
1190*4882a593Smuzhiyun {0x46, 0x00},
1191*4882a593Smuzhiyun {0x47, 0x00},
1192*4882a593Smuzhiyun {0x50, 0x30},
1193*4882a593Smuzhiyun {0x51, 0x6f},
1194*4882a593Smuzhiyun {0x52, 0x67},
1195*4882a593Smuzhiyun {0x53, 0x48},
1196*4882a593Smuzhiyun {0x54, 0x30},
1197*4882a593Smuzhiyun {0x55, 0x6f},
1198*4882a593Smuzhiyun {0x56, 0x67},
1199*4882a593Smuzhiyun {0x57, 0x48},
1200*4882a593Smuzhiyun {0x58, 0x30},
1201*4882a593Smuzhiyun {0x59, 0x6f},
1202*4882a593Smuzhiyun {0x5a, 0x67},
1203*4882a593Smuzhiyun {0x5b, 0x48},
1204*4882a593Smuzhiyun {0x5c, 0x30},
1205*4882a593Smuzhiyun {0x5d, 0x6f},
1206*4882a593Smuzhiyun {0x5e, 0x67},
1207*4882a593Smuzhiyun {0x5f, 0x48},
1208*4882a593Smuzhiyun {0x96, 0x00},
1209*4882a593Smuzhiyun {0x97, 0x00},
1210*4882a593Smuzhiyun {0x98, 0x00},
1211*4882a593Smuzhiyun {0x99, 0x00},
1212*4882a593Smuzhiyun {0x9a, 0x00},
1213*4882a593Smuzhiyun {0x9b, 0x00},
1214*4882a593Smuzhiyun {0x9c, 0x00},
1215*4882a593Smuzhiyun {0x9d, 0x00},
1216*4882a593Smuzhiyun {0x9e, 0x00},
1217*4882a593Smuzhiyun {0xb6, 0x00},
1218*4882a593Smuzhiyun {0xb7, 0x00},
1219*4882a593Smuzhiyun {0xb8, 0x00},
1220*4882a593Smuzhiyun {0xb9, 0x00},
1221*4882a593Smuzhiyun {0xba, 0x00},
1222*4882a593Smuzhiyun {0xbb, 0x00},
1223*4882a593Smuzhiyun {0xbc, 0x00},
1224*4882a593Smuzhiyun {0xbd, 0x00},
1225*4882a593Smuzhiyun {0xbe, 0x00},
1226*4882a593Smuzhiyun {0xd6, 0x00},
1227*4882a593Smuzhiyun {0xd7, 0x00},
1228*4882a593Smuzhiyun {0xd8, 0x00},
1229*4882a593Smuzhiyun {0xd9, 0x00},
1230*4882a593Smuzhiyun {0xda, 0x00},
1231*4882a593Smuzhiyun {0xdb, 0x00},
1232*4882a593Smuzhiyun {0xdc, 0x00},
1233*4882a593Smuzhiyun {0xdd, 0x00},
1234*4882a593Smuzhiyun {0xde, 0x00},
1235*4882a593Smuzhiyun {0xf6, 0x00},
1236*4882a593Smuzhiyun {0xf7, 0x00},
1237*4882a593Smuzhiyun {0xf8, 0x00},
1238*4882a593Smuzhiyun {0xf9, 0x00},
1239*4882a593Smuzhiyun {0xfa, 0x00},
1240*4882a593Smuzhiyun {0xfb, 0x00},
1241*4882a593Smuzhiyun {0xfc, 0x00},
1242*4882a593Smuzhiyun {0xfd, 0x00},
1243*4882a593Smuzhiyun {0xfe, 0x00},
1244*4882a593Smuzhiyun {0xff, 0x0a},
1245*4882a593Smuzhiyun {0x3d, 0x00},
1246*4882a593Smuzhiyun {0x3c, 0x00},
1247*4882a593Smuzhiyun {0x30, 0xac},
1248*4882a593Smuzhiyun {0x31, 0x78},
1249*4882a593Smuzhiyun {0x32, 0x17},
1250*4882a593Smuzhiyun {0x33, 0xc1},
1251*4882a593Smuzhiyun {0x34, 0x40},
1252*4882a593Smuzhiyun {0x35, 0x00},
1253*4882a593Smuzhiyun {0x36, 0xc3},
1254*4882a593Smuzhiyun {0x37, 0x0a},
1255*4882a593Smuzhiyun {0x38, 0x00},
1256*4882a593Smuzhiyun {0x39, 0x02},
1257*4882a593Smuzhiyun {0x3a, 0x00},
1258*4882a593Smuzhiyun {0x3b, 0xb2},
1259*4882a593Smuzhiyun {0x25, 0x10},
1260*4882a593Smuzhiyun {0x27, 0x1e},
1261*4882a593Smuzhiyun {0xbd, 0x00},
1262*4882a593Smuzhiyun {0xbc, 0x00},
1263*4882a593Smuzhiyun {0xb0, 0xac},
1264*4882a593Smuzhiyun {0xb1, 0x78},
1265*4882a593Smuzhiyun {0xb2, 0x17},
1266*4882a593Smuzhiyun {0xb3, 0xc1},
1267*4882a593Smuzhiyun {0xb4, 0x40},
1268*4882a593Smuzhiyun {0xb5, 0x00},
1269*4882a593Smuzhiyun {0xb6, 0xc3},
1270*4882a593Smuzhiyun {0xb7, 0x0a},
1271*4882a593Smuzhiyun {0xb8, 0x00},
1272*4882a593Smuzhiyun {0xb9, 0x02},
1273*4882a593Smuzhiyun {0xba, 0x00},
1274*4882a593Smuzhiyun {0xbb, 0xb2},
1275*4882a593Smuzhiyun {0xa5, 0x10},
1276*4882a593Smuzhiyun {0xa7, 0x1e},
1277*4882a593Smuzhiyun {0xff, 0x0b},
1278*4882a593Smuzhiyun {0x3d, 0x00},
1279*4882a593Smuzhiyun {0x3c, 0x00},
1280*4882a593Smuzhiyun {0x30, 0xac},
1281*4882a593Smuzhiyun {0x31, 0x78},
1282*4882a593Smuzhiyun {0x32, 0x17},
1283*4882a593Smuzhiyun {0x33, 0xc1},
1284*4882a593Smuzhiyun {0x34, 0x40},
1285*4882a593Smuzhiyun {0x35, 0x00},
1286*4882a593Smuzhiyun {0x36, 0xc3},
1287*4882a593Smuzhiyun {0x37, 0x0a},
1288*4882a593Smuzhiyun {0x38, 0x00},
1289*4882a593Smuzhiyun {0x39, 0x02},
1290*4882a593Smuzhiyun {0x3a, 0x00},
1291*4882a593Smuzhiyun {0x3b, 0xb2},
1292*4882a593Smuzhiyun {0x25, 0x10},
1293*4882a593Smuzhiyun {0x27, 0x1e},
1294*4882a593Smuzhiyun {0xbd, 0x00},
1295*4882a593Smuzhiyun {0xbc, 0x00},
1296*4882a593Smuzhiyun {0xb0, 0xac},
1297*4882a593Smuzhiyun {0xb1, 0x78},
1298*4882a593Smuzhiyun {0xb2, 0x17},
1299*4882a593Smuzhiyun {0xb3, 0xc1},
1300*4882a593Smuzhiyun {0xb4, 0x40},
1301*4882a593Smuzhiyun {0xb5, 0x00},
1302*4882a593Smuzhiyun {0xb6, 0xc3},
1303*4882a593Smuzhiyun {0xb7, 0x0a},
1304*4882a593Smuzhiyun {0xb8, 0x00},
1305*4882a593Smuzhiyun {0xb9, 0x02},
1306*4882a593Smuzhiyun {0xba, 0x00},
1307*4882a593Smuzhiyun {0xbb, 0xb2},
1308*4882a593Smuzhiyun {0xa5, 0x10},
1309*4882a593Smuzhiyun {0xa7, 0x1e},
1310*4882a593Smuzhiyun {0xFF, 0x21},
1311*4882a593Smuzhiyun {0x3E, 0x00},
1312*4882a593Smuzhiyun {0x3F, 0x00},
1313*4882a593Smuzhiyun {0xFF, 0x20},
1314*4882a593Smuzhiyun {0x01, 0x55},
1315*4882a593Smuzhiyun {0x00, 0x00},
1316*4882a593Smuzhiyun {0x40, 0x01},
1317*4882a593Smuzhiyun {0x0F, 0x00},
1318*4882a593Smuzhiyun {0x0D, 0x01}, //0x01:4lane;0x00:2lane
1319*4882a593Smuzhiyun {0x40, 0x00},
1320*4882a593Smuzhiyun {0x00, 0xFF}, //ch1/2/3/4 enabled
1321*4882a593Smuzhiyun //{0x00, 0x33}, //ch1/2 enabled
1322*4882a593Smuzhiyun //{0x00, 0x11}, //ch1 enabled
1323*4882a593Smuzhiyun {0xFF, 0x01},
1324*4882a593Smuzhiyun {0xC8, 0x00},
1325*4882a593Smuzhiyun {0xC9, 0x00},
1326*4882a593Smuzhiyun {0xCA, 0x00},
1327*4882a593Smuzhiyun {0xCB, 0x00},
1328*4882a593Smuzhiyun //pattern enabled
1329*4882a593Smuzhiyun {0xFF, 0x00},
1330*4882a593Smuzhiyun {0x1C, 0x1A},
1331*4882a593Smuzhiyun {0x1D, 0x1A},
1332*4882a593Smuzhiyun {0x1E, 0x1A},
1333*4882a593Smuzhiyun {0x1F, 0x1A},
1334*4882a593Smuzhiyun {0xFF, 0x05},
1335*4882a593Smuzhiyun {0x6A, 0x80},
1336*4882a593Smuzhiyun {0xFF, 0x06},
1337*4882a593Smuzhiyun {0x6A, 0x80},
1338*4882a593Smuzhiyun {0xFF, 0x07},
1339*4882a593Smuzhiyun {0x6A, 0x80},
1340*4882a593Smuzhiyun {0xFF, 0x08},
1341*4882a593Smuzhiyun {0x6A, 0x80},
1342*4882a593Smuzhiyun SensorEnd
1343*4882a593Smuzhiyun };
1344*4882a593Smuzhiyun
1345*4882a593Smuzhiyun /* 1080p Preview resolution setting*/
1346*4882a593Smuzhiyun static struct rk_sensor_reg sensor_preview_data_1080p_25hz[] = {
1347*4882a593Smuzhiyun {0xff, 0x04},
1348*4882a593Smuzhiyun {0xa0, 0x24},
1349*4882a593Smuzhiyun {0xa1, 0x24},
1350*4882a593Smuzhiyun {0xa2, 0x24},
1351*4882a593Smuzhiyun {0xa3, 0x24},
1352*4882a593Smuzhiyun {0xa4, 0x24},
1353*4882a593Smuzhiyun {0xa5, 0x24},
1354*4882a593Smuzhiyun {0xa6, 0x24},
1355*4882a593Smuzhiyun {0xa7, 0x24},
1356*4882a593Smuzhiyun {0xa8, 0x24},
1357*4882a593Smuzhiyun {0xa9, 0x24},
1358*4882a593Smuzhiyun {0xaa, 0x24},
1359*4882a593Smuzhiyun {0xab, 0x24},
1360*4882a593Smuzhiyun {0xac, 0x24},
1361*4882a593Smuzhiyun {0xad, 0x24},
1362*4882a593Smuzhiyun {0xae, 0x24},
1363*4882a593Smuzhiyun {0xaf, 0x24},
1364*4882a593Smuzhiyun {0xb0, 0x24},
1365*4882a593Smuzhiyun {0xb1, 0x24},
1366*4882a593Smuzhiyun {0xb2, 0x24},
1367*4882a593Smuzhiyun {0xb3, 0x24},
1368*4882a593Smuzhiyun {0xb4, 0x24},
1369*4882a593Smuzhiyun {0xb5, 0x24},
1370*4882a593Smuzhiyun {0xb6, 0x24},
1371*4882a593Smuzhiyun {0xb7, 0x24},
1372*4882a593Smuzhiyun {0xb8, 0x24},
1373*4882a593Smuzhiyun {0xb9, 0x24},
1374*4882a593Smuzhiyun {0xba, 0x24},
1375*4882a593Smuzhiyun {0xbb, 0x24},
1376*4882a593Smuzhiyun {0xbc, 0x24},
1377*4882a593Smuzhiyun {0xbd, 0x24},
1378*4882a593Smuzhiyun {0xbe, 0x24},
1379*4882a593Smuzhiyun {0xbf, 0x24},
1380*4882a593Smuzhiyun {0xc0, 0x24},
1381*4882a593Smuzhiyun {0xc1, 0x24},
1382*4882a593Smuzhiyun {0xc2, 0x24},
1383*4882a593Smuzhiyun {0xc3, 0x24},
1384*4882a593Smuzhiyun {0xff, 0x21},
1385*4882a593Smuzhiyun {0x07, 0x80},
1386*4882a593Smuzhiyun {0x07, 0x00},
1387*4882a593Smuzhiyun {0xff, 0x0A},
1388*4882a593Smuzhiyun {0x77, 0x8F},
1389*4882a593Smuzhiyun {0xF7, 0x8F},
1390*4882a593Smuzhiyun {0xff, 0x0B},
1391*4882a593Smuzhiyun {0x77, 0x8F},
1392*4882a593Smuzhiyun {0xF7, 0x8F},
1393*4882a593Smuzhiyun {0xFF, 0x21},
1394*4882a593Smuzhiyun {0x40, 0xB4},
1395*4882a593Smuzhiyun {0x41, 0x00},
1396*4882a593Smuzhiyun {0x42, 0x03},
1397*4882a593Smuzhiyun {0x43, 0x43},
1398*4882a593Smuzhiyun {0x11, 0x08},
1399*4882a593Smuzhiyun {0x10, 0x13},
1400*4882a593Smuzhiyun {0x12, 0x0B},
1401*4882a593Smuzhiyun {0x13, 0x12},
1402*4882a593Smuzhiyun {0x17, 0x02},
1403*4882a593Smuzhiyun {0x18, 0x12},
1404*4882a593Smuzhiyun {0x15, 0x07},
1405*4882a593Smuzhiyun {0x14, 0x2D},
1406*4882a593Smuzhiyun {0x16, 0x0B},
1407*4882a593Smuzhiyun {0x19, 0x09},
1408*4882a593Smuzhiyun {0x1A, 0x15},
1409*4882a593Smuzhiyun {0x1B, 0x11},
1410*4882a593Smuzhiyun {0x1C, 0x0E},
1411*4882a593Smuzhiyun {0x44, 0x00},
1412*4882a593Smuzhiyun {0x49, 0xF3},
1413*4882a593Smuzhiyun {0x49, 0xF0},
1414*4882a593Smuzhiyun {0x44, 0x02},
1415*4882a593Smuzhiyun {0x08, 0x40}, //0x40:non-continue;0x48:continuous
1416*4882a593Smuzhiyun {0x0F, 0x01},
1417*4882a593Smuzhiyun {0x38, 0x1E},
1418*4882a593Smuzhiyun {0x39, 0x1E},
1419*4882a593Smuzhiyun {0x3A, 0x1E},
1420*4882a593Smuzhiyun {0x3B, 0x1E},
1421*4882a593Smuzhiyun {0x07, 0x0f}, //0x07:2lane;0x0f:4lane
1422*4882a593Smuzhiyun {0x2D, 0x01}, //0x00:2lane;0x01:4lane
1423*4882a593Smuzhiyun {0x45, 0x02},
1424*4882a593Smuzhiyun {0xFF, 0x13},
1425*4882a593Smuzhiyun {0x30, 0x00},
1426*4882a593Smuzhiyun {0x31, 0x00},
1427*4882a593Smuzhiyun {0x32, 0x00},
1428*4882a593Smuzhiyun {0xFF, 0x00},
1429*4882a593Smuzhiyun {0x00, 0x00},
1430*4882a593Smuzhiyun {0x01, 0x00},
1431*4882a593Smuzhiyun {0x02, 0x00},
1432*4882a593Smuzhiyun {0x03, 0x00},
1433*4882a593Smuzhiyun {0x04, 0x00}, //sd_mode
1434*4882a593Smuzhiyun {0x05, 0x00},
1435*4882a593Smuzhiyun {0x06, 0x00},
1436*4882a593Smuzhiyun {0x07, 0x00},
1437*4882a593Smuzhiyun {0x08, 0x03}, //ahd_mode
1438*4882a593Smuzhiyun {0x09, 0x03},
1439*4882a593Smuzhiyun {0x0a, 0x03},
1440*4882a593Smuzhiyun {0x0b, 0x03},
1441*4882a593Smuzhiyun {0x0c, 0x00},
1442*4882a593Smuzhiyun {0x0d, 0x00},
1443*4882a593Smuzhiyun {0x0e, 0x00},
1444*4882a593Smuzhiyun {0x0f, 0x00},
1445*4882a593Smuzhiyun {0x10, 0x20}, //video_format
1446*4882a593Smuzhiyun {0x11, 0x20},
1447*4882a593Smuzhiyun {0x12, 0x20},
1448*4882a593Smuzhiyun {0x13, 0x20},
1449*4882a593Smuzhiyun {0x14, 0x00},
1450*4882a593Smuzhiyun {0x15, 0x00},
1451*4882a593Smuzhiyun {0x16, 0x00},
1452*4882a593Smuzhiyun {0x17, 0x00},
1453*4882a593Smuzhiyun {0x18, 0x13},
1454*4882a593Smuzhiyun {0x19, 0x13},
1455*4882a593Smuzhiyun {0x1a, 0x13},
1456*4882a593Smuzhiyun {0x1b, 0x13},
1457*4882a593Smuzhiyun {0x1c, 0x1a},
1458*4882a593Smuzhiyun {0x1d, 0x1a},
1459*4882a593Smuzhiyun {0x1e, 0x1a},
1460*4882a593Smuzhiyun {0x1f, 0x1a},
1461*4882a593Smuzhiyun {0x20, 0x00},
1462*4882a593Smuzhiyun {0x21, 0x00},
1463*4882a593Smuzhiyun {0x22, 0x00},
1464*4882a593Smuzhiyun {0x23, 0x00},
1465*4882a593Smuzhiyun {0x24, 0x86}, //contrast
1466*4882a593Smuzhiyun {0x25, 0x86},
1467*4882a593Smuzhiyun {0x26, 0x86},
1468*4882a593Smuzhiyun {0x27, 0x86},
1469*4882a593Smuzhiyun {0x28, 0x80}, //black_level
1470*4882a593Smuzhiyun {0x29, 0x80},
1471*4882a593Smuzhiyun {0x2a, 0x80},
1472*4882a593Smuzhiyun {0x2b, 0x80},
1473*4882a593Smuzhiyun {0x30, 0x00}, //y_peaking_mode
1474*4882a593Smuzhiyun {0x31, 0x00},
1475*4882a593Smuzhiyun {0x32, 0x00},
1476*4882a593Smuzhiyun {0x33, 0x00},
1477*4882a593Smuzhiyun {0x34, 0x00}, //y_fir_mode
1478*4882a593Smuzhiyun {0x35, 0x00},
1479*4882a593Smuzhiyun {0x36, 0x00},
1480*4882a593Smuzhiyun {0x37, 0x00},
1481*4882a593Smuzhiyun {0x40, 0x00},
1482*4882a593Smuzhiyun {0x41, 0x00},
1483*4882a593Smuzhiyun {0x42, 0x00},
1484*4882a593Smuzhiyun {0x43, 0x00},
1485*4882a593Smuzhiyun {0x44, 0x00},
1486*4882a593Smuzhiyun {0x45, 0x00},
1487*4882a593Smuzhiyun {0x46, 0x00},
1488*4882a593Smuzhiyun {0x47, 0x00},
1489*4882a593Smuzhiyun {0x48, 0x00},
1490*4882a593Smuzhiyun {0x49, 0x00},
1491*4882a593Smuzhiyun {0x4a, 0x00},
1492*4882a593Smuzhiyun {0x4b, 0x00},
1493*4882a593Smuzhiyun {0x4c, 0xfe},
1494*4882a593Smuzhiyun {0x4d, 0xfe},
1495*4882a593Smuzhiyun {0x4e, 0xfe},
1496*4882a593Smuzhiyun {0x4f, 0xfe},
1497*4882a593Smuzhiyun {0x50, 0xfb},
1498*4882a593Smuzhiyun {0x51, 0xfb},
1499*4882a593Smuzhiyun {0x52, 0xfb},
1500*4882a593Smuzhiyun {0x53, 0xfb},
1501*4882a593Smuzhiyun {0x58, 0x80},
1502*4882a593Smuzhiyun {0x59, 0x80},
1503*4882a593Smuzhiyun {0x5a, 0x80},
1504*4882a593Smuzhiyun {0x5b, 0x80},
1505*4882a593Smuzhiyun {0x5c, 0x82}, //pal_cm_off
1506*4882a593Smuzhiyun {0x5d, 0x82},
1507*4882a593Smuzhiyun {0x5e, 0x82},
1508*4882a593Smuzhiyun {0x5f, 0x82},
1509*4882a593Smuzhiyun {0x60, 0x10},
1510*4882a593Smuzhiyun {0x61, 0x10},
1511*4882a593Smuzhiyun {0x62, 0x10},
1512*4882a593Smuzhiyun {0x63, 0x10},
1513*4882a593Smuzhiyun {0x64, 0x05}, //y_delay
1514*4882a593Smuzhiyun {0x65, 0x05},
1515*4882a593Smuzhiyun {0x66, 0x05},
1516*4882a593Smuzhiyun {0x67, 0x05},
1517*4882a593Smuzhiyun {0x68, 0x48}, //h_delay_a //h_delay_lsb
1518*4882a593Smuzhiyun {0x69, 0x48},
1519*4882a593Smuzhiyun {0x6a, 0x48},
1520*4882a593Smuzhiyun {0x6b, 0x48},
1521*4882a593Smuzhiyun {0x6c, 0x00},
1522*4882a593Smuzhiyun {0x6d, 0x00},
1523*4882a593Smuzhiyun {0x6e, 0x00},
1524*4882a593Smuzhiyun {0x6f, 0x00},
1525*4882a593Smuzhiyun // {0x78, 0x21},
1526*4882a593Smuzhiyun // {0x79, 0x21},
1527*4882a593Smuzhiyun // {0x7a, 0x21},
1528*4882a593Smuzhiyun // {0x7b, 0x21},
1529*4882a593Smuzhiyun {0x78, 0x22},
1530*4882a593Smuzhiyun {0x79, 0x22},
1531*4882a593Smuzhiyun {0x7a, 0x22},
1532*4882a593Smuzhiyun {0x7b, 0x22},
1533*4882a593Smuzhiyun {0xFF, 0x01},
1534*4882a593Smuzhiyun {0x7C, 0x00},
1535*4882a593Smuzhiyun {0x84, 0x04},
1536*4882a593Smuzhiyun {0x85, 0x04},
1537*4882a593Smuzhiyun {0x86, 0x04},
1538*4882a593Smuzhiyun {0x87, 0x04},
1539*4882a593Smuzhiyun {0x88, 0x01},
1540*4882a593Smuzhiyun {0x89, 0x01},
1541*4882a593Smuzhiyun {0x8a, 0x01},
1542*4882a593Smuzhiyun {0x8b, 0x01},
1543*4882a593Smuzhiyun {0x8c, 0x02},
1544*4882a593Smuzhiyun {0x8d, 0x02},
1545*4882a593Smuzhiyun {0x8e, 0x02},
1546*4882a593Smuzhiyun {0x8f, 0x02},
1547*4882a593Smuzhiyun {0xEC, 0x00},
1548*4882a593Smuzhiyun {0xED, 0x00},
1549*4882a593Smuzhiyun {0xEE, 0x00},
1550*4882a593Smuzhiyun {0xEF, 0x00},
1551*4882a593Smuzhiyun {0xFF, 0x05},
1552*4882a593Smuzhiyun {0x00, 0xd0},
1553*4882a593Smuzhiyun {0x01, 0x2c},
1554*4882a593Smuzhiyun {0x05, 0x24}, //d_agc_option
1555*4882a593Smuzhiyun {0x1d, 0x0c},
1556*4882a593Smuzhiyun {0x24, 0x2a},
1557*4882a593Smuzhiyun {0x25, 0xdc}, //fsc_lock_mode
1558*4882a593Smuzhiyun {0x26, 0x40},
1559*4882a593Smuzhiyun {0x27, 0x57},
1560*4882a593Smuzhiyun {0x28, 0x80}, //s_point
1561*4882a593Smuzhiyun {0x2b, 0xa8}, //saturation_b
1562*4882a593Smuzhiyun {0x31, 0x82},
1563*4882a593Smuzhiyun {0x32, 0x10},
1564*4882a593Smuzhiyun {0x38, 0x13},
1565*4882a593Smuzhiyun {0x47, 0xEE},
1566*4882a593Smuzhiyun {0x50, 0xc6},
1567*4882a593Smuzhiyun {0x53, 0x00},
1568*4882a593Smuzhiyun {0x57, 0x00},
1569*4882a593Smuzhiyun {0x58, 0x77},
1570*4882a593Smuzhiyun {0x59, 0x00},
1571*4882a593Smuzhiyun {0x5C, 0x78},
1572*4882a593Smuzhiyun {0x5F, 0x00},
1573*4882a593Smuzhiyun {0x62, 0x20},
1574*4882a593Smuzhiyun {0x64, 0x00},
1575*4882a593Smuzhiyun {0x65, 0x00},
1576*4882a593Smuzhiyun {0x69, 0x00},
1577*4882a593Smuzhiyun {0x6E, 0x00}, //VBLK_EXT_EN
1578*4882a593Smuzhiyun {0x6F, 0x00}, //VBLK_EXT_[7:0]
1579*4882a593Smuzhiyun {0x90, 0x01}, //comb_mode
1580*4882a593Smuzhiyun {0x92, 0x00},
1581*4882a593Smuzhiyun {0x94, 0x00},
1582*4882a593Smuzhiyun {0x95, 0x00},
1583*4882a593Smuzhiyun {0xa9, 0x00},
1584*4882a593Smuzhiyun {0xb5, 0x80},
1585*4882a593Smuzhiyun {0xb7, 0xfc},
1586*4882a593Smuzhiyun {0xb8, 0x39},
1587*4882a593Smuzhiyun {0xb9, 0x72},
1588*4882a593Smuzhiyun {0xbb, 0x0f},
1589*4882a593Smuzhiyun {0xd1, 0x30}, //burst_dec_c
1590*4882a593Smuzhiyun {0xd5, 0x80},
1591*4882a593Smuzhiyun {0xFF, 0x09},
1592*4882a593Smuzhiyun {0x40, 0x00},
1593*4882a593Smuzhiyun {0x41, 0x00},
1594*4882a593Smuzhiyun {0x42, 0x00},
1595*4882a593Smuzhiyun {0x43, 0x00},
1596*4882a593Smuzhiyun {0x44, 0x00},
1597*4882a593Smuzhiyun {0x45, 0x00},
1598*4882a593Smuzhiyun {0x46, 0x00},
1599*4882a593Smuzhiyun {0x47, 0x00},
1600*4882a593Smuzhiyun {0x50, 0x30},
1601*4882a593Smuzhiyun {0x51, 0x6f},
1602*4882a593Smuzhiyun {0x52, 0x67},
1603*4882a593Smuzhiyun {0x53, 0x48},
1604*4882a593Smuzhiyun {0x54, 0x30},
1605*4882a593Smuzhiyun {0x55, 0x6f},
1606*4882a593Smuzhiyun {0x56, 0x67},
1607*4882a593Smuzhiyun {0x57, 0x48},
1608*4882a593Smuzhiyun {0x58, 0x30},
1609*4882a593Smuzhiyun {0x59, 0x6f},
1610*4882a593Smuzhiyun {0x5a, 0x67},
1611*4882a593Smuzhiyun {0x5b, 0x48},
1612*4882a593Smuzhiyun {0x5c, 0x30},
1613*4882a593Smuzhiyun {0x5d, 0x6f},
1614*4882a593Smuzhiyun {0x5e, 0x67},
1615*4882a593Smuzhiyun {0x5f, 0x48},
1616*4882a593Smuzhiyun {0x96, 0x00},
1617*4882a593Smuzhiyun {0x97, 0x00},
1618*4882a593Smuzhiyun {0x98, 0x00},
1619*4882a593Smuzhiyun {0x99, 0x00},
1620*4882a593Smuzhiyun {0x9a, 0x00},
1621*4882a593Smuzhiyun {0x9b, 0x00},
1622*4882a593Smuzhiyun {0x9c, 0x00},
1623*4882a593Smuzhiyun {0x9d, 0x00},
1624*4882a593Smuzhiyun {0x9e, 0x00},
1625*4882a593Smuzhiyun {0xb6, 0x00},
1626*4882a593Smuzhiyun {0xb7, 0x00},
1627*4882a593Smuzhiyun {0xb8, 0x00},
1628*4882a593Smuzhiyun {0xb9, 0x00},
1629*4882a593Smuzhiyun {0xba, 0x00},
1630*4882a593Smuzhiyun {0xbb, 0x00},
1631*4882a593Smuzhiyun {0xbc, 0x00},
1632*4882a593Smuzhiyun {0xbd, 0x00},
1633*4882a593Smuzhiyun {0xbe, 0x00},
1634*4882a593Smuzhiyun {0xd6, 0x00},
1635*4882a593Smuzhiyun {0xd7, 0x00},
1636*4882a593Smuzhiyun {0xd8, 0x00},
1637*4882a593Smuzhiyun {0xd9, 0x00},
1638*4882a593Smuzhiyun {0xda, 0x00},
1639*4882a593Smuzhiyun {0xdb, 0x00},
1640*4882a593Smuzhiyun {0xdc, 0x00},
1641*4882a593Smuzhiyun {0xdd, 0x00},
1642*4882a593Smuzhiyun {0xde, 0x00},
1643*4882a593Smuzhiyun {0xf6, 0x00},
1644*4882a593Smuzhiyun {0xf7, 0x00},
1645*4882a593Smuzhiyun {0xf8, 0x00},
1646*4882a593Smuzhiyun {0xf9, 0x00},
1647*4882a593Smuzhiyun {0xfa, 0x00},
1648*4882a593Smuzhiyun {0xfb, 0x00},
1649*4882a593Smuzhiyun {0xfc, 0x00},
1650*4882a593Smuzhiyun {0xfd, 0x00},
1651*4882a593Smuzhiyun {0xfe, 0x00},
1652*4882a593Smuzhiyun {0xff, 0x0a},
1653*4882a593Smuzhiyun {0x3d, 0x00},
1654*4882a593Smuzhiyun {0x3c, 0x00},
1655*4882a593Smuzhiyun {0x30, 0xac},
1656*4882a593Smuzhiyun {0x31, 0x78},
1657*4882a593Smuzhiyun {0x32, 0x17},
1658*4882a593Smuzhiyun {0x33, 0xc1},
1659*4882a593Smuzhiyun {0x34, 0x40},
1660*4882a593Smuzhiyun {0x35, 0x00},
1661*4882a593Smuzhiyun {0x36, 0xc3},
1662*4882a593Smuzhiyun {0x37, 0x0a},
1663*4882a593Smuzhiyun {0x38, 0x00},
1664*4882a593Smuzhiyun {0x39, 0x02},
1665*4882a593Smuzhiyun {0x3a, 0x00},
1666*4882a593Smuzhiyun {0x3b, 0xb2},
1667*4882a593Smuzhiyun {0x25, 0x10},
1668*4882a593Smuzhiyun {0x27, 0x1e},
1669*4882a593Smuzhiyun {0xbd, 0x00},
1670*4882a593Smuzhiyun {0xbc, 0x00},
1671*4882a593Smuzhiyun {0xb0, 0xac},
1672*4882a593Smuzhiyun {0xb1, 0x78},
1673*4882a593Smuzhiyun {0xb2, 0x17},
1674*4882a593Smuzhiyun {0xb3, 0xc1},
1675*4882a593Smuzhiyun {0xb4, 0x40},
1676*4882a593Smuzhiyun {0xb5, 0x00},
1677*4882a593Smuzhiyun {0xb6, 0xc3},
1678*4882a593Smuzhiyun {0xb7, 0x0a},
1679*4882a593Smuzhiyun {0xb8, 0x00},
1680*4882a593Smuzhiyun {0xb9, 0x02},
1681*4882a593Smuzhiyun {0xba, 0x00},
1682*4882a593Smuzhiyun {0xbb, 0xb2},
1683*4882a593Smuzhiyun {0xa5, 0x10},
1684*4882a593Smuzhiyun {0xa7, 0x1e},
1685*4882a593Smuzhiyun {0xff, 0x0b},
1686*4882a593Smuzhiyun {0x3d, 0x00},
1687*4882a593Smuzhiyun {0x3c, 0x00},
1688*4882a593Smuzhiyun {0x30, 0xac},
1689*4882a593Smuzhiyun {0x31, 0x78},
1690*4882a593Smuzhiyun {0x32, 0x17},
1691*4882a593Smuzhiyun {0x33, 0xc1},
1692*4882a593Smuzhiyun {0x34, 0x40},
1693*4882a593Smuzhiyun {0x35, 0x00},
1694*4882a593Smuzhiyun {0x36, 0xc3},
1695*4882a593Smuzhiyun {0x37, 0x0a},
1696*4882a593Smuzhiyun {0x38, 0x00},
1697*4882a593Smuzhiyun {0x39, 0x02},
1698*4882a593Smuzhiyun {0x3a, 0x00},
1699*4882a593Smuzhiyun {0x3b, 0xb2},
1700*4882a593Smuzhiyun {0x25, 0x10},
1701*4882a593Smuzhiyun {0x27, 0x1e},
1702*4882a593Smuzhiyun {0xbd, 0x00},
1703*4882a593Smuzhiyun {0xbc, 0x00},
1704*4882a593Smuzhiyun {0xb0, 0xac},
1705*4882a593Smuzhiyun {0xb1, 0x78},
1706*4882a593Smuzhiyun {0xb2, 0x17},
1707*4882a593Smuzhiyun {0xb3, 0xc1},
1708*4882a593Smuzhiyun {0xb4, 0x40},
1709*4882a593Smuzhiyun {0xb5, 0x00},
1710*4882a593Smuzhiyun {0xb6, 0xc3},
1711*4882a593Smuzhiyun {0xb7, 0x0a},
1712*4882a593Smuzhiyun {0xb8, 0x00},
1713*4882a593Smuzhiyun {0xb9, 0x02},
1714*4882a593Smuzhiyun {0xba, 0x00},
1715*4882a593Smuzhiyun {0xbb, 0xb2},
1716*4882a593Smuzhiyun {0xa5, 0x10},
1717*4882a593Smuzhiyun {0xa7, 0x1e},
1718*4882a593Smuzhiyun {0xFF, 0x21},
1719*4882a593Smuzhiyun {0x3E, 0x00},
1720*4882a593Smuzhiyun {0x3F, 0x00},
1721*4882a593Smuzhiyun {0xFF, 0x20},
1722*4882a593Smuzhiyun {0x01, 0x00},
1723*4882a593Smuzhiyun {0x00, 0x00},
1724*4882a593Smuzhiyun {0x40, 0x01},
1725*4882a593Smuzhiyun {0x0F, 0x00},
1726*4882a593Smuzhiyun {0x0D, 0x01}, //0x01:4lane;0x00:2lane
1727*4882a593Smuzhiyun {0x40, 0x00},
1728*4882a593Smuzhiyun {0x00, 0xFF}, //ch1/2/3/4 enabled
1729*4882a593Smuzhiyun //{0x00, 0x33}, //ch1/2 enabled
1730*4882a593Smuzhiyun //{0x00, 0x11}, //ch1 enabled
1731*4882a593Smuzhiyun {0xFF, 0x01},
1732*4882a593Smuzhiyun {0xC8, 0x00},
1733*4882a593Smuzhiyun {0xC9, 0x00},
1734*4882a593Smuzhiyun {0xCA, 0x00},
1735*4882a593Smuzhiyun {0xCB, 0x00},
1736*4882a593Smuzhiyun //pattern enabled
1737*4882a593Smuzhiyun {0xFF, 0x00},
1738*4882a593Smuzhiyun {0x1C, 0x1A},
1739*4882a593Smuzhiyun {0x1D, 0x1A},
1740*4882a593Smuzhiyun {0x1E, 0x1A},
1741*4882a593Smuzhiyun {0x1F, 0x1A},
1742*4882a593Smuzhiyun {0xFF, 0x05},
1743*4882a593Smuzhiyun {0x6A, 0x80},
1744*4882a593Smuzhiyun {0xFF, 0x06},
1745*4882a593Smuzhiyun {0x6A, 0x80},
1746*4882a593Smuzhiyun {0xFF, 0x07},
1747*4882a593Smuzhiyun {0x6A, 0x80},
1748*4882a593Smuzhiyun {0xFF, 0x08},
1749*4882a593Smuzhiyun {0x6A, 0x80},
1750*4882a593Smuzhiyun SensorEnd
1751*4882a593Smuzhiyun };
1752*4882a593Smuzhiyun
1753*4882a593Smuzhiyun /* format detect open*/
1754*4882a593Smuzhiyun static struct rk_sensor_reg sensor_open_format_detect[] = {
1755*4882a593Smuzhiyun {0xff, 0x13},
1756*4882a593Smuzhiyun {0x1f, 0x23},
1757*4882a593Smuzhiyun {0x30, 0xff},
1758*4882a593Smuzhiyun {0x31, 0xff},
1759*4882a593Smuzhiyun {0x32, 0xff},
1760*4882a593Smuzhiyun SensorEnd
1761*4882a593Smuzhiyun };
1762*4882a593Smuzhiyun
nvp6324_reinit_parameter(struct vehicle_ad_dev * ad,unsigned char cvstd)1763*4882a593Smuzhiyun static void nvp6324_reinit_parameter(struct vehicle_ad_dev *ad, unsigned char cvstd)
1764*4882a593Smuzhiyun {
1765*4882a593Smuzhiyun int i = 0;
1766*4882a593Smuzhiyun
1767*4882a593Smuzhiyun switch (cvstd) {
1768*4882a593Smuzhiyun case CVSTD_PAL:
1769*4882a593Smuzhiyun ad->cfg.width = FORCE_PAL_WIDTH;
1770*4882a593Smuzhiyun ad->cfg.height = FORCE_PAL_HEIGHT;
1771*4882a593Smuzhiyun ad->cfg.start_x = 0;
1772*4882a593Smuzhiyun ad->cfg.start_y = 0;
1773*4882a593Smuzhiyun ad->cfg.input_format = CIF_INPUT_FORMAT_PAL;
1774*4882a593Smuzhiyun ad->cfg.output_format = FORCE_CIF_OUTPUT_FORMAT;
1775*4882a593Smuzhiyun ad->cfg.field_order = 1;
1776*4882a593Smuzhiyun ad->cfg.yuv_order = 0;/*00 - UYVY*/
1777*4882a593Smuzhiyun ad->cfg.href = 0;
1778*4882a593Smuzhiyun ad->cfg.vsync = 0;
1779*4882a593Smuzhiyun ad->cfg.frame_rate = 25;//25 30
1780*4882a593Smuzhiyun ad->cfg.mipi_freq = JAGUAR1_LINK_FREQ_320M;
1781*4882a593Smuzhiyun break;
1782*4882a593Smuzhiyun case CVSTD_NTSC:
1783*4882a593Smuzhiyun ad->cfg.width = FORCE_NTSC_WIDTH;
1784*4882a593Smuzhiyun ad->cfg.height = FORCE_NTSC_HEIGHT;
1785*4882a593Smuzhiyun ad->cfg.start_x = 0;
1786*4882a593Smuzhiyun ad->cfg.start_y = 0;
1787*4882a593Smuzhiyun ad->cfg.input_format = CIF_INPUT_FORMAT_NTSC;
1788*4882a593Smuzhiyun ad->cfg.output_format = FORCE_CIF_OUTPUT_FORMAT;
1789*4882a593Smuzhiyun ad->cfg.field_order = 1;
1790*4882a593Smuzhiyun ad->cfg.yuv_order = 0;/*00 - UYVY*/
1791*4882a593Smuzhiyun ad->cfg.href = 0;
1792*4882a593Smuzhiyun ad->cfg.vsync = 0;
1793*4882a593Smuzhiyun ad->cfg.frame_rate = 30;//25 30
1794*4882a593Smuzhiyun ad->cfg.mipi_freq = JAGUAR1_LINK_FREQ_320M;
1795*4882a593Smuzhiyun break;
1796*4882a593Smuzhiyun case CVSTD_720P25:
1797*4882a593Smuzhiyun ad->cfg.width = 1280;
1798*4882a593Smuzhiyun ad->cfg.height = 720;
1799*4882a593Smuzhiyun ad->cfg.start_x = 0;
1800*4882a593Smuzhiyun ad->cfg.start_y = 0;
1801*4882a593Smuzhiyun ad->cfg.input_format = CIF_INPUT_FORMAT_YUV;
1802*4882a593Smuzhiyun ad->cfg.output_format = FORCE_CIF_OUTPUT_FORMAT;
1803*4882a593Smuzhiyun ad->cfg.field_order = 0;
1804*4882a593Smuzhiyun ad->cfg.yuv_order = 0;/*00 - UYVY*/
1805*4882a593Smuzhiyun ad->cfg.href = 0;
1806*4882a593Smuzhiyun ad->cfg.vsync = 0;
1807*4882a593Smuzhiyun ad->cfg.frame_rate = 25;
1808*4882a593Smuzhiyun ad->cfg.mipi_freq = JAGUAR1_LINK_FREQ_320M;
1809*4882a593Smuzhiyun break;
1810*4882a593Smuzhiyun
1811*4882a593Smuzhiyun case CVSTD_1080P25:
1812*4882a593Smuzhiyun ad->cfg.width = 1920;
1813*4882a593Smuzhiyun ad->cfg.height = 1080;
1814*4882a593Smuzhiyun ad->cfg.start_x = 0;
1815*4882a593Smuzhiyun ad->cfg.start_y = 0;
1816*4882a593Smuzhiyun ad->cfg.input_format = CIF_INPUT_FORMAT_YUV;
1817*4882a593Smuzhiyun ad->cfg.output_format = FORCE_CIF_OUTPUT_FORMAT;
1818*4882a593Smuzhiyun ad->cfg.field_order = 0;
1819*4882a593Smuzhiyun ad->cfg.yuv_order = 0;/*00 - UYVY*/
1820*4882a593Smuzhiyun ad->cfg.href = 0;
1821*4882a593Smuzhiyun ad->cfg.vsync = 0;
1822*4882a593Smuzhiyun ad->cfg.frame_rate = 25;
1823*4882a593Smuzhiyun ad->cfg.mipi_freq = JAGUAR1_LINK_FREQ_640M;
1824*4882a593Smuzhiyun break;
1825*4882a593Smuzhiyun
1826*4882a593Smuzhiyun default:
1827*4882a593Smuzhiyun ad->cfg.width = 1920;
1828*4882a593Smuzhiyun ad->cfg.height = 1080;
1829*4882a593Smuzhiyun ad->cfg.start_x = 0;
1830*4882a593Smuzhiyun ad->cfg.start_y = 0;
1831*4882a593Smuzhiyun ad->cfg.input_format = CIF_INPUT_FORMAT_YUV;
1832*4882a593Smuzhiyun ad->cfg.output_format = FORCE_CIF_OUTPUT_FORMAT;
1833*4882a593Smuzhiyun ad->cfg.field_order = 0;
1834*4882a593Smuzhiyun ad->cfg.yuv_order = 0;/*00 - UYVY*/
1835*4882a593Smuzhiyun ad->cfg.href = 0;
1836*4882a593Smuzhiyun ad->cfg.vsync = 0;
1837*4882a593Smuzhiyun ad->cfg.frame_rate = 25;
1838*4882a593Smuzhiyun ad->cfg.mipi_freq = JAGUAR1_LINK_FREQ_640M;
1839*4882a593Smuzhiyun break;
1840*4882a593Smuzhiyun }
1841*4882a593Smuzhiyun ad->cfg.type = V4L2_MBUS_CSI2_DPHY;
1842*4882a593Smuzhiyun ad->cfg.mbus_flags = V4L2_MBUS_CSI2_4_LANE |
1843*4882a593Smuzhiyun V4L2_MBUS_CSI2_CHANNELS;
1844*4882a593Smuzhiyun ad->cfg.mbus_code = MEDIA_BUS_FMT_UYVY8_2X8;
1845*4882a593Smuzhiyun
1846*4882a593Smuzhiyun switch (ad->cfg.mbus_flags & V4L2_MBUS_CSI2_LANES) {
1847*4882a593Smuzhiyun case V4L2_MBUS_CSI2_1_LANE:
1848*4882a593Smuzhiyun ad->cfg.lanes = 1;
1849*4882a593Smuzhiyun break;
1850*4882a593Smuzhiyun case V4L2_MBUS_CSI2_2_LANE:
1851*4882a593Smuzhiyun ad->cfg.lanes = 2;
1852*4882a593Smuzhiyun break;
1853*4882a593Smuzhiyun case V4L2_MBUS_CSI2_3_LANE:
1854*4882a593Smuzhiyun ad->cfg.lanes = 3;
1855*4882a593Smuzhiyun break;
1856*4882a593Smuzhiyun case V4L2_MBUS_CSI2_4_LANE:
1857*4882a593Smuzhiyun ad->cfg.lanes = 4;
1858*4882a593Smuzhiyun break;
1859*4882a593Smuzhiyun default:
1860*4882a593Smuzhiyun ad->cfg.lanes = 1;
1861*4882a593Smuzhiyun break;
1862*4882a593Smuzhiyun }
1863*4882a593Smuzhiyun
1864*4882a593Smuzhiyun /* fix crop info from dts config */
1865*4882a593Smuzhiyun for (i = 0; i < 4; i++) {
1866*4882a593Smuzhiyun if ((ad->defrects[i].width == ad->cfg.width) &&
1867*4882a593Smuzhiyun (ad->defrects[i].height == ad->cfg.height)) {
1868*4882a593Smuzhiyun ad->cfg.start_x = ad->defrects[i].crop_x;
1869*4882a593Smuzhiyun ad->cfg.start_y = ad->defrects[i].crop_y;
1870*4882a593Smuzhiyun ad->cfg.width = ad->defrects[i].crop_width;
1871*4882a593Smuzhiyun ad->cfg.height = ad->defrects[i].crop_height;
1872*4882a593Smuzhiyun }
1873*4882a593Smuzhiyun }
1874*4882a593Smuzhiyun }
1875*4882a593Smuzhiyun
nvp6324_reg_init(struct vehicle_ad_dev * ad,unsigned char cvstd)1876*4882a593Smuzhiyun static void nvp6324_reg_init(struct vehicle_ad_dev *ad, unsigned char cvstd)
1877*4882a593Smuzhiyun {
1878*4882a593Smuzhiyun struct rk_sensor_reg *sensor;
1879*4882a593Smuzhiyun int i;
1880*4882a593Smuzhiyun
1881*4882a593Smuzhiyun switch (cvstd) {
1882*4882a593Smuzhiyun case CVSTD_NTSC:
1883*4882a593Smuzhiyun VEHICLE_DG("%s, init CVSTD_NTSC mode", __func__);
1884*4882a593Smuzhiyun sensor = sensor_preview_data_ntsc_30hz;
1885*4882a593Smuzhiyun break;
1886*4882a593Smuzhiyun case CVSTD_PAL:
1887*4882a593Smuzhiyun VEHICLE_DG("%s, init CVSTD_PAL mode", __func__);
1888*4882a593Smuzhiyun sensor = sensor_preview_data_pal_25hz;
1889*4882a593Smuzhiyun break;
1890*4882a593Smuzhiyun case CVSTD_720P25:
1891*4882a593Smuzhiyun VEHICLE_DG("%s, init CVSTD_720P25 mode)", __func__);
1892*4882a593Smuzhiyun sensor = sensor_preview_data_720p_25hz;
1893*4882a593Smuzhiyun break;
1894*4882a593Smuzhiyun case CVSTD_1080P25:
1895*4882a593Smuzhiyun VEHICLE_DG("%s, init CVSTD_1080P25 mode", __func__);
1896*4882a593Smuzhiyun sensor = sensor_preview_data_1080p_25hz;
1897*4882a593Smuzhiyun break;
1898*4882a593Smuzhiyun default:
1899*4882a593Smuzhiyun VEHICLE_DG("%s, init CVSTD_1080P25 mode", __func__);
1900*4882a593Smuzhiyun sensor = sensor_preview_data_1080p_25hz;
1901*4882a593Smuzhiyun break;
1902*4882a593Smuzhiyun }
1903*4882a593Smuzhiyun i = 0;
1904*4882a593Smuzhiyun while ((sensor[i].reg != SEQCMD_END) && (sensor[i].reg != 0xFC000000)) {
1905*4882a593Smuzhiyun vehicle_sensor_write(ad, sensor[i].reg, sensor[i].val);
1906*4882a593Smuzhiyun i++;
1907*4882a593Smuzhiyun }
1908*4882a593Smuzhiyun /* open format detect*/
1909*4882a593Smuzhiyun sensor = sensor_open_format_detect;
1910*4882a593Smuzhiyun i = 0;
1911*4882a593Smuzhiyun while ((sensor[i].reg != SEQCMD_END) && (sensor[i].reg != 0xFC000000)) {
1912*4882a593Smuzhiyun vehicle_sensor_write(ad, sensor[i].reg, sensor[i].val);
1913*4882a593Smuzhiyun i++;
1914*4882a593Smuzhiyun }
1915*4882a593Smuzhiyun
1916*4882a593Smuzhiyun vehicle_sensor_write(ad, 0xff, 0x05 + ad->ad_chl);
1917*4882a593Smuzhiyun vehicle_sensor_write(ad, 0x82, 0xff);
1918*4882a593Smuzhiyun vehicle_sensor_write(ad, 0xb8, 0xb9);
1919*4882a593Smuzhiyun }
1920*4882a593Smuzhiyun
nvp6324_channel_set(struct vehicle_ad_dev * ad,int channel)1921*4882a593Smuzhiyun void nvp6324_channel_set(struct vehicle_ad_dev *ad, int channel)
1922*4882a593Smuzhiyun {
1923*4882a593Smuzhiyun unsigned int reg;
1924*4882a593Smuzhiyun unsigned char val = 0x00;
1925*4882a593Smuzhiyun
1926*4882a593Smuzhiyun //detect interesting channel
1927*4882a593Smuzhiyun reg = channel;
1928*4882a593Smuzhiyun ad->ad_chl = channel;
1929*4882a593Smuzhiyun VEHICLE_DG("%s, channel set(%d)", __func__, ad->ad_chl);
1930*4882a593Smuzhiyun vehicle_sensor_write(ad, 0xff, 0x00);
1931*4882a593Smuzhiyun vehicle_sensor_write(ad, reg, val);
1932*4882a593Smuzhiyun }
1933*4882a593Smuzhiyun
nvp6324_ad_get_cfg(struct vehicle_cfg ** cfg)1934*4882a593Smuzhiyun int nvp6324_ad_get_cfg(struct vehicle_cfg **cfg)
1935*4882a593Smuzhiyun {
1936*4882a593Smuzhiyun
1937*4882a593Smuzhiyun if (!nvp6324_g_addev)
1938*4882a593Smuzhiyun return -ENODEV;
1939*4882a593Smuzhiyun
1940*4882a593Smuzhiyun switch (cvstd_state) {
1941*4882a593Smuzhiyun case VIDEO_UNPLUG:
1942*4882a593Smuzhiyun nvp6324_g_addev->cfg.ad_ready = false;
1943*4882a593Smuzhiyun break;
1944*4882a593Smuzhiyun case VIDEO_LOCKED:
1945*4882a593Smuzhiyun nvp6324_g_addev->cfg.ad_ready = true;
1946*4882a593Smuzhiyun break;
1947*4882a593Smuzhiyun case VIDEO_IN:
1948*4882a593Smuzhiyun nvp6324_g_addev->cfg.ad_ready = false;
1949*4882a593Smuzhiyun break;
1950*4882a593Smuzhiyun }
1951*4882a593Smuzhiyun
1952*4882a593Smuzhiyun nvp6324_g_addev->cfg.ad_ready = true;
1953*4882a593Smuzhiyun nvp6324_g_addev->cfg.drop_frames = nvp6324_g_addev->drop_frames;
1954*4882a593Smuzhiyun
1955*4882a593Smuzhiyun *cfg = &nvp6324_g_addev->cfg;
1956*4882a593Smuzhiyun
1957*4882a593Smuzhiyun return 0;
1958*4882a593Smuzhiyun }
1959*4882a593Smuzhiyun
nvp6324_ad_check_cif_error(struct vehicle_ad_dev * ad,int last_line)1960*4882a593Smuzhiyun void nvp6324_ad_check_cif_error(struct vehicle_ad_dev *ad, int last_line)
1961*4882a593Smuzhiyun {
1962*4882a593Smuzhiyun VEHICLE_DG("%s, last_line %d\n", __func__, last_line);
1963*4882a593Smuzhiyun
1964*4882a593Smuzhiyun if (last_line < 1)
1965*4882a593Smuzhiyun return;
1966*4882a593Smuzhiyun
1967*4882a593Smuzhiyun ad->cif_error_last_line = last_line;
1968*4882a593Smuzhiyun if (cvstd_mode == CVSTD_PAL) {
1969*4882a593Smuzhiyun if (last_line == FORCE_NTSC_HEIGHT) {
1970*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
1971*4882a593Smuzhiyun queue_delayed_work(
1972*4882a593Smuzhiyun ad->state_check_work.state_check_wq,
1973*4882a593Smuzhiyun &ad->state_check_work.work,
1974*4882a593Smuzhiyun msecs_to_jiffies(0));
1975*4882a593Smuzhiyun }
1976*4882a593Smuzhiyun } else if (cvstd_mode == CVSTD_NTSC) {
1977*4882a593Smuzhiyun if (last_line == FORCE_PAL_HEIGHT) {
1978*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
1979*4882a593Smuzhiyun queue_delayed_work(
1980*4882a593Smuzhiyun ad->state_check_work.state_check_wq,
1981*4882a593Smuzhiyun &ad->state_check_work.work,
1982*4882a593Smuzhiyun msecs_to_jiffies(0));
1983*4882a593Smuzhiyun }
1984*4882a593Smuzhiyun } else if (cvstd_mode == CVSTD_1080P25) {
1985*4882a593Smuzhiyun if (last_line == FORCE_1080P_HEIGHT) {
1986*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
1987*4882a593Smuzhiyun queue_delayed_work(
1988*4882a593Smuzhiyun ad->state_check_work.state_check_wq,
1989*4882a593Smuzhiyun &ad->state_check_work.work,
1990*4882a593Smuzhiyun msecs_to_jiffies(0));
1991*4882a593Smuzhiyun }
1992*4882a593Smuzhiyun } else if (cvstd_mode == CVSTD_720P25) {
1993*4882a593Smuzhiyun if (last_line == FORCE_720P_HEIGHT) {
1994*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
1995*4882a593Smuzhiyun queue_delayed_work(
1996*4882a593Smuzhiyun ad->state_check_work.state_check_wq,
1997*4882a593Smuzhiyun &ad->state_check_work.work,
1998*4882a593Smuzhiyun msecs_to_jiffies(0));
1999*4882a593Smuzhiyun }
2000*4882a593Smuzhiyun }
2001*4882a593Smuzhiyun }
2002*4882a593Smuzhiyun
nvp6324_check_id(struct vehicle_ad_dev * ad)2003*4882a593Smuzhiyun int nvp6324_check_id(struct vehicle_ad_dev *ad)
2004*4882a593Smuzhiyun {
2005*4882a593Smuzhiyun int ret = 0;
2006*4882a593Smuzhiyun u8 pid;
2007*4882a593Smuzhiyun
2008*4882a593Smuzhiyun ret = vehicle_sensor_write(ad, 0xFF, 0x00);
2009*4882a593Smuzhiyun ret |= vehicle_sensor_read(ad, 0xf4, &pid);
2010*4882a593Smuzhiyun if (ret)
2011*4882a593Smuzhiyun return ret;
2012*4882a593Smuzhiyun if (pid != JAGUAR1_CHIP_ID) {
2013*4882a593Smuzhiyun VEHICLE_DGERR("%s: expected 0xB0, detected: 0x%02x !",
2014*4882a593Smuzhiyun ad->ad_name, pid);
2015*4882a593Smuzhiyun ret = -EINVAL;
2016*4882a593Smuzhiyun } else {
2017*4882a593Smuzhiyun VEHICLE_INFO("%s Found NVP6324 sensor: id(0x%2x) !\n", __func__, pid);
2018*4882a593Smuzhiyun }
2019*4882a593Smuzhiyun
2020*4882a593Smuzhiyun return ret;
2021*4882a593Smuzhiyun }
2022*4882a593Smuzhiyun
nvp6324_check_cvstd(struct vehicle_ad_dev * ad,bool activate_check)2023*4882a593Smuzhiyun static int nvp6324_check_cvstd(struct vehicle_ad_dev *ad, bool activate_check)
2024*4882a593Smuzhiyun {
2025*4882a593Smuzhiyun
2026*4882a593Smuzhiyun u8 videoloss = 0;
2027*4882a593Smuzhiyun int ret = 0;
2028*4882a593Smuzhiyun unsigned char cvstd = 0;
2029*4882a593Smuzhiyun
2030*4882a593Smuzhiyun ret = vehicle_sensor_write(ad, 0xFF, 0x00);
2031*4882a593Smuzhiyun ret |= vehicle_sensor_read(ad, 0xa4 + ad->ad_chl, &videoloss);
2032*4882a593Smuzhiyun
2033*4882a593Smuzhiyun video_mode = videoloss;
2034*4882a593Smuzhiyun
2035*4882a593Smuzhiyun ret |= vehicle_sensor_write(ad, 0xFF, 0x01);
2036*4882a593Smuzhiyun ret |= vehicle_sensor_read(ad, 0x10 + (0x20 * (ad->ad_chl%4)), &cvstd);
2037*4882a593Smuzhiyun
2038*4882a593Smuzhiyun if (ret)
2039*4882a593Smuzhiyun return ret;
2040*4882a593Smuzhiyun
2041*4882a593Smuzhiyun if (cvstd == 0x21) {
2042*4882a593Smuzhiyun cvstd_mode = CVSTD_720P25;
2043*4882a593Smuzhiyun VEHICLE_DG("%s(%d): 720P25\n", __func__, __LINE__);
2044*4882a593Smuzhiyun } else if (cvstd == 0x31) {
2045*4882a593Smuzhiyun cvstd_mode = CVSTD_1080P25;
2046*4882a593Smuzhiyun VEHICLE_DG("%s(%d): 1080P25", __func__, __LINE__);
2047*4882a593Smuzhiyun } else if (cvstd == 0x00) {
2048*4882a593Smuzhiyun cvstd_mode = CVSTD_NTSC;
2049*4882a593Smuzhiyun VEHICLE_DG("%s(%d): 960H NTSC\n", __func__, __LINE__);
2050*4882a593Smuzhiyun } else if (cvstd == 0x10) {
2051*4882a593Smuzhiyun cvstd_mode = CVSTD_PAL;
2052*4882a593Smuzhiyun VEHICLE_DG("%s(%d): 960H PAL\n", __func__, __LINE__);
2053*4882a593Smuzhiyun } else if (cvstd == 0xff) {
2054*4882a593Smuzhiyun cvstd_mode = cvstd_old;
2055*4882a593Smuzhiyun VEHICLE_DG("%s(%d): no ahd plugin!\n", __func__, __LINE__);
2056*4882a593Smuzhiyun } else {
2057*4882a593Smuzhiyun cvstd_mode = cvstd_old;
2058*4882a593Smuzhiyun VEHICLE_DG("%s(%d): not support ahd mode!\n", __func__, __LINE__);
2059*4882a593Smuzhiyun }
2060*4882a593Smuzhiyun
2061*4882a593Smuzhiyun return 0;
2062*4882a593Smuzhiyun }
2063*4882a593Smuzhiyun
nvp6324_stream(struct vehicle_ad_dev * ad,int enable)2064*4882a593Smuzhiyun int nvp6324_stream(struct vehicle_ad_dev *ad, int enable)
2065*4882a593Smuzhiyun {
2066*4882a593Smuzhiyun VEHICLE_DG("%s on(%d)\n", __func__, enable);
2067*4882a593Smuzhiyun
2068*4882a593Smuzhiyun g_nvp6324_streaming = (enable != 0);
2069*4882a593Smuzhiyun if (g_nvp6324_streaming) {
2070*4882a593Smuzhiyun vehicle_sensor_write(ad, 0xff, 0x21);
2071*4882a593Smuzhiyun vehicle_sensor_write(ad, 0x07, 0x0f);
2072*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
2073*4882a593Smuzhiyun queue_delayed_work(ad->state_check_work.state_check_wq,
2074*4882a593Smuzhiyun &ad->state_check_work.work, msecs_to_jiffies(200));
2075*4882a593Smuzhiyun } else {
2076*4882a593Smuzhiyun vehicle_sensor_write(ad, 0xff, 0x21);
2077*4882a593Smuzhiyun vehicle_sensor_write(ad, 0x07, 0x8f);
2078*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq)
2079*4882a593Smuzhiyun cancel_delayed_work_sync(&ad->state_check_work.work);
2080*4882a593Smuzhiyun }
2081*4882a593Smuzhiyun
2082*4882a593Smuzhiyun return 0;
2083*4882a593Smuzhiyun }
2084*4882a593Smuzhiyun
nvp6324_power_on(struct vehicle_ad_dev * ad)2085*4882a593Smuzhiyun static void nvp6324_power_on(struct vehicle_ad_dev *ad)
2086*4882a593Smuzhiyun {
2087*4882a593Smuzhiyun /* gpio_direction_output(ad->power, ad->pwr_active); */
2088*4882a593Smuzhiyun VEHICLE_DG("gpio: power(%d), powerdown(%d), reset(%d)",
2089*4882a593Smuzhiyun ad->power, ad->powerdown, ad->reset);
2090*4882a593Smuzhiyun if (gpio_is_valid(ad->power)) {
2091*4882a593Smuzhiyun gpio_request(ad->power, "nvp6324_power");
2092*4882a593Smuzhiyun gpio_direction_output(ad->power, ad->pwr_active);
2093*4882a593Smuzhiyun /* gpio_set_value(ad->power, ad->pwr_active); */
2094*4882a593Smuzhiyun }
2095*4882a593Smuzhiyun
2096*4882a593Smuzhiyun if (gpio_is_valid(ad->powerdown)) {
2097*4882a593Smuzhiyun gpio_request(ad->powerdown, "nvp6324_pwd");
2098*4882a593Smuzhiyun gpio_direction_output(ad->powerdown, 1);
2099*4882a593Smuzhiyun /* gpio_set_value(ad->powerdown, !ad->pwdn_active); */
2100*4882a593Smuzhiyun }
2101*4882a593Smuzhiyun
2102*4882a593Smuzhiyun if (gpio_is_valid(ad->reset)) {
2103*4882a593Smuzhiyun gpio_request(ad->reset, "nvp6324_rst");
2104*4882a593Smuzhiyun gpio_direction_output(ad->reset, 0);
2105*4882a593Smuzhiyun usleep_range(1500, 2000);
2106*4882a593Smuzhiyun gpio_direction_output(ad->reset, 1);
2107*4882a593Smuzhiyun }
2108*4882a593Smuzhiyun }
2109*4882a593Smuzhiyun
nvp6324_power_deinit(struct vehicle_ad_dev * ad)2110*4882a593Smuzhiyun static void nvp6324_power_deinit(struct vehicle_ad_dev *ad)
2111*4882a593Smuzhiyun {
2112*4882a593Smuzhiyun if (gpio_is_valid(ad->reset))
2113*4882a593Smuzhiyun gpio_free(ad->reset);
2114*4882a593Smuzhiyun if (gpio_is_valid(ad->power))
2115*4882a593Smuzhiyun gpio_free(ad->power);
2116*4882a593Smuzhiyun if (gpio_is_valid(ad->powerdown))
2117*4882a593Smuzhiyun gpio_free(ad->powerdown);
2118*4882a593Smuzhiyun }
2119*4882a593Smuzhiyun
nvp6324_check_state_work(struct work_struct * work)2120*4882a593Smuzhiyun static void nvp6324_check_state_work(struct work_struct *work)
2121*4882a593Smuzhiyun {
2122*4882a593Smuzhiyun struct vehicle_ad_dev *ad;
2123*4882a593Smuzhiyun
2124*4882a593Smuzhiyun ad = nvp6324_g_addev;
2125*4882a593Smuzhiyun
2126*4882a593Smuzhiyun if (ad->cif_error_last_line > 0) {
2127*4882a593Smuzhiyun nvp6324_check_cvstd(ad, true);
2128*4882a593Smuzhiyun ad->cif_error_last_line = 0;
2129*4882a593Smuzhiyun } else {
2130*4882a593Smuzhiyun nvp6324_check_cvstd(ad, false);
2131*4882a593Smuzhiyun }
2132*4882a593Smuzhiyun
2133*4882a593Smuzhiyun if (cvstd_old != cvstd_mode ||
2134*4882a593Smuzhiyun cvstd_old_state != cvstd_state || (video_old != video_mode)) {
2135*4882a593Smuzhiyun VEHICLE_INFO("%s:ad sensor std mode change, cvstd_old(%d), cvstd_mode(%d)\n",
2136*4882a593Smuzhiyun __func__, cvstd_old, cvstd_mode);
2137*4882a593Smuzhiyun cvstd_old = cvstd_mode;
2138*4882a593Smuzhiyun cvstd_old_state = cvstd_state;
2139*4882a593Smuzhiyun video_old = video_mode;
2140*4882a593Smuzhiyun
2141*4882a593Smuzhiyun nvp6324_reinit_parameter(ad, cvstd_mode);
2142*4882a593Smuzhiyun nvp6324_reg_init(ad, cvstd_mode);
2143*4882a593Smuzhiyun vehicle_ad_stat_change_notify();
2144*4882a593Smuzhiyun }
2145*4882a593Smuzhiyun if (g_nvp6324_streaming) {
2146*4882a593Smuzhiyun queue_delayed_work(ad->state_check_work.state_check_wq,
2147*4882a593Smuzhiyun &ad->state_check_work.work, msecs_to_jiffies(100));
2148*4882a593Smuzhiyun }
2149*4882a593Smuzhiyun }
2150*4882a593Smuzhiyun
nvp6324_ad_deinit(void)2151*4882a593Smuzhiyun int nvp6324_ad_deinit(void)
2152*4882a593Smuzhiyun {
2153*4882a593Smuzhiyun struct vehicle_ad_dev *ad;
2154*4882a593Smuzhiyun
2155*4882a593Smuzhiyun ad = nvp6324_g_addev;
2156*4882a593Smuzhiyun
2157*4882a593Smuzhiyun if (!ad)
2158*4882a593Smuzhiyun return -ENODEV;
2159*4882a593Smuzhiyun
2160*4882a593Smuzhiyun if (ad->state_check_work.state_check_wq) {
2161*4882a593Smuzhiyun cancel_delayed_work_sync(&ad->state_check_work.work);
2162*4882a593Smuzhiyun flush_delayed_work(&ad->state_check_work.work);
2163*4882a593Smuzhiyun flush_workqueue(ad->state_check_work.state_check_wq);
2164*4882a593Smuzhiyun destroy_workqueue(ad->state_check_work.state_check_wq);
2165*4882a593Smuzhiyun }
2166*4882a593Smuzhiyun if (ad->irq)
2167*4882a593Smuzhiyun free_irq(ad->irq, ad);
2168*4882a593Smuzhiyun nvp6324_power_deinit(ad);
2169*4882a593Smuzhiyun
2170*4882a593Smuzhiyun return 0;
2171*4882a593Smuzhiyun }
2172*4882a593Smuzhiyun
get_ad_mode_from_fix_format(int fix_format)2173*4882a593Smuzhiyun static __maybe_unused int get_ad_mode_from_fix_format(int fix_format)
2174*4882a593Smuzhiyun {
2175*4882a593Smuzhiyun int mode = -1;
2176*4882a593Smuzhiyun
2177*4882a593Smuzhiyun switch (fix_format) {
2178*4882a593Smuzhiyun case AD_FIX_FORMAT_PAL:
2179*4882a593Smuzhiyun case AD_FIX_FORMAT_NTSC:
2180*4882a593Smuzhiyun case AD_FIX_FORMAT_720P_50FPS:
2181*4882a593Smuzhiyun case AD_FIX_FORMAT_720P_30FPS:
2182*4882a593Smuzhiyun case AD_FIX_FORMAT_720P_25FPS:
2183*4882a593Smuzhiyun mode = CVSTD_720P25;
2184*4882a593Smuzhiyun break;
2185*4882a593Smuzhiyun case AD_FIX_FORMAT_1080P_30FPS:
2186*4882a593Smuzhiyun case AD_FIX_FORMAT_1080P_25FPS:
2187*4882a593Smuzhiyun
2188*4882a593Smuzhiyun default:
2189*4882a593Smuzhiyun mode = CVSTD_720P25;
2190*4882a593Smuzhiyun break;
2191*4882a593Smuzhiyun }
2192*4882a593Smuzhiyun
2193*4882a593Smuzhiyun return mode;
2194*4882a593Smuzhiyun }
2195*4882a593Smuzhiyun
nvp6324_ad_init(struct vehicle_ad_dev * ad)2196*4882a593Smuzhiyun int nvp6324_ad_init(struct vehicle_ad_dev *ad)
2197*4882a593Smuzhiyun {
2198*4882a593Smuzhiyun int val;
2199*4882a593Smuzhiyun int i = 0;
2200*4882a593Smuzhiyun
2201*4882a593Smuzhiyun nvp6324_g_addev = ad;
2202*4882a593Smuzhiyun
2203*4882a593Smuzhiyun /* 1. i2c init */
2204*4882a593Smuzhiyun while (ad->adapter == NULL) {
2205*4882a593Smuzhiyun ad->adapter = i2c_get_adapter(ad->i2c_chl);
2206*4882a593Smuzhiyun usleep_range(10000, 12000);
2207*4882a593Smuzhiyun }
2208*4882a593Smuzhiyun if (ad->adapter == NULL)
2209*4882a593Smuzhiyun return -ENODEV;
2210*4882a593Smuzhiyun
2211*4882a593Smuzhiyun if (!i2c_check_functionality(ad->adapter, I2C_FUNC_I2C))
2212*4882a593Smuzhiyun return -EIO;
2213*4882a593Smuzhiyun
2214*4882a593Smuzhiyun nvp6324_power_on(ad);
2215*4882a593Smuzhiyun
2216*4882a593Smuzhiyun while (++i < 5) {
2217*4882a593Smuzhiyun usleep_range(10000, 12000);
2218*4882a593Smuzhiyun val = vehicle_generic_sensor_read(ad, 0xf0);
2219*4882a593Smuzhiyun if (val != 0xff)
2220*4882a593Smuzhiyun break;
2221*4882a593Smuzhiyun VEHICLE_DGERR("nvp6324_init i2c_reg_read fail\n");
2222*4882a593Smuzhiyun }
2223*4882a593Smuzhiyun
2224*4882a593Smuzhiyun nvp6324_reg_init(ad, cvstd_mode);
2225*4882a593Smuzhiyun
2226*4882a593Smuzhiyun nvp6324_reinit_parameter(ad, cvstd_mode);
2227*4882a593Smuzhiyun
2228*4882a593Smuzhiyun INIT_DELAYED_WORK(&ad->state_check_work.work, nvp6324_check_state_work);
2229*4882a593Smuzhiyun ad->state_check_work.state_check_wq =
2230*4882a593Smuzhiyun create_singlethread_workqueue("vehicle-ad-nvp6324");
2231*4882a593Smuzhiyun
2232*4882a593Smuzhiyun /* nvp6324_check_cvstd(ad, true); */
2233*4882a593Smuzhiyun
2234*4882a593Smuzhiyun queue_delayed_work(ad->state_check_work.state_check_wq,
2235*4882a593Smuzhiyun &ad->state_check_work.work, msecs_to_jiffies(100));
2236*4882a593Smuzhiyun
2237*4882a593Smuzhiyun return 0;
2238*4882a593Smuzhiyun }
2239