Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

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