18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * zc030x registers
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (c) 2008 Mauro Carvalho Chehab <mchehab@kernel.org>
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci * The register aliases used here came from this driver:
88c2ecf20Sopenharmony_ci *	http://zc0302.sourceforge.net/zc0302.php
98c2ecf20Sopenharmony_ci */
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ci/* Define the register map */
128c2ecf20Sopenharmony_ci#define ZC3XX_R000_SYSTEMCONTROL       0x0000
138c2ecf20Sopenharmony_ci#define ZC3XX_R001_SYSTEMOPERATING     0x0001
148c2ecf20Sopenharmony_ci
158c2ecf20Sopenharmony_ci/* Picture size */
168c2ecf20Sopenharmony_ci#define ZC3XX_R002_CLOCKSELECT         0x0002
178c2ecf20Sopenharmony_ci#define ZC3XX_R003_FRAMEWIDTHHIGH      0x0003
188c2ecf20Sopenharmony_ci#define ZC3XX_R004_FRAMEWIDTHLOW       0x0004
198c2ecf20Sopenharmony_ci#define ZC3XX_R005_FRAMEHEIGHTHIGH     0x0005
208c2ecf20Sopenharmony_ci#define ZC3XX_R006_FRAMEHEIGHTLOW      0x0006
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_ci/* JPEG control */
238c2ecf20Sopenharmony_ci#define ZC3XX_R008_CLOCKSETTING        0x0008
248c2ecf20Sopenharmony_ci
258c2ecf20Sopenharmony_ci/* Test mode */
268c2ecf20Sopenharmony_ci#define ZC3XX_R00B_TESTMODECONTROL     0x000b
278c2ecf20Sopenharmony_ci
288c2ecf20Sopenharmony_ci/* Frame retrieving */
298c2ecf20Sopenharmony_ci#define ZC3XX_R00C_LASTACQTIME         0x000c
308c2ecf20Sopenharmony_ci#define ZC3XX_R00D_MONITORRES          0x000d
318c2ecf20Sopenharmony_ci#define ZC3XX_R00E_TIMESTAMPHIGH       0x000e
328c2ecf20Sopenharmony_ci#define ZC3XX_R00F_TIMESTAMPLOW        0x000f
338c2ecf20Sopenharmony_ci#define ZC3XX_R018_FRAMELOST           0x0018
348c2ecf20Sopenharmony_ci#define ZC3XX_R019_AUTOADJUSTFPS       0x0019
358c2ecf20Sopenharmony_ci#define ZC3XX_R01A_LASTFRAMESTATE      0x001a
368c2ecf20Sopenharmony_ci#define ZC3XX_R025_DATACOUNTER         0x0025
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_ci/* Stream and sensor specific */
398c2ecf20Sopenharmony_ci#define ZC3XX_R010_CMOSSENSORSELECT    0x0010
408c2ecf20Sopenharmony_ci#define ZC3XX_R011_VIDEOSTATUS         0x0011
418c2ecf20Sopenharmony_ci#define ZC3XX_R012_VIDEOCONTROLFUNC    0x0012
428c2ecf20Sopenharmony_ci
438c2ecf20Sopenharmony_ci/* Horizontal and vertical synchros */
448c2ecf20Sopenharmony_ci#define ZC3XX_R01D_HSYNC_0             0x001d
458c2ecf20Sopenharmony_ci#define ZC3XX_R01E_HSYNC_1             0x001e
468c2ecf20Sopenharmony_ci#define ZC3XX_R01F_HSYNC_2             0x001f
478c2ecf20Sopenharmony_ci#define ZC3XX_R020_HSYNC_3             0x0020
488c2ecf20Sopenharmony_ci
498c2ecf20Sopenharmony_ci/* Target picture size in byte */
508c2ecf20Sopenharmony_ci#define ZC3XX_R022_TARGETPICTSIZE_0    0x0022
518c2ecf20Sopenharmony_ci#define ZC3XX_R023_TARGETPICTSIZE_1    0x0023
528c2ecf20Sopenharmony_ci#define ZC3XX_R024_TARGETPICTSIZE_2    0x0024
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ci/* Audio registers */
558c2ecf20Sopenharmony_ci#define ZC3XX_R030_AUDIOADC            0x0030
568c2ecf20Sopenharmony_ci#define ZC3XX_R031_AUDIOSTREAMSTATUS   0x0031
578c2ecf20Sopenharmony_ci#define ZC3XX_R032_AUDIOSTATUS         0x0032
588c2ecf20Sopenharmony_ci
598c2ecf20Sopenharmony_ci/* Sensor interface */
608c2ecf20Sopenharmony_ci#define ZC3XX_R080_HBLANKHIGH          0x0080
618c2ecf20Sopenharmony_ci#define ZC3XX_R081_HBLANKLOW           0x0081
628c2ecf20Sopenharmony_ci#define ZC3XX_R082_RESETLEVELADDR      0x0082
638c2ecf20Sopenharmony_ci#define ZC3XX_R083_RGAINADDR           0x0083
648c2ecf20Sopenharmony_ci#define ZC3XX_R084_GGAINADDR           0x0084
658c2ecf20Sopenharmony_ci#define ZC3XX_R085_BGAINADDR           0x0085
668c2ecf20Sopenharmony_ci#define ZC3XX_R086_EXPTIMEHIGH         0x0086
678c2ecf20Sopenharmony_ci#define ZC3XX_R087_EXPTIMEMID          0x0087
688c2ecf20Sopenharmony_ci#define ZC3XX_R088_EXPTIMELOW          0x0088
698c2ecf20Sopenharmony_ci#define ZC3XX_R089_RESETBLACKHIGH      0x0089
708c2ecf20Sopenharmony_ci#define ZC3XX_R08A_RESETWHITEHIGH      0x008a
718c2ecf20Sopenharmony_ci#define ZC3XX_R08B_I2CDEVICEADDR       0x008b
728c2ecf20Sopenharmony_ci#define ZC3XX_R08C_I2CIDLEANDNACK      0x008c
738c2ecf20Sopenharmony_ci#define ZC3XX_R08D_COMPABILITYMODE     0x008d
748c2ecf20Sopenharmony_ci#define ZC3XX_R08E_COMPABILITYMODE2    0x008e
758c2ecf20Sopenharmony_ci
768c2ecf20Sopenharmony_ci/* I2C control */
778c2ecf20Sopenharmony_ci#define ZC3XX_R090_I2CCOMMAND          0x0090
788c2ecf20Sopenharmony_ci#define ZC3XX_R091_I2CSTATUS           0x0091
798c2ecf20Sopenharmony_ci#define ZC3XX_R092_I2CADDRESSSELECT    0x0092
808c2ecf20Sopenharmony_ci#define ZC3XX_R093_I2CSETVALUE         0x0093
818c2ecf20Sopenharmony_ci#define ZC3XX_R094_I2CWRITEACK         0x0094
828c2ecf20Sopenharmony_ci#define ZC3XX_R095_I2CREAD             0x0095
838c2ecf20Sopenharmony_ci#define ZC3XX_R096_I2CREADACK          0x0096
848c2ecf20Sopenharmony_ci
858c2ecf20Sopenharmony_ci/* Window inside the sensor array */
868c2ecf20Sopenharmony_ci#define ZC3XX_R097_WINYSTARTHIGH       0x0097
878c2ecf20Sopenharmony_ci#define ZC3XX_R098_WINYSTARTLOW        0x0098
888c2ecf20Sopenharmony_ci#define ZC3XX_R099_WINXSTARTHIGH       0x0099
898c2ecf20Sopenharmony_ci#define ZC3XX_R09A_WINXSTARTLOW        0x009a
908c2ecf20Sopenharmony_ci#define ZC3XX_R09B_WINHEIGHTHIGH       0x009b
918c2ecf20Sopenharmony_ci#define ZC3XX_R09C_WINHEIGHTLOW        0x009c
928c2ecf20Sopenharmony_ci#define ZC3XX_R09D_WINWIDTHHIGH        0x009d
938c2ecf20Sopenharmony_ci#define ZC3XX_R09E_WINWIDTHLOW         0x009e
948c2ecf20Sopenharmony_ci#define ZC3XX_R119_FIRSTYHIGH          0x0119
958c2ecf20Sopenharmony_ci#define ZC3XX_R11A_FIRSTYLOW           0x011a
968c2ecf20Sopenharmony_ci#define ZC3XX_R11B_FIRSTXHIGH          0x011b
978c2ecf20Sopenharmony_ci#define ZC3XX_R11C_FIRSTXLOW           0x011c
988c2ecf20Sopenharmony_ci
998c2ecf20Sopenharmony_ci/* Max sensor array size */
1008c2ecf20Sopenharmony_ci#define ZC3XX_R09F_MAXXHIGH            0x009f
1018c2ecf20Sopenharmony_ci#define ZC3XX_R0A0_MAXXLOW             0x00a0
1028c2ecf20Sopenharmony_ci#define ZC3XX_R0A1_MAXYHIGH            0x00a1
1038c2ecf20Sopenharmony_ci#define ZC3XX_R0A2_MAXYLOW             0x00a2
1048c2ecf20Sopenharmony_ci#define ZC3XX_R0A3_EXPOSURETIMEHIGH    0x00a3
1058c2ecf20Sopenharmony_ci#define ZC3XX_R0A4_EXPOSURETIMELOW     0x00a4
1068c2ecf20Sopenharmony_ci#define ZC3XX_R0A5_EXPOSUREGAIN        0x00a5
1078c2ecf20Sopenharmony_ci#define ZC3XX_R0A6_EXPOSUREBLACKLVL    0x00a6
1088c2ecf20Sopenharmony_ci
1098c2ecf20Sopenharmony_ci/* Other registers */
1108c2ecf20Sopenharmony_ci#define ZC3XX_R100_OPERATIONMODE       0x0100
1118c2ecf20Sopenharmony_ci#define ZC3XX_R101_SENSORCORRECTION    0x0101
1128c2ecf20Sopenharmony_ci
1138c2ecf20Sopenharmony_ci/* Gains */
1148c2ecf20Sopenharmony_ci#define ZC3XX_R116_RGAIN               0x0116
1158c2ecf20Sopenharmony_ci#define ZC3XX_R117_GGAIN               0x0117
1168c2ecf20Sopenharmony_ci#define ZC3XX_R118_BGAIN               0x0118
1178c2ecf20Sopenharmony_ci#define ZC3XX_R11D_GLOBALGAIN          0x011d
1188c2ecf20Sopenharmony_ci#define ZC3XX_R1A8_DIGITALGAIN         0x01a8
1198c2ecf20Sopenharmony_ci#define ZC3XX_R1A9_DIGITALLIMITDIFF    0x01a9
1208c2ecf20Sopenharmony_ci#define ZC3XX_R1AA_DIGITALGAINSTEP     0x01aa
1218c2ecf20Sopenharmony_ci
1228c2ecf20Sopenharmony_ci/* Auto correction */
1238c2ecf20Sopenharmony_ci#define ZC3XX_R180_AUTOCORRECTENABLE   0x0180
1248c2ecf20Sopenharmony_ci#define ZC3XX_R181_WINXSTART           0x0181
1258c2ecf20Sopenharmony_ci#define ZC3XX_R182_WINXWIDTH           0x0182
1268c2ecf20Sopenharmony_ci#define ZC3XX_R183_WINXCENTER          0x0183
1278c2ecf20Sopenharmony_ci#define ZC3XX_R184_WINYSTART           0x0184
1288c2ecf20Sopenharmony_ci#define ZC3XX_R185_WINYWIDTH           0x0185
1298c2ecf20Sopenharmony_ci#define ZC3XX_R186_WINYCENTER          0x0186
1308c2ecf20Sopenharmony_ci
1318c2ecf20Sopenharmony_ci/* Gain range */
1328c2ecf20Sopenharmony_ci#define ZC3XX_R187_MAXGAIN             0x0187
1338c2ecf20Sopenharmony_ci#define ZC3XX_R188_MINGAIN             0x0188
1348c2ecf20Sopenharmony_ci
1358c2ecf20Sopenharmony_ci/* Auto exposure and white balance */
1368c2ecf20Sopenharmony_ci#define ZC3XX_R189_AWBSTATUS           0x0189
1378c2ecf20Sopenharmony_ci#define ZC3XX_R18A_AWBFREEZE           0x018a
1388c2ecf20Sopenharmony_ci#define ZC3XX_R18B_AESTATUS            0x018b
1398c2ecf20Sopenharmony_ci#define ZC3XX_R18C_AEFREEZE            0x018c
1408c2ecf20Sopenharmony_ci#define ZC3XX_R18F_AEUNFREEZE          0x018f
1418c2ecf20Sopenharmony_ci#define ZC3XX_R190_EXPOSURELIMITHIGH   0x0190
1428c2ecf20Sopenharmony_ci#define ZC3XX_R191_EXPOSURELIMITMID    0x0191
1438c2ecf20Sopenharmony_ci#define ZC3XX_R192_EXPOSURELIMITLOW    0x0192
1448c2ecf20Sopenharmony_ci#define ZC3XX_R195_ANTIFLICKERHIGH     0x0195
1458c2ecf20Sopenharmony_ci#define ZC3XX_R196_ANTIFLICKERMID      0x0196
1468c2ecf20Sopenharmony_ci#define ZC3XX_R197_ANTIFLICKERLOW      0x0197
1478c2ecf20Sopenharmony_ci
1488c2ecf20Sopenharmony_ci/* What is this ? */
1498c2ecf20Sopenharmony_ci#define ZC3XX_R18D_YTARGET             0x018d
1508c2ecf20Sopenharmony_ci#define ZC3XX_R18E_RESETLVL            0x018e
1518c2ecf20Sopenharmony_ci
1528c2ecf20Sopenharmony_ci/* Color */
1538c2ecf20Sopenharmony_ci#define ZC3XX_R1A0_REDMEANAFTERAGC     0x01a0
1548c2ecf20Sopenharmony_ci#define ZC3XX_R1A1_GREENMEANAFTERAGC   0x01a1
1558c2ecf20Sopenharmony_ci#define ZC3XX_R1A2_BLUEMEANAFTERAGC    0x01a2
1568c2ecf20Sopenharmony_ci#define ZC3XX_R1A3_REDMEANAFTERAWB     0x01a3
1578c2ecf20Sopenharmony_ci#define ZC3XX_R1A4_GREENMEANAFTERAWB   0x01a4
1588c2ecf20Sopenharmony_ci#define ZC3XX_R1A5_BLUEMEANAFTERAWB    0x01a5
1598c2ecf20Sopenharmony_ci#define ZC3XX_R1A6_YMEANAFTERAE        0x01a6
1608c2ecf20Sopenharmony_ci#define ZC3XX_R1A7_CALCGLOBALMEAN      0x01a7
1618c2ecf20Sopenharmony_ci
1628c2ecf20Sopenharmony_ci/* Matrixes */
1638c2ecf20Sopenharmony_ci
1648c2ecf20Sopenharmony_ci/* Color matrix is like :
1658c2ecf20Sopenharmony_ci   R' = R * RGB00 + G * RGB01 + B * RGB02 + RGB03
1668c2ecf20Sopenharmony_ci   G' = R * RGB10 + G * RGB11 + B * RGB22 + RGB13
1678c2ecf20Sopenharmony_ci   B' = R * RGB20 + G * RGB21 + B * RGB12 + RGB23
1688c2ecf20Sopenharmony_ci */
1698c2ecf20Sopenharmony_ci#define ZC3XX_R10A_RGB00               0x010a
1708c2ecf20Sopenharmony_ci#define ZC3XX_R10B_RGB01               0x010b
1718c2ecf20Sopenharmony_ci#define ZC3XX_R10C_RGB02               0x010c
1728c2ecf20Sopenharmony_ci#define ZC3XX_R113_RGB03               0x0113
1738c2ecf20Sopenharmony_ci#define ZC3XX_R10D_RGB10               0x010d
1748c2ecf20Sopenharmony_ci#define ZC3XX_R10E_RGB11               0x010e
1758c2ecf20Sopenharmony_ci#define ZC3XX_R10F_RGB12               0x010f
1768c2ecf20Sopenharmony_ci#define ZC3XX_R114_RGB13               0x0114
1778c2ecf20Sopenharmony_ci#define ZC3XX_R110_RGB20               0x0110
1788c2ecf20Sopenharmony_ci#define ZC3XX_R111_RGB21               0x0111
1798c2ecf20Sopenharmony_ci#define ZC3XX_R112_RGB22               0x0112
1808c2ecf20Sopenharmony_ci#define ZC3XX_R115_RGB23               0x0115
1818c2ecf20Sopenharmony_ci
1828c2ecf20Sopenharmony_ci/* Gamma matrix */
1838c2ecf20Sopenharmony_ci#define ZC3XX_R120_GAMMA00             0x0120
1848c2ecf20Sopenharmony_ci#define ZC3XX_R121_GAMMA01             0x0121
1858c2ecf20Sopenharmony_ci#define ZC3XX_R122_GAMMA02             0x0122
1868c2ecf20Sopenharmony_ci#define ZC3XX_R123_GAMMA03             0x0123
1878c2ecf20Sopenharmony_ci#define ZC3XX_R124_GAMMA04             0x0124
1888c2ecf20Sopenharmony_ci#define ZC3XX_R125_GAMMA05             0x0125
1898c2ecf20Sopenharmony_ci#define ZC3XX_R126_GAMMA06             0x0126
1908c2ecf20Sopenharmony_ci#define ZC3XX_R127_GAMMA07             0x0127
1918c2ecf20Sopenharmony_ci#define ZC3XX_R128_GAMMA08             0x0128
1928c2ecf20Sopenharmony_ci#define ZC3XX_R129_GAMMA09             0x0129
1938c2ecf20Sopenharmony_ci#define ZC3XX_R12A_GAMMA0A             0x012a
1948c2ecf20Sopenharmony_ci#define ZC3XX_R12B_GAMMA0B             0x012b
1958c2ecf20Sopenharmony_ci#define ZC3XX_R12C_GAMMA0C             0x012c
1968c2ecf20Sopenharmony_ci#define ZC3XX_R12D_GAMMA0D             0x012d
1978c2ecf20Sopenharmony_ci#define ZC3XX_R12E_GAMMA0E             0x012e
1988c2ecf20Sopenharmony_ci#define ZC3XX_R12F_GAMMA0F             0x012f
1998c2ecf20Sopenharmony_ci#define ZC3XX_R130_GAMMA10             0x0130
2008c2ecf20Sopenharmony_ci#define ZC3XX_R131_GAMMA11             0x0131
2018c2ecf20Sopenharmony_ci#define ZC3XX_R132_GAMMA12             0x0132
2028c2ecf20Sopenharmony_ci#define ZC3XX_R133_GAMMA13             0x0133
2038c2ecf20Sopenharmony_ci#define ZC3XX_R134_GAMMA14             0x0134
2048c2ecf20Sopenharmony_ci#define ZC3XX_R135_GAMMA15             0x0135
2058c2ecf20Sopenharmony_ci#define ZC3XX_R136_GAMMA16             0x0136
2068c2ecf20Sopenharmony_ci#define ZC3XX_R137_GAMMA17             0x0137
2078c2ecf20Sopenharmony_ci#define ZC3XX_R138_GAMMA18             0x0138
2088c2ecf20Sopenharmony_ci#define ZC3XX_R139_GAMMA19             0x0139
2098c2ecf20Sopenharmony_ci#define ZC3XX_R13A_GAMMA1A             0x013a
2108c2ecf20Sopenharmony_ci#define ZC3XX_R13B_GAMMA1B             0x013b
2118c2ecf20Sopenharmony_ci#define ZC3XX_R13C_GAMMA1C             0x013c
2128c2ecf20Sopenharmony_ci#define ZC3XX_R13D_GAMMA1D             0x013d
2138c2ecf20Sopenharmony_ci#define ZC3XX_R13E_GAMMA1E             0x013e
2148c2ecf20Sopenharmony_ci#define ZC3XX_R13F_GAMMA1F             0x013f
2158c2ecf20Sopenharmony_ci
2168c2ecf20Sopenharmony_ci/* Luminance gamma */
2178c2ecf20Sopenharmony_ci#define ZC3XX_R140_YGAMMA00            0x0140
2188c2ecf20Sopenharmony_ci#define ZC3XX_R141_YGAMMA01            0x0141
2198c2ecf20Sopenharmony_ci#define ZC3XX_R142_YGAMMA02            0x0142
2208c2ecf20Sopenharmony_ci#define ZC3XX_R143_YGAMMA03            0x0143
2218c2ecf20Sopenharmony_ci#define ZC3XX_R144_YGAMMA04            0x0144
2228c2ecf20Sopenharmony_ci#define ZC3XX_R145_YGAMMA05            0x0145
2238c2ecf20Sopenharmony_ci#define ZC3XX_R146_YGAMMA06            0x0146
2248c2ecf20Sopenharmony_ci#define ZC3XX_R147_YGAMMA07            0x0147
2258c2ecf20Sopenharmony_ci#define ZC3XX_R148_YGAMMA08            0x0148
2268c2ecf20Sopenharmony_ci#define ZC3XX_R149_YGAMMA09            0x0149
2278c2ecf20Sopenharmony_ci#define ZC3XX_R14A_YGAMMA0A            0x014a
2288c2ecf20Sopenharmony_ci#define ZC3XX_R14B_YGAMMA0B            0x014b
2298c2ecf20Sopenharmony_ci#define ZC3XX_R14C_YGAMMA0C            0x014c
2308c2ecf20Sopenharmony_ci#define ZC3XX_R14D_YGAMMA0D            0x014d
2318c2ecf20Sopenharmony_ci#define ZC3XX_R14E_YGAMMA0E            0x014e
2328c2ecf20Sopenharmony_ci#define ZC3XX_R14F_YGAMMA0F            0x014f
2338c2ecf20Sopenharmony_ci#define ZC3XX_R150_YGAMMA10            0x0150
2348c2ecf20Sopenharmony_ci#define ZC3XX_R151_YGAMMA11            0x0151
2358c2ecf20Sopenharmony_ci
2368c2ecf20Sopenharmony_ci#define ZC3XX_R1C5_SHARPNESSMODE       0x01c5
2378c2ecf20Sopenharmony_ci#define ZC3XX_R1C6_SHARPNESS00         0x01c6
2388c2ecf20Sopenharmony_ci#define ZC3XX_R1C7_SHARPNESS01         0x01c7
2398c2ecf20Sopenharmony_ci#define ZC3XX_R1C8_SHARPNESS02         0x01c8
2408c2ecf20Sopenharmony_ci#define ZC3XX_R1C9_SHARPNESS03         0x01c9
2418c2ecf20Sopenharmony_ci#define ZC3XX_R1CA_SHARPNESS04         0x01ca
2428c2ecf20Sopenharmony_ci#define ZC3XX_R1CB_SHARPNESS05         0x01cb
2438c2ecf20Sopenharmony_ci
2448c2ecf20Sopenharmony_ci/* Dead pixels */
2458c2ecf20Sopenharmony_ci#define ZC3XX_R250_DEADPIXELSMODE      0x0250
2468c2ecf20Sopenharmony_ci
2478c2ecf20Sopenharmony_ci/* EEPROM */
2488c2ecf20Sopenharmony_ci#define ZC3XX_R300_EEPROMCONFIG        0x0300
2498c2ecf20Sopenharmony_ci#define ZC3XX_R301_EEPROMACCESS        0x0301
2508c2ecf20Sopenharmony_ci#define ZC3XX_R302_EEPROMSTATUS        0x0302
251