12f2abcf4SHaojian Zhuang /* 22f2abcf4SHaojian Zhuang * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved. 32f2abcf4SHaojian Zhuang * 42f2abcf4SHaojian Zhuang * SPDX-License-Identifier: BSD-3-Clause 52f2abcf4SHaojian Zhuang */ 6c3cf06f1SAntonio Nino Diaz #ifndef HI3660_CRG_H 7c3cf06f1SAntonio Nino Diaz #define HI3660_CRG_H 82f2abcf4SHaojian Zhuang 92f2abcf4SHaojian Zhuang #define CRG_REG_BASE 0xFFF35000 102f2abcf4SHaojian Zhuang 112f2abcf4SHaojian Zhuang #define CRG_PEREN0_REG (CRG_REG_BASE + 0x000) 122f2abcf4SHaojian Zhuang #define CRG_PERDIS0_REG (CRG_REG_BASE + 0x004) 132f2abcf4SHaojian Zhuang #define CRG_PERSTAT0_REG (CRG_REG_BASE + 0x008) 14*d3b6df7cSJustin Chadwell #define PEREN0_GT_CLK_AOMM (1U << 31) 152f2abcf4SHaojian Zhuang 162f2abcf4SHaojian Zhuang #define CRG_PEREN1_REG (CRG_REG_BASE + 0x010) 172f2abcf4SHaojian Zhuang #define CRG_PERDIS1_REG (CRG_REG_BASE + 0x014) 182f2abcf4SHaojian Zhuang #define CRG_PERSTAT1_REG (CRG_REG_BASE + 0x018) 192f2abcf4SHaojian Zhuang #define CRG_PEREN2_REG (CRG_REG_BASE + 0x020) 202f2abcf4SHaojian Zhuang #define CRG_PERDIS2_REG (CRG_REG_BASE + 0x024) 212f2abcf4SHaojian Zhuang #define CRG_PERSTAT2_REG (CRG_REG_BASE + 0x028) 222f2abcf4SHaojian Zhuang #define PEREN2_HKADCSSI (1 << 24) 232f2abcf4SHaojian Zhuang 242f2abcf4SHaojian Zhuang #define CRG_PEREN3_REG (CRG_REG_BASE + 0x030) 252f2abcf4SHaojian Zhuang #define CRG_PERDIS3_REG (CRG_REG_BASE + 0x034) 262f2abcf4SHaojian Zhuang 272f2abcf4SHaojian Zhuang #define CRG_PEREN4_REG (CRG_REG_BASE + 0x040) 282f2abcf4SHaojian Zhuang #define CRG_PERDIS4_REG (CRG_REG_BASE + 0x044) 292f2abcf4SHaojian Zhuang #define CRG_PERCLKEN4_REG (CRG_REG_BASE + 0x048) 302f2abcf4SHaojian Zhuang #define CRG_PERSTAT4_REG (CRG_REG_BASE + 0x04C) 312f2abcf4SHaojian Zhuang #define GT_ACLK_USB3OTG (1 << 1) 322f2abcf4SHaojian Zhuang #define GT_CLK_USB3OTG_REF (1 << 0) 332f2abcf4SHaojian Zhuang 342f2abcf4SHaojian Zhuang #define CRG_PEREN5_REG (CRG_REG_BASE + 0x050) 352f2abcf4SHaojian Zhuang #define CRG_PERDIS5_REG (CRG_REG_BASE + 0x054) 362f2abcf4SHaojian Zhuang #define CRG_PERSTAT5_REG (CRG_REG_BASE + 0x058) 372f2abcf4SHaojian Zhuang #define CRG_PERRSTEN0_REG (CRG_REG_BASE + 0x060) 382f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS0_REG (CRG_REG_BASE + 0x064) 392f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT0_REG (CRG_REG_BASE + 0x068) 402f2abcf4SHaojian Zhuang #define CRG_PERRSTEN1_REG (CRG_REG_BASE + 0x06C) 412f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS1_REG (CRG_REG_BASE + 0x070) 422f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT1_REG (CRG_REG_BASE + 0x074) 432f2abcf4SHaojian Zhuang #define CRG_PERRSTEN2_REG (CRG_REG_BASE + 0x078) 442f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS2_REG (CRG_REG_BASE + 0x07C) 452f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT2_REG (CRG_REG_BASE + 0x080) 462f2abcf4SHaojian Zhuang #define PERRSTEN2_HKADCSSI (1 << 24) 472f2abcf4SHaojian Zhuang 482f2abcf4SHaojian Zhuang #define CRG_PERRSTEN3_REG (CRG_REG_BASE + 0x084) 492f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS3_REG (CRG_REG_BASE + 0x088) 502f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT3_REG (CRG_REG_BASE + 0x08C) 512f2abcf4SHaojian Zhuang #define CRG_PERRSTEN4_REG (CRG_REG_BASE + 0x090) 522f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS4_REG (CRG_REG_BASE + 0x094) 532f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT4_REG (CRG_REG_BASE + 0x098) 542f2abcf4SHaojian Zhuang #define IP_RST_USB3OTG_MUX (1 << 8) 552f2abcf4SHaojian Zhuang #define IP_RST_USB3OTG_AHBIF (1 << 7) 562f2abcf4SHaojian Zhuang #define IP_RST_USB3OTG_32K (1 << 6) 572f2abcf4SHaojian Zhuang #define IP_RST_USB3OTG (1 << 5) 582f2abcf4SHaojian Zhuang #define IP_RST_USB3OTGPHY_POR (1 << 3) 592f2abcf4SHaojian Zhuang 602f2abcf4SHaojian Zhuang #define CRG_PERRSTEN5_REG (CRG_REG_BASE + 0x09C) 612f2abcf4SHaojian Zhuang #define CRG_PERRSTDIS5_REG (CRG_REG_BASE + 0x0A0) 622f2abcf4SHaojian Zhuang #define CRG_PERRSTSTAT5_REG (CRG_REG_BASE + 0x0A4) 632f2abcf4SHaojian Zhuang 642f2abcf4SHaojian Zhuang /* bit fields in CRG_PERI */ 65*d3b6df7cSJustin Chadwell #define PERI_PCLK_PCTRL_BIT (1U << 31) 662f2abcf4SHaojian Zhuang #define PERI_TIMER12_BIT (1 << 25) 672f2abcf4SHaojian Zhuang #define PERI_TIMER11_BIT (1 << 24) 682f2abcf4SHaojian Zhuang #define PERI_TIMER10_BIT (1 << 23) 692f2abcf4SHaojian Zhuang #define PERI_TIMER9_BIT (1 << 22) 702f2abcf4SHaojian Zhuang #define PERI_UART5_BIT (1 << 15) 712f2abcf4SHaojian Zhuang #define PERI_UFS_BIT (1 << 12) 722f2abcf4SHaojian Zhuang #define PERI_ARST_UFS_BIT (1 << 7) 732f2abcf4SHaojian Zhuang #define PERI_PPLL2_EN_CPU (1 << 3) 742f2abcf4SHaojian Zhuang #define PERI_PWM_BIT (1 << 0) 752f2abcf4SHaojian Zhuang #define PERI_DDRC_BIT (1 << 0) 762f2abcf4SHaojian Zhuang #define PERI_DDRC_D_BIT (1 << 4) 772f2abcf4SHaojian Zhuang #define PERI_DDRC_C_BIT (1 << 3) 782f2abcf4SHaojian Zhuang #define PERI_DDRC_B_BIT (1 << 2) 792f2abcf4SHaojian Zhuang #define PERI_DDRC_A_BIT (1 << 1) 802f2abcf4SHaojian Zhuang #define PERI_DDRC_DMUX_BIT (1 << 0) 812f2abcf4SHaojian Zhuang 822f2abcf4SHaojian Zhuang #define CRG_CLKDIV0_REG (CRG_REG_BASE + 0x0A0) 832f2abcf4SHaojian Zhuang #define SC_DIV_LPMCU_MASK ((0x1F << 5) << 16) 842f2abcf4SHaojian Zhuang #define SC_DIV_LPMCU(x) (((x) & 0x1F) << 5) 852f2abcf4SHaojian Zhuang 862f2abcf4SHaojian Zhuang #define CRG_CLKDIV1_REG (CRG_REG_BASE + 0x0B0) 872f2abcf4SHaojian Zhuang #define SEL_LPMCU_PLL_MASK ((1 << 1) << 16) 882f2abcf4SHaojian Zhuang #define SEL_SYSBUS_MASK ((1 << 0) << 16) 892f2abcf4SHaojian Zhuang #define SEL_LPMCU_PLL1 (1 << 1) 902f2abcf4SHaojian Zhuang #define SEL_LPMCU_PLL0 (0 << 1) 912f2abcf4SHaojian Zhuang #define SEL_SYSBUS_PLL0 (1 << 0) 922f2abcf4SHaojian Zhuang #define SEL_SYSBUS_PLL1 (0 << 0) 932f2abcf4SHaojian Zhuang 942f2abcf4SHaojian Zhuang #define CRG_CLKDIV3_REG (CRG_REG_BASE + 0x0B4) 952f2abcf4SHaojian Zhuang #define CRG_CLKDIV5_REG (CRG_REG_BASE + 0x0BC) 962f2abcf4SHaojian Zhuang #define CRG_CLKDIV8_REG (CRG_REG_BASE + 0x0C8) 972f2abcf4SHaojian Zhuang 982f2abcf4SHaojian Zhuang #define CRG_CLKDIV12_REG (CRG_REG_BASE + 0x0D8) 992f2abcf4SHaojian Zhuang #define SC_DIV_A53HPM_MASK (0x7 << 13) 1002f2abcf4SHaojian Zhuang #define SC_DIV_A53HPM(x) (((x) & 0x7) << 13) 1012f2abcf4SHaojian Zhuang 1022f2abcf4SHaojian Zhuang #define CRG_CLKDIV16_REG (CRG_REG_BASE + 0x0E8) 1032f2abcf4SHaojian Zhuang #define DDRC_CLK_SW_REQ_CFG_MASK (0x3 << 12) 1042f2abcf4SHaojian Zhuang #define DDRC_CLK_SW_REQ_CFG(x) (((x) & 0x3) << 12) 1052f2abcf4SHaojian Zhuang #define SC_DIV_UFSPHY_CFG_MASK (0x3 << 9) 1062f2abcf4SHaojian Zhuang #define SC_DIV_UFSPHY_CFG(x) (((x) & 0x3) << 9) 1072f2abcf4SHaojian Zhuang #define DDRCPLL_SW (1 << 8) 1082f2abcf4SHaojian Zhuang 1092f2abcf4SHaojian Zhuang #define CRG_CLKDIV17_REG (CRG_REG_BASE + 0x0EC) 1102f2abcf4SHaojian Zhuang #define SC_DIV_UFS_PERIBUS (1 << 14) 1112f2abcf4SHaojian Zhuang 1122f2abcf4SHaojian Zhuang #define CRG_CLKDIV18_REG (CRG_REG_BASE + 0x0F0) 1132f2abcf4SHaojian Zhuang #define CRG_CLKDIV19_REG (CRG_REG_BASE + 0x0F4) 1142f2abcf4SHaojian Zhuang #define CRG_CLKDIV20_REG (CRG_REG_BASE + 0x0F8) 1152f2abcf4SHaojian Zhuang #define CLKDIV20_GT_CLK_AOMM (1 << 3) 1162f2abcf4SHaojian Zhuang 1172f2abcf4SHaojian Zhuang #define CRG_CLKDIV22_REG (CRG_REG_BASE + 0x100) 1182f2abcf4SHaojian Zhuang #define SEL_PLL_320M_MASK (1 << 16) 1192f2abcf4SHaojian Zhuang #define SEL_PLL2_320M (1 << 0) 1202f2abcf4SHaojian Zhuang #define SEL_PLL0_320M (0 << 0) 1212f2abcf4SHaojian Zhuang 1222f2abcf4SHaojian Zhuang #define CRG_CLKDIV23_REG (CRG_REG_BASE + 0x104) 1232f2abcf4SHaojian Zhuang #define PERI_DDRC_SW_BIT (1 << 13) 1242f2abcf4SHaojian Zhuang #define DIV_CLK_DDRSYS_MASK (0x3 << 10) 1252f2abcf4SHaojian Zhuang #define DIV_CLK_DDRSYS(x) (((x) & 0x3) << 10) 1262f2abcf4SHaojian Zhuang #define GET_DIV_CLK_DDRSYS(x) (((x) & DIV_CLK_DDRSYS_MASK) >> 10) 1272f2abcf4SHaojian Zhuang #define DIV_CLK_DDRCFG_MASK (0x6 << 5) 1282f2abcf4SHaojian Zhuang #define DIV_CLK_DDRCFG(x) (((x) & 0x6) << 5) 1292f2abcf4SHaojian Zhuang #define GET_DIV_CLK_DDRCFG(x) (((x) & DIV_CLK_DDRCFG_MASK) >> 5) 1302f2abcf4SHaojian Zhuang #define DIV_CLK_DDRC_MASK 0x1F 1312f2abcf4SHaojian Zhuang #define DIV_CLK_DDRC(x) ((x) & DIV_CLK_DDRC_MASK) 1322f2abcf4SHaojian Zhuang #define GET_DIV_CLK_DDRC(x) ((x) & DIV_CLK_DDRC_MASK) 1332f2abcf4SHaojian Zhuang 1342f2abcf4SHaojian Zhuang #define CRG_CLKDIV25_REG (CRG_REG_BASE + 0x10C) 1352f2abcf4SHaojian Zhuang #define DIV_SYSBUS_PLL_MASK (0xF << 16) 1362f2abcf4SHaojian Zhuang #define DIV_SYSBUS_PLL(x) ((x) & 0xF) 1372f2abcf4SHaojian Zhuang 1382f2abcf4SHaojian Zhuang #define CRG_PERI_CTRL2_REG (CRG_REG_BASE + 0x128) 1392f2abcf4SHaojian Zhuang #define PERI_TIME_STAMP_CLK_MASK (0x7 << 28) 1402f2abcf4SHaojian Zhuang #define PERI_TIME_STAMP_CLK_DIV(x) (((x) & 0x7) << 22) 1412f2abcf4SHaojian Zhuang 1422f2abcf4SHaojian Zhuang #define CRG_ISODIS_REG (CRG_REG_BASE + 0x148) 1432f2abcf4SHaojian Zhuang #define CRG_PERPWREN_REG (CRG_REG_BASE + 0x150) 1442f2abcf4SHaojian Zhuang 1452f2abcf4SHaojian Zhuang #define CRG_PEREN7_REG (CRG_REG_BASE + 0x420) 1462f2abcf4SHaojian Zhuang #define CRG_PERDIS7_REG (CRG_REG_BASE + 0x424) 1472f2abcf4SHaojian Zhuang #define CRG_PERSTAT7_REG (CRG_REG_BASE + 0x428) 1482f2abcf4SHaojian Zhuang #define GT_CLK_UFSPHY_CFG (1 << 14) 1492f2abcf4SHaojian Zhuang 1502f2abcf4SHaojian Zhuang #define CRG_PEREN8_REG (CRG_REG_BASE + 0x430) 1512f2abcf4SHaojian Zhuang #define CRG_PERDIS8_REG (CRG_REG_BASE + 0x434) 1522f2abcf4SHaojian Zhuang #define CRG_PERSTAT8_REG (CRG_REG_BASE + 0x438) 1532f2abcf4SHaojian Zhuang #define PERI_DMC_D_BIT (1 << 22) 1542f2abcf4SHaojian Zhuang #define PERI_DMC_C_BIT (1 << 21) 1552f2abcf4SHaojian Zhuang #define PERI_DMC_B_BIT (1 << 20) 1562f2abcf4SHaojian Zhuang #define PERI_DMC_A_BIT (1 << 19) 1572f2abcf4SHaojian Zhuang #define PERI_DMC_BIT (1 << 18) 1582f2abcf4SHaojian Zhuang 1592f2abcf4SHaojian Zhuang #define CRG_PEREN11_REG (CRG_REG_BASE + 0x460) 1602f2abcf4SHaojian Zhuang #define PPLL1_GATE_CPU (1 << 18) 1612f2abcf4SHaojian Zhuang 1622f2abcf4SHaojian Zhuang #define CRG_PERSTAT11_REG (CRG_REG_BASE + 0x46C) 1632f2abcf4SHaojian Zhuang #define PPLL3_EN_STAT (1 << 21) 1642f2abcf4SHaojian Zhuang #define PPLL2_EN_STAT (1 << 20) 1652f2abcf4SHaojian Zhuang #define PPLL1_EN_STAT (1 << 19) 1662f2abcf4SHaojian Zhuang 1672f2abcf4SHaojian Zhuang #define CRG_IVP_SEC_RSTDIS_REG (CRG_REG_BASE + 0xC04) 1682f2abcf4SHaojian Zhuang #define CRG_ISP_SEC_RSTDIS_REG (CRG_REG_BASE + 0xC84) 1692f2abcf4SHaojian Zhuang 1702f2abcf4SHaojian Zhuang #define CRG_RVBAR(c, n) (0xE00 + (0x10 * c) + (0x4 * n)) 1712f2abcf4SHaojian Zhuang #define CRG_GENERAL_SEC_RSTEN_REG (CRG_REG_BASE + 0xE20) 1722f2abcf4SHaojian Zhuang #define CRG_GENERAL_SEC_RSTDIS_REG (CRG_REG_BASE + 0xE24) 1732f2abcf4SHaojian Zhuang #define IP_RST_GPIO0_SEC (1 << 2) 1742f2abcf4SHaojian Zhuang 1752f2abcf4SHaojian Zhuang #define CRG_GENERAL_SEC_CLKDIV0_REG (CRG_REG_BASE + 0xE90) 1762f2abcf4SHaojian Zhuang #define SC_DIV_AO_HISE_MASK 3 1772f2abcf4SHaojian Zhuang #define SC_DIV_AO_HISE(x) ((x) & 0x3) 1782f2abcf4SHaojian Zhuang 179c3cf06f1SAntonio Nino Diaz #endif /* HI3660_CRG_H */ 180