xref: /arm-trusted-firmware/plat/hisilicon/hikey960/include/hi3660_crg.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
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