162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci#ifndef _CARMINEFB_REGS_H 362306a36Sopenharmony_ci#define _CARMINEFB_REGS_H 462306a36Sopenharmony_ci 562306a36Sopenharmony_ci#define CARMINE_OVERLAY_EXT_MODE (0x00000002) 662306a36Sopenharmony_ci#define CARMINE_GRAPH_REG (0x00000000) 762306a36Sopenharmony_ci#define CARMINE_DISP0_REG (0x00100000) 862306a36Sopenharmony_ci#define CARMINE_DISP1_REG (0x00140000) 962306a36Sopenharmony_ci#define CARMINE_WB_REG (0x00180000) 1062306a36Sopenharmony_ci#define CARMINE_DCTL_REG (0x00300000) 1162306a36Sopenharmony_ci#define CARMINE_CTL_REG (0x00400000) 1262306a36Sopenharmony_ci#define CARMINE_WINDOW_MODE (0x00000001) 1362306a36Sopenharmony_ci#define CARMINE_EXTEND_MODE (CARMINE_WINDOW_MODE | \ 1462306a36Sopenharmony_ci CARMINE_OVERLAY_EXT_MODE) 1562306a36Sopenharmony_ci#define CARMINE_L0E (1 << 16) 1662306a36Sopenharmony_ci#define CARMINE_L2E (1 << 18) 1762306a36Sopenharmony_ci#define CARMINE_DEN (1 << 31) 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#define CARMINE_EXT_CMODE_DIRECT24_RGBA (0xC0000000) 2062306a36Sopenharmony_ci#define CARMINE_DCTL_REG_MODE_ADD (0x00) 2162306a36Sopenharmony_ci#define CARMINE_DCTL_REG_SETTIME1_EMODE (0x04) 2262306a36Sopenharmony_ci#define CARMINE_DCTL_REG_REFRESH_SETTIME2 (0x08) 2362306a36Sopenharmony_ci#define CARMINE_DCTL_REG_RSV0_STATES (0x0C) 2462306a36Sopenharmony_ci#define CARMINE_DCTL_REG_RSV2_RSV1 (0x10) 2562306a36Sopenharmony_ci#define CARMINE_DCTL_REG_DDRIF2_DDRIF1 (0x14) 2662306a36Sopenharmony_ci#define CARMINE_DCTL_REG_IOCONT1_IOCONT0 (0x24) 2762306a36Sopenharmony_ci#define CARMINE_DCTL_REG_STATES_MASK (0x000F) 2862306a36Sopenharmony_ci#define CARMINE_DCTL_INIT_WAIT_INTERVAL (1) 2962306a36Sopenharmony_ci#define CARMINE_DCTL_INIT_WAIT_LIMIT (5000) 3062306a36Sopenharmony_ci#define CARMINE_WB_REG_WBM_DEFAULT (0x0001c020) 3162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0RM (0x1880) 3262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0PX (0x1884) 3362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0PY (0x1888) 3462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2RM (0x18A0) 3562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2PX (0x18A4) 3662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2PY (0x18A8) 3762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3RM (0x18B0) 3862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3PX (0x18B4) 3962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3PY (0x18B8) 4062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4RM (0x18C0) 4162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4PX (0x18C4) 4262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4PY (0x18C8) 4362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5RM (0x18D0) 4462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5PX (0x18D4) 4562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5PY (0x18D8) 4662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6RM (0x1924) 4762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6PX (0x1928) 4862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6PY (0x192C) 4962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7RM (0x1964) 5062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7PX (0x1968) 5162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7PY (0x196C) 5262306a36Sopenharmony_ci#define CARMINE_WB_REG_WBM (0x0004) 5362306a36Sopenharmony_ci#define CARMINE_DISP_HTP_SHIFT (16) 5462306a36Sopenharmony_ci#define CARMINE_DISP_HDB_SHIFT (16) 5562306a36Sopenharmony_ci#define CARMINE_DISP_HSW_SHIFT (16) 5662306a36Sopenharmony_ci#define CARMINE_DISP_VSW_SHIFT (24) 5762306a36Sopenharmony_ci#define CARMINE_DISP_VTR_SHIFT (16) 5862306a36Sopenharmony_ci#define CARMINE_DISP_VDP_SHIFT (16) 5962306a36Sopenharmony_ci#define CARMINE_CURSOR_CUTZ_MASK (0x00000100) 6062306a36Sopenharmony_ci#define CARMINE_CURSOR0_PRIORITY_MASK (0x00010000) 6162306a36Sopenharmony_ci#define CARMINE_CURSOR1_PRIORITY_MASK (0x00020000) 6262306a36Sopenharmony_ci#define CARMINE_DISP_WIDTH_SHIFT (16) 6362306a36Sopenharmony_ci#define CARMINE_DISP_WIN_H_SHIFT (16) 6462306a36Sopenharmony_ci#define CARMINE_DISP_REG_H_TOTAL (0x0004) 6562306a36Sopenharmony_ci#define CARMINE_DISP_REG_H_PERIOD (0x0008) 6662306a36Sopenharmony_ci#define CARMINE_DISP_REG_V_H_W_H_POS (0x000C) 6762306a36Sopenharmony_ci#define CARMINE_DISP_REG_V_TOTAL (0x0010) 6862306a36Sopenharmony_ci#define CARMINE_DISP_REG_V_PERIOD_POS (0x0014) 6962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_MODE_W_H (0x0020) 7062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_ORG_ADR (0x0024) 7162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_DISP_ADR (0x0028) 7262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_DISP_POS (0x002C) 7362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIDTH (0x0030) 7462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_ORG_ADR (0x0034) 7562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_MODE_W_H (0x0040) 7662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_ORG_ADR1 (0x0044) 7762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_DISP_ADR1 (0x0048) 7862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_DISP_POS (0x0054) 7962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_MODE_W_H (0x0058) 8062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_ORG_ADR1 (0x005C) 8162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_DISP_ADR1 (0x0060) 8262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_DISP_POS (0x006C) 8362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_MODE_W_H (0x0070) 8462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_ORG_ADR1 (0x0074) 8562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_DISP_ADR1 (0x0078) 8662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_DISP_POS (0x0084) 8762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_MODE_W_H (0x0088) 8862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_ORG_ADR1 (0x008C) 8962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_DISP_ADR1 (0x0090) 9062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_DISP_POS (0x009C) 9162306a36Sopenharmony_ci#define CARMINE_DISP_REG_CURSOR_MODE (0x00A0) 9262306a36Sopenharmony_ci#define CARMINE_DISP_REG_CUR1_POS (0x00A8) 9362306a36Sopenharmony_ci#define CARMINE_DISP_REG_CUR2_POS (0x00B0) 9462306a36Sopenharmony_ci#define CARMINE_DISP_REG_C_TRANS (0x00BC) 9562306a36Sopenharmony_ci#define CARMINE_DISP_REG_MLMR_TRANS (0x00C0) 9662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_EXT_MODE (0x0110) 9762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_WIN_POS (0x0114) 9862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_WIN_SIZE (0x0118) 9962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_EXT_MODE (0x0120) 10062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIN_POS (0x0124) 10162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_WIN_SIZE (0x0128) 10262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_EXT_MODE (0x0130) 10362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_WIN_POS (0x0134) 10462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_WIN_SIZE (0x0138) 10562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_EXT_MODE (0x0140) 10662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_WIN_POS (0x0144) 10762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_WIN_SIZE (0x0148) 10862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_EXT_MODE (0x0150) 10962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_WIN_POS (0x0154) 11062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_WIN_SIZE (0x0158) 11162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_EXT_MODE (0x0160) 11262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_WIN_POS (0x0164) 11362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_WIN_SIZE (0x0168) 11462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_EXT_MODE (0x1918) 11562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_WIN_POS (0x191c) 11662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_WIN_SIZE (0x1920) 11762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_EXT_MODE (0x1958) 11862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_WIN_POS (0x195c) 11962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_WIN_SIZE (0x1960) 12062306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L0 (0x00B4) 12162306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L1 (0x0188) 12262306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L2 (0x018C) 12362306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L3 (0x0190) 12462306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L4 (0x0194) 12562306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L5 (0x0198) 12662306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L6 (0x1990) 12762306a36Sopenharmony_ci#define CARMINE_DISP_REG_BLEND_MODE_L7 (0x1994) 12862306a36Sopenharmony_ci#define CARMINE_DISP_REG_L0_TRANS (0x01A0) 12962306a36Sopenharmony_ci#define CARMINE_DISP_REG_L1_TRANS (0x01A4) 13062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L2_TRANS (0x01A8) 13162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L3_TRANS (0x01AC) 13262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L4_TRANS (0x01B0) 13362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L5_TRANS (0x01B4) 13462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_TRANS (0x1998) 13562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_TRANS (0x199c) 13662306a36Sopenharmony_ci#define CARMINE_EXTEND_MODE_MASK (0x00000003) 13762306a36Sopenharmony_ci#define CARMINE_DISP_DCM_MASK (0x0000FFFF) 13862306a36Sopenharmony_ci#define CARMINE_DISP_REG_DCM1 (0x0100) 13962306a36Sopenharmony_ci#define CARMINE_DISP_WIDTH_UNIT (64) 14062306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_MODE_W_H (0x1900) 14162306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_ORG_ADR1 (0x1904) 14262306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_DISP_ADR0 (0x1908) 14362306a36Sopenharmony_ci#define CARMINE_DISP_REG_L6_DISP_POS (0x1914) 14462306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_MODE_W_H (0x1940) 14562306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_ORG_ADR1 (0x1944) 14662306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_DISP_ADR0 (0x1948) 14762306a36Sopenharmony_ci#define CARMINE_DISP_REG_L7_DISP_POS (0x1954) 14862306a36Sopenharmony_ci#define CARMINE_CTL_REG_CLOCK_ENABLE (0x000C) 14962306a36Sopenharmony_ci#define CARMINE_CTL_REG_SOFTWARE_RESET (0x0010) 15062306a36Sopenharmony_ci#define CARMINE_CTL_REG_IST_MASK_ALL (0x07FFFFFF) 15162306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_VRINTM (0x00028064) 15262306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_VRERRM (0x0002806C) 15362306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_PX (0x0004005C) 15462306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_PY (0x00040060) 15562306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_LX (0x00040064) 15662306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_LY (0x00040068) 15762306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_TX (0x0004006C) 15862306a36Sopenharmony_ci#define CARMINE_GRAPH_REG_DC_OFFSET_TY (0x00040070) 15962306a36Sopenharmony_ci 16062306a36Sopenharmony_ci#endif 161