blob: a1bd94e8ce5289418a6f86e0412888ff65e8baf7 [file] [log] [blame]
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -03001/*
2 * zc030x registers
3 *
4 * Copyright (c) 2008 Mauro Carvalho Chehab <mchehab@infradead.org>
5 *
6 * The register aliases used here came from this driver:
7 * http://zc0302.sourceforge.net/zc0302.php
8 *
9 * This code is placed under the terms of the GNU General Public License v2
10 */
11
12/* Define the register map */
13#define ZC3XX_R000_SYSTEMCONTROL 0x0000
14#define ZC3XX_R001_SYSTEMOPERATING 0x0001
15
16/* Picture size */
17#define ZC3XX_R002_CLOCKSELECT 0x0002
18#define ZC3XX_R003_FRAMEWIDTHHIGH 0x0003
19#define ZC3XX_R004_FRAMEWIDTHLOW 0x0004
20#define ZC3XX_R005_FRAMEHEIGHTHIGH 0x0005
21#define ZC3XX_R006_FRAMEHEIGHTLOW 0x0006
22
23/* JPEG control */
24#define ZC3XX_R008_CLOCKSETTING 0x0008
25
26/* Test mode */
27#define ZC3XX_R00B_TESTMODECONTROL 0x000b
28
29/* Frame retreiving */
30#define ZC3XX_R00C_LASTACQTIME 0x000c
31#define ZC3XX_R00D_MONITORRES 0x000d
32#define ZC3XX_R00E_TIMESTAMPHIGH 0x000e
33#define ZC3XX_R00F_TIMESTAMPLOW 0x000f
34#define ZC3XX_R018_FRAMELOST 0x0018
35#define ZC3XX_R019_AUTOADJUSTFPS 0x0019
36#define ZC3XX_R01A_LASTFRAMESTATE 0x001a
37#define ZC3XX_R025_DATACOUNTER 0x0025
38
39/* Stream and sensor specific */
40#define ZC3XX_R010_CMOSSENSORSELECT 0x0010
41#define ZC3XX_R011_VIDEOSTATUS 0x0011
42#define ZC3XX_R012_VIDEOCONTROLFUNC 0x0012
43
44/* Horizontal and vertical synchros */
45#define ZC3XX_R01D_HSYNC_0 0x001d
46#define ZC3XX_R01E_HSYNC_1 0x001e
47#define ZC3XX_R01F_HSYNC_2 0x001f
48#define ZC3XX_R020_HSYNC_3 0x0020
49
50/* Target picture size in byte */
51#define ZC3XX_R022_TARGETPICTSIZE_0 0x0022
52#define ZC3XX_R023_TARGETPICTSIZE_1 0x0023
53#define ZC3XX_R024_TARGETPICTSIZE_2 0x0024
54
55/* Audio registers */
56#define ZC3XX_R030_AUDIOADC 0x0030
57#define ZC3XX_R031_AUDIOSTREAMSTATUS 0x0031
58#define ZC3XX_R032_AUDIOSTATUS 0x0032
59
60/* Sensor interface */
61#define ZC3XX_R080_HBLANKHIGH 0x0080
62#define ZC3XX_R081_HBLANKLOW 0x0081
63#define ZC3XX_R082_RESETLEVELADDR 0x0082
64#define ZC3XX_R083_RGAINADDR 0x0083
65#define ZC3XX_R084_GGAINADDR 0x0084
66#define ZC3XX_R085_BGAINADDR 0x0085
67#define ZC3XX_R086_EXPTIMEHIGH 0x0086
68#define ZC3XX_R087_EXPTIMEMID 0x0087
69#define ZC3XX_R088_EXPTIMELOW 0x0088
70#define ZC3XX_R089_RESETBLACKHIGH 0x0089
71#define ZC3XX_R08A_RESETWHITEHIGH 0x008a
72#define ZC3XX_R08B_I2CDEVICEADDR 0x008b
73#define ZC3XX_R08C_I2CIDLEANDNACK 0x008c
74#define ZC3XX_R08D_COMPABILITYMODE 0x008d
75#define ZC3XX_R08E_COMPABILITYMODE2 0x008e
76
77/* I2C control */
78#define ZC3XX_R090_I2CCOMMAND 0x0090
79#define ZC3XX_R091_I2CSTATUS 0x0091
80#define ZC3XX_R092_I2CADDRESSSELECT 0x0092
81#define ZC3XX_R093_I2CSETVALUE 0x0093
82#define ZC3XX_R094_I2CWRITEACK 0x0094
83#define ZC3XX_R095_I2CREAD 0x0095
84#define ZC3XX_R096_I2CREADACK 0x0096
85
86/* Window inside the sensor array */
87#define ZC3XX_R097_WINYSTARTHIGH 0x0097
88#define ZC3XX_R098_WINYSTARTLOW 0x0098
89#define ZC3XX_R099_WINXSTARTHIGH 0x0099
90#define ZC3XX_R09A_WINXSTARTLOW 0x009a
91#define ZC3XX_R09B_WINHEIGHTHIGH 0x009b
92#define ZC3XX_R09C_WINHEIGHTLOW 0x009c
93#define ZC3XX_R09D_WINWIDTHHIGH 0x009d
94#define ZC3XX_R09E_WINWIDTHLOW 0x009e
95#define ZC3XX_R119_FIRSTYHIGH 0x0119
96#define ZC3XX_R11A_FIRSTYLOW 0x011a
97#define ZC3XX_R11B_FIRSTXHIGH 0x011b
98#define ZC3XX_R11C_FIRSTXLOW 0x011c
99
100/* Max sensor array size */
101#define ZC3XX_R09F_MAXXHIGH 0x009f
102#define ZC3XX_R0A0_MAXXLOW 0x00a0
103#define ZC3XX_R0A1_MAXYHIGH 0x00a1
104#define ZC3XX_R0A2_MAXYLOW 0x00a2
105#define ZC3XX_R0A3_EXPOSURETIMEHIGH 0x00a3
106#define ZC3XX_R0A4_EXPOSURETIMELOW 0x00a4
107#define ZC3XX_R0A5_EXPOSUREGAIN 0x00a5
108#define ZC3XX_R0A6_EXPOSUREBLACKLVL 0x00a6
109
110/* Other registers */
111#define ZC3XX_R100_OPERATIONMODE 0x0100
112#define ZC3XX_R101_SENSORCORRECTION 0x0101
113
114/* Gains */
115#define ZC3XX_R116_RGAIN 0x0116
116#define ZC3XX_R117_GGAIN 0x0117
117#define ZC3XX_R118_BGAIN 0x0118
118#define ZC3XX_R11D_GLOBALGAIN 0x011d
119#define ZC3XX_R1A8_DIGITALGAIN 0x01a8
120#define ZC3XX_R1A9_DIGITALLIMITDIFF 0x01a9
121#define ZC3XX_R1AA_DIGITALGAINSTEP 0x01aa
122
123/* Auto correction */
124#define ZC3XX_R180_AUTOCORRECTENABLE 0x0180
125#define ZC3XX_R181_WINXSTART 0x0181
126#define ZC3XX_R182_WINXWIDTH 0x0182
127#define ZC3XX_R183_WINXCENTER 0x0183
128#define ZC3XX_R184_WINYSTART 0x0184
129#define ZC3XX_R185_WINYWIDTH 0x0185
130#define ZC3XX_R186_WINYCENTER 0x0186
131
132/* Gain range */
133#define ZC3XX_R187_MAXGAIN 0x0187
134#define ZC3XX_R188_MINGAIN 0x0188
135
136/* Auto exposure and white balance */
137#define ZC3XX_R189_AWBSTATUS 0x0189
138#define ZC3XX_R18A_AWBFREEZE 0x018a
139#define ZC3XX_R18B_AESTATUS 0x018b
140#define ZC3XX_R18C_AEFREEZE 0x018c
141#define ZC3XX_R18F_AEUNFREEZE 0x018f
142#define ZC3XX_R190_EXPOSURELIMITHIGH 0x0190
143#define ZC3XX_R191_EXPOSURELIMITMID 0x0191
144#define ZC3XX_R192_EXPOSURELIMITLOW 0x0192
145#define ZC3XX_R195_ANTIFLICKERHIGH 0x0195
146#define ZC3XX_R196_ANTIFLICKERMID 0x0196
147#define ZC3XX_R197_ANTIFLICKERLOW 0x0197
148
149/* What is this ? */
150#define ZC3XX_R18D_YTARGET 0x018d
151#define ZC3XX_R18E_RESETLVL 0x018e
152
153/* Color */
154#define ZC3XX_R1A0_REDMEANAFTERAGC 0x01a0
155#define ZC3XX_R1A1_GREENMEANAFTERAGC 0x01a1
156#define ZC3XX_R1A2_BLUEMEANAFTERAGC 0x01a2
157#define ZC3XX_R1A3_REDMEANAFTERAWB 0x01a3
158#define ZC3XX_R1A4_GREENMEANAFTERAWB 0x01a4
159#define ZC3XX_R1A5_BLUEMEANAFTERAWB 0x01a5
160#define ZC3XX_R1A6_YMEANAFTERAE 0x01a6
161#define ZC3XX_R1A7_CALCGLOBALMEAN 0x01a7
162
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300163/* Matrixes */
164
165/* Color matrix is like :
166 R' = R * RGB00 + G * RGB01 + B * RGB02 + RGB03
167 G' = R * RGB10 + G * RGB11 + B * RGB22 + RGB13
168 B' = R * RGB20 + G * RGB21 + B * RGB12 + RGB23
169 */
170#define ZC3XX_R10A_RGB00 0x010a
171#define ZC3XX_R10B_RGB01 0x010b
172#define ZC3XX_R10C_RGB02 0x010c
173#define ZC3XX_R113_RGB03 0x0113
174#define ZC3XX_R10D_RGB10 0x010d
175#define ZC3XX_R10E_RGB11 0x010e
176#define ZC3XX_R10F_RGB12 0x010f
177#define ZC3XX_R114_RGB13 0x0114
178#define ZC3XX_R110_RGB20 0x0110
179#define ZC3XX_R111_RGB21 0x0111
180#define ZC3XX_R112_RGB22 0x0112
181#define ZC3XX_R115_RGB23 0x0115
182
183/* Gamma matrix */
184#define ZC3XX_R120_GAMMA00 0x0120
185#define ZC3XX_R121_GAMMA01 0x0121
186#define ZC3XX_R122_GAMMA02 0x0122
187#define ZC3XX_R123_GAMMA03 0x0123
188#define ZC3XX_R124_GAMMA04 0x0124
189#define ZC3XX_R125_GAMMA05 0x0125
190#define ZC3XX_R126_GAMMA06 0x0126
191#define ZC3XX_R127_GAMMA07 0x0127
192#define ZC3XX_R128_GAMMA08 0x0128
193#define ZC3XX_R129_GAMMA09 0x0129
194#define ZC3XX_R12A_GAMMA0A 0x012a
195#define ZC3XX_R12B_GAMMA0B 0x012b
196#define ZC3XX_R12C_GAMMA0C 0x012c
197#define ZC3XX_R12D_GAMMA0D 0x012d
198#define ZC3XX_R12E_GAMMA0E 0x012e
199#define ZC3XX_R12F_GAMMA0F 0x012f
200#define ZC3XX_R130_GAMMA10 0x0130
201#define ZC3XX_R131_GAMMA11 0x0131
202#define ZC3XX_R132_GAMMA12 0x0132
203#define ZC3XX_R133_GAMMA13 0x0133
204#define ZC3XX_R134_GAMMA14 0x0134
205#define ZC3XX_R135_GAMMA15 0x0135
206#define ZC3XX_R136_GAMMA16 0x0136
207#define ZC3XX_R137_GAMMA17 0x0137
208#define ZC3XX_R138_GAMMA18 0x0138
209#define ZC3XX_R139_GAMMA19 0x0139
210#define ZC3XX_R13A_GAMMA1A 0x013a
211#define ZC3XX_R13B_GAMMA1B 0x013b
212#define ZC3XX_R13C_GAMMA1C 0x013c
213#define ZC3XX_R13D_GAMMA1D 0x013d
214#define ZC3XX_R13E_GAMMA1E 0x013e
215#define ZC3XX_R13F_GAMMA1F 0x013f
216
217/* Luminance gamma */
218#define ZC3XX_R140_YGAMMA00 0x0140
219#define ZC3XX_R141_YGAMMA01 0x0141
220#define ZC3XX_R142_YGAMMA02 0x0142
221#define ZC3XX_R143_YGAMMA03 0x0143
222#define ZC3XX_R144_YGAMMA04 0x0144
223#define ZC3XX_R145_YGAMMA05 0x0145
224#define ZC3XX_R146_YGAMMA06 0x0146
225#define ZC3XX_R147_YGAMMA07 0x0147
226#define ZC3XX_R148_YGAMMA08 0x0148
227#define ZC3XX_R149_YGAMMA09 0x0149
228#define ZC3XX_R14A_YGAMMA0A 0x014a
229#define ZC3XX_R14B_YGAMMA0B 0x014b
230#define ZC3XX_R14C_YGAMMA0C 0x014c
231#define ZC3XX_R14D_YGAMMA0D 0x014d
232#define ZC3XX_R14E_YGAMMA0E 0x014e
233#define ZC3XX_R14F_YGAMMA0F 0x014f
234#define ZC3XX_R150_YGAMMA10 0x0150
235#define ZC3XX_R151_YGAMMA11 0x0151
236
237#define ZC3XX_R1C5_SHARPNESSMODE 0x01c5
238#define ZC3XX_R1C6_SHARPNESS00 0x01c6
239#define ZC3XX_R1C7_SHARPNESS01 0x01c7
240#define ZC3XX_R1C8_SHARPNESS02 0x01c8
241#define ZC3XX_R1C9_SHARPNESS03 0x01c9
242#define ZC3XX_R1CA_SHARPNESS04 0x01ca
243#define ZC3XX_R1CB_SHARPNESS05 0x01cb
244
Mauro Carvalho Chehab9a97a2a2008-07-15 14:23:08 -0300245/* Dead pixels */
246#define ZC3XX_R250_DEADPIXELSMODE 0x0250
247
248/* EEPROM */
249#define ZC3XX_R300_EEPROMCONFIG 0x0300
250#define ZC3XX_R301_EEPROMACCESS 0x0301
251#define ZC3XX_R302_EEPROMSTATUS 0x0302