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_CRG_H 7*91f16700Schasinglulu #define HI3660_CRG_H 8*91f16700Schasinglulu 9*91f16700Schasinglulu #define CRG_REG_BASE 0xFFF35000 10*91f16700Schasinglulu 11*91f16700Schasinglulu #define CRG_PEREN0_REG (CRG_REG_BASE + 0x000) 12*91f16700Schasinglulu #define CRG_PERDIS0_REG (CRG_REG_BASE + 0x004) 13*91f16700Schasinglulu #define CRG_PERSTAT0_REG (CRG_REG_BASE + 0x008) 14*91f16700Schasinglulu #define PEREN0_GT_CLK_AOMM (1U << 31) 15*91f16700Schasinglulu 16*91f16700Schasinglulu #define CRG_PEREN1_REG (CRG_REG_BASE + 0x010) 17*91f16700Schasinglulu #define CRG_PERDIS1_REG (CRG_REG_BASE + 0x014) 18*91f16700Schasinglulu #define CRG_PERSTAT1_REG (CRG_REG_BASE + 0x018) 19*91f16700Schasinglulu #define CRG_PEREN2_REG (CRG_REG_BASE + 0x020) 20*91f16700Schasinglulu #define CRG_PERDIS2_REG (CRG_REG_BASE + 0x024) 21*91f16700Schasinglulu #define CRG_PERSTAT2_REG (CRG_REG_BASE + 0x028) 22*91f16700Schasinglulu #define PEREN2_HKADCSSI (1 << 24) 23*91f16700Schasinglulu 24*91f16700Schasinglulu #define CRG_PEREN3_REG (CRG_REG_BASE + 0x030) 25*91f16700Schasinglulu #define CRG_PERDIS3_REG (CRG_REG_BASE + 0x034) 26*91f16700Schasinglulu 27*91f16700Schasinglulu #define CRG_PEREN4_REG (CRG_REG_BASE + 0x040) 28*91f16700Schasinglulu #define CRG_PERDIS4_REG (CRG_REG_BASE + 0x044) 29*91f16700Schasinglulu #define CRG_PERCLKEN4_REG (CRG_REG_BASE + 0x048) 30*91f16700Schasinglulu #define CRG_PERSTAT4_REG (CRG_REG_BASE + 0x04C) 31*91f16700Schasinglulu #define GT_ACLK_USB3OTG (1 << 1) 32*91f16700Schasinglulu #define GT_CLK_USB3OTG_REF (1 << 0) 33*91f16700Schasinglulu 34*91f16700Schasinglulu #define CRG_PEREN5_REG (CRG_REG_BASE + 0x050) 35*91f16700Schasinglulu #define CRG_PERDIS5_REG (CRG_REG_BASE + 0x054) 36*91f16700Schasinglulu #define CRG_PERSTAT5_REG (CRG_REG_BASE + 0x058) 37*91f16700Schasinglulu #define CRG_PERRSTEN0_REG (CRG_REG_BASE + 0x060) 38*91f16700Schasinglulu #define CRG_PERRSTDIS0_REG (CRG_REG_BASE + 0x064) 39*91f16700Schasinglulu #define CRG_PERRSTSTAT0_REG (CRG_REG_BASE + 0x068) 40*91f16700Schasinglulu #define CRG_PERRSTEN1_REG (CRG_REG_BASE + 0x06C) 41*91f16700Schasinglulu #define CRG_PERRSTDIS1_REG (CRG_REG_BASE + 0x070) 42*91f16700Schasinglulu #define CRG_PERRSTSTAT1_REG (CRG_REG_BASE + 0x074) 43*91f16700Schasinglulu #define CRG_PERRSTEN2_REG (CRG_REG_BASE + 0x078) 44*91f16700Schasinglulu #define CRG_PERRSTDIS2_REG (CRG_REG_BASE + 0x07C) 45*91f16700Schasinglulu #define CRG_PERRSTSTAT2_REG (CRG_REG_BASE + 0x080) 46*91f16700Schasinglulu #define PERRSTEN2_HKADCSSI (1 << 24) 47*91f16700Schasinglulu 48*91f16700Schasinglulu #define CRG_PERRSTEN3_REG (CRG_REG_BASE + 0x084) 49*91f16700Schasinglulu #define CRG_PERRSTDIS3_REG (CRG_REG_BASE + 0x088) 50*91f16700Schasinglulu #define CRG_PERRSTSTAT3_REG (CRG_REG_BASE + 0x08C) 51*91f16700Schasinglulu #define CRG_PERRSTEN4_REG (CRG_REG_BASE + 0x090) 52*91f16700Schasinglulu #define CRG_PERRSTDIS4_REG (CRG_REG_BASE + 0x094) 53*91f16700Schasinglulu #define CRG_PERRSTSTAT4_REG (CRG_REG_BASE + 0x098) 54*91f16700Schasinglulu #define IP_RST_USB3OTG_MUX (1 << 8) 55*91f16700Schasinglulu #define IP_RST_USB3OTG_AHBIF (1 << 7) 56*91f16700Schasinglulu #define IP_RST_USB3OTG_32K (1 << 6) 57*91f16700Schasinglulu #define IP_RST_USB3OTG (1 << 5) 58*91f16700Schasinglulu #define IP_RST_USB3OTGPHY_POR (1 << 3) 59*91f16700Schasinglulu 60*91f16700Schasinglulu #define CRG_PERRSTEN5_REG (CRG_REG_BASE + 0x09C) 61*91f16700Schasinglulu #define CRG_PERRSTDIS5_REG (CRG_REG_BASE + 0x0A0) 62*91f16700Schasinglulu #define CRG_PERRSTSTAT5_REG (CRG_REG_BASE + 0x0A4) 63*91f16700Schasinglulu 64*91f16700Schasinglulu /* bit fields in CRG_PERI */ 65*91f16700Schasinglulu #define PERI_PCLK_PCTRL_BIT (1U << 31) 66*91f16700Schasinglulu #define PERI_TIMER12_BIT (1 << 25) 67*91f16700Schasinglulu #define PERI_TIMER11_BIT (1 << 24) 68*91f16700Schasinglulu #define PERI_TIMER10_BIT (1 << 23) 69*91f16700Schasinglulu #define PERI_TIMER9_BIT (1 << 22) 70*91f16700Schasinglulu #define PERI_UART5_BIT (1 << 15) 71*91f16700Schasinglulu #define PERI_UFS_BIT (1 << 12) 72*91f16700Schasinglulu #define PERI_ARST_UFS_BIT (1 << 7) 73*91f16700Schasinglulu #define PERI_PPLL2_EN_CPU (1 << 3) 74*91f16700Schasinglulu #define PERI_PWM_BIT (1 << 0) 75*91f16700Schasinglulu #define PERI_DDRC_BIT (1 << 0) 76*91f16700Schasinglulu #define PERI_DDRC_D_BIT (1 << 4) 77*91f16700Schasinglulu #define PERI_DDRC_C_BIT (1 << 3) 78*91f16700Schasinglulu #define PERI_DDRC_B_BIT (1 << 2) 79*91f16700Schasinglulu #define PERI_DDRC_A_BIT (1 << 1) 80*91f16700Schasinglulu #define PERI_DDRC_DMUX_BIT (1 << 0) 81*91f16700Schasinglulu 82*91f16700Schasinglulu #define CRG_CLKDIV0_REG (CRG_REG_BASE + 0x0A0) 83*91f16700Schasinglulu #define SC_DIV_LPMCU_MASK ((0x1F << 5) << 16) 84*91f16700Schasinglulu #define SC_DIV_LPMCU(x) (((x) & 0x1F) << 5) 85*91f16700Schasinglulu 86*91f16700Schasinglulu #define CRG_CLKDIV1_REG (CRG_REG_BASE + 0x0B0) 87*91f16700Schasinglulu #define SEL_LPMCU_PLL_MASK ((1 << 1) << 16) 88*91f16700Schasinglulu #define SEL_SYSBUS_MASK ((1 << 0) << 16) 89*91f16700Schasinglulu #define SEL_LPMCU_PLL1 (1 << 1) 90*91f16700Schasinglulu #define SEL_LPMCU_PLL0 (0 << 1) 91*91f16700Schasinglulu #define SEL_SYSBUS_PLL0 (1 << 0) 92*91f16700Schasinglulu #define SEL_SYSBUS_PLL1 (0 << 0) 93*91f16700Schasinglulu 94*91f16700Schasinglulu #define CRG_CLKDIV3_REG (CRG_REG_BASE + 0x0B4) 95*91f16700Schasinglulu #define CRG_CLKDIV5_REG (CRG_REG_BASE + 0x0BC) 96*91f16700Schasinglulu #define CRG_CLKDIV8_REG (CRG_REG_BASE + 0x0C8) 97*91f16700Schasinglulu 98*91f16700Schasinglulu #define CRG_CLKDIV12_REG (CRG_REG_BASE + 0x0D8) 99*91f16700Schasinglulu #define SC_DIV_A53HPM_MASK (0x7 << 13) 100*91f16700Schasinglulu #define SC_DIV_A53HPM(x) (((x) & 0x7) << 13) 101*91f16700Schasinglulu 102*91f16700Schasinglulu #define CRG_CLKDIV16_REG (CRG_REG_BASE + 0x0E8) 103*91f16700Schasinglulu #define DDRC_CLK_SW_REQ_CFG_MASK (0x3 << 12) 104*91f16700Schasinglulu #define DDRC_CLK_SW_REQ_CFG(x) (((x) & 0x3) << 12) 105*91f16700Schasinglulu #define SC_DIV_UFSPHY_CFG_MASK (0x3 << 9) 106*91f16700Schasinglulu #define SC_DIV_UFSPHY_CFG(x) (((x) & 0x3) << 9) 107*91f16700Schasinglulu #define DDRCPLL_SW (1 << 8) 108*91f16700Schasinglulu 109*91f16700Schasinglulu #define CRG_CLKDIV17_REG (CRG_REG_BASE + 0x0EC) 110*91f16700Schasinglulu #define SC_DIV_UFS_PERIBUS (1 << 14) 111*91f16700Schasinglulu 112*91f16700Schasinglulu #define CRG_CLKDIV18_REG (CRG_REG_BASE + 0x0F0) 113*91f16700Schasinglulu #define CRG_CLKDIV19_REG (CRG_REG_BASE + 0x0F4) 114*91f16700Schasinglulu #define CRG_CLKDIV20_REG (CRG_REG_BASE + 0x0F8) 115*91f16700Schasinglulu #define CLKDIV20_GT_CLK_AOMM (1 << 3) 116*91f16700Schasinglulu 117*91f16700Schasinglulu #define CRG_CLKDIV22_REG (CRG_REG_BASE + 0x100) 118*91f16700Schasinglulu #define SEL_PLL_320M_MASK (1 << 16) 119*91f16700Schasinglulu #define SEL_PLL2_320M (1 << 0) 120*91f16700Schasinglulu #define SEL_PLL0_320M (0 << 0) 121*91f16700Schasinglulu 122*91f16700Schasinglulu #define CRG_CLKDIV23_REG (CRG_REG_BASE + 0x104) 123*91f16700Schasinglulu #define PERI_DDRC_SW_BIT (1 << 13) 124*91f16700Schasinglulu #define DIV_CLK_DDRSYS_MASK (0x3 << 10) 125*91f16700Schasinglulu #define DIV_CLK_DDRSYS(x) (((x) & 0x3) << 10) 126*91f16700Schasinglulu #define GET_DIV_CLK_DDRSYS(x) (((x) & DIV_CLK_DDRSYS_MASK) >> 10) 127*91f16700Schasinglulu #define DIV_CLK_DDRCFG_MASK (0x6 << 5) 128*91f16700Schasinglulu #define DIV_CLK_DDRCFG(x) (((x) & 0x6) << 5) 129*91f16700Schasinglulu #define GET_DIV_CLK_DDRCFG(x) (((x) & DIV_CLK_DDRCFG_MASK) >> 5) 130*91f16700Schasinglulu #define DIV_CLK_DDRC_MASK 0x1F 131*91f16700Schasinglulu #define DIV_CLK_DDRC(x) ((x) & DIV_CLK_DDRC_MASK) 132*91f16700Schasinglulu #define GET_DIV_CLK_DDRC(x) ((x) & DIV_CLK_DDRC_MASK) 133*91f16700Schasinglulu 134*91f16700Schasinglulu #define CRG_CLKDIV25_REG (CRG_REG_BASE + 0x10C) 135*91f16700Schasinglulu #define DIV_SYSBUS_PLL_MASK (0xF << 16) 136*91f16700Schasinglulu #define DIV_SYSBUS_PLL(x) ((x) & 0xF) 137*91f16700Schasinglulu 138*91f16700Schasinglulu #define CRG_PERI_CTRL2_REG (CRG_REG_BASE + 0x128) 139*91f16700Schasinglulu #define PERI_TIME_STAMP_CLK_MASK (0x7 << 28) 140*91f16700Schasinglulu #define PERI_TIME_STAMP_CLK_DIV(x) (((x) & 0x7) << 22) 141*91f16700Schasinglulu 142*91f16700Schasinglulu #define CRG_ISODIS_REG (CRG_REG_BASE + 0x148) 143*91f16700Schasinglulu #define CRG_PERPWREN_REG (CRG_REG_BASE + 0x150) 144*91f16700Schasinglulu 145*91f16700Schasinglulu #define CRG_PEREN7_REG (CRG_REG_BASE + 0x420) 146*91f16700Schasinglulu #define CRG_PERDIS7_REG (CRG_REG_BASE + 0x424) 147*91f16700Schasinglulu #define CRG_PERSTAT7_REG (CRG_REG_BASE + 0x428) 148*91f16700Schasinglulu #define GT_CLK_UFSPHY_CFG (1 << 14) 149*91f16700Schasinglulu 150*91f16700Schasinglulu #define CRG_PEREN8_REG (CRG_REG_BASE + 0x430) 151*91f16700Schasinglulu #define CRG_PERDIS8_REG (CRG_REG_BASE + 0x434) 152*91f16700Schasinglulu #define CRG_PERSTAT8_REG (CRG_REG_BASE + 0x438) 153*91f16700Schasinglulu #define PERI_DMC_D_BIT (1 << 22) 154*91f16700Schasinglulu #define PERI_DMC_C_BIT (1 << 21) 155*91f16700Schasinglulu #define PERI_DMC_B_BIT (1 << 20) 156*91f16700Schasinglulu #define PERI_DMC_A_BIT (1 << 19) 157*91f16700Schasinglulu #define PERI_DMC_BIT (1 << 18) 158*91f16700Schasinglulu 159*91f16700Schasinglulu #define CRG_PEREN11_REG (CRG_REG_BASE + 0x460) 160*91f16700Schasinglulu #define PPLL1_GATE_CPU (1 << 18) 161*91f16700Schasinglulu 162*91f16700Schasinglulu #define CRG_PERSTAT11_REG (CRG_REG_BASE + 0x46C) 163*91f16700Schasinglulu #define PPLL3_EN_STAT (1 << 21) 164*91f16700Schasinglulu #define PPLL2_EN_STAT (1 << 20) 165*91f16700Schasinglulu #define PPLL1_EN_STAT (1 << 19) 166*91f16700Schasinglulu 167*91f16700Schasinglulu #define CRG_IVP_SEC_RSTDIS_REG (CRG_REG_BASE + 0xC04) 168*91f16700Schasinglulu #define CRG_ISP_SEC_RSTDIS_REG (CRG_REG_BASE + 0xC84) 169*91f16700Schasinglulu 170*91f16700Schasinglulu #define CRG_RVBAR(c, n) (0xE00 + (0x10 * c) + (0x4 * n)) 171*91f16700Schasinglulu #define CRG_GENERAL_SEC_RSTEN_REG (CRG_REG_BASE + 0xE20) 172*91f16700Schasinglulu #define CRG_GENERAL_SEC_RSTDIS_REG (CRG_REG_BASE + 0xE24) 173*91f16700Schasinglulu #define IP_RST_GPIO0_SEC (1 << 2) 174*91f16700Schasinglulu 175*91f16700Schasinglulu #define CRG_GENERAL_SEC_CLKDIV0_REG (CRG_REG_BASE + 0xE90) 176*91f16700Schasinglulu #define SC_DIV_AO_HISE_MASK 3 177*91f16700Schasinglulu #define SC_DIV_AO_HISE(x) ((x) & 0x3) 178*91f16700Schasinglulu 179*91f16700Schasinglulu #endif /* HI3660_CRG_H */ 180