1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef __ATMEL_ISC_REGS_H 3 #define __ATMEL_ISC_REGS_H 4 5 #include <linux/bitops.h> 6 7 /* ISC Control Enable Register 0 */ 8 #define ISC_CTRLEN 0x00000000 9 10 /* ISC Control Disable Register 0 */ 11 #define ISC_CTRLDIS 0x00000004 12 13 /* ISC Control Status Register 0 */ 14 #define ISC_CTRLSR 0x00000008 15 16 #define ISC_CTRL_CAPTURE BIT(0) 17 #define ISC_CTRL_UPPRO BIT(1) 18 #define ISC_CTRL_HISREQ BIT(2) 19 #define ISC_CTRL_HISCLR BIT(3) 20 21 /* ISC Parallel Front End Configuration 0 Register */ 22 #define ISC_PFE_CFG0 0x0000000c 23 24 #define ISC_PFE_CFG0_HPOL_LOW BIT(0) 25 #define ISC_PFE_CFG0_VPOL_LOW BIT(1) 26 #define ISC_PFE_CFG0_PPOL_LOW BIT(2) 27 #define ISC_PFE_CFG0_CCIR656 BIT(9) 28 #define ISC_PFE_CFG0_CCIR_CRC BIT(10) 29 30 #define ISC_PFE_CFG0_MODE_PROGRESSIVE (0x0 << 4) 31 #define ISC_PFE_CFG0_MODE_MASK GENMASK(6, 4) 32 33 #define ISC_PFE_CFG0_BPS_EIGHT (0x4 << 28) 34 #define ISC_PFG_CFG0_BPS_NINE (0x3 << 28) 35 #define ISC_PFG_CFG0_BPS_TEN (0x2 << 28) 36 #define ISC_PFG_CFG0_BPS_ELEVEN (0x1 << 28) 37 #define ISC_PFG_CFG0_BPS_TWELVE (0x0 << 28) 38 #define ISC_PFE_CFG0_BPS_MASK GENMASK(30, 28) 39 40 #define ISC_PFE_CFG0_COLEN BIT(12) 41 #define ISC_PFE_CFG0_ROWEN BIT(13) 42 43 /* ISC Parallel Front End Configuration 1 Register */ 44 #define ISC_PFE_CFG1 0x00000010 45 46 #define ISC_PFE_CFG1_COLMIN(v) ((v)) 47 #define ISC_PFE_CFG1_COLMIN_MASK GENMASK(15, 0) 48 #define ISC_PFE_CFG1_COLMAX(v) ((v) << 16) 49 #define ISC_PFE_CFG1_COLMAX_MASK GENMASK(31, 16) 50 51 /* ISC Parallel Front End Configuration 2 Register */ 52 #define ISC_PFE_CFG2 0x00000014 53 54 #define ISC_PFE_CFG2_ROWMIN(v) ((v)) 55 #define ISC_PFE_CFG2_ROWMIN_MASK GENMASK(15, 0) 56 #define ISC_PFE_CFG2_ROWMAX(v) ((v) << 16) 57 #define ISC_PFE_CFG2_ROWMAX_MASK GENMASK(31, 16) 58 59 /* ISC Clock Enable Register */ 60 #define ISC_CLKEN 0x00000018 61 62 /* ISC Clock Disable Register */ 63 #define ISC_CLKDIS 0x0000001c 64 65 /* ISC Clock Status Register */ 66 #define ISC_CLKSR 0x00000020 67 #define ISC_CLKSR_SIP BIT(31) 68 69 #define ISC_CLK(n) BIT(n) 70 71 /* ISC Clock Configuration Register */ 72 #define ISC_CLKCFG 0x00000024 73 #define ISC_CLKCFG_DIV_SHIFT(n) ((n)*16) 74 #define ISC_CLKCFG_DIV_MASK(n) GENMASK(((n)*16 + 7), (n)*16) 75 #define ISC_CLKCFG_SEL_SHIFT(n) ((n)*16 + 8) 76 #define ISC_CLKCFG_SEL_MASK(n) GENMASK(((n)*17 + 8), ((n)*16 + 8)) 77 78 /* ISC Interrupt Enable Register */ 79 #define ISC_INTEN 0x00000028 80 81 /* ISC Interrupt Disable Register */ 82 #define ISC_INTDIS 0x0000002c 83 84 /* ISC Interrupt Mask Register */ 85 #define ISC_INTMASK 0x00000030 86 87 /* ISC Interrupt Status Register */ 88 #define ISC_INTSR 0x00000034 89 90 #define ISC_INT_DDONE BIT(8) 91 #define ISC_INT_HISDONE BIT(12) 92 93 /* ISC White Balance Control Register */ 94 #define ISC_WB_CTRL 0x00000058 95 96 /* ISC White Balance Configuration Register */ 97 #define ISC_WB_CFG 0x0000005c 98 99 /* ISC White Balance Offset for R, GR Register */ 100 #define ISC_WB_O_RGR 0x00000060 101 102 /* ISC White Balance Offset for B, GB Register */ 103 #define ISC_WB_O_BGB 0x00000064 104 105 /* ISC White Balance Gain for R, GR Register */ 106 #define ISC_WB_G_RGR 0x00000068 107 108 /* ISC White Balance Gain for B, GB Register */ 109 #define ISC_WB_G_BGB 0x0000006c 110 111 /* ISC Color Filter Array Control Register */ 112 #define ISC_CFA_CTRL 0x00000070 113 114 /* ISC Color Filter Array Configuration Register */ 115 #define ISC_CFA_CFG 0x00000074 116 #define ISC_CFA_CFG_EITPOL BIT(4) 117 118 #define ISC_BAY_CFG_GRGR 0x0 119 #define ISC_BAY_CFG_RGRG 0x1 120 #define ISC_BAY_CFG_GBGB 0x2 121 #define ISC_BAY_CFG_BGBG 0x3 122 123 /* ISC Color Correction Control Register */ 124 #define ISC_CC_CTRL 0x00000078 125 126 /* ISC Color Correction RR RG Register */ 127 #define ISC_CC_RR_RG 0x0000007c 128 129 /* ISC Color Correction RB OR Register */ 130 #define ISC_CC_RB_OR 0x00000080 131 132 /* ISC Color Correction GR GG Register */ 133 #define ISC_CC_GR_GG 0x00000084 134 135 /* ISC Color Correction GB OG Register */ 136 #define ISC_CC_GB_OG 0x00000088 137 138 /* ISC Color Correction BR BG Register */ 139 #define ISC_CC_BR_BG 0x0000008c 140 141 /* ISC Color Correction BB OB Register */ 142 #define ISC_CC_BB_OB 0x00000090 143 144 /* ISC Gamma Correction Control Register */ 145 #define ISC_GAM_CTRL 0x00000094 146 147 /* ISC_Gamma Correction Blue Entry Register */ 148 #define ISC_GAM_BENTRY 0x00000098 149 150 /* ISC_Gamma Correction Green Entry Register */ 151 #define ISC_GAM_GENTRY 0x00000198 152 153 /* ISC_Gamma Correction Green Entry Register */ 154 #define ISC_GAM_RENTRY 0x00000298 155 156 /* Color Space Conversion Control Register */ 157 #define ISC_CSC_CTRL 0x00000398 158 159 /* Color Space Conversion YR YG Register */ 160 #define ISC_CSC_YR_YG 0x0000039c 161 162 /* Color Space Conversion YB OY Register */ 163 #define ISC_CSC_YB_OY 0x000003a0 164 165 /* Color Space Conversion CBR CBG Register */ 166 #define ISC_CSC_CBR_CBG 0x000003a4 167 168 /* Color Space Conversion CBB OCB Register */ 169 #define ISC_CSC_CBB_OCB 0x000003a8 170 171 /* Color Space Conversion CRR CRG Register */ 172 #define ISC_CSC_CRR_CRG 0x000003ac 173 174 /* Color Space Conversion CRB OCR Register */ 175 #define ISC_CSC_CRB_OCR 0x000003b0 176 177 /* Contrast And Brightness Control Register */ 178 #define ISC_CBC_CTRL 0x000003b4 179 180 /* Contrast And Brightness Configuration Register */ 181 #define ISC_CBC_CFG 0x000003b8 182 183 /* Brightness Register */ 184 #define ISC_CBC_BRIGHT 0x000003bc 185 #define ISC_CBC_BRIGHT_MASK GENMASK(10, 0) 186 187 /* Contrast Register */ 188 #define ISC_CBC_CONTRAST 0x000003c0 189 #define ISC_CBC_CONTRAST_MASK GENMASK(11, 0) 190 191 /* Subsampling 4:4:4 to 4:2:2 Control Register */ 192 #define ISC_SUB422_CTRL 0x000003c4 193 194 /* Subsampling 4:2:2 to 4:2:0 Control Register */ 195 #define ISC_SUB420_CTRL 0x000003cc 196 197 /* Rounding, Limiting and Packing Configuration Register */ 198 #define ISC_RLP_CFG 0x000003d0 199 200 #define ISC_RLP_CFG_MODE_DAT8 0x0 201 #define ISC_RLP_CFG_MODE_DAT9 0x1 202 #define ISC_RLP_CFG_MODE_DAT10 0x2 203 #define ISC_RLP_CFG_MODE_DAT11 0x3 204 #define ISC_RLP_CFG_MODE_DAT12 0x4 205 #define ISC_RLP_CFG_MODE_DATY8 0x5 206 #define ISC_RLP_CFG_MODE_DATY10 0x6 207 #define ISC_RLP_CFG_MODE_ARGB444 0x7 208 #define ISC_RLP_CFG_MODE_ARGB555 0x8 209 #define ISC_RLP_CFG_MODE_RGB565 0x9 210 #define ISC_RLP_CFG_MODE_ARGB32 0xa 211 #define ISC_RLP_CFG_MODE_YYCC 0xb 212 #define ISC_RLP_CFG_MODE_YYCC_LIMITED 0xc 213 #define ISC_RLP_CFG_MODE_MASK GENMASK(3, 0) 214 215 /* Histogram Control Register */ 216 #define ISC_HIS_CTRL 0x000003d4 217 218 #define ISC_HIS_CTRL_EN BIT(0) 219 #define ISC_HIS_CTRL_DIS 0x0 220 221 /* Histogram Configuration Register */ 222 #define ISC_HIS_CFG 0x000003d8 223 224 #define ISC_HIS_CFG_MODE_GR 0x0 225 #define ISC_HIS_CFG_MODE_R 0x1 226 #define ISC_HIS_CFG_MODE_GB 0x2 227 #define ISC_HIS_CFG_MODE_B 0x3 228 #define ISC_HIS_CFG_MODE_Y 0x4 229 #define ISC_HIS_CFG_MODE_RAW 0x5 230 #define ISC_HIS_CFG_MODE_YCCIR656 0x6 231 232 #define ISC_HIS_CFG_BAYSEL_SHIFT 4 233 234 #define ISC_HIS_CFG_RAR BIT(8) 235 236 /* DMA Configuration Register */ 237 #define ISC_DCFG 0x000003e0 238 #define ISC_DCFG_IMODE_PACKED8 0x0 239 #define ISC_DCFG_IMODE_PACKED16 0x1 240 #define ISC_DCFG_IMODE_PACKED32 0x2 241 #define ISC_DCFG_IMODE_YC422SP 0x3 242 #define ISC_DCFG_IMODE_YC422P 0x4 243 #define ISC_DCFG_IMODE_YC420SP 0x5 244 #define ISC_DCFG_IMODE_YC420P 0x6 245 #define ISC_DCFG_IMODE_MASK GENMASK(2, 0) 246 247 #define ISC_DCFG_YMBSIZE_SINGLE (0x0 << 4) 248 #define ISC_DCFG_YMBSIZE_BEATS4 (0x1 << 4) 249 #define ISC_DCFG_YMBSIZE_BEATS8 (0x2 << 4) 250 #define ISC_DCFG_YMBSIZE_BEATS16 (0x3 << 4) 251 #define ISC_DCFG_YMBSIZE_MASK GENMASK(5, 4) 252 253 #define ISC_DCFG_CMBSIZE_SINGLE (0x0 << 8) 254 #define ISC_DCFG_CMBSIZE_BEATS4 (0x1 << 8) 255 #define ISC_DCFG_CMBSIZE_BEATS8 (0x2 << 8) 256 #define ISC_DCFG_CMBSIZE_BEATS16 (0x3 << 8) 257 #define ISC_DCFG_CMBSIZE_MASK GENMASK(9, 8) 258 259 /* DMA Control Register */ 260 #define ISC_DCTRL 0x000003e4 261 262 #define ISC_DCTRL_DVIEW_PACKED (0x0 << 1) 263 #define ISC_DCTRL_DVIEW_SEMIPLANAR (0x1 << 1) 264 #define ISC_DCTRL_DVIEW_PLANAR (0x2 << 1) 265 #define ISC_DCTRL_DVIEW_MASK GENMASK(2, 1) 266 267 #define ISC_DCTRL_IE_IS (0x0 << 4) 268 269 /* DMA Descriptor Address Register */ 270 #define ISC_DNDA 0x000003e8 271 272 /* DMA Address 0 Register */ 273 #define ISC_DAD0 0x000003ec 274 275 /* DMA Address 1 Register */ 276 #define ISC_DAD1 0x000003f4 277 278 /* DMA Address 2 Register */ 279 #define ISC_DAD2 0x000003fc 280 281 /* Histogram Entry */ 282 #define ISC_HIS_ENTRY 0x00000410 283 284 #endif 285