1f6b690e6SBo Shen /* 2f6b690e6SBo Shen * Header file for AT91/AT32 MULTI LAYER LCD Controller 3f6b690e6SBo Shen * 4f6b690e6SBo Shen * Data structure and register user interface 5f6b690e6SBo Shen * 6f6b690e6SBo Shen * Copyright (C) 2012 Atmel Corporation 7f6b690e6SBo Shen * 8*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 9f6b690e6SBo Shen */ 10f6b690e6SBo Shen #ifndef __ATMEL_HLCDC_H__ 11f6b690e6SBo Shen #define __ATMEL_HLCDC_H__ 12f6b690e6SBo Shen 13f6b690e6SBo Shen /* Atmel multi layer lcdc hardware registers */ 14f6b690e6SBo Shen struct atmel_hlcd_regs { 15f6b690e6SBo Shen u32 lcdc_lcdcfg0; 16f6b690e6SBo Shen u32 lcdc_lcdcfg1; 17f6b690e6SBo Shen u32 lcdc_lcdcfg2; 18f6b690e6SBo Shen u32 lcdc_lcdcfg3; 19f6b690e6SBo Shen u32 lcdc_lcdcfg4; 20f6b690e6SBo Shen u32 lcdc_lcdcfg5; 21f6b690e6SBo Shen u32 lcdc_lcdcfg6; 22f6b690e6SBo Shen u32 res1; 23f6b690e6SBo Shen u32 lcdc_lcden; 24f6b690e6SBo Shen u32 lcdc_lcddis; 25f6b690e6SBo Shen u32 lcdc_lcdsr; 26f6b690e6SBo Shen u32 res2; 27f6b690e6SBo Shen u32 lcdc_lcdidr; 28f6b690e6SBo Shen u32 res3[3]; 29f6b690e6SBo Shen u32 lcdc_basecher; 30f6b690e6SBo Shen u32 res4[3]; 31f6b690e6SBo Shen u32 lcdc_baseidr; 32f6b690e6SBo Shen u32 res5[3]; 33f6b690e6SBo Shen u32 lcdc_baseaddr; 34f6b690e6SBo Shen u32 lcdc_basectrl; 35f6b690e6SBo Shen u32 lcdc_basenext; 36f6b690e6SBo Shen u32 lcdc_basecfg0; 37f6b690e6SBo Shen u32 lcdc_basecfg1; 38f6b690e6SBo Shen u32 lcdc_basecfg2; 39f6b690e6SBo Shen u32 lcdc_basecfg3; 40f6b690e6SBo Shen u32 lcdc_basecfg4; 41f6b690e6SBo Shen }; 42f6b690e6SBo Shen 43f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKPOL (0x1 << 0) 44f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKSEL (0x1 << 2) 45f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKPWMSEL (0x1 << 3) 46f6b690e6SBo Shen #define LCDC_LCDCFG0_CGDISBASE (0x1 << 8) 47f6b690e6SBo Shen #define LCDC_LCDCFG0_CGDISOVR1 (0x1 << 9) 48f6b690e6SBo Shen #define LCDC_LCDCFG0_CGDISHEO (0x1 << 11) 49f6b690e6SBo Shen #define LCDC_LCDCFG0_CGDISHCR (0x1 << 12) 50f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKDIV_Pos 16 51f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKDIV_Msk (0xff << LCDC_LCDCFG0_CLKDIV_Pos) 52f6b690e6SBo Shen #define LCDC_LCDCFG0_CLKDIV(value) \ 53f6b690e6SBo Shen ((LCDC_LCDCFG0_CLKDIV_Msk & ((value) << LCDC_LCDCFG0_CLKDIV_Pos))) 54f6b690e6SBo Shen 55f6b690e6SBo Shen #define LCDC_LCDCFG1_HSPW_Pos 0 56f6b690e6SBo Shen #define LCDC_LCDCFG1_HSPW_Msk (0x3f << LCDC_LCDCFG1_HSPW_Pos) 57f6b690e6SBo Shen #define LCDC_LCDCFG1_HSPW(value) \ 58f6b690e6SBo Shen ((LCDC_LCDCFG1_HSPW_Msk & ((value) << LCDC_LCDCFG1_HSPW_Pos))) 59f6b690e6SBo Shen #define LCDC_LCDCFG1_VSPW_Pos 16 60f6b690e6SBo Shen #define LCDC_LCDCFG1_VSPW_Msk (0x3f << LCDC_LCDCFG1_VSPW_Pos) 61f6b690e6SBo Shen #define LCDC_LCDCFG1_VSPW(value) \ 62f6b690e6SBo Shen ((LCDC_LCDCFG1_VSPW_Msk & ((value) << LCDC_LCDCFG1_VSPW_Pos))) 63f6b690e6SBo Shen 64f6b690e6SBo Shen #define LCDC_LCDCFG2_VFPW_Pos 0 65f6b690e6SBo Shen #define LCDC_LCDCFG2_VFPW_Msk (0x3f << LCDC_LCDCFG2_VFPW_Pos) 66f6b690e6SBo Shen #define LCDC_LCDCFG2_VFPW(value) \ 67f6b690e6SBo Shen ((LCDC_LCDCFG2_VFPW_Msk & ((value) << LCDC_LCDCFG2_VFPW_Pos))) 68f6b690e6SBo Shen #define LCDC_LCDCFG2_VBPW_Pos 16 69f6b690e6SBo Shen #define LCDC_LCDCFG2_VBPW_Msk (0x3f << LCDC_LCDCFG2_VBPW_Pos) 70f6b690e6SBo Shen #define LCDC_LCDCFG2_VBPW(value) \ 71f6b690e6SBo Shen ((LCDC_LCDCFG2_VBPW_Msk & ((value) << LCDC_LCDCFG2_VBPW_Pos))) 72f6b690e6SBo Shen 73f6b690e6SBo Shen #define LCDC_LCDCFG3_HFPW_Pos 0 74f6b690e6SBo Shen #define LCDC_LCDCFG3_HFPW_Msk (0xff << LCDC_LCDCFG3_HFPW_Pos) 75f6b690e6SBo Shen #define LCDC_LCDCFG3_HFPW(value) \ 76f6b690e6SBo Shen ((LCDC_LCDCFG3_HFPW_Msk & ((value) << LCDC_LCDCFG3_HFPW_Pos))) 77f6b690e6SBo Shen #define LCDC_LCDCFG3_HBPW_Pos 16 78f6b690e6SBo Shen #define LCDC_LCDCFG3_HBPW_Msk (0xff << LCDC_LCDCFG3_HBPW_Pos) 79f6b690e6SBo Shen #define LCDC_LCDCFG3_HBPW(value) \ 80f6b690e6SBo Shen ((LCDC_LCDCFG3_HBPW_Msk & ((value) << LCDC_LCDCFG3_HBPW_Pos))) 81f6b690e6SBo Shen 82f6b690e6SBo Shen #define LCDC_LCDCFG4_PPL_Pos 0 83f6b690e6SBo Shen #define LCDC_LCDCFG4_PPL_Msk (0x7ff << LCDC_LCDCFG4_PPL_Pos) 84f6b690e6SBo Shen #define LCDC_LCDCFG4_PPL(value) \ 85f6b690e6SBo Shen ((LCDC_LCDCFG4_PPL_Msk & ((value) << LCDC_LCDCFG4_PPL_Pos))) 86f6b690e6SBo Shen #define LCDC_LCDCFG4_RPF_Pos 16 87f6b690e6SBo Shen #define LCDC_LCDCFG4_RPF_Msk (0x7ff << LCDC_LCDCFG4_RPF_Pos) 88f6b690e6SBo Shen #define LCDC_LCDCFG4_RPF(value) \ 89f6b690e6SBo Shen ((LCDC_LCDCFG4_RPF_Msk & ((value) << LCDC_LCDCFG4_RPF_Pos))) 90f6b690e6SBo Shen 91f6b690e6SBo Shen #define LCDC_LCDCFG5_HSPOL (0x1 << 0) 92f6b690e6SBo Shen #define LCDC_LCDCFG5_VSPOL (0x1 << 1) 93f6b690e6SBo Shen #define LCDC_LCDCFG5_VSPDLYS (0x1 << 2) 94f6b690e6SBo Shen #define LCDC_LCDCFG5_VSPDLYE (0x1 << 3) 95f6b690e6SBo Shen #define LCDC_LCDCFG5_DISPPOL (0x1 << 4) 96f6b690e6SBo Shen #define LCDC_LCDCFG5_SERIAL (0x1 << 5) 97f6b690e6SBo Shen #define LCDC_LCDCFG5_DITHER (0x1 << 6) 98f6b690e6SBo Shen #define LCDC_LCDCFG5_DISPDLY (0x1 << 7) 99f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_Pos 8 100f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_Msk (0x3 << LCDC_LCDCFG5_MODE_Pos) 101f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_OUTPUT_12BPP (0x0 << 8) 102f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_OUTPUT_16BPP (0x1 << 8) 103f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_OUTPUT_18BPP (0x2 << 8) 104f6b690e6SBo Shen #define LCDC_LCDCFG5_MODE_OUTPUT_24BPP (0x3 << 8) 105f6b690e6SBo Shen #define LCDC_LCDCFG5_VSPSU (0x1 << 12) 106f6b690e6SBo Shen #define LCDC_LCDCFG5_VSPHO (0x1 << 13) 107f6b690e6SBo Shen #define LCDC_LCDCFG5_GUARDTIME_Pos 16 108f6b690e6SBo Shen #define LCDC_LCDCFG5_GUARDTIME_Msk (0x1f << LCDC_LCDCFG5_GUARDTIME_Pos) 109f6b690e6SBo Shen #define LCDC_LCDCFG5_GUARDTIME(value) \ 110f6b690e6SBo Shen ((LCDC_LCDCFG5_GUARDTIME_Msk & ((value) << LCDC_LCDCFG5_GUARDTIME_Pos))) 111f6b690e6SBo Shen 112f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMPS_Pos 0 113f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMPS_Msk (0x7 << LCDC_LCDCFG6_PWMPS_Pos) 114f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMPS(value) \ 115f6b690e6SBo Shen ((LCDC_LCDCFG6_PWMPS_Msk & ((value) << LCDC_LCDCFG6_PWMPS_Pos))) 116f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMPOL (0x1 << 4) 117f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMCVAL_Pos 8 118f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMCVAL_Msk (0xff << LCDC_LCDCFG6_PWMCVAL_Pos) 119f6b690e6SBo Shen #define LCDC_LCDCFG6_PWMCVAL(value) \ 120f6b690e6SBo Shen ((LCDC_LCDCFG6_PWMCVAL_Msk & ((value) << LCDC_LCDCFG6_PWMCVAL_Pos))) 121f6b690e6SBo Shen 122f6b690e6SBo Shen #define LCDC_LCDEN_CLKEN (0x1 << 0) 123f6b690e6SBo Shen #define LCDC_LCDEN_SYNCEN (0x1 << 1) 124f6b690e6SBo Shen #define LCDC_LCDEN_DISPEN (0x1 << 2) 125f6b690e6SBo Shen #define LCDC_LCDEN_PWMEN (0x1 << 3) 126f6b690e6SBo Shen 127f6b690e6SBo Shen #define LCDC_LCDDIS_CLKDIS (0x1 << 0) 128f6b690e6SBo Shen #define LCDC_LCDDIS_SYNCDIS (0x1 << 1) 129f6b690e6SBo Shen #define LCDC_LCDDIS_DISPDIS (0x1 << 2) 130f6b690e6SBo Shen #define LCDC_LCDDIS_PWMDIS (0x1 << 3) 131f6b690e6SBo Shen #define LCDC_LCDDIS_CLKRST (0x1 << 8) 132f6b690e6SBo Shen #define LCDC_LCDDIS_SYNCRST (0x1 << 9) 133f6b690e6SBo Shen #define LCDC_LCDDIS_DISPRST (0x1 << 10) 134f6b690e6SBo Shen #define LCDC_LCDDIS_PWMRST (0x1 << 11) 135f6b690e6SBo Shen 136f6b690e6SBo Shen #define LCDC_LCDSR_CLKSTS (0x1 << 0) 137f6b690e6SBo Shen #define LCDC_LCDSR_LCDSTS (0x1 << 1) 138f6b690e6SBo Shen #define LCDC_LCDSR_DISPSTS (0x1 << 2) 139f6b690e6SBo Shen #define LCDC_LCDSR_PWMSTS (0x1 << 3) 140f6b690e6SBo Shen #define LCDC_LCDSR_SIPSTS (0x1 << 4) 141f6b690e6SBo Shen 142f6b690e6SBo Shen #define LCDC_LCDIDR_SOFID (0x1 << 0) 143f6b690e6SBo Shen #define LCDC_LCDIDR_DISID (0x1 << 1) 144f6b690e6SBo Shen #define LCDC_LCDIDR_DISPID (0x1 << 2) 145f6b690e6SBo Shen #define LCDC_LCDIDR_FIFOERRID (0x1 << 4) 146f6b690e6SBo Shen #define LCDC_LCDIDR_BASEID (0x1 << 8) 147f6b690e6SBo Shen #define LCDC_LCDIDR_OVR1ID (0x1 << 9) 148f6b690e6SBo Shen #define LCDC_LCDIDR_HEOID (0x1 << 11) 149f6b690e6SBo Shen #define LCDC_LCDIDR_HCRID (0x1 << 12) 150f6b690e6SBo Shen 151f6b690e6SBo Shen #define LCDC_BASECHER_CHEN (0x1 << 0) 152f6b690e6SBo Shen #define LCDC_BASECHER_UPDATEEN (0x1 << 1) 153f6b690e6SBo Shen #define LCDC_BASECHER_A2QEN (0x1 << 2) 154f6b690e6SBo Shen 155f6b690e6SBo Shen #define LCDC_BASEIDR_DMA (0x1 << 2) 156f6b690e6SBo Shen #define LCDC_BASEIDR_DSCR (0x1 << 3) 157f6b690e6SBo Shen #define LCDC_BASEIDR_ADD (0x1 << 4) 158f6b690e6SBo Shen #define LCDC_BASEIDR_DONE (0x1 << 5) 159f6b690e6SBo Shen #define LCDC_BASEIDR_OVR (0x1 << 6) 160f6b690e6SBo Shen 161f6b690e6SBo Shen #define LCDC_BASECTRL_DFETCH (0x1 << 0) 162f6b690e6SBo Shen #define LCDC_BASECTRL_LFETCH (0x1 << 1) 163f6b690e6SBo Shen #define LCDC_BASECTRL_DMAIEN (0x1 << 2) 164f6b690e6SBo Shen #define LCDC_BASECTRL_DSCRIEN (0x1 << 3) 165f6b690e6SBo Shen #define LCDC_BASECTRL_ADDIEN (0x1 << 4) 166f6b690e6SBo Shen #define LCDC_BASECTRL_DONEIEN (0x1 << 5) 167f6b690e6SBo Shen 168f6b690e6SBo Shen #define LCDC_BASECFG0_BLEN_Pos 4 169f6b690e6SBo Shen #define LCDC_BASECFG0_BLEN_AHB_SINGLE (0x0 << 4) 170f6b690e6SBo Shen #define LCDC_BASECFG0_BLEN_AHB_INCR4 (0x1 << 4) 171f6b690e6SBo Shen #define LCDC_BASECFG0_BLEN_AHB_INCR8 (0x2 << 4) 172f6b690e6SBo Shen #define LCDC_BASECFG0_BLEN_AHB_INCR16 (0x3 << 4) 173f6b690e6SBo Shen #define LCDC_BASECFG0_DLBO (0x1 << 8) 174f6b690e6SBo Shen 175f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_12BPP_RGB_444 (0x0 << 4) 176f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_16BPP_ARGB_4444 (0x1 << 4) 177f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_16BPP_RGBA_4444 (0x2 << 4) 178f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_16BPP_RGB_565 (0x3 << 4) 179f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_16BPP_TRGB_1555 (0x4 << 4) 180f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_18BPP_RGB_666 (0x5 << 4) 181f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_18BPP_RGB_666_PACKED (0x6 << 4) 182f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_19BPP_TRGB_1666 (0x7 << 4) 183f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_19BPP_TRGB_PACKED (0x8 << 4) 184f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_24BPP_RGB_888 (0x9 << 4) 185f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_24BPP_RGB_888_PACKED (0xA << 4) 186f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_25BPP_TRGB_1888 (0xB << 4) 187f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_32BPP_ARGB_8888 (0xC << 4) 188f6b690e6SBo Shen #define LCDC_BASECFG1_RGBMODE_32BPP_RGBA_8888 (0xD << 4) 189f6b690e6SBo Shen 190f6b690e6SBo Shen #define LCDC_BASECFG2_XSTRIDE_Pos 0 191f6b690e6SBo Shen #define LCDC_BASECFG2_XSTRIDE_Msk (0xffffffff << LCDC_BASECFG2_XSTRIDE_Pos) 192f6b690e6SBo Shen #define LCDC_BASECFG2_XSTRIDE(value) \ 193f6b690e6SBo Shen ((LCDC_BASECFG2_XSTRIDE_Msk & ((value) << LCDC_BASECFG2_XSTRIDE_Pos))) 194f6b690e6SBo Shen 195f6b690e6SBo Shen #define LCDC_BASECFG3_BDEF_Pos 0 196f6b690e6SBo Shen #define LCDC_BASECFG3_BDEF_Msk (0xff << LCDC_BASECFG3_BDEF_Pos) 197f6b690e6SBo Shen #define LCDC_BASECFG3_BDEF(value) \ 198f6b690e6SBo Shen ((LCDC_BASECFG3_BDEF_Msk & ((value) << LCDC_BASECFG3_BDEF_Pos))) 199f6b690e6SBo Shen #define LCDC_BASECFG3_GDEF_Pos 8 200f6b690e6SBo Shen #define LCDC_BASECFG3_GDEF_Msk (0xff << LCDC_BASECFG3_GDEF_Pos) 201f6b690e6SBo Shen #define LCDC_BASECFG3_GDEF(value) \ 202f6b690e6SBo Shen ((LCDC_BASECFG3_GDEF_Msk & ((value) << LCDC_BASECFG3_GDEF_Pos))) 203f6b690e6SBo Shen #define LCDC_BASECFG3_RDEF_Pos 16 204f6b690e6SBo Shen #define LCDC_BASECFG3_RDEF_Msk (0xff << LCDC_BASECFG3_RDEF_Pos) 205f6b690e6SBo Shen #define LCDC_BASECFG3_RDEF(value) \ 206f6b690e6SBo Shen ((LCDC_BASECFG3_RDEF_Msk & ((value) << LCDC_BASECFG3_RDEF_Pos))) 207f6b690e6SBo Shen 208cfcd1c03SBo Shen #define LCDC_BASECLUT_BCLUT_Pos 0 209cfcd1c03SBo Shen #define LCDC_BASECLUT_BCLUT_Msk (0xff << LCDC_BASECLUT_BCLUT_Pos) 210cfcd1c03SBo Shen #define LCDC_BASECLUT_GCLUT_Pos 8 211cfcd1c03SBo Shen #define LCDC_BASECLUT_GCLUT_Msk (0xff << LCDC_BASECLUT_GCLUT_Pos) 212cfcd1c03SBo Shen #define LCDC_BASECLUT_RCLUT_Pos 16 213cfcd1c03SBo Shen #define LCDC_BASECLUT_RCLUT_Msk (0xff << LCDC_BASECLUT_RCLUT_Pos) 214cfcd1c03SBo Shen 215f6b690e6SBo Shen #define LCDC_BASECFG4_DMA (0x1 << 8) 216f6b690e6SBo Shen #define LCDC_BASECFG4_REP (0x1 << 9) 217f6b690e6SBo Shen 218f6b690e6SBo Shen struct lcd_dma_desc { 219f6b690e6SBo Shen u32 address; 220f6b690e6SBo Shen u32 control; 221f6b690e6SBo Shen u32 next; 222f6b690e6SBo Shen }; 223f6b690e6SBo Shen 224f6b690e6SBo Shen #define ATMEL_LCDC_LUT(n) (0x0400 + ((n)*4)) 225f6b690e6SBo Shen 226f6b690e6SBo Shen #endif /* __ATMEL_HLCDC_H__ */ 227