xref: /OK3568_Linux_fs/u-boot/arch/arm/include/asm/arch-rockchip/cru_rk3528.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright (c) 2022 Rockchip Electronics Co. Ltd.
4*4882a593Smuzhiyun  * Author: Joseph Chen <chenjh@rock-chips.com>
5*4882a593Smuzhiyun  */
6*4882a593Smuzhiyun 
7*4882a593Smuzhiyun #ifndef _ASM_ARCH_CRU_RK3528_H
8*4882a593Smuzhiyun #define _ASM_ARCH_CRU_RK3528_H
9*4882a593Smuzhiyun 
10*4882a593Smuzhiyun #define MHz		1000000
11*4882a593Smuzhiyun #define KHz		1000
12*4882a593Smuzhiyun #define OSC_HZ		(24 * MHz)
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun #define CPU_PVTPLL_HZ	(1200 * MHz)
15*4882a593Smuzhiyun #define APLL_HZ		(600 * MHz)
16*4882a593Smuzhiyun #define GPLL_HZ		(1188 * MHz)
17*4882a593Smuzhiyun #define CPLL_HZ		(996 * MHz)
18*4882a593Smuzhiyun #define PPLL_HZ		(1000 * MHz)
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun /* RK3528 pll id */
21*4882a593Smuzhiyun enum rk3528_pll_id {
22*4882a593Smuzhiyun 	APLL,
23*4882a593Smuzhiyun 	CPLL,
24*4882a593Smuzhiyun 	GPLL,
25*4882a593Smuzhiyun 	PPLL,
26*4882a593Smuzhiyun 	DPLL,
27*4882a593Smuzhiyun 	PLL_COUNT,
28*4882a593Smuzhiyun };
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun struct rk3528_clk_info {
31*4882a593Smuzhiyun 	unsigned long id;
32*4882a593Smuzhiyun 	char *name;
33*4882a593Smuzhiyun };
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun struct rk3528_clk_priv {
36*4882a593Smuzhiyun 	struct rk3528_cru *cru;
37*4882a593Smuzhiyun 	struct rk3528_sysgrf *grf;
38*4882a593Smuzhiyun 	ulong ppll_hz;
39*4882a593Smuzhiyun 	ulong gpll_hz;
40*4882a593Smuzhiyun 	ulong cpll_hz;
41*4882a593Smuzhiyun 	ulong armclk_hz;
42*4882a593Smuzhiyun 	ulong armclk_enter_hz;
43*4882a593Smuzhiyun 	ulong armclk_init_hz;
44*4882a593Smuzhiyun 	bool sync_kernel;
45*4882a593Smuzhiyun 	bool set_armclk_rate;
46*4882a593Smuzhiyun };
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun struct rk3528_pll {
49*4882a593Smuzhiyun 	unsigned int con0;
50*4882a593Smuzhiyun 	unsigned int con1;
51*4882a593Smuzhiyun 	unsigned int con2;
52*4882a593Smuzhiyun 	unsigned int con3;
53*4882a593Smuzhiyun 	unsigned int con4;
54*4882a593Smuzhiyun 	unsigned int reserved0[3];
55*4882a593Smuzhiyun };
56*4882a593Smuzhiyun 
57*4882a593Smuzhiyun struct rk3528_cru {
58*4882a593Smuzhiyun 	uint32_t apll_con[5];
59*4882a593Smuzhiyun 	uint32_t reserved0014[3];
60*4882a593Smuzhiyun 	uint32_t cpll_con[5];
61*4882a593Smuzhiyun 	uint32_t reserved0034[11];
62*4882a593Smuzhiyun 	uint32_t gpll_con[5];
63*4882a593Smuzhiyun 	uint32_t reserved0074[51+32];
64*4882a593Smuzhiyun 	uint32_t reserved01c0[48];
65*4882a593Smuzhiyun 	uint32_t mode_con[1];
66*4882a593Smuzhiyun 	uint32_t reserved0284[31];
67*4882a593Smuzhiyun 	uint32_t clksel_con[91];
68*4882a593Smuzhiyun 	uint32_t reserved046c[229];
69*4882a593Smuzhiyun 	uint32_t gate_con[46];
70*4882a593Smuzhiyun 	uint32_t reserved08b8[82];
71*4882a593Smuzhiyun 	uint32_t softrst_con[47];
72*4882a593Smuzhiyun 	uint32_t reserved0abc[81];
73*4882a593Smuzhiyun 	uint32_t glb_cnt_th;
74*4882a593Smuzhiyun 	uint32_t glb_rst_st;
75*4882a593Smuzhiyun 	uint32_t glb_srst_fst;
76*4882a593Smuzhiyun 	uint32_t glb_srst_snd;
77*4882a593Smuzhiyun 	uint32_t glb_rst_con;
78*4882a593Smuzhiyun 	uint32_t reserved0c14[6];
79*4882a593Smuzhiyun 	uint32_t corewfi_con;
80*4882a593Smuzhiyun 	uint32_t reserved0c30[15604];
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun 	/* pmucru */
83*4882a593Smuzhiyun 	uint32_t reserved10000[192];
84*4882a593Smuzhiyun 	uint32_t pmuclksel_con[3];
85*4882a593Smuzhiyun 	uint32_t reserved1030c[317];
86*4882a593Smuzhiyun 	uint32_t pmugate_con[3];
87*4882a593Smuzhiyun 	uint32_t reserved1080c[125];
88*4882a593Smuzhiyun 	uint32_t pmusoftrst_con[3];
89*4882a593Smuzhiyun 	uint32_t reserved10a08[7550+8191];
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun 	/* pciecru */
92*4882a593Smuzhiyun 	uint32_t reserved20000[32];
93*4882a593Smuzhiyun 	uint32_t ppll_con[5];
94*4882a593Smuzhiyun 	uint32_t reserved20094[155];
95*4882a593Smuzhiyun 	uint32_t pcieclksel_con[2];
96*4882a593Smuzhiyun 	uint32_t reserved20308[318];
97*4882a593Smuzhiyun 	uint32_t pciegate_con;
98*4882a593Smuzhiyun };
99*4882a593Smuzhiyun check_member(rk3528_cru, pciegate_con, 0x20800);
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun struct rk3528_grf_clk_priv {
102*4882a593Smuzhiyun 	struct rk3528_grf *grf;
103*4882a593Smuzhiyun };
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun struct pll_rate_table {
106*4882a593Smuzhiyun 	unsigned long rate;
107*4882a593Smuzhiyun 	unsigned int fbdiv;
108*4882a593Smuzhiyun 	unsigned int postdiv1;
109*4882a593Smuzhiyun 	unsigned int refdiv;
110*4882a593Smuzhiyun 	unsigned int postdiv2;
111*4882a593Smuzhiyun 	unsigned int dsmpd;
112*4882a593Smuzhiyun 	unsigned int frac;
113*4882a593Smuzhiyun };
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun #define RK3528_PMU_CRU_BASE			0x10000
116*4882a593Smuzhiyun #define RK3528_PCIE_CRU_BASE			0x20000
117*4882a593Smuzhiyun #define RK3528_DDRPHY_CRU_BASE			0x28000
118*4882a593Smuzhiyun #define RK3528_PLL_CON(x)			((x) * 0x4)
119*4882a593Smuzhiyun #define RK3528_PCIE_PLL_CON(x)			((x) * 0x4 + RK3528_PCIE_CRU_BASE)
120*4882a593Smuzhiyun #define RK3528_DDRPHY_PLL_CON(x)		((x) * 0x4 + RK3528_DDRPHY_CRU_BASE)
121*4882a593Smuzhiyun #define RK3528_MODE_CON				0x280
122*4882a593Smuzhiyun #define RK3528_CLKSEL_CON(x)			((x) * 0x4 + 0x300)
123*4882a593Smuzhiyun #define RK3528_PMU_CLKSEL_CON(x)		((x) * 0x4 + 0x300 + RK3528_PMU_CRU_BASE)
124*4882a593Smuzhiyun #define RK3528_PCIE_CLKSEL_CON(x)		((x) * 0x4 + 0x300 + RK3528_PCIE_CRU_BASE)
125*4882a593Smuzhiyun #define RK3528_DDRPHY_MODE_CON			(0x280 + RK3528_DDRPHY_CRU_BASE)
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun #define RK3528_DIV_ACLK_M_CORE_MASK		0x1f
128*4882a593Smuzhiyun #define RK3528_DIV_ACLK_M_CORE_SHIFT		11
129*4882a593Smuzhiyun #define RK3528_DIV_PCLK_DBG_MASK		0x1f
130*4882a593Smuzhiyun #define RK3528_DIV_PCLK_DBG_SHIFT		1
131*4882a593Smuzhiyun 
132*4882a593Smuzhiyun enum {
133*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON00 */
134*4882a593Smuzhiyun 	CLK_MATRIX_50M_SRC_DIV_SHIFT             = 2,
135*4882a593Smuzhiyun 	CLK_MATRIX_50M_SRC_DIV_MASK              = 0x1F << CLK_MATRIX_50M_SRC_DIV_SHIFT,
136*4882a593Smuzhiyun 	CLK_MATRIX_100M_SRC_DIV_SHIFT            = 7,
137*4882a593Smuzhiyun 	CLK_MATRIX_100M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_100M_SRC_DIV_SHIFT,
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON01 */
140*4882a593Smuzhiyun 	CLK_MATRIX_150M_SRC_DIV_SHIFT            = 0,
141*4882a593Smuzhiyun 	CLK_MATRIX_150M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_150M_SRC_DIV_SHIFT,
142*4882a593Smuzhiyun 	CLK_MATRIX_200M_SRC_DIV_SHIFT            = 5,
143*4882a593Smuzhiyun 	CLK_MATRIX_200M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_200M_SRC_DIV_SHIFT,
144*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_DIV_SHIFT            = 10,
145*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_250M_SRC_DIV_SHIFT,
146*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_SEL_SHIFT            = 15,
147*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_SEL_MASK             = 0x1 << CLK_MATRIX_250M_SRC_SEL_SHIFT,
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON02 */
150*4882a593Smuzhiyun 	CLK_MATRIX_300M_SRC_DIV_SHIFT            = 0,
151*4882a593Smuzhiyun 	CLK_MATRIX_300M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_300M_SRC_DIV_SHIFT,
152*4882a593Smuzhiyun 	CLK_MATRIX_339M_SRC_DIV_SHIFT            = 5,
153*4882a593Smuzhiyun 	CLK_MATRIX_339M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_339M_SRC_DIV_SHIFT,
154*4882a593Smuzhiyun 	CLK_MATRIX_400M_SRC_DIV_SHIFT            = 10,
155*4882a593Smuzhiyun 	CLK_MATRIX_400M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_400M_SRC_DIV_SHIFT,
156*4882a593Smuzhiyun 
157*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON03 */
158*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_DIV_SHIFT            = 6,
159*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_500M_SRC_DIV_SHIFT,
160*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_SEL_SHIFT            = 11,
161*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_SEL_MASK             = 0x1 << CLK_MATRIX_500M_SRC_SEL_SHIFT,
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON04 */
164*4882a593Smuzhiyun 	CLK_MATRIX_600M_SRC_DIV_SHIFT            = 0,
165*4882a593Smuzhiyun 	CLK_MATRIX_600M_SRC_DIV_MASK             = 0x1F << CLK_MATRIX_600M_SRC_DIV_SHIFT,
166*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_SEL_CLK_GPLL_MUX     = 0U,
167*4882a593Smuzhiyun 	CLK_MATRIX_250M_SRC_SEL_CLK_CPLL_MUX     = 1U,
168*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_SEL_CLK_GPLL_MUX     = 0U,
169*4882a593Smuzhiyun 	CLK_MATRIX_500M_SRC_SEL_CLK_CPLL_MUX     = 1U,
170*4882a593Smuzhiyun 
171*4882a593Smuzhiyun 	/* PMUCRU_CLKSEL_CON00 */
172*4882a593Smuzhiyun 	CLK_I2C2_SEL_SHIFT                       = 0,
173*4882a593Smuzhiyun 	CLK_I2C2_SEL_MASK                        = 0x3 << CLK_I2C2_SEL_SHIFT,
174*4882a593Smuzhiyun 
175*4882a593Smuzhiyun 	/* PCIE_CRU_CLKSEL_CON01 */
176*4882a593Smuzhiyun 	PCIE_CLK_MATRIX_50M_SRC_DIV_SHIFT        = 7,
177*4882a593Smuzhiyun 	PCIE_CLK_MATRIX_50M_SRC_DIV_MASK         = 0x1f << PCIE_CLK_MATRIX_50M_SRC_DIV_SHIFT,
178*4882a593Smuzhiyun 	PCIE_CLK_MATRIX_100M_SRC_DIV_SHIFT       = 11,
179*4882a593Smuzhiyun 	PCIE_CLK_MATRIX_100M_SRC_DIV_MASK        = 0x1f << PCIE_CLK_MATRIX_100M_SRC_DIV_SHIFT,
180*4882a593Smuzhiyun 
181*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON32 */
182*4882a593Smuzhiyun 	DCLK_VOP_SRC0_SEL_SHIFT                  = 10,
183*4882a593Smuzhiyun 	DCLK_VOP_SRC0_SEL_MASK                   = 0x1 << DCLK_VOP_SRC0_SEL_SHIFT,
184*4882a593Smuzhiyun 	DCLK_VOP_SRC0_DIV_SHIFT                  = 2,
185*4882a593Smuzhiyun 	DCLK_VOP_SRC0_DIV_MASK                   = 0xFF << DCLK_VOP_SRC0_DIV_SHIFT,
186*4882a593Smuzhiyun 
187*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON33 */
188*4882a593Smuzhiyun 	DCLK_VOP_SRC1_SEL_SHIFT                  = 8,
189*4882a593Smuzhiyun 	DCLK_VOP_SRC1_SEL_MASK                   = 0x1 << DCLK_VOP_SRC1_SEL_SHIFT,
190*4882a593Smuzhiyun 	DCLK_VOP_SRC1_DIV_SHIFT                  = 0,
191*4882a593Smuzhiyun 	DCLK_VOP_SRC1_DIV_MASK                   = 0xFF << DCLK_VOP_SRC1_DIV_SHIFT,
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON43 */
194*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_SHIFT                = 14,
195*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_MASK                 = 0x3 << CLK_CORE_CRYPTO_SEL_SHIFT,
196*4882a593Smuzhiyun 	ACLK_BUS_VOPGL_ROOT_DIV_SHIFT            = 0U,
197*4882a593Smuzhiyun 	ACLK_BUS_VOPGL_ROOT_DIV_MASK             = 0x7U << ACLK_BUS_VOPGL_ROOT_DIV_SHIFT,
198*4882a593Smuzhiyun 
199*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON44 */
200*4882a593Smuzhiyun 	CLK_PWM0_SEL_SHIFT                       = 6,
201*4882a593Smuzhiyun 	CLK_PWM0_SEL_MASK                        = 0x3 << CLK_PWM0_SEL_SHIFT,
202*4882a593Smuzhiyun 	CLK_PWM1_SEL_SHIFT                       = 8,
203*4882a593Smuzhiyun 	CLK_PWM1_SEL_MASK                        = 0x3 << CLK_PWM1_SEL_SHIFT,
204*4882a593Smuzhiyun 	CLK_PWM0_SEL_CLK_MATRIX_100M_SRC         = 0U,
205*4882a593Smuzhiyun 	CLK_PWM0_SEL_CLK_MATRIX_50M_SRC          = 1U,
206*4882a593Smuzhiyun 	CLK_PWM0_SEL_XIN_OSC0_FUNC               = 2U,
207*4882a593Smuzhiyun 	CLK_PWM1_SEL_CLK_MATRIX_100M_SRC         = 0U,
208*4882a593Smuzhiyun 	CLK_PWM1_SEL_CLK_MATRIX_50M_SRC          = 1U,
209*4882a593Smuzhiyun 	CLK_PWM1_SEL_XIN_OSC0_FUNC               = 2U,
210*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_SHIFT                 = 0,
211*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_MASK                  = 0x3 << CLK_PKA_CRYPTO_SEL_SHIFT,
212*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_CLK_MATRIX_300M_SRC  = 0U,
213*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_CLK_MATRIX_200M_SRC  = 1U,
214*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_CLK_MATRIX_100M_SRC  = 2U,
215*4882a593Smuzhiyun 	CLK_CORE_CRYPTO_SEL_XIN_OSC0_FUNC        = 3U,
216*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_CLK_MATRIX_300M_SRC   = 0U,
217*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_CLK_MATRIX_200M_SRC   = 1U,
218*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_CLK_MATRIX_100M_SRC   = 2U,
219*4882a593Smuzhiyun 	CLK_PKA_CRYPTO_SEL_XIN_OSC0_FUNC         = 3U,
220*4882a593Smuzhiyun 
221*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON60 */
222*4882a593Smuzhiyun 	CLK_MATRIX_25M_SRC_DIV_SHIFT             = 2,
223*4882a593Smuzhiyun 	CLK_MATRIX_25M_SRC_DIV_MASK              = 0xff << CLK_MATRIX_25M_SRC_DIV_SHIFT,
224*4882a593Smuzhiyun 	CLK_MATRIX_125M_SRC_DIV_SHIFT            = 10,
225*4882a593Smuzhiyun 	CLK_MATRIX_125M_SRC_DIV_MASK             = 0x1f << CLK_MATRIX_125M_SRC_DIV_SHIFT,
226*4882a593Smuzhiyun 
227*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON61 */
228*4882a593Smuzhiyun 	SCLK_SFC_DIV_SHIFT                       = 6,
229*4882a593Smuzhiyun 	SCLK_SFC_DIV_MASK                        = 0x3F << SCLK_SFC_DIV_SHIFT,
230*4882a593Smuzhiyun 	SCLK_SFC_SEL_SHIFT                       = 12,
231*4882a593Smuzhiyun 	SCLK_SFC_SEL_MASK                        = 0x3 << SCLK_SFC_SEL_SHIFT,
232*4882a593Smuzhiyun 	SCLK_SFC_SEL_CLK_GPLL_MUX                = 0U,
233*4882a593Smuzhiyun 	SCLK_SFC_SEL_CLK_CPLL_MUX                = 1U,
234*4882a593Smuzhiyun 	SCLK_SFC_SEL_XIN_OSC0_FUNC               = 2U,
235*4882a593Smuzhiyun 
236*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON62 */
237*4882a593Smuzhiyun 	CCLK_SRC_EMMC_DIV_SHIFT                  = 0,
238*4882a593Smuzhiyun 	CCLK_SRC_EMMC_DIV_MASK                   = 0x3F << CCLK_SRC_EMMC_DIV_SHIFT,
239*4882a593Smuzhiyun 	CCLK_SRC_EMMC_SEL_SHIFT                  = 6,
240*4882a593Smuzhiyun 	CCLK_SRC_EMMC_SEL_MASK                   = 0x3 << CCLK_SRC_EMMC_SEL_SHIFT,
241*4882a593Smuzhiyun 	BCLK_EMMC_SEL_SHIFT                      = 8,
242*4882a593Smuzhiyun 	BCLK_EMMC_SEL_MASK                       = 0x3 << BCLK_EMMC_SEL_SHIFT,
243*4882a593Smuzhiyun 
244*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON63 */
245*4882a593Smuzhiyun 	CLK_I2C3_SEL_SHIFT                       = 12,
246*4882a593Smuzhiyun 	CLK_I2C3_SEL_MASK                        = 0x3 << CLK_I2C3_SEL_SHIFT,
247*4882a593Smuzhiyun 	CLK_I2C5_SEL_SHIFT                       = 14,
248*4882a593Smuzhiyun 	CLK_I2C5_SEL_MASK                        = 0x3 << CLK_I2C5_SEL_SHIFT,
249*4882a593Smuzhiyun 	CLK_SPI1_SEL_SHIFT                       = 10,
250*4882a593Smuzhiyun 	CLK_SPI1_SEL_MASK                        = 0x3 << CLK_SPI1_SEL_SHIFT,
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON64 */
253*4882a593Smuzhiyun 	CLK_I2C6_SEL_SHIFT                       = 0,
254*4882a593Smuzhiyun 	CLK_I2C6_SEL_MASK                        = 0x3 << CLK_I2C6_SEL_SHIFT,
255*4882a593Smuzhiyun 
256*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON74 */
257*4882a593Smuzhiyun 	CLK_SARADC_DIV_SHIFT                     = 0,
258*4882a593Smuzhiyun 	CLK_SARADC_DIV_MASK                      = 0x7 << CLK_SARADC_DIV_SHIFT,
259*4882a593Smuzhiyun 	CLK_TSADC_DIV_SHIFT                      = 3,
260*4882a593Smuzhiyun 	CLK_TSADC_DIV_MASK                       = 0x1F << CLK_TSADC_DIV_SHIFT,
261*4882a593Smuzhiyun 	CLK_TSADC_TSEN_DIV_SHIFT                 = 8,
262*4882a593Smuzhiyun 	CLK_TSADC_TSEN_DIV_MASK                  = 0x1F << CLK_TSADC_TSEN_DIV_SHIFT,
263*4882a593Smuzhiyun 
264*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON79 */
265*4882a593Smuzhiyun 	CLK_I2C1_SEL_SHIFT                       = 9,
266*4882a593Smuzhiyun 	CLK_I2C1_SEL_MASK                        = 0x3 << CLK_I2C1_SEL_SHIFT,
267*4882a593Smuzhiyun 	CLK_I2C0_SEL_SHIFT                       = 11,
268*4882a593Smuzhiyun 	CLK_I2C0_SEL_MASK                        = 0x3 << CLK_I2C0_SEL_SHIFT,
269*4882a593Smuzhiyun 	CLK_SPI0_SEL_SHIFT                       = 13,
270*4882a593Smuzhiyun 	CLK_SPI0_SEL_MASK                        = 0x3 << CLK_SPI0_SEL_SHIFT,
271*4882a593Smuzhiyun 
272*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON83 */
273*4882a593Smuzhiyun 	ACLK_VOP_ROOT_DIV_SHIFT                  = 12,
274*4882a593Smuzhiyun 	ACLK_VOP_ROOT_DIV_MASK                   = 0x7 << ACLK_VOP_ROOT_DIV_SHIFT,
275*4882a593Smuzhiyun 	ACLK_VOP_ROOT_SEL_SHIFT                  = 15,
276*4882a593Smuzhiyun 	ACLK_VOP_ROOT_SEL_MASK                   = 0x1 << ACLK_VOP_ROOT_SEL_SHIFT,
277*4882a593Smuzhiyun 
278*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON84 */
279*4882a593Smuzhiyun 	DCLK_VOP0_SEL_SHIFT                      = 0,
280*4882a593Smuzhiyun 	DCLK_VOP0_SEL_MASK                       = 0x1 << DCLK_VOP0_SEL_SHIFT,
281*4882a593Smuzhiyun 	DCLK_VOP_SRC_SEL_CLK_GPLL_MUX            = 0U,
282*4882a593Smuzhiyun 	DCLK_VOP_SRC_SEL_CLK_CPLL_MUX            = 1U,
283*4882a593Smuzhiyun 	ACLK_VOP_ROOT_SEL_CLK_GPLL_MUX           = 0U,
284*4882a593Smuzhiyun 	ACLK_VOP_ROOT_SEL_CLK_CPLL_MUX           = 1U,
285*4882a593Smuzhiyun 	DCLK_VOP0_SEL_DCLK_VOP_SRC0              = 0U,
286*4882a593Smuzhiyun 	DCLK_VOP0_SEL_CLK_HDMIPHY_PIXEL_IO       = 1U,
287*4882a593Smuzhiyun 
288*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON85 */
289*4882a593Smuzhiyun 	CLK_I2C4_SEL_SHIFT                       = 13,
290*4882a593Smuzhiyun 	CLK_I2C4_SEL_MASK                        = 0x3 << CLK_I2C4_SEL_SHIFT,
291*4882a593Smuzhiyun 	CLK_I2C7_SEL_SHIFT                       = 0,
292*4882a593Smuzhiyun 	CLK_I2C7_SEL_MASK                        = 0x3 << CLK_I2C7_SEL_SHIFT,
293*4882a593Smuzhiyun 	CLK_I2C3_SEL_CLK_MATRIX_200M_SRC         = 0U,
294*4882a593Smuzhiyun 	CLK_I2C3_SEL_CLK_MATRIX_100M_SRC         = 1U,
295*4882a593Smuzhiyun 	CLK_I2C3_SEL_CLK_MATRIX_50M_SRC          = 2U,
296*4882a593Smuzhiyun 	CLK_I2C3_SEL_XIN_OSC0_FUNC               = 3U,
297*4882a593Smuzhiyun 	CLK_SPI1_SEL_CLK_MATRIX_200M_SRC         = 0U,
298*4882a593Smuzhiyun 	CLK_SPI1_SEL_CLK_MATRIX_100M_SRC         = 1U,
299*4882a593Smuzhiyun 	CLK_SPI1_SEL_CLK_MATRIX_50M_SRC          = 2U,
300*4882a593Smuzhiyun 	CLK_SPI1_SEL_XIN_OSC0_FUNC               = 3U,
301*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_DIV_SHIFT                = 0,
302*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_DIV_MASK                 = 0x3F << CCLK_SRC_SDMMC0_DIV_SHIFT,
303*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_SEL_SHIFT                = 6,
304*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_SEL_MASK                 = 0x3 << CCLK_SRC_SDMMC0_SEL_SHIFT,
305*4882a593Smuzhiyun 	CCLK_SRC_EMMC_SEL_CLK_GPLL_MUX           = 0U,
306*4882a593Smuzhiyun 	CCLK_SRC_EMMC_SEL_CLK_CPLL_MUX           = 1U,
307*4882a593Smuzhiyun 	CCLK_SRC_EMMC_SEL_XIN_OSC0_FUNC          = 2U,
308*4882a593Smuzhiyun 	BCLK_EMMC_SEL_CLK_MATRIX_200M_SRC        = 0U,
309*4882a593Smuzhiyun 	BCLK_EMMC_SEL_CLK_MATRIX_100M_SRC        = 1U,
310*4882a593Smuzhiyun 	BCLK_EMMC_SEL_CLK_MATRIX_50M_SRC         = 2U,
311*4882a593Smuzhiyun 	BCLK_EMMC_SEL_XIN_OSC0_FUNC              = 3U,
312*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_SEL_CLK_GPLL_MUX         = 0U,
313*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_SEL_CLK_CPLL_MUX         = 1U,
314*4882a593Smuzhiyun 	CCLK_SRC_SDMMC0_SEL_XIN_OSC0_FUNC        = 2U,
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON04 */
317*4882a593Smuzhiyun 	CLK_UART0_SRC_DIV_SHIFT                  = 5,
318*4882a593Smuzhiyun 	CLK_UART0_SRC_DIV_MASK                   = 0x1F << CLK_UART0_SRC_DIV_SHIFT,
319*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON05 */
320*4882a593Smuzhiyun 	CLK_UART0_FRAC_DIV_SHIFT                 = 0,
321*4882a593Smuzhiyun 	CLK_UART0_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART0_FRAC_DIV_SHIFT,
322*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON06 */
323*4882a593Smuzhiyun 	SCLK_UART0_SRC_SEL_SHIFT                 = 0,
324*4882a593Smuzhiyun 	SCLK_UART0_SRC_SEL_MASK                  = 0x3 << SCLK_UART0_SRC_SEL_SHIFT,
325*4882a593Smuzhiyun 	CLK_UART1_SRC_DIV_SHIFT                  = 2,
326*4882a593Smuzhiyun 	CLK_UART1_SRC_DIV_MASK                   = 0x1F << CLK_UART1_SRC_DIV_SHIFT,
327*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON07 */
328*4882a593Smuzhiyun 	CLK_UART1_FRAC_DIV_SHIFT                 = 0,
329*4882a593Smuzhiyun 	CLK_UART1_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART1_FRAC_DIV_SHIFT,
330*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON08 */
331*4882a593Smuzhiyun 	SCLK_UART1_SRC_SEL_SHIFT                 = 0,
332*4882a593Smuzhiyun 	SCLK_UART1_SRC_SEL_MASK                  = 0x3 << SCLK_UART1_SRC_SEL_SHIFT,
333*4882a593Smuzhiyun 	CLK_UART2_SRC_DIV_SHIFT                  = 2,
334*4882a593Smuzhiyun 	CLK_UART2_SRC_DIV_MASK                   = 0x1F << CLK_UART2_SRC_DIV_SHIFT,
335*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON09 */
336*4882a593Smuzhiyun 	CLK_UART2_FRAC_DIV_SHIFT                 = 0,
337*4882a593Smuzhiyun 	CLK_UART2_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART2_FRAC_DIV_SHIFT,
338*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON10 */
339*4882a593Smuzhiyun 	SCLK_UART2_SRC_SEL_SHIFT                 = 0,
340*4882a593Smuzhiyun 	SCLK_UART2_SRC_SEL_MASK                  = 0x3 << SCLK_UART2_SRC_SEL_SHIFT,
341*4882a593Smuzhiyun 	CLK_UART3_SRC_DIV_SHIFT                  = 2,
342*4882a593Smuzhiyun 	CLK_UART3_SRC_DIV_MASK                   = 0x1F << CLK_UART3_SRC_DIV_SHIFT,
343*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON11 */
344*4882a593Smuzhiyun 	CLK_UART3_FRAC_DIV_SHIFT                 = 0,
345*4882a593Smuzhiyun 	CLK_UART3_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART3_FRAC_DIV_SHIFT,
346*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON12 */
347*4882a593Smuzhiyun 	SCLK_UART3_SRC_SEL_SHIFT                 = 0,
348*4882a593Smuzhiyun 	SCLK_UART3_SRC_SEL_MASK                  = 0x3 << SCLK_UART3_SRC_SEL_SHIFT,
349*4882a593Smuzhiyun 	CLK_UART4_SRC_DIV_SHIFT                  = 2,
350*4882a593Smuzhiyun 	CLK_UART4_SRC_DIV_MASK                   = 0x1F << CLK_UART4_SRC_DIV_SHIFT,
351*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON13 */
352*4882a593Smuzhiyun 	CLK_UART4_FRAC_DIV_SHIFT                 = 0,
353*4882a593Smuzhiyun 	CLK_UART4_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART4_FRAC_DIV_SHIFT,
354*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON14 */
355*4882a593Smuzhiyun 	SCLK_UART4_SRC_SEL_SHIFT                 = 0,
356*4882a593Smuzhiyun 	SCLK_UART4_SRC_SEL_MASK                  = 0x3 << SCLK_UART4_SRC_SEL_SHIFT,
357*4882a593Smuzhiyun 	CLK_UART5_SRC_DIV_SHIFT                  = 2,
358*4882a593Smuzhiyun 	CLK_UART5_SRC_DIV_MASK                   = 0x1F << CLK_UART5_SRC_DIV_SHIFT,
359*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON15 */
360*4882a593Smuzhiyun 	CLK_UART5_FRAC_DIV_SHIFT                 = 0,
361*4882a593Smuzhiyun 	CLK_UART5_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART5_FRAC_DIV_SHIFT,
362*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON16 */
363*4882a593Smuzhiyun 	SCLK_UART5_SRC_SEL_SHIFT                 = 0,
364*4882a593Smuzhiyun 	SCLK_UART5_SRC_SEL_MASK                  = 0x3 << SCLK_UART5_SRC_SEL_SHIFT,
365*4882a593Smuzhiyun 	CLK_UART6_SRC_DIV_SHIFT                  = 2,
366*4882a593Smuzhiyun 	CLK_UART6_SRC_DIV_MASK                   = 0x1F << CLK_UART6_SRC_DIV_SHIFT,
367*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON17 */
368*4882a593Smuzhiyun 	CLK_UART6_FRAC_DIV_SHIFT                 = 0,
369*4882a593Smuzhiyun 	CLK_UART6_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART6_FRAC_DIV_SHIFT,
370*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON18 */
371*4882a593Smuzhiyun 	SCLK_UART6_SRC_SEL_SHIFT                 = 0,
372*4882a593Smuzhiyun 	SCLK_UART6_SRC_SEL_MASK                  = 0x3 << SCLK_UART6_SRC_SEL_SHIFT,
373*4882a593Smuzhiyun 	CLK_UART7_SRC_DIV_SHIFT                  = 2,
374*4882a593Smuzhiyun 	CLK_UART7_SRC_DIV_MASK                   = 0x1F << CLK_UART7_SRC_DIV_SHIFT,
375*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON19 */
376*4882a593Smuzhiyun 	CLK_UART7_FRAC_DIV_SHIFT                 = 0,
377*4882a593Smuzhiyun 	CLK_UART7_FRAC_DIV_MASK                  = 0xFFFFFFFF << CLK_UART7_FRAC_DIV_SHIFT,
378*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON20 */
379*4882a593Smuzhiyun 	SCLK_UART7_SRC_SEL_SHIFT                 = 0,
380*4882a593Smuzhiyun 	SCLK_UART7_SRC_SEL_MASK                  = 0x3 << SCLK_UART7_SRC_SEL_SHIFT,
381*4882a593Smuzhiyun 	SCLK_UART0_SRC_SEL_CLK_UART0_SRC         = 0U,
382*4882a593Smuzhiyun 	SCLK_UART0_SRC_SEL_CLK_UART0_FRAC        = 1U,
383*4882a593Smuzhiyun 	SCLK_UART0_SRC_SEL_XIN_OSC0_FUNC         = 2U,
384*4882a593Smuzhiyun 
385*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON60 */
386*4882a593Smuzhiyun 	CLK_GMAC1_VPU_25M_DIV_SHIFT              = 2,
387*4882a593Smuzhiyun 	CLK_GMAC1_VPU_25M_DIV_MASK               = 0xFF << CLK_GMAC1_VPU_25M_DIV_SHIFT,
388*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON66 */
389*4882a593Smuzhiyun 	CLK_GMAC1_SRC_VPU_DIV_SHIFT              = 0,
390*4882a593Smuzhiyun 	CLK_GMAC1_SRC_VPU_DIV_MASK               = 0x3F << CLK_GMAC1_SRC_VPU_DIV_SHIFT,
391*4882a593Smuzhiyun 	/* CRU_CLKSEL_CON84 */
392*4882a593Smuzhiyun 	CLK_GMAC0_SRC_DIV_SHIFT                  = 3,
393*4882a593Smuzhiyun 	CLK_GMAC0_SRC_DIV_MASK                   = 0x3F << CLK_GMAC0_SRC_DIV_SHIFT,
394*4882a593Smuzhiyun };
395*4882a593Smuzhiyun 
396*4882a593Smuzhiyun #endif
397