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