1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu #ifndef HI3660_H 7*91f16700Schasinglulu #define HI3660_H 8*91f16700Schasinglulu 9*91f16700Schasinglulu #include <hi3660_crg.h> 10*91f16700Schasinglulu #include <hi3660_hkadc.h> 11*91f16700Schasinglulu #include <hi3660_mem_map.h> 12*91f16700Schasinglulu 13*91f16700Schasinglulu #define ASP_CFG_REG_BASE 0xE804E000 14*91f16700Schasinglulu 15*91f16700Schasinglulu #define ASP_CFG_MMBUF_CTRL_REG (ASP_CFG_REG_BASE + 0x148) 16*91f16700Schasinglulu 17*91f16700Schasinglulu #define LP_RAM_BASE 0xFFF50000 18*91f16700Schasinglulu 19*91f16700Schasinglulu #define SCTRL_REG_BASE 0xFFF0A000 20*91f16700Schasinglulu 21*91f16700Schasinglulu #define SCTRL_CONTROL_REG (SCTRL_REG_BASE + 0x000) 22*91f16700Schasinglulu #define SCTRL_CONTROL_SYS_MODE(x) (((x) & 0xf) << 3) 23*91f16700Schasinglulu #define SCTRL_CONTROL_SYS_MODE_NORMAL ((1 << 2) << 3) 24*91f16700Schasinglulu #define SCTRL_CONTROL_SYS_MODE_SLOW ((1 << 1) << 3) 25*91f16700Schasinglulu #define SCTRL_CONTROL_SYS_MODE_MASK (0xf << 3) 26*91f16700Schasinglulu #define SCTRL_CONTROL_MODE_CTRL_NORMAL (1 << 2) 27*91f16700Schasinglulu #define SCTRL_CONTROL_MODE_CTRL_SLOW (1 << 1) 28*91f16700Schasinglulu #define SCTRL_CONTROL_MODE_CTRL_MASK 0x7 29*91f16700Schasinglulu 30*91f16700Schasinglulu #define SCTRL_SCSYSSTAT_REG (SCTRL_REG_BASE + 0x004) 31*91f16700Schasinglulu 32*91f16700Schasinglulu #define SCTRL_DEEPSLEEPED_REG (SCTRL_REG_BASE + 0x008) 33*91f16700Schasinglulu #define SCTRL_EFUSE_USB_MASK (1 << 30) 34*91f16700Schasinglulu #define SCTRL_EFUSE_USB_PLL (1 << 30) 35*91f16700Schasinglulu #define SCTRL_EFUSE_USB_ABB (0 << 30) 36*91f16700Schasinglulu #define SCTRL_EFUSE_UFS_MASK (3 << 6) 37*91f16700Schasinglulu #define SCTRL_EFUSE_UFS_PLL (1 << 6) 38*91f16700Schasinglulu #define SCTRL_EFUSE_UFS_ABB (0 << 6) 39*91f16700Schasinglulu 40*91f16700Schasinglulu #define SCTRL_SCISOEN_REG (SCTRL_REG_BASE + 0x040) 41*91f16700Schasinglulu #define SCTRL_SCISODIS_REG (SCTRL_REG_BASE + 0x044) 42*91f16700Schasinglulu #define SCISO_MMBUFISO (1 << 3) 43*91f16700Schasinglulu 44*91f16700Schasinglulu #define SCTRL_SCPWREN_REG (SCTRL_REG_BASE + 0x060) 45*91f16700Schasinglulu #define SCPWREN_MMBUFPWREN (1 << 3) 46*91f16700Schasinglulu 47*91f16700Schasinglulu #define SCTRL_PLL_CTRL0_REG (SCTRL_REG_BASE + 0x100) 48*91f16700Schasinglulu #define SCTRL_PLL0_POSTDIV2(x) (((x) & 0x7) << 23) 49*91f16700Schasinglulu #define SCTRL_PLL0_POSTDIV1(x) (((x) & 0x7) << 20) 50*91f16700Schasinglulu #define SCTRL_PLL0_FBDIV(x) (((x) & 0xfff) << 8) 51*91f16700Schasinglulu #define SCTRL_PLL0_REFDIV(x) (((x) & 0x3f) << 2) 52*91f16700Schasinglulu #define SCTRL_PLL0_EN (1 << 0) 53*91f16700Schasinglulu 54*91f16700Schasinglulu #define SCTRL_PLL_CTRL1_REG (SCTRL_REG_BASE + 0x104) 55*91f16700Schasinglulu #define SCTRL_PLL0_CLK_NO_GATE (1 << 26) 56*91f16700Schasinglulu #define SCTRL_PLL0_CFG_VLD (1 << 25) 57*91f16700Schasinglulu #define SCTRL_PLL0_FRACDIV(x) ((x) & 0xFFFFFF) 58*91f16700Schasinglulu 59*91f16700Schasinglulu #define SCTRL_PLL_STAT_REG (SCTRL_REG_BASE + 0x10C) 60*91f16700Schasinglulu #define SCTRL_PLL0_STAT (1 << 0) 61*91f16700Schasinglulu 62*91f16700Schasinglulu #define SCTRL_SCPEREN0_REG (SCTRL_REG_BASE + 0x160) 63*91f16700Schasinglulu #define SCTRL_SCPERDIS0_REG (SCTRL_REG_BASE + 0x164) 64*91f16700Schasinglulu #define SCTRL_SCPERSTAT0_REG (SCTRL_REG_BASE + 0x168) 65*91f16700Schasinglulu 66*91f16700Schasinglulu #define SCTRL_SCPEREN1_REG (SCTRL_REG_BASE + 0x170) 67*91f16700Schasinglulu #define SCTRL_SCPERDIS1_REG (SCTRL_REG_BASE + 0x174) 68*91f16700Schasinglulu #define SCTRL_SCPEREN1_REG (SCTRL_REG_BASE + 0x170) 69*91f16700Schasinglulu #define SCTRL_SCPERDIS1_REG (SCTRL_REG_BASE + 0x174) 70*91f16700Schasinglulu #define SCPEREN1_WAIT_DDR_SELFREFRESH_DONE_BYPASS (1u << 31) 71*91f16700Schasinglulu #define SCPEREN_GT_PCLK_MMBUFCFG (1 << 25) 72*91f16700Schasinglulu #define SCPEREN_GT_PCLK_MMBUF (1 << 23) 73*91f16700Schasinglulu #define SCPEREN_GT_ACLK_MMBUF (1 << 22) 74*91f16700Schasinglulu #define SCPEREN_GT_CLK_NOC_AOBUS2MMBUF (1 << 6) 75*91f16700Schasinglulu 76*91f16700Schasinglulu #define SCTRL_SCPEREN2_REG (SCTRL_REG_BASE + 0x190) 77*91f16700Schasinglulu #define SCTRL_SCPERDIS2_REG (SCTRL_REG_BASE + 0x194) 78*91f16700Schasinglulu #define SCTRL_SCPERSTAT2_REG (SCTRL_REG_BASE + 0x198) 79*91f16700Schasinglulu #define SCTRL_SCPERRSTEN0_REG (SCTRL_REG_BASE + 0x200) 80*91f16700Schasinglulu #define SCTRL_SCPERRSTDIS0_REG (SCTRL_REG_BASE + 0x204) 81*91f16700Schasinglulu #define SCTRL_SCPERRSTSTAT0_REG (SCTRL_REG_BASE + 0x208) 82*91f16700Schasinglulu #define SCTRL_SCPERRSTEN1_REG (SCTRL_REG_BASE + 0x20C) 83*91f16700Schasinglulu #define SCTRL_SCPERRSTDIS1_REG (SCTRL_REG_BASE + 0x210) 84*91f16700Schasinglulu #define SCTRL_SCPERRSTSTAT1_REG (SCTRL_REG_BASE + 0x214) 85*91f16700Schasinglulu #define IP_RST_MMBUFCFG (1 << 12) 86*91f16700Schasinglulu #define IP_RST_MMBUF (1 << 11) 87*91f16700Schasinglulu 88*91f16700Schasinglulu #define SCTRL_SCPERRSTEN2_REG (SCTRL_REG_BASE + 0x218) 89*91f16700Schasinglulu #define SCTRL_SCPERRSTDIS2_REG (SCTRL_REG_BASE + 0x21C) 90*91f16700Schasinglulu #define SCTRL_SCPERRSTSTAT2_REG (SCTRL_REG_BASE + 0x220) 91*91f16700Schasinglulu 92*91f16700Schasinglulu #define SCTRL_SCCLKDIV2_REG (SCTRL_REG_BASE + 0x258) 93*91f16700Schasinglulu #define SEL_CLK_MMBUF_MASK (0x3 << 8) 94*91f16700Schasinglulu #define SEL_CLK_MMBUF_PLL0 (0x3 << 8) 95*91f16700Schasinglulu #define SCCLKDIV2_GT_PCLK_MMBUF (1 << 7) 96*91f16700Schasinglulu 97*91f16700Schasinglulu #define SCTRL_SCCLKDIV4_REG (SCTRL_REG_BASE + 0x260) 98*91f16700Schasinglulu #define GT_MMBUF_SYS (1 << 13) 99*91f16700Schasinglulu #define GT_MMBUF_FLL (1 << 12) 100*91f16700Schasinglulu #define GT_PLL_CLK_MMBUF (1 << 11) 101*91f16700Schasinglulu 102*91f16700Schasinglulu #define SCTRL_SCCLKDIV6_REG (SCTRL_REG_BASE + 0x268) 103*91f16700Schasinglulu 104*91f16700Schasinglulu #define SCTRL_SCPERCTRL7_REG (SCTRL_REG_BASE + 0x31C) 105*91f16700Schasinglulu #define SCTRL_SCPERSTAT6_REG (SCTRL_REG_BASE + 0x378) 106*91f16700Schasinglulu 107*91f16700Schasinglulu #define SCTRL_SCINNERSTAT_REG (SCTRL_REG_BASE + 0x3A0) 108*91f16700Schasinglulu #define EMMC_UFS_SEL (1 << 15) 109*91f16700Schasinglulu 110*91f16700Schasinglulu #define SCTRL_BAK_DATA0_REG (SCTRL_REG_BASE + 0x40C) 111*91f16700Schasinglulu #define SCTRL_BAK_DATA4_REG (SCTRL_REG_BASE + 0x41C) 112*91f16700Schasinglulu 113*91f16700Schasinglulu #define SCTRL_LPMCU_CLKEN_REG (SCTRL_REG_BASE + 0x480) 114*91f16700Schasinglulu #define SCTRL_LPMCU_CLKDIS_REG (SCTRL_REG_BASE + 0x484) 115*91f16700Schasinglulu #define SCTRL_LPMCU_RSTEN_REG (SCTRL_REG_BASE + 0x500) 116*91f16700Schasinglulu #define SCTRL_LPMCU_RSTDIS_REG (SCTRL_REG_BASE + 0x504) 117*91f16700Schasinglulu #define DDRC_SOFT_BIT (1 << 6) 118*91f16700Schasinglulu #define DDRC_CLK_BIT (1 << 5) 119*91f16700Schasinglulu 120*91f16700Schasinglulu #define SCTRL_SCPEREN0_SEC_REG (SCTRL_REG_BASE + 0x900) 121*91f16700Schasinglulu #define SCTRL_SCPERDIS0_SEC_REG (SCTRL_REG_BASE + 0x904) 122*91f16700Schasinglulu #define MMBUF_SEC_CTRL_MASK (0xfff << 20) 123*91f16700Schasinglulu #define MMBUF_SEC_CTRL(x) (((x) & 0xfff) << 20) 124*91f16700Schasinglulu 125*91f16700Schasinglulu #define SCTRL_PERRSTEN1_SEC_REG (SCTRL_REG_BASE + 0xA50) 126*91f16700Schasinglulu #define SCTRL_PERRSTDIS1_SEC_REG (SCTRL_REG_BASE + 0xA54) 127*91f16700Schasinglulu #define SCTRL_PERRSTSTAT1_SEC_REG (SCTRL_REG_BASE + 0xA58) 128*91f16700Schasinglulu #define RST_ASP_SUBSYS_BIT (1 << 0) 129*91f16700Schasinglulu 130*91f16700Schasinglulu #define SCTRL_PERRSTEN2_SEC_REG (SCTRL_REG_BASE + 0xB50) 131*91f16700Schasinglulu #define SCTRL_PERRSTDIS2_SEC_REG (SCTRL_REG_BASE + 0xB54) 132*91f16700Schasinglulu #define SCTRL_PERRSTSTAT2_SEC_REG (SCTRL_REG_BASE + 0xB58) 133*91f16700Schasinglulu 134*91f16700Schasinglulu #define SCTRL_HISEECLKDIV_REG (SCTRL_REG_BASE + 0xC28) 135*91f16700Schasinglulu #define SC_SEL_HISEE_PLL_MASK (1 << 4) 136*91f16700Schasinglulu #define SC_SEL_HISEE_PLL0 (1 << 4) 137*91f16700Schasinglulu #define SC_SEL_HISEE_PLL2 (0 << 4) 138*91f16700Schasinglulu #define SC_DIV_HISEE_PLL_MASK (7 << 16) 139*91f16700Schasinglulu #define SC_DIV_HISEE_PLL(x) ((x) & 0x7) 140*91f16700Schasinglulu 141*91f16700Schasinglulu #define SCTRL_SCSOCID0_REG (SCTRL_REG_BASE + 0xE00) 142*91f16700Schasinglulu 143*91f16700Schasinglulu #define PMC_REG_BASE 0xFFF31000 144*91f16700Schasinglulu #define PMC_PPLL1_CTRL0_REG (PMC_REG_BASE + 0x038) 145*91f16700Schasinglulu #define PMC_PPLL1_CTRL1_REG (PMC_REG_BASE + 0x03C) 146*91f16700Schasinglulu #define PMC_PPLL2_CTRL0_REG (PMC_REG_BASE + 0x040) 147*91f16700Schasinglulu #define PMC_PPLL2_CTRL1_REG (PMC_REG_BASE + 0x044) 148*91f16700Schasinglulu #define PMC_PPLL3_CTRL0_REG (PMC_REG_BASE + 0x048) 149*91f16700Schasinglulu #define PMC_PPLL3_CTRL1_REG (PMC_REG_BASE + 0x04C) 150*91f16700Schasinglulu #define PPLLx_LOCK (1 << 26) 151*91f16700Schasinglulu #define PPLLx_WITHOUT_CLK_GATE (1 << 26) 152*91f16700Schasinglulu #define PPLLx_CFG_VLD (1 << 25) 153*91f16700Schasinglulu #define PPLLx_INT_MOD (1 << 24) 154*91f16700Schasinglulu #define PPLLx_POSTDIV2_MASK (0x7 << 23) 155*91f16700Schasinglulu #define PPLLx_POSTDIV2(x) (((x) & 0x7) << 23) 156*91f16700Schasinglulu #define PPLLx_POSTDIV1_MASK (0x7 << 20) 157*91f16700Schasinglulu #define PPLLx_POSTDIV1(x) (((x) & 0x7) << 20) 158*91f16700Schasinglulu #define PPLLx_FRACDIV_MASK (0x00FFFFFF) 159*91f16700Schasinglulu #define PPLLx_FRACDIV(x) ((x) & 0x00FFFFFF) 160*91f16700Schasinglulu #define PPLLx_FBDIV_MASK (0xfff << 8) 161*91f16700Schasinglulu #define PPLLx_FBDIV(x) (((x) & 0xfff) << 8) 162*91f16700Schasinglulu #define PPLLx_REFDIV_MASK (0x3f << 2) 163*91f16700Schasinglulu #define PPLLx_REFDIV(x) (((x) & 0x3f) << 2) 164*91f16700Schasinglulu #define PPLLx_BP (1 << 1) 165*91f16700Schasinglulu #define PPLLx_EN (1 << 0) 166*91f16700Schasinglulu 167*91f16700Schasinglulu #define PMC_DDRLP_CTRL_REG (PMC_REG_BASE + 0x30C) 168*91f16700Schasinglulu #define DDRC_CSYSREQ_CFG(x) ((x) & 0xF) 169*91f16700Schasinglulu 170*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_REG (PMC_REG_BASE + 0x380) 171*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_IVP (1 << 14) 172*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_DSS (1 << 13) 173*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_VENC (1 << 11) 174*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_VDEC (1 << 10) 175*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_ISP (1 << 5) 176*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEREQ_VCODEC (1 << 4) 177*91f16700Schasinglulu #define DDRPHY_BYPASS_MODE (1 << 0) 178*91f16700Schasinglulu 179*91f16700Schasinglulu #define PMC_NOC_POWER_IDLEACK_REG (PMC_REG_BASE + 0x384) 180*91f16700Schasinglulu #define PMC_NOC_POWER_IDLE_REG (PMC_REG_BASE + 0x388) 181*91f16700Schasinglulu 182*91f16700Schasinglulu #define PMU_SSI0_REG_BASE 0xFFF34000 183*91f16700Schasinglulu 184*91f16700Schasinglulu #define PMU_SSI0_LDO8_CTRL0_REG (PMU_SSI0_REG_BASE + (0x68 << 2)) 185*91f16700Schasinglulu #define LDO8_CTRL0_EN_1_8V 0x02 186*91f16700Schasinglulu 187*91f16700Schasinglulu #define PMU_SSI0_CLK_TOP_CTRL7_REG (PMU_SSI0_REG_BASE + (0x10C << 2)) 188*91f16700Schasinglulu #define NP_XO_ABB_DIG (1 << 1) 189*91f16700Schasinglulu 190*91f16700Schasinglulu #define LP_CONFIG_REG_BASE 0xFFF3F000 191*91f16700Schasinglulu 192*91f16700Schasinglulu #define DMAC_BASE 0xFDF30000 193*91f16700Schasinglulu 194*91f16700Schasinglulu #define CCI400_REG_BASE 0xE8100000 195*91f16700Schasinglulu #define CCI400_SL_IFACE3_CLUSTER_IX 0 196*91f16700Schasinglulu #define CCI400_SL_IFACE4_CLUSTER_IX 1 197*91f16700Schasinglulu 198*91f16700Schasinglulu #define GICD_REG_BASE 0xE82B1000 199*91f16700Schasinglulu #define GICC_REG_BASE 0xE82B2000 200*91f16700Schasinglulu /* 201*91f16700Schasinglulu * GIC400 interrupt handling related constants 202*91f16700Schasinglulu */ 203*91f16700Schasinglulu #define IRQ_SEC_PHY_TIMER 29 204*91f16700Schasinglulu #define IRQ_SEC_SGI_0 8 205*91f16700Schasinglulu #define IRQ_SEC_SGI_1 9 206*91f16700Schasinglulu #define IRQ_SEC_SGI_2 10 207*91f16700Schasinglulu #define IRQ_SEC_SGI_3 11 208*91f16700Schasinglulu #define IRQ_SEC_SGI_4 12 209*91f16700Schasinglulu #define IRQ_SEC_SGI_5 13 210*91f16700Schasinglulu #define IRQ_SEC_SGI_6 14 211*91f16700Schasinglulu #define IRQ_SEC_SGI_7 15 212*91f16700Schasinglulu #define IRQ_SEC_SGI_8 16 213*91f16700Schasinglulu 214*91f16700Schasinglulu #define IPC_REG_BASE 0xE896A000 215*91f16700Schasinglulu #define IPC_BASE (IPC_REG_BASE) 216*91f16700Schasinglulu 217*91f16700Schasinglulu #define IOMG_REG_BASE 0xE896C000 218*91f16700Schasinglulu 219*91f16700Schasinglulu /* GPIO46: HUB 3.3V enable. active low */ 220*91f16700Schasinglulu #define IOMG_044_REG (IOMG_REG_BASE + 0x0B0) 221*91f16700Schasinglulu #define IOMG_UART5_RX_REG (IOMG_REG_BASE + 0x0BC) 222*91f16700Schasinglulu #define IOMG_UART5_TX_REG (IOMG_REG_BASE + 0x0C0) 223*91f16700Schasinglulu 224*91f16700Schasinglulu #define IOCG_REG_BASE 0xE896C800 225*91f16700Schasinglulu 226*91f16700Schasinglulu /* GPIO005: PMIC SSI. (2 << 4) */ 227*91f16700Schasinglulu #define IOCG_006_REG (IOCG_REG_BASE + 0x018) 228*91f16700Schasinglulu 229*91f16700Schasinglulu #define TIMER9_REG_BASE 0xE8A00000 230*91f16700Schasinglulu 231*91f16700Schasinglulu #define WDT0_REG_BASE 0xE8A06000 232*91f16700Schasinglulu #define WDT1_REG_BASE 0xE8A07000 233*91f16700Schasinglulu #define WDT_CONTROL_OFFSET 0x008 234*91f16700Schasinglulu #define WDT_LOCK_OFFSET 0xC00 235*91f16700Schasinglulu 236*91f16700Schasinglulu #define WDT_UNLOCK 0x1ACCE551 237*91f16700Schasinglulu #define WDT_LOCKED 1 238*91f16700Schasinglulu 239*91f16700Schasinglulu #define PCTRL_REG_BASE 0xE8A09000 240*91f16700Schasinglulu #define PCTRL_PERI_CTRL3_REG (PCTRL_REG_BASE + 0x010) 241*91f16700Schasinglulu #define PCTRL_PERI_CTRL24_REG (PCTRL_REG_BASE + 0x064) 242*91f16700Schasinglulu 243*91f16700Schasinglulu #define GPIO0_BASE UL(0xE8A0B000) 244*91f16700Schasinglulu #define GPIO1_BASE UL(0xE8A0C000) 245*91f16700Schasinglulu #define GPIO2_BASE UL(0xE8A0D000) 246*91f16700Schasinglulu #define GPIO3_BASE UL(0xE8A0E000) 247*91f16700Schasinglulu #define GPIO4_BASE UL(0xE8A0F000) 248*91f16700Schasinglulu #define GPIO5_BASE UL(0xE8A10000) 249*91f16700Schasinglulu #define GPIO6_BASE UL(0xE8A11000) 250*91f16700Schasinglulu #define GPIO7_BASE UL(0xE8A12000) 251*91f16700Schasinglulu #define GPIO8_BASE UL(0xE8A13000) 252*91f16700Schasinglulu #define GPIO9_BASE UL(0xE8A14000) 253*91f16700Schasinglulu #define GPIO10_BASE UL(0xE8A15000) 254*91f16700Schasinglulu #define GPIO11_BASE UL(0xE8A16000) 255*91f16700Schasinglulu #define GPIO12_BASE UL(0xE8A17000) 256*91f16700Schasinglulu #define GPIO13_BASE UL(0xE8A18000) 257*91f16700Schasinglulu #define GPIO14_BASE UL(0xE8A19000) 258*91f16700Schasinglulu #define GPIO15_BASE UL(0xE8A1A000) 259*91f16700Schasinglulu #define GPIO16_BASE UL(0xE8A1B000) 260*91f16700Schasinglulu #define GPIO17_BASE UL(0xE8A1C000) 261*91f16700Schasinglulu #define GPIO20_BASE UL(0xE8A1F000) 262*91f16700Schasinglulu #define GPIO21_BASE UL(0xE8A20000) 263*91f16700Schasinglulu #define GPIO22_BASE UL(0xFFF0B000) 264*91f16700Schasinglulu #define GPIO23_BASE UL(0xFFF0C000) 265*91f16700Schasinglulu #define GPIO24_BASE UL(0xFFF0D000) 266*91f16700Schasinglulu #define GPIO25_BASE UL(0xFFF0E000) 267*91f16700Schasinglulu #define GPIO26_BASE UL(0xFFF0F000) 268*91f16700Schasinglulu #define GPIO27_BASE UL(0xFFF10000) 269*91f16700Schasinglulu #define GPIO28_BASE UL(0xFFF1D000) 270*91f16700Schasinglulu 271*91f16700Schasinglulu #define TZC_REG_BASE 0xE8A21000 272*91f16700Schasinglulu #define TZC_STAT0_REG (TZC_REG_BASE + 0x800) 273*91f16700Schasinglulu #define TZC_EN0_REG (TZC_REG_BASE + 0x804) 274*91f16700Schasinglulu #define TZC_DIS0_REG (TZC_REG_BASE + 0x808) 275*91f16700Schasinglulu #define TZC_STAT1_REG (TZC_REG_BASE + 0x80C) 276*91f16700Schasinglulu #define TZC_EN1_REG (TZC_REG_BASE + 0x810) 277*91f16700Schasinglulu #define TZC_DIS1_REG (TZC_REG_BASE + 0x814) 278*91f16700Schasinglulu #define TZC_STAT2_REG (TZC_REG_BASE + 0x818) 279*91f16700Schasinglulu #define TZC_EN2_REG (TZC_REG_BASE + 0x81C) 280*91f16700Schasinglulu #define TZC_DIS2_REG (TZC_REG_BASE + 0x820) 281*91f16700Schasinglulu #define TZC_STAT3_REG (TZC_REG_BASE + 0x824) 282*91f16700Schasinglulu #define TZC_EN3_REG (TZC_REG_BASE + 0x828) 283*91f16700Schasinglulu #define TZC_DIS3_REG (TZC_REG_BASE + 0x82C) 284*91f16700Schasinglulu #define TZC_STAT4_REG (TZC_REG_BASE + 0x830) 285*91f16700Schasinglulu #define TZC_EN4_REG (TZC_REG_BASE + 0x834) 286*91f16700Schasinglulu #define TZC_DIS4_REG (TZC_REG_BASE + 0x838) 287*91f16700Schasinglulu #define TZC_STAT5_REG (TZC_REG_BASE + 0x83C) 288*91f16700Schasinglulu #define TZC_EN5_REG (TZC_REG_BASE + 0x840) 289*91f16700Schasinglulu #define TZC_DIS5_REG (TZC_REG_BASE + 0x844) 290*91f16700Schasinglulu #define TZC_STAT6_REG (TZC_REG_BASE + 0x848) 291*91f16700Schasinglulu #define TZC_EN6_REG (TZC_REG_BASE + 0x84C) 292*91f16700Schasinglulu #define TZC_DIS6_REG (TZC_REG_BASE + 0x850) 293*91f16700Schasinglulu #define TZC_STAT7_REG (TZC_REG_BASE + 0x854) 294*91f16700Schasinglulu #define TZC_EN7_REG (TZC_REG_BASE + 0x858) 295*91f16700Schasinglulu #define TZC_DIS7_REG (TZC_REG_BASE + 0x85C) 296*91f16700Schasinglulu #define TZC_STAT8_REG (TZC_REG_BASE + 0x860) 297*91f16700Schasinglulu #define TZC_EN8_REG (TZC_REG_BASE + 0x864) 298*91f16700Schasinglulu #define TZC_DIS8_REG (TZC_REG_BASE + 0x868) 299*91f16700Schasinglulu 300*91f16700Schasinglulu #define MMBUF_BASE 0xEA800000 301*91f16700Schasinglulu 302*91f16700Schasinglulu #define ACPU_DMCPACK0_BASE 0xEA900000 303*91f16700Schasinglulu 304*91f16700Schasinglulu #define ACPU_DMCPACK1_BASE 0xEA920000 305*91f16700Schasinglulu 306*91f16700Schasinglulu #define ACPU_DMCPACK2_BASE 0xEA940000 307*91f16700Schasinglulu 308*91f16700Schasinglulu #define ACPU_DMCPACK3_BASE 0xEA960000 309*91f16700Schasinglulu 310*91f16700Schasinglulu #define UART5_REG_BASE 0xFDF05000 311*91f16700Schasinglulu 312*91f16700Schasinglulu #define USB3OTG_REG_BASE 0xFF100000 313*91f16700Schasinglulu 314*91f16700Schasinglulu #define UFS_REG_BASE 0xFF3B0000 315*91f16700Schasinglulu 316*91f16700Schasinglulu #define UFS_SYS_REG_BASE 0xFF3B1000 317*91f16700Schasinglulu 318*91f16700Schasinglulu #define UFS_SYS_PSW_POWER_CTRL_REG (UFS_SYS_REG_BASE + 0x004) 319*91f16700Schasinglulu #define UFS_SYS_PHY_ISO_EN_REG (UFS_SYS_REG_BASE + 0x008) 320*91f16700Schasinglulu #define UFS_SYS_HC_LP_CTRL_REG (UFS_SYS_REG_BASE + 0x00C) 321*91f16700Schasinglulu #define UFS_SYS_PHY_CLK_CTRL_REG (UFS_SYS_REG_BASE + 0x010) 322*91f16700Schasinglulu #define UFS_SYS_PSW_CLK_CTRL_REG (UFS_SYS_REG_BASE + 0x014) 323*91f16700Schasinglulu #define UFS_SYS_CLOCK_GATE_BYPASS_REG (UFS_SYS_REG_BASE + 0x018) 324*91f16700Schasinglulu #define UFS_SYS_RESET_CTRL_EN_REG (UFS_SYS_REG_BASE + 0x01C) 325*91f16700Schasinglulu #define UFS_SYS_MONITOR_HH_REG (UFS_SYS_REG_BASE + 0x03C) 326*91f16700Schasinglulu #define UFS_SYS_UFS_SYSCTRL_REG (UFS_SYS_REG_BASE + 0x05C) 327*91f16700Schasinglulu #define UFS_SYS_UFS_DEVICE_RESET_CTRL_REG (UFS_SYS_REG_BASE + 0x060) 328*91f16700Schasinglulu #define UFS_SYS_UFS_APB_ADDR_MASK_REG (UFS_SYS_REG_BASE + 0x064) 329*91f16700Schasinglulu 330*91f16700Schasinglulu #define BIT_UFS_PSW_ISO_CTRL (1 << 16) 331*91f16700Schasinglulu #define BIT_UFS_PSW_MTCMOS_EN (1 << 0) 332*91f16700Schasinglulu #define BIT_UFS_REFCLK_ISO_EN (1 << 16) 333*91f16700Schasinglulu #define BIT_UFS_PHY_ISO_CTRL (1 << 0) 334*91f16700Schasinglulu #define BIT_SYSCTRL_LP_ISOL_EN (1 << 16) 335*91f16700Schasinglulu #define BIT_SYSCTRL_PWR_READY (1 << 8) 336*91f16700Schasinglulu #define BIT_SYSCTRL_REF_CLOCK_EN (1 << 24) 337*91f16700Schasinglulu #define MASK_SYSCTRL_REF_CLOCK_SEL (3 << 8) 338*91f16700Schasinglulu #define MASK_SYSCTRL_CFG_CLOCK_FREQ (0xFF) 339*91f16700Schasinglulu #define BIT_SYSCTRL_PSW_CLK_EN (1 << 4) 340*91f16700Schasinglulu #define MASK_UFS_CLK_GATE_BYPASS (0x3F) 341*91f16700Schasinglulu #define BIT_SYSCTRL_LP_RESET_N (1 << 0) 342*91f16700Schasinglulu #define BIT_UFS_REFCLK_SRC_SE1 (1 << 0) 343*91f16700Schasinglulu #define MASK_UFS_SYSCTRL_BYPASS (0x3F << 16) 344*91f16700Schasinglulu #define MASK_UFS_DEVICE_RESET (1 << 16) 345*91f16700Schasinglulu #define BIT_UFS_DEVICE_RESET (1 << 0) 346*91f16700Schasinglulu 347*91f16700Schasinglulu #define GPIO18_BASE UL(0xFF3B4000) 348*91f16700Schasinglulu #define GPIO19_BASE UL(0xFF3B5000) 349*91f16700Schasinglulu 350*91f16700Schasinglulu #define IOMG_FIX_REG_BASE 0xFF3B6000 351*91f16700Schasinglulu 352*91f16700Schasinglulu /* GPIO150: LED */ 353*91f16700Schasinglulu #define IOMG_FIX_006_REG (IOMG_FIX_REG_BASE + 0x018) 354*91f16700Schasinglulu /* GPIO151: LED */ 355*91f16700Schasinglulu #define IOMG_FIX_007_REG (IOMG_FIX_REG_BASE + 0x01C) 356*91f16700Schasinglulu 357*91f16700Schasinglulu #define IOMG_AO_REG_BASE 0xFFF11000 358*91f16700Schasinglulu 359*91f16700Schasinglulu /* GPIO189: LED */ 360*91f16700Schasinglulu #define IOMG_AO_011_REG (IOMG_AO_REG_BASE + 0x02C) 361*91f16700Schasinglulu /* GPIO190: LED */ 362*91f16700Schasinglulu #define IOMG_AO_012_REG (IOMG_AO_REG_BASE + 0x030) 363*91f16700Schasinglulu /* GPIO202: type C enable. active low */ 364*91f16700Schasinglulu #define IOMG_AO_023_REG (IOMG_AO_REG_BASE + 0x05C) 365*91f16700Schasinglulu /* GPIO206: USB switch. active low */ 366*91f16700Schasinglulu #define IOMG_AO_026_REG (IOMG_AO_REG_BASE + 0x068) 367*91f16700Schasinglulu /* GPIO219: PD interrupt. pull up */ 368*91f16700Schasinglulu #define IOMG_AO_039_REG (IOMG_AO_REG_BASE + 0x09C) 369*91f16700Schasinglulu /* GPIO213: PCIE_CLKREQ_N */ 370*91f16700Schasinglulu #define IOMG_AO_033_REG (IOMG_AO_REG_BASE + 0x084) 371*91f16700Schasinglulu 372*91f16700Schasinglulu #define IOCG_AO_REG_BASE 0xFFF1187C 373*91f16700Schasinglulu /* GPIO219: PD interrupt. pull up */ 374*91f16700Schasinglulu #define IOCG_AO_043_REG (IOCG_AO_REG_BASE + 0x030) 375*91f16700Schasinglulu 376*91f16700Schasinglulu #define EDMAC_BASE 0xfdf30000 377*91f16700Schasinglulu #define EDMAC_SEC_CTRL (EDMAC_BASE + 0x694) 378*91f16700Schasinglulu #define EDMAC_AXI_CONF(x) (EDMAC_BASE + 0x820 + (x << 6)) 379*91f16700Schasinglulu #define EDMAC_SEC_CTRL_INTR_SEC (1 << 1) 380*91f16700Schasinglulu #define EDMAC_SEC_CTRL_GLOBAL_SEC (1 << 0) 381*91f16700Schasinglulu #define EDMAC_CHANNEL_NUMS 16 382*91f16700Schasinglulu 383*91f16700Schasinglulu #define IOMCU_DMAC_BASE 0xffd77000 384*91f16700Schasinglulu #define IOMCU_DMAC_SEC_CTRL (IOMCU_DMAC_BASE + 0x694) 385*91f16700Schasinglulu #define IOMCU_DMAC_AXI_CONF(x) (IOMCU_DMAC_BASE + 0x820 + ((x) << 6)) 386*91f16700Schasinglulu #define IOMCU_DMAC_AXI_CONF_ARPROT_NS (1 << 6) 387*91f16700Schasinglulu #define IOMCU_DMAC_AXI_CONF_AWPROT_NS (1 << 18) 388*91f16700Schasinglulu #define IOMCU_DMAC_SEC_CTRL_INTR_SEC (1 << 1) 389*91f16700Schasinglulu #define IOMCU_DMAC_SEC_CTRL_GLOBAL_SEC (1 << 0) 390*91f16700Schasinglulu #define IOMCU_DMAC_CHANNEL_NUMS 8 391*91f16700Schasinglulu 392*91f16700Schasinglulu #endif /* HI3660_H */ 393