9 /*****cru reg offset*****/
11 #define CRU_MODE_CON 0x40
12 #define CRU_CLKSEL_CON 0x44
13 #define CRU_CLKGATE_CON 0xd0
14 #define CRU_GLB_SRST_FST 0x100
15 #define CRU_GLB_SRST_SND 0x104
16 #define CRU_SOFTRST_CON 0x110
18 #define PLL_CONS(id, i) ((id) * 0x10 + ((i) * 4))
20 #define CRU_CLKSELS_CON_CNT (35)
21 #define CRU_CLKSELS_CON(i) (CRU_CLKSEL_CON + ((i) * 4))
23 #define CRU_CLKGATES_CON_CNT (10)
24 #define CRU_CLKGATES_CON(i) (CRU_CLKGATE_CON + ((i) * 4))
26 #define CRU_SOFTRSTS_CON_CNT (9)
27 #define CRU_SOFTRSTS_CON(i) (CRU_SOFTRST_CON + ((i) * 4))
29 #define CRU_MISC_CON (0x134)
30 #define CRU_GLB_CNT_TH (0x140)
32 /********************************************************************/
33 #define CRU_GET_REG_BITS_VAL(reg,bits_shift, msk) (((reg) >> (bits_shift))&(msk))
34 #define CRU_W_MSK(bits_shift, msk) ((msk) << ((bits_shift) + 16))
35 #define CRU_SET_BITS(val,bits_shift, msk) (((val)&(msk)) << (bits_shift))
37 #define CRU_W_MSK_SETBITS(val,bits_shift,msk) (CRU_W_MSK(bits_shift, msk)|CRU_SET_BITS(val,bits_shift, msk))
39 /*******************PLL CON0 BITS***************************/
41 #define PLL_CLKFACTOR_SET(val, shift, msk) \
42 ((((val) - 1) & (msk)) << (shift))
44 #define PLL_CLKFACTOR_GET(reg, shift, msk) \
45 ((((reg) >> (shift)) & (msk)) + 1)
47 #define PLL_OD_MSK (0x3f)
48 #define PLL_OD_SHIFT (0x0)
50 #define PLL_CLKOD(val) PLL_CLKFACTOR_SET(val, PLL_OD_SHIFT, PLL_OD_MSK)
51 #define PLL_NO(reg) PLL_CLKFACTOR_GET(reg, PLL_OD_SHIFT, PLL_OD_MSK)
53 #define PLL_NO_SHIFT(reg) PLL_CLKFACTOR_GET(reg, PLL_OD_SHIFT, PLL_OD_MSK)
55 #define PLL_CLKOD_SET(val) (PLL_CLKOD(val) | CRU_W_MSK(PLL_OD_SHIFT, PLL_OD_MSK))
57 #define PLL_NR_MSK (0x3f)
58 #define PLL_NR_SHIFT (8)
59 #define PLL_CLKR(val) PLL_CLKFACTOR_SET(val, PLL_NR_SHIFT, PLL_NR_MSK)
60 #define PLL_NR(reg) PLL_CLKFACTOR_GET(reg, PLL_NR_SHIFT, PLL_NR_MSK)
62 #define PLL_CLKR_SET(val) (PLL_CLKR(val) | CRU_W_MSK(PLL_NR_SHIFT, PLL_NR_MSK))
64 /*******************PLL CON1 BITS***************************/
66 #define PLL_NF_MSK (0xffff)
67 #define PLL_NF_SHIFT (0)
68 #define PLL_CLKF(val) PLL_CLKFACTOR_SET(val, PLL_NF_SHIFT, PLL_NF_MSK)
69 #define PLL_NF(reg) PLL_CLKFACTOR_GET(reg, PLL_NF_SHIFT, PLL_NF_MSK)
71 #define PLL_CLKF_SET(val) (PLL_CLKF(val) | CRU_W_MSK(PLL_NF_SHIFT, PLL_NF_MSK))
73 /*******************PLL CON2 BITS***************************/
75 #define PLL_BWADJ_MSK (0xfff)
76 #define PLL_BWADJ_SHIFT (0)
77 #define PLL_CLK_BWADJ_SET(val) ((val) | CRU_W_MSK(PLL_BWADJ_SHIFT, PLL_BWADJ_MSK))
79 /*******************PLL CON3 BITS***************************/
82 #define PLL_REST_MSK (1 << 5)
83 #define PLL_REST_W_MSK (PLL_REST_MSK << 16)
84 #define PLL_REST (1 << 5)
85 #define PLL_REST_RESM (0 << 5)
88 #define PLL_BYPASS_MSK (1 << 0)
89 #define PLL_BYPASS (1 << 0)
90 #define PLL_NO_BYPASS (0 << 0)
92 #define PLL_PWR_DN_MSK (1 << 1)
93 #define PLL_PWR_DN_W_MSK (PLL_PWR_DN_MSK << 16)
94 #define PLL_PWR_DN (1 << 1)
95 #define PLL_PWR_ON (0 << 1)
97 #define PLL_STANDBY_MSK (1 << 2)
98 #define PLL_STANDBY (1 << 2)
99 #define PLL_NO_STANDBY (0 << 2)
100 /*******************CLKSEL0 BITS***************************/
102 #define CORE_PERIPH_W_MSK (3 << 22)
103 #define CORE_PERIPH_MSK (3 << 6)
104 #define CORE_PERIPH_2 (0 << 6)
105 #define CORE_PERIPH_4 (1 << 6)
106 #define CORE_PERIPH_8 (2 << 6)
107 #define CORE_PERIPH_16 (3 << 6)
109 #define CORE_SEL_PLL_MSK (1 << 8)
110 #define CORE_SEL_PLL_W_MSK (1 << 24)
111 #define CORE_SEL_APLL (0 << 8)
112 #define CORE_SEL_GPLL (1 << 8)
114 #define CORE_CLK_DIV_W_MSK (0x1F << 25)
115 #define CORE_CLK_DIV_MSK (0x1F << 9)
116 #define CORE_CLK_DIV(i) (((i) - 1) & 0x1F)
118 #define CPU_SEL_PLL_MSK (1 << 5)
119 #define CPU_SEL_PLL_W_MSK (1 << 21)
120 #define CPU_SEL_APLL (0 << 5)
121 #define CPU_SEL_GPLL (1 << 5)
123 #define CPU_CLK_DIV_W_MSK (0x1F << 16)
124 #define CPU_CLK_DIV_MSK (0x1F)
125 #define CPU_CLK_DIV(i) (((i) - 1) & 0x1F)
127 /*******************CLKSEL1 BITS***************************/
129 #define GET_CORE_ACLK_VAL(reg) ((reg)>=4 ?8:((reg)+1))
131 #define CPU_ACLK_W_MSK (7 << 16)
132 #define CPU_ACLK_MSK (7 << 0)
133 #define CPU_ACLK_11 (0 << 0)
134 #define CPU_ACLK_21 (1 << 0)
135 #define CPU_ACLK_31 (2 << 0)
136 #define CPU_ACLK_41 (3 << 0)
137 #define CPU_ACLK_81 (4 << 0)
139 #define CORE_ACLK_W_MSK (7 << 19)
140 #define CORE_ACLK_MSK (7 << 3)
141 #define CORE_ACLK_11 (0 << 3)
142 #define CORE_ACLK_21 (1 << 3)
143 #define CORE_ACLK_31 (2 << 3)
144 #define CORE_ACLK_41 (3 << 3)
145 #define CORE_ACLK_81 (4 << 3)
147 #define ACLK_HCLK_W_MSK (3 << 24)
148 #define ACLK_HCLK_MSK (3 << 8)
149 #define ACLK_HCLK_11 (0 << 8)
150 #define ACLK_HCLK_21 (1 << 8)
151 #define ACLK_HCLK_41 (2 << 8)
153 #define ACLK_PCLK_W_MSK (3 << 28)
154 #define ACLK_PCLK_MSK (3 << 12)
155 #define ACLK_PCLK_11 (0 << 12)
156 #define ACLK_PCLK_21 (1 << 12)
157 #define ACLK_PCLK_41 (2 << 12)
158 #define ACLK_PCLK_81 (3 << 12)
160 #define AHB2APB_W_MSK (3 << 30)
161 #define AHB2APB_MSK (3 << 14)
162 #define AHB2APB_11 (0 << 14)
163 #define AHB2APB_21 (1 << 14)
164 #define AHB2APB_41 (2 << 14)
166 /*******************MODE BITS***************************/
168 #define PLL_MODE_MSK(id) (0x3 << ((id) * 4))
169 #define PLL_MODE_SLOW(id) ((0x0<<((id)*4))|(0x3<<(16+(id)*4)))
170 #define PLL_MODE_NORM(id) ((0x1<<((id)*4))|(0x3<<(16+(id)*4)))
171 #define PLL_MODE_DEEP(id) ((0x2<<((id)*4))|(0x3<<(16+(id)*4)))
173 /*******************clksel10***************************/
175 #define PERI_ACLK_DIV_MASK 0x1f
176 #define PERI_ACLK_DIV_OFF 0
178 #define PERI_HCLK_DIV_MASK 0x3
179 #define PERI_HCLK_DIV_OFF 8
181 #define PERI_PCLK_DIV_MASK 0x3
182 #define PERI_PCLK_DIV_OFF 12
184 /*******************gate BITS***************************/
186 #define CLK_GATE_CLKID(i) (16 * (i))
187 #define CLK_GATE_CLKID_CONS(i) CRU_CLKGATES_CON((i) / 16)
189 #define CLK_GATE(i) (1 << ((i)%16))
190 #define CLK_UN_GATE(i) (0)
192 #define CLK_GATE_W_MSK(i) (1 << (((i) % 16) + 16))
195 /* SCU CLK GATE 0 CON */
196 CLK_GATE_CORE_PERIPH = CLK_GATE_CLKID(0),
197 CLK_GATE_CPU_GPLL_PATH,
216 CLK_GATE_TIMER0 = CLK_GATE_CLKID(1),
221 CLK_GATE_ACLK_LCDC1_SRC,
227 CLK_GATE_UART0_FRAC_SRC,
229 CLK_GATE_UART1_FRAC_SRC,
232 CLK_GATE_UART2_FRAC_SRC,
234 CLK_GATE_UART3_FRAC_SRC,
236 CLK_GATE_PERIPH_SRC = CLK_GATE_CLKID(2),
237 CLK_GATE_ACLK_PERIPH,
238 CLK_GATE_HCLK_PERIPH,
239 CLK_GATE_PCLK_PERIPH,
244 CLK_GATE_HSADC_FRAC_SRC,
256 CLK_GATE_ACLK_LCDC0_SRC = CLK_GATE_CLKID(3),
257 CLK_GATE_DCLK_LCDC0_SRC,
258 CLK_GATE_DCLK_LCDC1_SRC,
259 CLK_GATE_PCLKIN_CIF0,
263 CLK_GATE_HSICPHY_SRC,
276 CLK_GATE_HCLK_PERI_AXI_MATRIX = CLK_GATE_CLKID(4),
277 CLK_GATE_PCLK_PERI_AXI_MATRIX,
278 CLK_GATE_ACLK_CPU_PERI,
279 CLK_GATE_ACLK_PERI_AXI_MATRIX,
281 CLK_GATE_ACLK_PEI_NIU,
282 CLK_GATE_HCLK_USB_PERI,
283 CLK_GATE_HCLK_PERI_AHB_ARBI,
284 CLK_GATE_HCLK_EMEM_PERI,
286 CLK_GATE_HCLK_CPUBUS,
287 CLK_GATE_HCLK_AHB2APB,
288 CLK_GATE_ACLK_STRC_SYS,
289 CLK_GATE_ACLK_L2MEM_CON,
291 CLK_GATE_ACLK_INTMEM,
296 CLK_GATE_ACLK_DMAC1 = CLK_GATE_CLKID(5),
304 CLK_GATE_PCLK_DDRUPCTL,
308 CLK_GATE_HCLK_SDMMC0,
316 CLK_GATE_ACLK_LCDC0 = CLK_GATE_CLKID(6),
331 CLK_GATE_HCLK_VIO_BUS,
333 CLK_GATE_ACLK_VCODEC,
334 CLK_GATE_HCLK_VIDEO_H2H,
336 CLK_GATE_HCLK_EMAC = CLK_GATE_CLKID(7),
338 CLK_GATE_HCLK_I2S0_2CH,
344 CLK_GATE_PCLK_TIMER0,
346 CLK_GATE_PCLK_TIMER1,
347 CLK_GATE_PCLK_TIMER2,
353 CLK_GATE_PCLK_SARADC,
356 CLK_GATE_PCLK_UART0 = CLK_GATE_CLKID(8),
376 CLK_GATE_CLK_CORE_DBG = CLK_GATE_CLKID(9),
384 CLK_GATE_ACLK_GPU_MST,
386 CLK_GATE_ACLK_GPU_SLV,
399 /* for compatible with rk30xx */
400 #define CLK_GATE_ACLK_CIF1 CLK_GATE_ACLK_CIF0
401 #define CLK_GATE_ACLK_INTMEM0 CLK_GATE_CLK_L2C
402 #define CLK_GATE_ACLK_INTMEM1 CLK_GATE_ACLK_INTMEM0
403 #define CLK_GATE_ACLK_INTMEM2 CLK_GATE_ACLK_INTMEM0
404 #define CLK_GATE_ACLK_INTMEM3 CLK_GATE_ACLK_INTMEM0
406 #define SOFT_RST_ID(i) (16 * (i))
408 enum cru_soft_reset {
409 SOFT_RST_0RES0 = SOFT_RST_ID(0),
426 SOFT_RST_STRC_SYS_AXI,
429 SOFT_RST_1RES0 = SOFT_RST_ID(1),
431 SOFT_RST_L2MEM_CON_AXI,
449 SOFT_RST_GPIO0 = SOFT_RST_ID(2),
469 SOFT_RST_PWM0 = SOFT_RST_ID(3),
480 SOFT_RST_PERIPHSYS_AXI,
481 SOFT_RST_PERIPHSYS_AHB,
482 SOFT_RST_PERIPHSYS_APB,
489 SOFT_RST_DMA2 = SOFT_RST_ID(4),
509 SOFT_RST_TZPC = SOFT_RST_ID(5),
522 SOFT_RST_DDRCTRL_APB,
529 SOFT_RST_6RES0 = SOFT_RST_ID(6),
532 SOFT_RST_VIO_BUS_AHB,
547 SOFT_RST_CIF1,//SOFT_RST_6RES15,
549 SOFT_RST_VCODEC_AXI = SOFT_RST_ID(7),
554 SOFT_RST_VCODEC_NIU_AXI,
561 SOFT_RST_GPU_NIU_AXI,
569 SOFT_RST_TPIU_APB = SOFT_RST_ID(8),
592 /*****cru reg end*****/
594 static inline void cru_set_soft_reset(enum cru_soft_reset idx, bool on)
596 const void __iomem *reg = RK30_CRU_BASE + CRU_SOFTRSTS_CON(idx >> 4);
597 u32 val = on ? 0x10001U << (idx & 0xf) : 0x10000U << (idx & 0xf);
598 writel_relaxed(val, reg);