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