blob: 412b73e55fa16ff1c16aa7b6fec29b1cbc704c91 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Simon Glass421358c2015-08-30 16:55:31 -06002/*
3 * (C) Copyright 2015 Google, Inc
4 *
5 * (C) Copyright 2008-2014 Rockchip Electronics
6 * Peter, Software Engineering, <superpeter.cai@gmail.com>.
Simon Glass421358c2015-08-30 16:55:31 -06007 */
8#ifndef _ASM_ARCH_CRU_RK3288_H
9#define _ASM_ARCH_CRU_RK3288_H
10
11#define OSC_HZ (24 * 1000 * 1000)
12
13#define APLL_HZ (1800 * 1000000)
14#define GPLL_HZ (594 * 1000000)
15#define CPLL_HZ (384 * 1000000)
16#define NPLL_HZ (384 * 1000000)
17
18/* The SRAM is clocked off aclk_bus, so we want to max it out for boot speed */
19#define PD_BUS_ACLK_HZ 297000000
20#define PD_BUS_HCLK_HZ 148500000
21#define PD_BUS_PCLK_HZ 74250000
22
23#define PERI_ACLK_HZ 148500000
24#define PERI_HCLK_HZ 148500000
25#define PERI_PCLK_HZ 74250000
26
Simon Glass901c2ce2016-10-01 20:04:52 -060027/* Private data for the clock driver - used by rockchip_get_cru() */
28struct rk3288_clk_priv {
29 struct rk3288_grf *grf;
Jagan Teki783acfd2020-01-09 14:22:17 +053030 struct rockchip_cru *cru;
Simon Glass901c2ce2016-10-01 20:04:52 -060031 ulong rate;
32};
33
Jagan Teki783acfd2020-01-09 14:22:17 +053034struct rockchip_cru {
Simon Glass421358c2015-08-30 16:55:31 -060035 struct rk3288_pll {
36 u32 con0;
37 u32 con1;
38 u32 con2;
39 u32 con3;
40 } pll[5];
41 u32 cru_mode_con;
42 u32 reserved0[3];
43 u32 cru_clksel_con[43];
44 u32 reserved1[21];
45 u32 cru_clkgate_con[19];
46 u32 reserved2;
47 u32 cru_glb_srst_fst_value;
48 u32 cru_glb_srst_snd_value;
49 u32 cru_softrst_con[12];
50 u32 cru_misc_con;
51 u32 cru_glb_cnt_th;
52 u32 cru_glb_rst_con;
53 u32 reserved3;
Jagan Teki4fe57d22020-01-09 14:22:18 +053054 u32 glb_rst_st;
Simon Glass421358c2015-08-30 16:55:31 -060055 u32 reserved4;
56 u32 cru_sdmmc_con[2];
57 u32 cru_sdio0_con[2];
58 u32 cru_sdio1_con[2];
59 u32 cru_emmc_con[2];
60};
Jagan Teki783acfd2020-01-09 14:22:17 +053061check_member(rockchip_cru, cru_emmc_con[1], 0x021c);
Simon Glass421358c2015-08-30 16:55:31 -060062
63/* CRU_CLKSEL11_CON */
64enum {
65 HSICPHY_DIV_SHIFT = 8,
Simon Glass303384f2017-05-31 17:57:31 -060066 HSICPHY_DIV_MASK = 0x3f << HSICPHY_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060067
68 MMC0_PLL_SHIFT = 6,
Simon Glass303384f2017-05-31 17:57:31 -060069 MMC0_PLL_MASK = 3 << MMC0_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060070 MMC0_PLL_SELECT_CODEC = 0,
71 MMC0_PLL_SELECT_GENERAL,
72 MMC0_PLL_SELECT_24MHZ,
73
74 MMC0_DIV_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -060075 MMC0_DIV_MASK = 0x3f << MMC0_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060076};
77
Simon Glasscf6741b2018-12-27 20:15:20 -070078/* CRU_CLKSEL8_CON */
79enum {
80 I2S0_FRAC_DENOM_SHIFT = 0,
81 I2S0_FRAC_DENOM_MASK = 0xffff << I2S0_FRAC_DENOM_SHIFT,
82 I2S0_FRAC_NUMER_SHIFT = 16,
83 I2S0_FRAC_NUMER_MASK = 0xffffu << I2S0_FRAC_NUMER_SHIFT,
84};
85
Simon Glass421358c2015-08-30 16:55:31 -060086/* CRU_CLKSEL12_CON */
87enum {
88 EMMC_PLL_SHIFT = 0xe,
Simon Glass303384f2017-05-31 17:57:31 -060089 EMMC_PLL_MASK = 3 << EMMC_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060090 EMMC_PLL_SELECT_CODEC = 0,
91 EMMC_PLL_SELECT_GENERAL,
92 EMMC_PLL_SELECT_24MHZ,
93
94 EMMC_DIV_SHIFT = 8,
Kever Yanga10ece22017-07-31 09:28:14 +080095 EMMC_DIV_MASK = 0x3f << EMMC_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060096
97 SDIO0_PLL_SHIFT = 6,
Simon Glass303384f2017-05-31 17:57:31 -060098 SDIO0_PLL_MASK = 3 << SDIO0_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -060099 SDIO0_PLL_SELECT_CODEC = 0,
100 SDIO0_PLL_SELECT_GENERAL,
101 SDIO0_PLL_SELECT_24MHZ,
102
103 SDIO0_DIV_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600104 SDIO0_DIV_MASK = 0x3f << SDIO0_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600105};
106
Sjoerd Simons3ce69bf2016-02-28 22:24:59 +0100107/* CRU_CLKSEL21_CON */
108enum {
Simon Glass303384f2017-05-31 17:57:31 -0600109 MAC_DIV_CON_SHIFT = 0xf,
110 MAC_DIV_CON_MASK = 0x1f << MAC_DIV_CON_SHIFT,
Sjoerd Simons3ce69bf2016-02-28 22:24:59 +0100111
Simon Glass303384f2017-05-31 17:57:31 -0600112 RMII_EXTCLK_SHIFT = 4,
113 RMII_EXTCLK_MASK = 1 << RMII_EXTCLK_SHIFT,
Sjoerd Simons3ce69bf2016-02-28 22:24:59 +0100114 RMII_EXTCLK_SELECT_INT_DIV_CLK = 0,
115 RMII_EXTCLK_SELECT_EXT_CLK = 1,
116
Simon Glass303384f2017-05-31 17:57:31 -0600117 EMAC_PLL_SHIFT = 0,
118 EMAC_PLL_MASK = 0x3 << EMAC_PLL_SHIFT,
119 EMAC_PLL_SELECT_NEW = 0x0,
120 EMAC_PLL_SELECT_CODEC = 0x1,
121 EMAC_PLL_SELECT_GENERAL = 0x2,
Sjoerd Simons3ce69bf2016-02-28 22:24:59 +0100122};
123
Simon Glass421358c2015-08-30 16:55:31 -0600124/* CRU_CLKSEL25_CON */
125enum {
126 SPI1_PLL_SHIFT = 0xf,
Simon Glass303384f2017-05-31 17:57:31 -0600127 SPI1_PLL_MASK = 1 << SPI1_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600128 SPI1_PLL_SELECT_CODEC = 0,
129 SPI1_PLL_SELECT_GENERAL,
130
131 SPI1_DIV_SHIFT = 8,
Simon Glass303384f2017-05-31 17:57:31 -0600132 SPI1_DIV_MASK = 0x7f << SPI1_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600133
134 SPI0_PLL_SHIFT = 7,
Simon Glass303384f2017-05-31 17:57:31 -0600135 SPI0_PLL_MASK = 1 << SPI0_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600136 SPI0_PLL_SELECT_CODEC = 0,
137 SPI0_PLL_SELECT_GENERAL,
138
139 SPI0_DIV_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600140 SPI0_DIV_MASK = 0x7f << SPI0_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600141};
142
Simon Glass94906e42016-01-21 19:45:17 -0700143/* CRU_CLKSEL37_CON */
144enum {
145 PCLK_CORE_DBG_DIV_SHIFT = 9,
Simon Glass303384f2017-05-31 17:57:31 -0600146 PCLK_CORE_DBG_DIV_MASK = 0x1f << PCLK_CORE_DBG_DIV_SHIFT,
Simon Glass94906e42016-01-21 19:45:17 -0700147
148 ATCLK_CORE_DIV_CON_SHIFT = 4,
Simon Glass303384f2017-05-31 17:57:31 -0600149 ATCLK_CORE_DIV_CON_MASK = 0x1f << ATCLK_CORE_DIV_CON_SHIFT,
Simon Glass94906e42016-01-21 19:45:17 -0700150
151 CLK_L2RAM_DIV_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600152 CLK_L2RAM_DIV_MASK = 7 << CLK_L2RAM_DIV_SHIFT,
Simon Glass94906e42016-01-21 19:45:17 -0700153};
154
Simon Glass421358c2015-08-30 16:55:31 -0600155/* CRU_CLKSEL39_CON */
156enum {
157 ACLK_HEVC_PLL_SHIFT = 0xe,
Simon Glass303384f2017-05-31 17:57:31 -0600158 ACLK_HEVC_PLL_MASK = 3 << ACLK_HEVC_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600159 ACLK_HEVC_PLL_SELECT_CODEC = 0,
160 ACLK_HEVC_PLL_SELECT_GENERAL,
161 ACLK_HEVC_PLL_SELECT_NEW,
162
163 ACLK_HEVC_DIV_SHIFT = 8,
Simon Glass303384f2017-05-31 17:57:31 -0600164 ACLK_HEVC_DIV_MASK = 0x1f << ACLK_HEVC_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600165
166 SPI2_PLL_SHIFT = 7,
Simon Glass303384f2017-05-31 17:57:31 -0600167 SPI2_PLL_MASK = 1 << SPI2_PLL_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600168 SPI2_PLL_SELECT_CODEC = 0,
169 SPI2_PLL_SELECT_GENERAL,
170
171 SPI2_DIV_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600172 SPI2_DIV_MASK = 0x7f << SPI2_DIV_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600173};
174
175/* CRU_MODE_CON */
176enum {
Simon Glass303384f2017-05-31 17:57:31 -0600177 CRU_MODE_MASK = 3,
178
Simon Glass5562bf12016-01-21 19:45:01 -0700179 NPLL_MODE_SHIFT = 0xe,
Simon Glass303384f2017-05-31 17:57:31 -0600180 NPLL_MODE_MASK = CRU_MODE_MASK << NPLL_MODE_SHIFT,
Simon Glass5562bf12016-01-21 19:45:01 -0700181 NPLL_MODE_SLOW = 0,
182 NPLL_MODE_NORMAL,
183 NPLL_MODE_DEEP,
Simon Glass421358c2015-08-30 16:55:31 -0600184
Simon Glass5562bf12016-01-21 19:45:01 -0700185 GPLL_MODE_SHIFT = 0xc,
Simon Glass303384f2017-05-31 17:57:31 -0600186 GPLL_MODE_MASK = CRU_MODE_MASK << GPLL_MODE_SHIFT,
Simon Glass5562bf12016-01-21 19:45:01 -0700187 GPLL_MODE_SLOW = 0,
188 GPLL_MODE_NORMAL,
189 GPLL_MODE_DEEP,
Simon Glass421358c2015-08-30 16:55:31 -0600190
Simon Glass5562bf12016-01-21 19:45:01 -0700191 CPLL_MODE_SHIFT = 8,
Simon Glass303384f2017-05-31 17:57:31 -0600192 CPLL_MODE_MASK = CRU_MODE_MASK << CPLL_MODE_SHIFT,
Simon Glass5562bf12016-01-21 19:45:01 -0700193 CPLL_MODE_SLOW = 0,
194 CPLL_MODE_NORMAL,
195 CPLL_MODE_DEEP,
Simon Glass421358c2015-08-30 16:55:31 -0600196
Simon Glass5562bf12016-01-21 19:45:01 -0700197 DPLL_MODE_SHIFT = 4,
Simon Glass303384f2017-05-31 17:57:31 -0600198 DPLL_MODE_MASK = CRU_MODE_MASK << DPLL_MODE_SHIFT,
Simon Glass5562bf12016-01-21 19:45:01 -0700199 DPLL_MODE_SLOW = 0,
200 DPLL_MODE_NORMAL,
201 DPLL_MODE_DEEP,
Simon Glass421358c2015-08-30 16:55:31 -0600202
Simon Glass5562bf12016-01-21 19:45:01 -0700203 APLL_MODE_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600204 APLL_MODE_MASK = CRU_MODE_MASK << APLL_MODE_SHIFT,
Simon Glass5562bf12016-01-21 19:45:01 -0700205 APLL_MODE_SLOW = 0,
206 APLL_MODE_NORMAL,
207 APLL_MODE_DEEP,
Simon Glass421358c2015-08-30 16:55:31 -0600208};
209
210/* CRU_APLL_CON0 */
211enum {
212 CLKR_SHIFT = 8,
Simon Glass303384f2017-05-31 17:57:31 -0600213 CLKR_MASK = 0x3f << CLKR_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600214
215 CLKOD_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600216 CLKOD_MASK = 0xf << CLKOD_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600217};
218
219/* CRU_APLL_CON1 */
220enum {
221 LOCK_SHIFT = 0x1f,
Simon Glass303384f2017-05-31 17:57:31 -0600222 LOCK_MASK = 1 << LOCK_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600223 LOCK_UNLOCK = 0,
224 LOCK_LOCK,
225
226 CLKF_SHIFT = 0,
Simon Glass303384f2017-05-31 17:57:31 -0600227 CLKF_MASK = 0x1fff << CLKF_SHIFT,
Simon Glass421358c2015-08-30 16:55:31 -0600228};
229
Simon Glass421358c2015-08-30 16:55:31 -0600230#endif