xref: /rk3399_ARM-atf/plat/hisilicon/hikey960/include/hi3660_crg.h (revision d0d0f171643a22bbc3d06f5b6dde40cc1d9d5d11)
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