18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci#ifndef _CARMINEFB_REGS_H 38c2ecf20Sopenharmony_ci#define _CARMINEFB_REGS_H 48c2ecf20Sopenharmony_ci 58c2ecf20Sopenharmony_ci#define CARMINE_OVERLAY_EXT_MODE (0x00000002) 68c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG (0x00000000) 78c2ecf20Sopenharmony_ci#define CARMINE_DISP0_REG (0x00100000) 88c2ecf20Sopenharmony_ci#define CARMINE_DISP1_REG (0x00140000) 98c2ecf20Sopenharmony_ci#define CARMINE_WB_REG (0x00180000) 108c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG (0x00300000) 118c2ecf20Sopenharmony_ci#define CARMINE_CTL_REG (0x00400000) 128c2ecf20Sopenharmony_ci#define CARMINE_WINDOW_MODE (0x00000001) 138c2ecf20Sopenharmony_ci#define CARMINE_EXTEND_MODE (CARMINE_WINDOW_MODE | \ 148c2ecf20Sopenharmony_ci CARMINE_OVERLAY_EXT_MODE) 158c2ecf20Sopenharmony_ci#define CARMINE_L0E (1 << 16) 168c2ecf20Sopenharmony_ci#define CARMINE_L2E (1 << 18) 178c2ecf20Sopenharmony_ci#define CARMINE_DEN (1 << 31) 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci#define CARMINE_EXT_CMODE_DIRECT24_RGBA (0xC0000000) 208c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_MODE_ADD (0x00) 218c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_SETTIME1_EMODE (0x04) 228c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_REFRESH_SETTIME2 (0x08) 238c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_RSV0_STATES (0x0C) 248c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_RSV2_RSV1 (0x10) 258c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_DDRIF2_DDRIF1 (0x14) 268c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_IOCONT1_IOCONT0 (0x24) 278c2ecf20Sopenharmony_ci#define CARMINE_DCTL_REG_STATES_MASK (0x000F) 288c2ecf20Sopenharmony_ci#define CARMINE_DCTL_INIT_WAIT_INTERVAL (1) 298c2ecf20Sopenharmony_ci#define CARMINE_DCTL_INIT_WAIT_LIMIT (5000) 308c2ecf20Sopenharmony_ci#define CARMINE_WB_REG_WBM_DEFAULT (0x0001c020) 318c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0RM (0x1880) 328c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0PX (0x1884) 338c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0PY (0x1888) 348c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2RM (0x18A0) 358c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2PX (0x18A4) 368c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2PY (0x18A8) 378c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3RM (0x18B0) 388c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3PX (0x18B4) 398c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3PY (0x18B8) 408c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4RM (0x18C0) 418c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4PX (0x18C4) 428c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4PY (0x18C8) 438c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5RM (0x18D0) 448c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5PX (0x18D4) 458c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5PY (0x18D8) 468c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6RM (0x1924) 478c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6PX (0x1928) 488c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6PY (0x192C) 498c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7RM (0x1964) 508c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7PX (0x1968) 518c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7PY (0x196C) 528c2ecf20Sopenharmony_ci#define CARMINE_WB_REG_WBM (0x0004) 538c2ecf20Sopenharmony_ci#define CARMINE_DISP_HTP_SHIFT (16) 548c2ecf20Sopenharmony_ci#define CARMINE_DISP_HDB_SHIFT (16) 558c2ecf20Sopenharmony_ci#define CARMINE_DISP_HSW_SHIFT (16) 568c2ecf20Sopenharmony_ci#define CARMINE_DISP_VSW_SHIFT (24) 578c2ecf20Sopenharmony_ci#define CARMINE_DISP_VTR_SHIFT (16) 588c2ecf20Sopenharmony_ci#define CARMINE_DISP_VDP_SHIFT (16) 598c2ecf20Sopenharmony_ci#define CARMINE_CURSOR_CUTZ_MASK (0x00000100) 608c2ecf20Sopenharmony_ci#define CARMINE_CURSOR0_PRIORITY_MASK (0x00010000) 618c2ecf20Sopenharmony_ci#define CARMINE_CURSOR1_PRIORITY_MASK (0x00020000) 628c2ecf20Sopenharmony_ci#define CARMINE_DISP_WIDTH_SHIFT (16) 638c2ecf20Sopenharmony_ci#define CARMINE_DISP_WIN_H_SHIFT (16) 648c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_H_TOTAL (0x0004) 658c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_H_PERIOD (0x0008) 668c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_V_H_W_H_POS (0x000C) 678c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_V_TOTAL (0x0010) 688c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_V_PERIOD_POS (0x0014) 698c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_MODE_W_H (0x0020) 708c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_ORG_ADR (0x0024) 718c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_DISP_ADR (0x0028) 728c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_DISP_POS (0x002C) 738c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIDTH (0x0030) 748c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_ORG_ADR (0x0034) 758c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_MODE_W_H (0x0040) 768c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_ORG_ADR1 (0x0044) 778c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_DISP_ADR1 (0x0048) 788c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_DISP_POS (0x0054) 798c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_MODE_W_H (0x0058) 808c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_ORG_ADR1 (0x005C) 818c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_DISP_ADR1 (0x0060) 828c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_DISP_POS (0x006C) 838c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_MODE_W_H (0x0070) 848c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_ORG_ADR1 (0x0074) 858c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_DISP_ADR1 (0x0078) 868c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_DISP_POS (0x0084) 878c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_MODE_W_H (0x0088) 888c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_ORG_ADR1 (0x008C) 898c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_DISP_ADR1 (0x0090) 908c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_DISP_POS (0x009C) 918c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_CURSOR_MODE (0x00A0) 928c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_CUR1_POS (0x00A8) 938c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_CUR2_POS (0x00B0) 948c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_C_TRANS (0x00BC) 958c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_MLMR_TRANS (0x00C0) 968c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_EXT_MODE (0x0110) 978c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_WIN_POS (0x0114) 988c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_WIN_SIZE (0x0118) 998c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_EXT_MODE (0x0120) 1008c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIN_POS (0x0124) 1018c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIN_SIZE (0x0128) 1028c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_EXT_MODE (0x0130) 1038c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_WIN_POS (0x0134) 1048c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_WIN_SIZE (0x0138) 1058c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_EXT_MODE (0x0140) 1068c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_WIN_POS (0x0144) 1078c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_WIN_SIZE (0x0148) 1088c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_EXT_MODE (0x0150) 1098c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_WIN_POS (0x0154) 1108c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_WIN_SIZE (0x0158) 1118c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_EXT_MODE (0x0160) 1128c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_WIN_POS (0x0164) 1138c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_WIN_SIZE (0x0168) 1148c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_EXT_MODE (0x1918) 1158c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_WIN_POS (0x191c) 1168c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_WIN_SIZE (0x1920) 1178c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_EXT_MODE (0x1958) 1188c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_WIN_POS (0x195c) 1198c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_WIN_SIZE (0x1960) 1208c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L0 (0x00B4) 1218c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L1 (0x0188) 1228c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L2 (0x018C) 1238c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L3 (0x0190) 1248c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L4 (0x0194) 1258c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L5 (0x0198) 1268c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L6 (0x1990) 1278c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L7 (0x1994) 1288c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L0_TRANS (0x01A0) 1298c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L1_TRANS (0x01A4) 1308c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L2_TRANS (0x01A8) 1318c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L3_TRANS (0x01AC) 1328c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L4_TRANS (0x01B0) 1338c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L5_TRANS (0x01B4) 1348c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_TRANS (0x1998) 1358c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_TRANS (0x199c) 1368c2ecf20Sopenharmony_ci#define CARMINE_EXTEND_MODE_MASK (0x00000003) 1378c2ecf20Sopenharmony_ci#define CARMINE_DISP_DCM_MASK (0x0000FFFF) 1388c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_DCM1 (0x0100) 1398c2ecf20Sopenharmony_ci#define CARMINE_DISP_WIDTH_UNIT (64) 1408c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_MODE_W_H (0x1900) 1418c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_ORG_ADR1 (0x1904) 1428c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_DISP_ADR0 (0x1908) 1438c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L6_DISP_POS (0x1914) 1448c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_MODE_W_H (0x1940) 1458c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_ORG_ADR1 (0x1944) 1468c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_DISP_ADR0 (0x1948) 1478c2ecf20Sopenharmony_ci#define CARMINE_DISP_REG_L7_DISP_POS (0x1954) 1488c2ecf20Sopenharmony_ci#define CARMINE_CTL_REG_CLOCK_ENABLE (0x000C) 1498c2ecf20Sopenharmony_ci#define CARMINE_CTL_REG_SOFTWARE_RESET (0x0010) 1508c2ecf20Sopenharmony_ci#define CARMINE_CTL_REG_IST_MASK_ALL (0x07FFFFFF) 1518c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_VRINTM (0x00028064) 1528c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_VRERRM (0x0002806C) 1538c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_PX (0x0004005C) 1548c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_PY (0x00040060) 1558c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_LX (0x00040064) 1568c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_LY (0x00040068) 1578c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_TX (0x0004006C) 1588c2ecf20Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_TY (0x00040070) 1598c2ecf20Sopenharmony_ci 1608c2ecf20Sopenharmony_ci#endif 161