1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) 2021 Linaro Ltd.
4 * Author: Sam Protsenko <semen.protsenko@linaro.org>
6 * Common Clock Framework support for Exynos850 SoC.
10 #include <linux/clk-provider.h>
12 #include <linux/platform_device.h>
14 #include <dt-bindings/clock/exynos850.h>
18 #include "clk-exynos-arm64.h"
20 /* NOTE: Must be equal to the last clock ID increased by one */
21 #define CLKS_NR_TOP (CLK_DOUT_CPUCL1_SWITCH + 1)
22 #define CLKS_NR_APM (CLK_GOUT_SYSREG_APM_PCLK + 1)
23 #define CLKS_NR_AUD (CLK_GOUT_AUD_CMU_AUD_PCLK + 1)
24 #define CLKS_NR_CMGP (CLK_GOUT_SYSREG_CMGP_PCLK + 1)
25 #define CLKS_NR_CPUCL0 (CLK_CLUSTER0_SCLK + 1)
26 #define CLKS_NR_CPUCL1 (CLK_CLUSTER1_SCLK + 1)
27 #define CLKS_NR_G3D (CLK_GOUT_G3D_SYSREG_PCLK + 1)
28 #define CLKS_NR_HSI (CLK_GOUT_HSI_CMU_HSI_PCLK + 1)
29 #define CLKS_NR_IS (CLK_GOUT_IS_SYSREG_PCLK + 1)
30 #define CLKS_NR_MFCMSCL (CLK_GOUT_MFCMSCL_SYSREG_PCLK + 1)
31 #define CLKS_NR_PERI (CLK_GOUT_BUSIF_TMU_PCLK + 1)
32 #define CLKS_NR_CORE (CLK_GOUT_SPDMA_CORE_ACLK + 1)
33 #define CLKS_NR_DPU (CLK_GOUT_DPU_SYSREG_PCLK + 1)
35 /* ---- CMU_TOP ------------------------------------------------------------- */
37 /* Register Offset definitions for CMU_TOP (0x120e0000) */
38 #define PLL_LOCKTIME_PLL_MMC 0x0000
39 #define PLL_LOCKTIME_PLL_SHARED0 0x0004
40 #define PLL_LOCKTIME_PLL_SHARED1 0x0008
41 #define PLL_CON0_PLL_MMC 0x0100
42 #define PLL_CON3_PLL_MMC 0x010c
43 #define PLL_CON0_PLL_SHARED0 0x0140
44 #define PLL_CON3_PLL_SHARED0 0x014c
45 #define PLL_CON0_PLL_SHARED1 0x0180
46 #define PLL_CON3_PLL_SHARED1 0x018c
47 #define CLK_CON_MUX_MUX_CLKCMU_APM_BUS 0x1000
48 #define CLK_CON_MUX_MUX_CLKCMU_AUD 0x1004
49 #define CLK_CON_MUX_MUX_CLKCMU_CORE_BUS 0x1014
50 #define CLK_CON_MUX_MUX_CLKCMU_CORE_CCI 0x1018
51 #define CLK_CON_MUX_MUX_CLKCMU_CORE_MMC_EMBD 0x101c
52 #define CLK_CON_MUX_MUX_CLKCMU_CORE_SSS 0x1020
53 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG 0x1024
54 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH 0x1028
55 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL1_DBG 0x102c
56 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH 0x1030
57 #define CLK_CON_MUX_MUX_CLKCMU_DPU 0x1034
58 #define CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH 0x1038
59 #define CLK_CON_MUX_MUX_CLKCMU_HSI_BUS 0x103c
60 #define CLK_CON_MUX_MUX_CLKCMU_HSI_MMC_CARD 0x1040
61 #define CLK_CON_MUX_MUX_CLKCMU_HSI_USB20DRD 0x1044
62 #define CLK_CON_MUX_MUX_CLKCMU_IS_BUS 0x1048
63 #define CLK_CON_MUX_MUX_CLKCMU_IS_GDC 0x104c
64 #define CLK_CON_MUX_MUX_CLKCMU_IS_ITP 0x1050
65 #define CLK_CON_MUX_MUX_CLKCMU_IS_VRA 0x1054
66 #define CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_JPEG 0x1058
67 #define CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_M2M 0x105c
68 #define CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MCSC 0x1060
69 #define CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MFC 0x1064
70 #define CLK_CON_MUX_MUX_CLKCMU_PERI_BUS 0x1070
71 #define CLK_CON_MUX_MUX_CLKCMU_PERI_IP 0x1074
72 #define CLK_CON_MUX_MUX_CLKCMU_PERI_UART 0x1078
73 #define CLK_CON_DIV_CLKCMU_APM_BUS 0x180c
74 #define CLK_CON_DIV_CLKCMU_AUD 0x1810
75 #define CLK_CON_DIV_CLKCMU_CORE_BUS 0x1820
76 #define CLK_CON_DIV_CLKCMU_CORE_CCI 0x1824
77 #define CLK_CON_DIV_CLKCMU_CORE_MMC_EMBD 0x1828
78 #define CLK_CON_DIV_CLKCMU_CORE_SSS 0x182c
79 #define CLK_CON_DIV_CLKCMU_CPUCL0_DBG 0x1830
80 #define CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH 0x1834
81 #define CLK_CON_DIV_CLKCMU_CPUCL1_DBG 0x1838
82 #define CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH 0x183c
83 #define CLK_CON_DIV_CLKCMU_DPU 0x1840
84 #define CLK_CON_DIV_CLKCMU_G3D_SWITCH 0x1844
85 #define CLK_CON_DIV_CLKCMU_HSI_BUS 0x1848
86 #define CLK_CON_DIV_CLKCMU_HSI_MMC_CARD 0x184c
87 #define CLK_CON_DIV_CLKCMU_HSI_USB20DRD 0x1850
88 #define CLK_CON_DIV_CLKCMU_IS_BUS 0x1854
89 #define CLK_CON_DIV_CLKCMU_IS_GDC 0x1858
90 #define CLK_CON_DIV_CLKCMU_IS_ITP 0x185c
91 #define CLK_CON_DIV_CLKCMU_IS_VRA 0x1860
92 #define CLK_CON_DIV_CLKCMU_MFCMSCL_JPEG 0x1864
93 #define CLK_CON_DIV_CLKCMU_MFCMSCL_M2M 0x1868
94 #define CLK_CON_DIV_CLKCMU_MFCMSCL_MCSC 0x186c
95 #define CLK_CON_DIV_CLKCMU_MFCMSCL_MFC 0x1870
96 #define CLK_CON_DIV_CLKCMU_PERI_BUS 0x187c
97 #define CLK_CON_DIV_CLKCMU_PERI_IP 0x1880
98 #define CLK_CON_DIV_CLKCMU_PERI_UART 0x1884
99 #define CLK_CON_DIV_PLL_SHARED0_DIV2 0x188c
100 #define CLK_CON_DIV_PLL_SHARED0_DIV3 0x1890
101 #define CLK_CON_DIV_PLL_SHARED0_DIV4 0x1894
102 #define CLK_CON_DIV_PLL_SHARED1_DIV2 0x1898
103 #define CLK_CON_DIV_PLL_SHARED1_DIV3 0x189c
104 #define CLK_CON_DIV_PLL_SHARED1_DIV4 0x18a0
105 #define CLK_CON_GAT_GATE_CLKCMU_APM_BUS 0x2008
106 #define CLK_CON_GAT_GATE_CLKCMU_AUD 0x200c
107 #define CLK_CON_GAT_GATE_CLKCMU_CORE_BUS 0x201c
108 #define CLK_CON_GAT_GATE_CLKCMU_CORE_CCI 0x2020
109 #define CLK_CON_GAT_GATE_CLKCMU_CORE_MMC_EMBD 0x2024
110 #define CLK_CON_GAT_GATE_CLKCMU_CORE_SSS 0x2028
111 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG 0x202c
112 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH 0x2030
113 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_DBG 0x2034
114 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH 0x2038
115 #define CLK_CON_GAT_GATE_CLKCMU_DPU 0x203c
116 #define CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH 0x2040
117 #define CLK_CON_GAT_GATE_CLKCMU_HSI_BUS 0x2044
118 #define CLK_CON_GAT_GATE_CLKCMU_HSI_MMC_CARD 0x2048
119 #define CLK_CON_GAT_GATE_CLKCMU_HSI_USB20DRD 0x204c
120 #define CLK_CON_GAT_GATE_CLKCMU_IS_BUS 0x2050
121 #define CLK_CON_GAT_GATE_CLKCMU_IS_GDC 0x2054
122 #define CLK_CON_GAT_GATE_CLKCMU_IS_ITP 0x2058
123 #define CLK_CON_GAT_GATE_CLKCMU_IS_VRA 0x205c
124 #define CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_JPEG 0x2060
125 #define CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_M2M 0x2064
126 #define CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MCSC 0x2068
127 #define CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MFC 0x206c
128 #define CLK_CON_GAT_GATE_CLKCMU_PERI_BUS 0x2080
129 #define CLK_CON_GAT_GATE_CLKCMU_PERI_IP 0x2084
130 #define CLK_CON_GAT_GATE_CLKCMU_PERI_UART 0x2088
132 static const unsigned long top_clk_regs
[] __initconst
= {
133 PLL_LOCKTIME_PLL_MMC
,
134 PLL_LOCKTIME_PLL_SHARED0
,
135 PLL_LOCKTIME_PLL_SHARED1
,
138 PLL_CON0_PLL_SHARED0
,
139 PLL_CON3_PLL_SHARED0
,
140 PLL_CON0_PLL_SHARED1
,
141 PLL_CON3_PLL_SHARED1
,
142 CLK_CON_MUX_MUX_CLKCMU_APM_BUS
,
143 CLK_CON_MUX_MUX_CLKCMU_AUD
,
144 CLK_CON_MUX_MUX_CLKCMU_CORE_BUS
,
145 CLK_CON_MUX_MUX_CLKCMU_CORE_CCI
,
146 CLK_CON_MUX_MUX_CLKCMU_CORE_MMC_EMBD
,
147 CLK_CON_MUX_MUX_CLKCMU_CORE_SSS
,
148 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG
,
149 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH
,
150 CLK_CON_MUX_MUX_CLKCMU_CPUCL1_DBG
,
151 CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH
,
152 CLK_CON_MUX_MUX_CLKCMU_DPU
,
153 CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH
,
154 CLK_CON_MUX_MUX_CLKCMU_HSI_BUS
,
155 CLK_CON_MUX_MUX_CLKCMU_HSI_MMC_CARD
,
156 CLK_CON_MUX_MUX_CLKCMU_HSI_USB20DRD
,
157 CLK_CON_MUX_MUX_CLKCMU_IS_BUS
,
158 CLK_CON_MUX_MUX_CLKCMU_IS_GDC
,
159 CLK_CON_MUX_MUX_CLKCMU_IS_ITP
,
160 CLK_CON_MUX_MUX_CLKCMU_IS_VRA
,
161 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_JPEG
,
162 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_M2M
,
163 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MCSC
,
164 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MFC
,
165 CLK_CON_MUX_MUX_CLKCMU_PERI_BUS
,
166 CLK_CON_MUX_MUX_CLKCMU_PERI_IP
,
167 CLK_CON_MUX_MUX_CLKCMU_PERI_UART
,
168 CLK_CON_DIV_CLKCMU_APM_BUS
,
169 CLK_CON_DIV_CLKCMU_AUD
,
170 CLK_CON_DIV_CLKCMU_CORE_BUS
,
171 CLK_CON_DIV_CLKCMU_CORE_CCI
,
172 CLK_CON_DIV_CLKCMU_CORE_MMC_EMBD
,
173 CLK_CON_DIV_CLKCMU_CORE_SSS
,
174 CLK_CON_DIV_CLKCMU_CPUCL0_DBG
,
175 CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH
,
176 CLK_CON_DIV_CLKCMU_CPUCL1_DBG
,
177 CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH
,
178 CLK_CON_DIV_CLKCMU_DPU
,
179 CLK_CON_DIV_CLKCMU_G3D_SWITCH
,
180 CLK_CON_DIV_CLKCMU_HSI_BUS
,
181 CLK_CON_DIV_CLKCMU_HSI_MMC_CARD
,
182 CLK_CON_DIV_CLKCMU_HSI_USB20DRD
,
183 CLK_CON_DIV_CLKCMU_IS_BUS
,
184 CLK_CON_DIV_CLKCMU_IS_GDC
,
185 CLK_CON_DIV_CLKCMU_IS_ITP
,
186 CLK_CON_DIV_CLKCMU_IS_VRA
,
187 CLK_CON_DIV_CLKCMU_MFCMSCL_JPEG
,
188 CLK_CON_DIV_CLKCMU_MFCMSCL_M2M
,
189 CLK_CON_DIV_CLKCMU_MFCMSCL_MCSC
,
190 CLK_CON_DIV_CLKCMU_MFCMSCL_MFC
,
191 CLK_CON_DIV_CLKCMU_PERI_BUS
,
192 CLK_CON_DIV_CLKCMU_PERI_IP
,
193 CLK_CON_DIV_CLKCMU_PERI_UART
,
194 CLK_CON_DIV_PLL_SHARED0_DIV2
,
195 CLK_CON_DIV_PLL_SHARED0_DIV3
,
196 CLK_CON_DIV_PLL_SHARED0_DIV4
,
197 CLK_CON_DIV_PLL_SHARED1_DIV2
,
198 CLK_CON_DIV_PLL_SHARED1_DIV3
,
199 CLK_CON_DIV_PLL_SHARED1_DIV4
,
200 CLK_CON_GAT_GATE_CLKCMU_APM_BUS
,
201 CLK_CON_GAT_GATE_CLKCMU_AUD
,
202 CLK_CON_GAT_GATE_CLKCMU_CORE_BUS
,
203 CLK_CON_GAT_GATE_CLKCMU_CORE_CCI
,
204 CLK_CON_GAT_GATE_CLKCMU_CORE_MMC_EMBD
,
205 CLK_CON_GAT_GATE_CLKCMU_CORE_SSS
,
206 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG
,
207 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH
,
208 CLK_CON_GAT_GATE_CLKCMU_CPUCL1_DBG
,
209 CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH
,
210 CLK_CON_GAT_GATE_CLKCMU_DPU
,
211 CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH
,
212 CLK_CON_GAT_GATE_CLKCMU_HSI_BUS
,
213 CLK_CON_GAT_GATE_CLKCMU_HSI_MMC_CARD
,
214 CLK_CON_GAT_GATE_CLKCMU_HSI_USB20DRD
,
215 CLK_CON_GAT_GATE_CLKCMU_IS_BUS
,
216 CLK_CON_GAT_GATE_CLKCMU_IS_GDC
,
217 CLK_CON_GAT_GATE_CLKCMU_IS_ITP
,
218 CLK_CON_GAT_GATE_CLKCMU_IS_VRA
,
219 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_JPEG
,
220 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_M2M
,
221 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MCSC
,
222 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MFC
,
223 CLK_CON_GAT_GATE_CLKCMU_PERI_BUS
,
224 CLK_CON_GAT_GATE_CLKCMU_PERI_IP
,
225 CLK_CON_GAT_GATE_CLKCMU_PERI_UART
,
229 * Do not provide PLL tables to core PLLs, as MANUAL_PLL_CTRL bit is not set
230 * for those PLLs by default, so set_rate operation would fail.
232 static const struct samsung_pll_clock top_pll_clks
[] __initconst
= {
233 /* CMU_TOP_PURECLKCOMP */
234 PLL(pll_0822x
, CLK_FOUT_SHARED0_PLL
, "fout_shared0_pll", "oscclk",
235 PLL_LOCKTIME_PLL_SHARED0
, PLL_CON3_PLL_SHARED0
,
237 PLL(pll_0822x
, CLK_FOUT_SHARED1_PLL
, "fout_shared1_pll", "oscclk",
238 PLL_LOCKTIME_PLL_SHARED1
, PLL_CON3_PLL_SHARED1
,
240 PLL(pll_0831x
, CLK_FOUT_MMC_PLL
, "fout_mmc_pll", "oscclk",
241 PLL_LOCKTIME_PLL_MMC
, PLL_CON3_PLL_MMC
, NULL
),
244 /* List of parent clocks for Muxes in CMU_TOP */
245 PNAME(mout_shared0_pll_p
) = { "oscclk", "fout_shared0_pll" };
246 PNAME(mout_shared1_pll_p
) = { "oscclk", "fout_shared1_pll" };
247 PNAME(mout_mmc_pll_p
) = { "oscclk", "fout_mmc_pll" };
248 /* List of parent clocks for Muxes in CMU_TOP: for CMU_APM */
249 PNAME(mout_clkcmu_apm_bus_p
) = { "dout_shared0_div4", "pll_shared1_div4" };
250 /* List of parent clocks for Muxes in CMU_TOP: for CMU_AUD */
251 PNAME(mout_aud_p
) = { "fout_shared1_pll", "dout_shared0_div2",
252 "dout_shared1_div2", "dout_shared0_div3" };
253 /* List of parent clocks for Muxes in CMU_TOP: for CMU_CORE */
254 PNAME(mout_core_bus_p
) = { "dout_shared1_div2", "dout_shared0_div3",
255 "dout_shared1_div3", "dout_shared0_div4" };
256 PNAME(mout_core_cci_p
) = { "dout_shared0_div2", "dout_shared1_div2",
257 "dout_shared0_div3", "dout_shared1_div3" };
258 PNAME(mout_core_mmc_embd_p
) = { "oscclk", "dout_shared0_div2",
259 "dout_shared1_div2", "dout_shared0_div3",
260 "dout_shared1_div3", "mout_mmc_pll",
261 "oscclk", "oscclk" };
262 PNAME(mout_core_sss_p
) = { "dout_shared0_div3", "dout_shared1_div3",
263 "dout_shared0_div4", "dout_shared1_div4" };
264 /* List of parent clocks for Muxes in CMU_TOP: for CMU_CPUCL0 */
265 PNAME(mout_cpucl0_switch_p
) = { "fout_shared0_pll", "fout_shared1_pll",
266 "dout_shared0_div2", "dout_shared1_div2" };
267 PNAME(mout_cpucl0_dbg_p
) = { "dout_shared0_div4", "dout_shared1_div4" };
268 /* List of parent clocks for Muxes in CMU_TOP: for CMU_CPUCL1 */
269 PNAME(mout_cpucl1_switch_p
) = { "fout_shared0_pll", "fout_shared1_pll",
270 "dout_shared0_div2", "dout_shared1_div2" };
271 PNAME(mout_cpucl1_dbg_p
) = { "dout_shared0_div4", "dout_shared1_div4" };
272 /* List of parent clocks for Muxes in CMU_TOP: for CMU_G3D */
273 PNAME(mout_g3d_switch_p
) = { "dout_shared0_div2", "dout_shared1_div2",
274 "dout_shared0_div3", "dout_shared1_div3" };
275 /* List of parent clocks for Muxes in CMU_TOP: for CMU_HSI */
276 PNAME(mout_hsi_bus_p
) = { "dout_shared0_div2", "dout_shared1_div2" };
277 PNAME(mout_hsi_mmc_card_p
) = { "oscclk", "dout_shared0_div2",
278 "dout_shared1_div2", "dout_shared0_div3",
279 "dout_shared1_div3", "mout_mmc_pll",
280 "oscclk", "oscclk" };
281 PNAME(mout_hsi_usb20drd_p
) = { "oscclk", "dout_shared0_div4",
282 "dout_shared1_div4", "oscclk" };
283 /* List of parent clocks for Muxes in CMU_TOP: for CMU_IS */
284 PNAME(mout_is_bus_p
) = { "dout_shared0_div2", "dout_shared1_div2",
285 "dout_shared0_div3", "dout_shared1_div3" };
286 PNAME(mout_is_itp_p
) = { "dout_shared0_div2", "dout_shared1_div2",
287 "dout_shared0_div3", "dout_shared1_div3" };
288 PNAME(mout_is_vra_p
) = { "dout_shared0_div2", "dout_shared1_div2",
289 "dout_shared0_div3", "dout_shared1_div3" };
290 PNAME(mout_is_gdc_p
) = { "dout_shared0_div2", "dout_shared1_div2",
291 "dout_shared0_div3", "dout_shared1_div3" };
292 /* List of parent clocks for Muxes in CMU_TOP: for CMU_MFCMSCL */
293 PNAME(mout_mfcmscl_mfc_p
) = { "dout_shared1_div2", "dout_shared0_div3",
294 "dout_shared1_div3", "dout_shared0_div4" };
295 PNAME(mout_mfcmscl_m2m_p
) = { "dout_shared1_div2", "dout_shared0_div3",
296 "dout_shared1_div3", "dout_shared0_div4" };
297 PNAME(mout_mfcmscl_mcsc_p
) = { "dout_shared1_div2", "dout_shared0_div3",
298 "dout_shared1_div3", "dout_shared0_div4" };
299 PNAME(mout_mfcmscl_jpeg_p
) = { "dout_shared0_div3", "dout_shared1_div3",
300 "dout_shared0_div4", "dout_shared1_div4" };
301 /* List of parent clocks for Muxes in CMU_TOP: for CMU_PERI */
302 PNAME(mout_peri_bus_p
) = { "dout_shared0_div4", "dout_shared1_div4" };
303 PNAME(mout_peri_uart_p
) = { "oscclk", "dout_shared0_div4",
304 "dout_shared1_div4", "oscclk" };
305 PNAME(mout_peri_ip_p
) = { "oscclk", "dout_shared0_div4",
306 "dout_shared1_div4", "oscclk" };
307 /* List of parent clocks for Muxes in CMU_TOP: for CMU_DPU */
308 PNAME(mout_dpu_p
) = { "dout_shared0_div3", "dout_shared1_div3",
309 "dout_shared0_div4", "dout_shared1_div4" };
311 static const struct samsung_mux_clock top_mux_clks
[] __initconst
= {
312 /* CMU_TOP_PURECLKCOMP */
313 MUX(CLK_MOUT_SHARED0_PLL
, "mout_shared0_pll", mout_shared0_pll_p
,
314 PLL_CON0_PLL_SHARED0
, 4, 1),
315 MUX(CLK_MOUT_SHARED1_PLL
, "mout_shared1_pll", mout_shared1_pll_p
,
316 PLL_CON0_PLL_SHARED1
, 4, 1),
317 MUX(CLK_MOUT_MMC_PLL
, "mout_mmc_pll", mout_mmc_pll_p
,
318 PLL_CON0_PLL_MMC
, 4, 1),
321 MUX(CLK_MOUT_CLKCMU_APM_BUS
, "mout_clkcmu_apm_bus",
322 mout_clkcmu_apm_bus_p
, CLK_CON_MUX_MUX_CLKCMU_APM_BUS
, 0, 1),
325 MUX(CLK_MOUT_AUD
, "mout_aud", mout_aud_p
,
326 CLK_CON_MUX_MUX_CLKCMU_AUD
, 0, 2),
329 MUX(CLK_MOUT_CORE_BUS
, "mout_core_bus", mout_core_bus_p
,
330 CLK_CON_MUX_MUX_CLKCMU_CORE_BUS
, 0, 2),
331 MUX(CLK_MOUT_CORE_CCI
, "mout_core_cci", mout_core_cci_p
,
332 CLK_CON_MUX_MUX_CLKCMU_CORE_CCI
, 0, 2),
333 MUX(CLK_MOUT_CORE_MMC_EMBD
, "mout_core_mmc_embd", mout_core_mmc_embd_p
,
334 CLK_CON_MUX_MUX_CLKCMU_CORE_MMC_EMBD
, 0, 3),
335 MUX(CLK_MOUT_CORE_SSS
, "mout_core_sss", mout_core_sss_p
,
336 CLK_CON_MUX_MUX_CLKCMU_CORE_SSS
, 0, 2),
339 MUX(CLK_MOUT_CPUCL0_DBG
, "mout_cpucl0_dbg", mout_cpucl0_dbg_p
,
340 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG
, 0, 1),
341 MUX(CLK_MOUT_CPUCL0_SWITCH
, "mout_cpucl0_switch", mout_cpucl0_switch_p
,
342 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH
, 0, 2),
345 MUX(CLK_MOUT_CPUCL1_DBG
, "mout_cpucl1_dbg", mout_cpucl1_dbg_p
,
346 CLK_CON_MUX_MUX_CLKCMU_CPUCL1_DBG
, 0, 1),
347 MUX(CLK_MOUT_CPUCL1_SWITCH
, "mout_cpucl1_switch", mout_cpucl1_switch_p
,
348 CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH
, 0, 2),
351 MUX(CLK_MOUT_DPU
, "mout_dpu", mout_dpu_p
,
352 CLK_CON_MUX_MUX_CLKCMU_DPU
, 0, 2),
355 MUX(CLK_MOUT_G3D_SWITCH
, "mout_g3d_switch", mout_g3d_switch_p
,
356 CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH
, 0, 2),
359 MUX(CLK_MOUT_HSI_BUS
, "mout_hsi_bus", mout_hsi_bus_p
,
360 CLK_CON_MUX_MUX_CLKCMU_HSI_BUS
, 0, 1),
361 MUX(CLK_MOUT_HSI_MMC_CARD
, "mout_hsi_mmc_card", mout_hsi_mmc_card_p
,
362 CLK_CON_MUX_MUX_CLKCMU_HSI_MMC_CARD
, 0, 3),
363 MUX(CLK_MOUT_HSI_USB20DRD
, "mout_hsi_usb20drd", mout_hsi_usb20drd_p
,
364 CLK_CON_MUX_MUX_CLKCMU_HSI_USB20DRD
, 0, 2),
367 MUX(CLK_MOUT_IS_BUS
, "mout_is_bus", mout_is_bus_p
,
368 CLK_CON_MUX_MUX_CLKCMU_IS_BUS
, 0, 2),
369 MUX(CLK_MOUT_IS_ITP
, "mout_is_itp", mout_is_itp_p
,
370 CLK_CON_MUX_MUX_CLKCMU_IS_ITP
, 0, 2),
371 MUX(CLK_MOUT_IS_VRA
, "mout_is_vra", mout_is_vra_p
,
372 CLK_CON_MUX_MUX_CLKCMU_IS_VRA
, 0, 2),
373 MUX(CLK_MOUT_IS_GDC
, "mout_is_gdc", mout_is_gdc_p
,
374 CLK_CON_MUX_MUX_CLKCMU_IS_GDC
, 0, 2),
377 MUX(CLK_MOUT_MFCMSCL_MFC
, "mout_mfcmscl_mfc", mout_mfcmscl_mfc_p
,
378 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MFC
, 0, 2),
379 MUX(CLK_MOUT_MFCMSCL_M2M
, "mout_mfcmscl_m2m", mout_mfcmscl_m2m_p
,
380 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_M2M
, 0, 2),
381 MUX(CLK_MOUT_MFCMSCL_MCSC
, "mout_mfcmscl_mcsc", mout_mfcmscl_mcsc_p
,
382 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_MCSC
, 0, 2),
383 MUX(CLK_MOUT_MFCMSCL_JPEG
, "mout_mfcmscl_jpeg", mout_mfcmscl_jpeg_p
,
384 CLK_CON_MUX_MUX_CLKCMU_MFCMSCL_JPEG
, 0, 2),
387 MUX(CLK_MOUT_PERI_BUS
, "mout_peri_bus", mout_peri_bus_p
,
388 CLK_CON_MUX_MUX_CLKCMU_PERI_BUS
, 0, 1),
389 MUX(CLK_MOUT_PERI_UART
, "mout_peri_uart", mout_peri_uart_p
,
390 CLK_CON_MUX_MUX_CLKCMU_PERI_UART
, 0, 2),
391 MUX(CLK_MOUT_PERI_IP
, "mout_peri_ip", mout_peri_ip_p
,
392 CLK_CON_MUX_MUX_CLKCMU_PERI_IP
, 0, 2),
395 static const struct samsung_div_clock top_div_clks
[] __initconst
= {
396 /* CMU_TOP_PURECLKCOMP */
397 DIV(CLK_DOUT_SHARED0_DIV3
, "dout_shared0_div3", "mout_shared0_pll",
398 CLK_CON_DIV_PLL_SHARED0_DIV3
, 0, 2),
399 DIV(CLK_DOUT_SHARED0_DIV2
, "dout_shared0_div2", "mout_shared0_pll",
400 CLK_CON_DIV_PLL_SHARED0_DIV2
, 0, 1),
401 DIV(CLK_DOUT_SHARED1_DIV3
, "dout_shared1_div3", "mout_shared1_pll",
402 CLK_CON_DIV_PLL_SHARED1_DIV3
, 0, 2),
403 DIV(CLK_DOUT_SHARED1_DIV2
, "dout_shared1_div2", "mout_shared1_pll",
404 CLK_CON_DIV_PLL_SHARED1_DIV2
, 0, 1),
405 DIV(CLK_DOUT_SHARED0_DIV4
, "dout_shared0_div4", "dout_shared0_div2",
406 CLK_CON_DIV_PLL_SHARED0_DIV4
, 0, 1),
407 DIV(CLK_DOUT_SHARED1_DIV4
, "dout_shared1_div4", "dout_shared1_div2",
408 CLK_CON_DIV_PLL_SHARED1_DIV4
, 0, 1),
411 DIV(CLK_DOUT_CLKCMU_APM_BUS
, "dout_clkcmu_apm_bus",
412 "gout_clkcmu_apm_bus", CLK_CON_DIV_CLKCMU_APM_BUS
, 0, 3),
415 DIV(CLK_DOUT_AUD
, "dout_aud", "gout_aud",
416 CLK_CON_DIV_CLKCMU_AUD
, 0, 4),
419 DIV(CLK_DOUT_CORE_BUS
, "dout_core_bus", "gout_core_bus",
420 CLK_CON_DIV_CLKCMU_CORE_BUS
, 0, 4),
421 DIV(CLK_DOUT_CORE_CCI
, "dout_core_cci", "gout_core_cci",
422 CLK_CON_DIV_CLKCMU_CORE_CCI
, 0, 4),
423 DIV(CLK_DOUT_CORE_MMC_EMBD
, "dout_core_mmc_embd", "gout_core_mmc_embd",
424 CLK_CON_DIV_CLKCMU_CORE_MMC_EMBD
, 0, 9),
425 DIV(CLK_DOUT_CORE_SSS
, "dout_core_sss", "gout_core_sss",
426 CLK_CON_DIV_CLKCMU_CORE_SSS
, 0, 4),
429 DIV(CLK_DOUT_CPUCL0_DBG
, "dout_cpucl0_dbg", "gout_cpucl0_dbg",
430 CLK_CON_DIV_CLKCMU_CPUCL0_DBG
, 0, 3),
431 DIV(CLK_DOUT_CPUCL0_SWITCH
, "dout_cpucl0_switch", "gout_cpucl0_switch",
432 CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH
, 0, 3),
435 DIV(CLK_DOUT_CPUCL1_DBG
, "dout_cpucl1_dbg", "gout_cpucl1_dbg",
436 CLK_CON_DIV_CLKCMU_CPUCL1_DBG
, 0, 3),
437 DIV(CLK_DOUT_CPUCL1_SWITCH
, "dout_cpucl1_switch", "gout_cpucl1_switch",
438 CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH
, 0, 3),
441 DIV(CLK_DOUT_DPU
, "dout_dpu", "gout_dpu",
442 CLK_CON_DIV_CLKCMU_DPU
, 0, 4),
445 DIV(CLK_DOUT_G3D_SWITCH
, "dout_g3d_switch", "gout_g3d_switch",
446 CLK_CON_DIV_CLKCMU_G3D_SWITCH
, 0, 3),
449 DIV(CLK_DOUT_HSI_BUS
, "dout_hsi_bus", "gout_hsi_bus",
450 CLK_CON_DIV_CLKCMU_HSI_BUS
, 0, 4),
451 DIV(CLK_DOUT_HSI_MMC_CARD
, "dout_hsi_mmc_card", "gout_hsi_mmc_card",
452 CLK_CON_DIV_CLKCMU_HSI_MMC_CARD
, 0, 9),
453 DIV(CLK_DOUT_HSI_USB20DRD
, "dout_hsi_usb20drd", "gout_hsi_usb20drd",
454 CLK_CON_DIV_CLKCMU_HSI_USB20DRD
, 0, 4),
457 DIV(CLK_DOUT_IS_BUS
, "dout_is_bus", "gout_is_bus",
458 CLK_CON_DIV_CLKCMU_IS_BUS
, 0, 4),
459 DIV(CLK_DOUT_IS_ITP
, "dout_is_itp", "gout_is_itp",
460 CLK_CON_DIV_CLKCMU_IS_ITP
, 0, 4),
461 DIV(CLK_DOUT_IS_VRA
, "dout_is_vra", "gout_is_vra",
462 CLK_CON_DIV_CLKCMU_IS_VRA
, 0, 4),
463 DIV(CLK_DOUT_IS_GDC
, "dout_is_gdc", "gout_is_gdc",
464 CLK_CON_DIV_CLKCMU_IS_GDC
, 0, 4),
467 DIV(CLK_DOUT_MFCMSCL_MFC
, "dout_mfcmscl_mfc", "gout_mfcmscl_mfc",
468 CLK_CON_DIV_CLKCMU_MFCMSCL_MFC
, 0, 4),
469 DIV(CLK_DOUT_MFCMSCL_M2M
, "dout_mfcmscl_m2m", "gout_mfcmscl_m2m",
470 CLK_CON_DIV_CLKCMU_MFCMSCL_M2M
, 0, 4),
471 DIV(CLK_DOUT_MFCMSCL_MCSC
, "dout_mfcmscl_mcsc", "gout_mfcmscl_mcsc",
472 CLK_CON_DIV_CLKCMU_MFCMSCL_MCSC
, 0, 4),
473 DIV(CLK_DOUT_MFCMSCL_JPEG
, "dout_mfcmscl_jpeg", "gout_mfcmscl_jpeg",
474 CLK_CON_DIV_CLKCMU_MFCMSCL_JPEG
, 0, 4),
477 DIV(CLK_DOUT_PERI_BUS
, "dout_peri_bus", "gout_peri_bus",
478 CLK_CON_DIV_CLKCMU_PERI_BUS
, 0, 4),
479 DIV(CLK_DOUT_PERI_UART
, "dout_peri_uart", "gout_peri_uart",
480 CLK_CON_DIV_CLKCMU_PERI_UART
, 0, 4),
481 DIV(CLK_DOUT_PERI_IP
, "dout_peri_ip", "gout_peri_ip",
482 CLK_CON_DIV_CLKCMU_PERI_IP
, 0, 4),
485 static const struct samsung_gate_clock top_gate_clks
[] __initconst
= {
487 GATE(CLK_GOUT_CORE_BUS
, "gout_core_bus", "mout_core_bus",
488 CLK_CON_GAT_GATE_CLKCMU_CORE_BUS
, 21, 0, 0),
489 GATE(CLK_GOUT_CORE_CCI
, "gout_core_cci", "mout_core_cci",
490 CLK_CON_GAT_GATE_CLKCMU_CORE_CCI
, 21, 0, 0),
491 GATE(CLK_GOUT_CORE_MMC_EMBD
, "gout_core_mmc_embd", "mout_core_mmc_embd",
492 CLK_CON_GAT_GATE_CLKCMU_CORE_MMC_EMBD
, 21, 0, 0),
493 GATE(CLK_GOUT_CORE_SSS
, "gout_core_sss", "mout_core_sss",
494 CLK_CON_GAT_GATE_CLKCMU_CORE_SSS
, 21, 0, 0),
497 GATE(CLK_GOUT_CLKCMU_APM_BUS
, "gout_clkcmu_apm_bus",
498 "mout_clkcmu_apm_bus", CLK_CON_GAT_GATE_CLKCMU_APM_BUS
, 21, 0, 0),
501 GATE(CLK_GOUT_AUD
, "gout_aud", "mout_aud",
502 CLK_CON_GAT_GATE_CLKCMU_AUD
, 21, 0, 0),
505 GATE(CLK_GOUT_CPUCL0_DBG
, "gout_cpucl0_dbg", "mout_cpucl0_dbg",
506 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG
, 21, 0, 0),
507 GATE(CLK_GOUT_CPUCL0_SWITCH
, "gout_cpucl0_switch", "mout_cpucl0_switch",
508 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH
, 21, 0, 0),
511 GATE(CLK_GOUT_CPUCL1_DBG
, "gout_cpucl1_dbg", "mout_cpucl1_dbg",
512 CLK_CON_GAT_GATE_CLKCMU_CPUCL1_DBG
, 21, 0, 0),
513 GATE(CLK_GOUT_CPUCL1_SWITCH
, "gout_cpucl1_switch", "mout_cpucl1_switch",
514 CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH
, 21, 0, 0),
517 GATE(CLK_GOUT_DPU
, "gout_dpu", "mout_dpu",
518 CLK_CON_GAT_GATE_CLKCMU_DPU
, 21, 0, 0),
521 GATE(CLK_GOUT_G3D_SWITCH
, "gout_g3d_switch", "mout_g3d_switch",
522 CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH
, 21, 0, 0),
525 GATE(CLK_GOUT_HSI_BUS
, "gout_hsi_bus", "mout_hsi_bus",
526 CLK_CON_GAT_GATE_CLKCMU_HSI_BUS
, 21, 0, 0),
527 GATE(CLK_GOUT_HSI_MMC_CARD
, "gout_hsi_mmc_card", "mout_hsi_mmc_card",
528 CLK_CON_GAT_GATE_CLKCMU_HSI_MMC_CARD
, 21, 0, 0),
529 GATE(CLK_GOUT_HSI_USB20DRD
, "gout_hsi_usb20drd", "mout_hsi_usb20drd",
530 CLK_CON_GAT_GATE_CLKCMU_HSI_USB20DRD
, 21, 0, 0),
533 /* TODO: These clocks have to be always enabled to access CMU_IS regs */
534 GATE(CLK_GOUT_IS_BUS
, "gout_is_bus", "mout_is_bus",
535 CLK_CON_GAT_GATE_CLKCMU_IS_BUS
, 21, CLK_IS_CRITICAL
, 0),
536 GATE(CLK_GOUT_IS_ITP
, "gout_is_itp", "mout_is_itp",
537 CLK_CON_GAT_GATE_CLKCMU_IS_ITP
, 21, CLK_IS_CRITICAL
, 0),
538 GATE(CLK_GOUT_IS_VRA
, "gout_is_vra", "mout_is_vra",
539 CLK_CON_GAT_GATE_CLKCMU_IS_VRA
, 21, CLK_IS_CRITICAL
, 0),
540 GATE(CLK_GOUT_IS_GDC
, "gout_is_gdc", "mout_is_gdc",
541 CLK_CON_GAT_GATE_CLKCMU_IS_GDC
, 21, CLK_IS_CRITICAL
, 0),
544 /* TODO: These have to be always enabled to access CMU_MFCMSCL regs */
545 GATE(CLK_GOUT_MFCMSCL_MFC
, "gout_mfcmscl_mfc", "mout_mfcmscl_mfc",
546 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MFC
, 21, CLK_IS_CRITICAL
, 0),
547 GATE(CLK_GOUT_MFCMSCL_M2M
, "gout_mfcmscl_m2m", "mout_mfcmscl_m2m",
548 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_M2M
, 21, CLK_IS_CRITICAL
, 0),
549 GATE(CLK_GOUT_MFCMSCL_MCSC
, "gout_mfcmscl_mcsc", "mout_mfcmscl_mcsc",
550 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_MCSC
, 21, CLK_IS_CRITICAL
, 0),
551 GATE(CLK_GOUT_MFCMSCL_JPEG
, "gout_mfcmscl_jpeg", "mout_mfcmscl_jpeg",
552 CLK_CON_GAT_GATE_CLKCMU_MFCMSCL_JPEG
, 21, CLK_IS_CRITICAL
, 0),
555 GATE(CLK_GOUT_PERI_BUS
, "gout_peri_bus", "mout_peri_bus",
556 CLK_CON_GAT_GATE_CLKCMU_PERI_BUS
, 21, 0, 0),
557 GATE(CLK_GOUT_PERI_UART
, "gout_peri_uart", "mout_peri_uart",
558 CLK_CON_GAT_GATE_CLKCMU_PERI_UART
, 21, 0, 0),
559 GATE(CLK_GOUT_PERI_IP
, "gout_peri_ip", "mout_peri_ip",
560 CLK_CON_GAT_GATE_CLKCMU_PERI_IP
, 21, 0, 0),
563 static const struct samsung_cmu_info top_cmu_info __initconst
= {
564 .pll_clks
= top_pll_clks
,
565 .nr_pll_clks
= ARRAY_SIZE(top_pll_clks
),
566 .mux_clks
= top_mux_clks
,
567 .nr_mux_clks
= ARRAY_SIZE(top_mux_clks
),
568 .div_clks
= top_div_clks
,
569 .nr_div_clks
= ARRAY_SIZE(top_div_clks
),
570 .gate_clks
= top_gate_clks
,
571 .nr_gate_clks
= ARRAY_SIZE(top_gate_clks
),
572 .nr_clk_ids
= CLKS_NR_TOP
,
573 .clk_regs
= top_clk_regs
,
574 .nr_clk_regs
= ARRAY_SIZE(top_clk_regs
),
577 static void __init
exynos850_cmu_top_init(struct device_node
*np
)
579 exynos_arm64_register_cmu(NULL
, np
, &top_cmu_info
);
582 /* Register CMU_TOP early, as it's a dependency for other early domains */
583 CLK_OF_DECLARE(exynos850_cmu_top
, "samsung,exynos850-cmu-top",
584 exynos850_cmu_top_init
);
586 /* ---- CMU_APM ------------------------------------------------------------- */
588 /* Register Offset definitions for CMU_APM (0x11800000) */
589 #define PLL_CON0_MUX_CLKCMU_APM_BUS_USER 0x0600
590 #define PLL_CON0_MUX_CLK_RCO_APM_I3C_USER 0x0610
591 #define PLL_CON0_MUX_CLK_RCO_APM_USER 0x0620
592 #define PLL_CON0_MUX_DLL_USER 0x0630
593 #define CLK_CON_MUX_MUX_CLKCMU_CHUB_BUS 0x1000
594 #define CLK_CON_MUX_MUX_CLK_APM_BUS 0x1004
595 #define CLK_CON_MUX_MUX_CLK_APM_I3C 0x1008
596 #define CLK_CON_DIV_CLKCMU_CHUB_BUS 0x1800
597 #define CLK_CON_DIV_DIV_CLK_APM_BUS 0x1804
598 #define CLK_CON_DIV_DIV_CLK_APM_I3C 0x1808
599 #define CLK_CON_GAT_CLKCMU_CMGP_BUS 0x2000
600 #define CLK_CON_GAT_GATE_CLKCMU_CHUB_BUS 0x2014
601 #define CLK_CON_GAT_GOUT_APM_APBIF_GPIO_ALIVE_PCLK 0x2018
602 #define CLK_CON_GAT_GOUT_APM_APBIF_PMU_ALIVE_PCLK 0x2020
603 #define CLK_CON_GAT_GOUT_APM_APBIF_RTC_PCLK 0x2024
604 #define CLK_CON_GAT_GOUT_APM_APBIF_TOP_RTC_PCLK 0x2028
605 #define CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_PCLK 0x2034
606 #define CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_SCLK 0x2038
607 #define CLK_CON_GAT_GOUT_APM_SPEEDY_APM_PCLK 0x20bc
608 #define CLK_CON_GAT_GOUT_APM_SYSREG_APM_PCLK 0x20c0
610 static const unsigned long apm_clk_regs
[] __initconst
= {
611 PLL_CON0_MUX_CLKCMU_APM_BUS_USER
,
612 PLL_CON0_MUX_CLK_RCO_APM_I3C_USER
,
613 PLL_CON0_MUX_CLK_RCO_APM_USER
,
614 PLL_CON0_MUX_DLL_USER
,
615 CLK_CON_MUX_MUX_CLKCMU_CHUB_BUS
,
616 CLK_CON_MUX_MUX_CLK_APM_BUS
,
617 CLK_CON_MUX_MUX_CLK_APM_I3C
,
618 CLK_CON_DIV_CLKCMU_CHUB_BUS
,
619 CLK_CON_DIV_DIV_CLK_APM_BUS
,
620 CLK_CON_DIV_DIV_CLK_APM_I3C
,
621 CLK_CON_GAT_CLKCMU_CMGP_BUS
,
622 CLK_CON_GAT_GATE_CLKCMU_CHUB_BUS
,
623 CLK_CON_GAT_GOUT_APM_APBIF_GPIO_ALIVE_PCLK
,
624 CLK_CON_GAT_GOUT_APM_APBIF_PMU_ALIVE_PCLK
,
625 CLK_CON_GAT_GOUT_APM_APBIF_RTC_PCLK
,
626 CLK_CON_GAT_GOUT_APM_APBIF_TOP_RTC_PCLK
,
627 CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_PCLK
,
628 CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_SCLK
,
629 CLK_CON_GAT_GOUT_APM_SPEEDY_APM_PCLK
,
630 CLK_CON_GAT_GOUT_APM_SYSREG_APM_PCLK
,
633 /* List of parent clocks for Muxes in CMU_APM */
634 PNAME(mout_apm_bus_user_p
) = { "oscclk_rco_apm", "dout_clkcmu_apm_bus" };
635 PNAME(mout_rco_apm_i3c_user_p
) = { "oscclk_rco_apm", "clk_rco_i3c_pmic" };
636 PNAME(mout_rco_apm_user_p
) = { "oscclk_rco_apm", "clk_rco_apm__alv" };
637 PNAME(mout_dll_user_p
) = { "oscclk_rco_apm", "clk_dll_dco" };
638 PNAME(mout_clkcmu_chub_bus_p
) = { "mout_apm_bus_user", "mout_dll_user" };
639 PNAME(mout_apm_bus_p
) = { "mout_rco_apm_user", "mout_apm_bus_user",
640 "mout_dll_user", "oscclk_rco_apm" };
641 PNAME(mout_apm_i3c_p
) = { "dout_apm_i3c", "mout_rco_apm_i3c_user" };
643 static const struct samsung_fixed_rate_clock apm_fixed_clks
[] __initconst
= {
644 FRATE(CLK_RCO_I3C_PMIC
, "clk_rco_i3c_pmic", NULL
, 0, 491520000),
645 FRATE(OSCCLK_RCO_APM
, "oscclk_rco_apm", NULL
, 0, 24576000),
646 FRATE(CLK_RCO_APM__ALV
, "clk_rco_apm__alv", NULL
, 0, 49152000),
647 FRATE(CLK_DLL_DCO
, "clk_dll_dco", NULL
, 0, 360000000),
650 static const struct samsung_mux_clock apm_mux_clks
[] __initconst
= {
651 MUX(CLK_MOUT_APM_BUS_USER
, "mout_apm_bus_user", mout_apm_bus_user_p
,
652 PLL_CON0_MUX_CLKCMU_APM_BUS_USER
, 4, 1),
653 MUX(CLK_MOUT_RCO_APM_I3C_USER
, "mout_rco_apm_i3c_user",
654 mout_rco_apm_i3c_user_p
, PLL_CON0_MUX_CLK_RCO_APM_I3C_USER
, 4, 1),
655 MUX(CLK_MOUT_RCO_APM_USER
, "mout_rco_apm_user", mout_rco_apm_user_p
,
656 PLL_CON0_MUX_CLK_RCO_APM_USER
, 4, 1),
657 MUX(CLK_MOUT_DLL_USER
, "mout_dll_user", mout_dll_user_p
,
658 PLL_CON0_MUX_DLL_USER
, 4, 1),
659 MUX(CLK_MOUT_CLKCMU_CHUB_BUS
, "mout_clkcmu_chub_bus",
660 mout_clkcmu_chub_bus_p
, CLK_CON_MUX_MUX_CLKCMU_CHUB_BUS
, 0, 1),
661 MUX(CLK_MOUT_APM_BUS
, "mout_apm_bus", mout_apm_bus_p
,
662 CLK_CON_MUX_MUX_CLK_APM_BUS
, 0, 2),
663 MUX(CLK_MOUT_APM_I3C
, "mout_apm_i3c", mout_apm_i3c_p
,
664 CLK_CON_MUX_MUX_CLK_APM_I3C
, 0, 1),
667 static const struct samsung_div_clock apm_div_clks
[] __initconst
= {
668 DIV(CLK_DOUT_CLKCMU_CHUB_BUS
, "dout_clkcmu_chub_bus",
669 "gout_clkcmu_chub_bus",
670 CLK_CON_DIV_CLKCMU_CHUB_BUS
, 0, 3),
671 DIV(CLK_DOUT_APM_BUS
, "dout_apm_bus", "mout_apm_bus",
672 CLK_CON_DIV_DIV_CLK_APM_BUS
, 0, 3),
673 DIV(CLK_DOUT_APM_I3C
, "dout_apm_i3c", "mout_apm_bus",
674 CLK_CON_DIV_DIV_CLK_APM_I3C
, 0, 3),
677 static const struct samsung_gate_clock apm_gate_clks
[] __initconst
= {
678 GATE(CLK_GOUT_CLKCMU_CMGP_BUS
, "gout_clkcmu_cmgp_bus", "dout_apm_bus",
679 CLK_CON_GAT_CLKCMU_CMGP_BUS
, 21, CLK_SET_RATE_PARENT
, 0),
680 GATE(CLK_GOUT_CLKCMU_CHUB_BUS
, "gout_clkcmu_chub_bus",
681 "mout_clkcmu_chub_bus",
682 CLK_CON_GAT_GATE_CLKCMU_CHUB_BUS
, 21, 0, 0),
683 GATE(CLK_GOUT_RTC_PCLK
, "gout_rtc_pclk", "dout_apm_bus",
684 CLK_CON_GAT_GOUT_APM_APBIF_RTC_PCLK
, 21, 0, 0),
685 GATE(CLK_GOUT_TOP_RTC_PCLK
, "gout_top_rtc_pclk", "dout_apm_bus",
686 CLK_CON_GAT_GOUT_APM_APBIF_TOP_RTC_PCLK
, 21, 0, 0),
687 GATE(CLK_GOUT_I3C_PCLK
, "gout_i3c_pclk", "dout_apm_bus",
688 CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_PCLK
, 21, 0, 0),
689 GATE(CLK_GOUT_I3C_SCLK
, "gout_i3c_sclk", "mout_apm_i3c",
690 CLK_CON_GAT_GOUT_APM_I3C_APM_PMIC_I_SCLK
, 21, 0, 0),
691 GATE(CLK_GOUT_SPEEDY_PCLK
, "gout_speedy_pclk", "dout_apm_bus",
692 CLK_CON_GAT_GOUT_APM_SPEEDY_APM_PCLK
, 21, 0, 0),
693 /* TODO: Should be enabled in GPIO driver (or made CLK_IS_CRITICAL) */
694 GATE(CLK_GOUT_GPIO_ALIVE_PCLK
, "gout_gpio_alive_pclk", "dout_apm_bus",
695 CLK_CON_GAT_GOUT_APM_APBIF_GPIO_ALIVE_PCLK
, 21, CLK_IGNORE_UNUSED
,
697 GATE(CLK_GOUT_PMU_ALIVE_PCLK
, "gout_pmu_alive_pclk", "dout_apm_bus",
698 CLK_CON_GAT_GOUT_APM_APBIF_PMU_ALIVE_PCLK
, 21, CLK_IS_CRITICAL
, 0),
699 GATE(CLK_GOUT_SYSREG_APM_PCLK
, "gout_sysreg_apm_pclk", "dout_apm_bus",
700 CLK_CON_GAT_GOUT_APM_SYSREG_APM_PCLK
, 21, 0, 0),
703 static const struct samsung_cmu_info apm_cmu_info __initconst
= {
704 .mux_clks
= apm_mux_clks
,
705 .nr_mux_clks
= ARRAY_SIZE(apm_mux_clks
),
706 .div_clks
= apm_div_clks
,
707 .nr_div_clks
= ARRAY_SIZE(apm_div_clks
),
708 .gate_clks
= apm_gate_clks
,
709 .nr_gate_clks
= ARRAY_SIZE(apm_gate_clks
),
710 .fixed_clks
= apm_fixed_clks
,
711 .nr_fixed_clks
= ARRAY_SIZE(apm_fixed_clks
),
712 .nr_clk_ids
= CLKS_NR_APM
,
713 .clk_regs
= apm_clk_regs
,
714 .nr_clk_regs
= ARRAY_SIZE(apm_clk_regs
),
715 .clk_name
= "dout_clkcmu_apm_bus",
718 /* ---- CMU_AUD ------------------------------------------------------------- */
720 #define PLL_LOCKTIME_PLL_AUD 0x0000
721 #define PLL_CON0_PLL_AUD 0x0100
722 #define PLL_CON3_PLL_AUD 0x010c
723 #define PLL_CON0_MUX_CLKCMU_AUD_CPU_USER 0x0600
724 #define PLL_CON0_MUX_TICK_USB_USER 0x0610
725 #define CLK_CON_MUX_MUX_CLK_AUD_CPU 0x1000
726 #define CLK_CON_MUX_MUX_CLK_AUD_CPU_HCH 0x1004
727 #define CLK_CON_MUX_MUX_CLK_AUD_FM 0x1008
728 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF0 0x100c
729 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF1 0x1010
730 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF2 0x1014
731 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF3 0x1018
732 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF4 0x101c
733 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF5 0x1020
734 #define CLK_CON_MUX_MUX_CLK_AUD_UAIF6 0x1024
735 #define CLK_CON_DIV_DIV_CLK_AUD_MCLK 0x1800
736 #define CLK_CON_DIV_DIV_CLK_AUD_AUDIF 0x1804
737 #define CLK_CON_DIV_DIV_CLK_AUD_BUSD 0x1808
738 #define CLK_CON_DIV_DIV_CLK_AUD_BUSP 0x180c
739 #define CLK_CON_DIV_DIV_CLK_AUD_CNT 0x1810
740 #define CLK_CON_DIV_DIV_CLK_AUD_CPU 0x1814
741 #define CLK_CON_DIV_DIV_CLK_AUD_CPU_ACLK 0x1818
742 #define CLK_CON_DIV_DIV_CLK_AUD_CPU_PCLKDBG 0x181c
743 #define CLK_CON_DIV_DIV_CLK_AUD_FM 0x1820
744 #define CLK_CON_DIV_DIV_CLK_AUD_FM_SPDY 0x1824
745 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF0 0x1828
746 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF1 0x182c
747 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF2 0x1830
748 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF3 0x1834
749 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF4 0x1838
750 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF5 0x183c
751 #define CLK_CON_DIV_DIV_CLK_AUD_UAIF6 0x1840
752 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_CNT 0x2000
753 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF0 0x2004
754 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF1 0x2008
755 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF2 0x200c
756 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF3 0x2010
757 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF4 0x2014
758 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF5 0x2018
759 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF6 0x201c
760 #define CLK_CON_GAT_CLK_AUD_CMU_AUD_PCLK 0x2020
761 #define CLK_CON_GAT_GOUT_AUD_ABOX_ACLK 0x2048
762 #define CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_SPDY 0x204c
763 #define CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_ASB 0x2050
764 #define CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_CA32 0x2054
765 #define CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_DAP 0x2058
766 #define CLK_CON_GAT_GOUT_AUD_CODEC_MCLK 0x206c
767 #define CLK_CON_GAT_GOUT_AUD_TZPC_PCLK 0x2070
768 #define CLK_CON_GAT_GOUT_AUD_GPIO_PCLK 0x2074
769 #define CLK_CON_GAT_GOUT_AUD_PPMU_ACLK 0x2088
770 #define CLK_CON_GAT_GOUT_AUD_PPMU_PCLK 0x208c
771 #define CLK_CON_GAT_GOUT_AUD_SYSMMU_CLK_S1 0x20b4
772 #define CLK_CON_GAT_GOUT_AUD_SYSREG_PCLK 0x20b8
773 #define CLK_CON_GAT_GOUT_AUD_WDT_PCLK 0x20bc
775 static const unsigned long aud_clk_regs
[] __initconst
= {
776 PLL_LOCKTIME_PLL_AUD
,
779 PLL_CON0_MUX_CLKCMU_AUD_CPU_USER
,
780 PLL_CON0_MUX_TICK_USB_USER
,
781 CLK_CON_MUX_MUX_CLK_AUD_CPU
,
782 CLK_CON_MUX_MUX_CLK_AUD_CPU_HCH
,
783 CLK_CON_MUX_MUX_CLK_AUD_FM
,
784 CLK_CON_MUX_MUX_CLK_AUD_UAIF0
,
785 CLK_CON_MUX_MUX_CLK_AUD_UAIF1
,
786 CLK_CON_MUX_MUX_CLK_AUD_UAIF2
,
787 CLK_CON_MUX_MUX_CLK_AUD_UAIF3
,
788 CLK_CON_MUX_MUX_CLK_AUD_UAIF4
,
789 CLK_CON_MUX_MUX_CLK_AUD_UAIF5
,
790 CLK_CON_MUX_MUX_CLK_AUD_UAIF6
,
791 CLK_CON_DIV_DIV_CLK_AUD_MCLK
,
792 CLK_CON_DIV_DIV_CLK_AUD_AUDIF
,
793 CLK_CON_DIV_DIV_CLK_AUD_BUSD
,
794 CLK_CON_DIV_DIV_CLK_AUD_BUSP
,
795 CLK_CON_DIV_DIV_CLK_AUD_CNT
,
796 CLK_CON_DIV_DIV_CLK_AUD_CPU
,
797 CLK_CON_DIV_DIV_CLK_AUD_CPU_ACLK
,
798 CLK_CON_DIV_DIV_CLK_AUD_CPU_PCLKDBG
,
799 CLK_CON_DIV_DIV_CLK_AUD_FM
,
800 CLK_CON_DIV_DIV_CLK_AUD_FM_SPDY
,
801 CLK_CON_DIV_DIV_CLK_AUD_UAIF0
,
802 CLK_CON_DIV_DIV_CLK_AUD_UAIF1
,
803 CLK_CON_DIV_DIV_CLK_AUD_UAIF2
,
804 CLK_CON_DIV_DIV_CLK_AUD_UAIF3
,
805 CLK_CON_DIV_DIV_CLK_AUD_UAIF4
,
806 CLK_CON_DIV_DIV_CLK_AUD_UAIF5
,
807 CLK_CON_DIV_DIV_CLK_AUD_UAIF6
,
808 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_CNT
,
809 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF0
,
810 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF1
,
811 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF2
,
812 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF3
,
813 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF4
,
814 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF5
,
815 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF6
,
816 CLK_CON_GAT_CLK_AUD_CMU_AUD_PCLK
,
817 CLK_CON_GAT_GOUT_AUD_ABOX_ACLK
,
818 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_SPDY
,
819 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_ASB
,
820 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_CA32
,
821 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_DAP
,
822 CLK_CON_GAT_GOUT_AUD_CODEC_MCLK
,
823 CLK_CON_GAT_GOUT_AUD_TZPC_PCLK
,
824 CLK_CON_GAT_GOUT_AUD_GPIO_PCLK
,
825 CLK_CON_GAT_GOUT_AUD_PPMU_ACLK
,
826 CLK_CON_GAT_GOUT_AUD_PPMU_PCLK
,
827 CLK_CON_GAT_GOUT_AUD_SYSMMU_CLK_S1
,
828 CLK_CON_GAT_GOUT_AUD_SYSREG_PCLK
,
829 CLK_CON_GAT_GOUT_AUD_WDT_PCLK
,
832 /* List of parent clocks for Muxes in CMU_AUD */
833 PNAME(mout_aud_pll_p
) = { "oscclk", "fout_aud_pll" };
834 PNAME(mout_aud_cpu_user_p
) = { "oscclk", "dout_aud" };
835 PNAME(mout_aud_cpu_p
) = { "dout_aud_cpu", "mout_aud_cpu_user" };
836 PNAME(mout_aud_cpu_hch_p
) = { "mout_aud_cpu", "oscclk" };
837 PNAME(mout_aud_uaif0_p
) = { "dout_aud_uaif0", "ioclk_audiocdclk0" };
838 PNAME(mout_aud_uaif1_p
) = { "dout_aud_uaif1", "ioclk_audiocdclk1" };
839 PNAME(mout_aud_uaif2_p
) = { "dout_aud_uaif2", "ioclk_audiocdclk2" };
840 PNAME(mout_aud_uaif3_p
) = { "dout_aud_uaif3", "ioclk_audiocdclk3" };
841 PNAME(mout_aud_uaif4_p
) = { "dout_aud_uaif4", "ioclk_audiocdclk4" };
842 PNAME(mout_aud_uaif5_p
) = { "dout_aud_uaif5", "ioclk_audiocdclk5" };
843 PNAME(mout_aud_uaif6_p
) = { "dout_aud_uaif6", "ioclk_audiocdclk6" };
844 PNAME(mout_aud_tick_usb_user_p
) = { "oscclk", "tick_usb" };
845 PNAME(mout_aud_fm_p
) = { "oscclk", "dout_aud_fm_spdy" };
848 * Do not provide PLL table to PLL_AUD, as MANUAL_PLL_CTRL bit is not set
849 * for that PLL by default, so set_rate operation would fail.
851 static const struct samsung_pll_clock aud_pll_clks
[] __initconst
= {
852 PLL(pll_0831x
, CLK_FOUT_AUD_PLL
, "fout_aud_pll", "oscclk",
853 PLL_LOCKTIME_PLL_AUD
, PLL_CON3_PLL_AUD
, NULL
),
856 static const struct samsung_fixed_rate_clock aud_fixed_clks
[] __initconst
= {
857 FRATE(IOCLK_AUDIOCDCLK0
, "ioclk_audiocdclk0", NULL
, 0, 25000000),
858 FRATE(IOCLK_AUDIOCDCLK1
, "ioclk_audiocdclk1", NULL
, 0, 25000000),
859 FRATE(IOCLK_AUDIOCDCLK2
, "ioclk_audiocdclk2", NULL
, 0, 25000000),
860 FRATE(IOCLK_AUDIOCDCLK3
, "ioclk_audiocdclk3", NULL
, 0, 25000000),
861 FRATE(IOCLK_AUDIOCDCLK4
, "ioclk_audiocdclk4", NULL
, 0, 25000000),
862 FRATE(IOCLK_AUDIOCDCLK5
, "ioclk_audiocdclk5", NULL
, 0, 25000000),
863 FRATE(IOCLK_AUDIOCDCLK6
, "ioclk_audiocdclk6", NULL
, 0, 25000000),
864 FRATE(TICK_USB
, "tick_usb", NULL
, 0, 60000000),
867 static const struct samsung_mux_clock aud_mux_clks
[] __initconst
= {
868 MUX(CLK_MOUT_AUD_PLL
, "mout_aud_pll", mout_aud_pll_p
,
869 PLL_CON0_PLL_AUD
, 4, 1),
870 MUX(CLK_MOUT_AUD_CPU_USER
, "mout_aud_cpu_user", mout_aud_cpu_user_p
,
871 PLL_CON0_MUX_CLKCMU_AUD_CPU_USER
, 4, 1),
872 MUX(CLK_MOUT_AUD_TICK_USB_USER
, "mout_aud_tick_usb_user",
873 mout_aud_tick_usb_user_p
,
874 PLL_CON0_MUX_TICK_USB_USER
, 4, 1),
875 MUX(CLK_MOUT_AUD_CPU
, "mout_aud_cpu", mout_aud_cpu_p
,
876 CLK_CON_MUX_MUX_CLK_AUD_CPU
, 0, 1),
877 MUX(CLK_MOUT_AUD_CPU_HCH
, "mout_aud_cpu_hch", mout_aud_cpu_hch_p
,
878 CLK_CON_MUX_MUX_CLK_AUD_CPU_HCH
, 0, 1),
879 MUX(CLK_MOUT_AUD_UAIF0
, "mout_aud_uaif0", mout_aud_uaif0_p
,
880 CLK_CON_MUX_MUX_CLK_AUD_UAIF0
, 0, 1),
881 MUX(CLK_MOUT_AUD_UAIF1
, "mout_aud_uaif1", mout_aud_uaif1_p
,
882 CLK_CON_MUX_MUX_CLK_AUD_UAIF1
, 0, 1),
883 MUX(CLK_MOUT_AUD_UAIF2
, "mout_aud_uaif2", mout_aud_uaif2_p
,
884 CLK_CON_MUX_MUX_CLK_AUD_UAIF2
, 0, 1),
885 MUX(CLK_MOUT_AUD_UAIF3
, "mout_aud_uaif3", mout_aud_uaif3_p
,
886 CLK_CON_MUX_MUX_CLK_AUD_UAIF3
, 0, 1),
887 MUX(CLK_MOUT_AUD_UAIF4
, "mout_aud_uaif4", mout_aud_uaif4_p
,
888 CLK_CON_MUX_MUX_CLK_AUD_UAIF4
, 0, 1),
889 MUX(CLK_MOUT_AUD_UAIF5
, "mout_aud_uaif5", mout_aud_uaif5_p
,
890 CLK_CON_MUX_MUX_CLK_AUD_UAIF5
, 0, 1),
891 MUX(CLK_MOUT_AUD_UAIF6
, "mout_aud_uaif6", mout_aud_uaif6_p
,
892 CLK_CON_MUX_MUX_CLK_AUD_UAIF6
, 0, 1),
893 MUX(CLK_MOUT_AUD_FM
, "mout_aud_fm", mout_aud_fm_p
,
894 CLK_CON_MUX_MUX_CLK_AUD_FM
, 0, 1),
897 static const struct samsung_div_clock aud_div_clks
[] __initconst
= {
898 DIV(CLK_DOUT_AUD_CPU
, "dout_aud_cpu", "mout_aud_pll",
899 CLK_CON_DIV_DIV_CLK_AUD_CPU
, 0, 4),
900 DIV(CLK_DOUT_AUD_BUSD
, "dout_aud_busd", "mout_aud_pll",
901 CLK_CON_DIV_DIV_CLK_AUD_BUSD
, 0, 4),
902 DIV(CLK_DOUT_AUD_BUSP
, "dout_aud_busp", "mout_aud_pll",
903 CLK_CON_DIV_DIV_CLK_AUD_BUSP
, 0, 4),
904 DIV(CLK_DOUT_AUD_AUDIF
, "dout_aud_audif", "mout_aud_pll",
905 CLK_CON_DIV_DIV_CLK_AUD_AUDIF
, 0, 9),
906 DIV(CLK_DOUT_AUD_CPU_ACLK
, "dout_aud_cpu_aclk", "mout_aud_cpu_hch",
907 CLK_CON_DIV_DIV_CLK_AUD_CPU_ACLK
, 0, 3),
908 DIV(CLK_DOUT_AUD_CPU_PCLKDBG
, "dout_aud_cpu_pclkdbg",
910 CLK_CON_DIV_DIV_CLK_AUD_CPU_PCLKDBG
, 0, 3),
911 DIV(CLK_DOUT_AUD_MCLK
, "dout_aud_mclk", "dout_aud_audif",
912 CLK_CON_DIV_DIV_CLK_AUD_MCLK
, 0, 2),
913 DIV(CLK_DOUT_AUD_CNT
, "dout_aud_cnt", "dout_aud_audif",
914 CLK_CON_DIV_DIV_CLK_AUD_CNT
, 0, 10),
915 DIV(CLK_DOUT_AUD_UAIF0
, "dout_aud_uaif0", "dout_aud_audif",
916 CLK_CON_DIV_DIV_CLK_AUD_UAIF0
, 0, 10),
917 DIV(CLK_DOUT_AUD_UAIF1
, "dout_aud_uaif1", "dout_aud_audif",
918 CLK_CON_DIV_DIV_CLK_AUD_UAIF1
, 0, 10),
919 DIV(CLK_DOUT_AUD_UAIF2
, "dout_aud_uaif2", "dout_aud_audif",
920 CLK_CON_DIV_DIV_CLK_AUD_UAIF2
, 0, 10),
921 DIV(CLK_DOUT_AUD_UAIF3
, "dout_aud_uaif3", "dout_aud_audif",
922 CLK_CON_DIV_DIV_CLK_AUD_UAIF3
, 0, 10),
923 DIV(CLK_DOUT_AUD_UAIF4
, "dout_aud_uaif4", "dout_aud_audif",
924 CLK_CON_DIV_DIV_CLK_AUD_UAIF4
, 0, 10),
925 DIV(CLK_DOUT_AUD_UAIF5
, "dout_aud_uaif5", "dout_aud_audif",
926 CLK_CON_DIV_DIV_CLK_AUD_UAIF5
, 0, 10),
927 DIV(CLK_DOUT_AUD_UAIF6
, "dout_aud_uaif6", "dout_aud_audif",
928 CLK_CON_DIV_DIV_CLK_AUD_UAIF6
, 0, 10),
929 DIV(CLK_DOUT_AUD_FM_SPDY
, "dout_aud_fm_spdy", "mout_aud_tick_usb_user",
930 CLK_CON_DIV_DIV_CLK_AUD_FM_SPDY
, 0, 1),
931 DIV(CLK_DOUT_AUD_FM
, "dout_aud_fm", "mout_aud_fm",
932 CLK_CON_DIV_DIV_CLK_AUD_FM
, 0, 10),
935 static const struct samsung_gate_clock aud_gate_clks
[] __initconst
= {
936 GATE(CLK_GOUT_AUD_CMU_AUD_PCLK
, "gout_aud_cmu_aud_pclk",
938 CLK_CON_GAT_CLK_AUD_CMU_AUD_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
939 GATE(CLK_GOUT_AUD_CA32_CCLK
, "gout_aud_ca32_cclk", "mout_aud_cpu_hch",
940 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_CA32
, 21, 0, 0),
941 GATE(CLK_GOUT_AUD_ASB_CCLK
, "gout_aud_asb_cclk", "dout_aud_cpu_aclk",
942 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_ASB
, 21, 0, 0),
943 GATE(CLK_GOUT_AUD_DAP_CCLK
, "gout_aud_dap_cclk", "dout_aud_cpu_pclkdbg",
944 CLK_CON_GAT_GOUT_AUD_ABOX_CCLK_DAP
, 21, 0, 0),
945 /* TODO: Should be enabled in ABOX driver (or made CLK_IS_CRITICAL) */
946 GATE(CLK_GOUT_AUD_ABOX_ACLK
, "gout_aud_abox_aclk", "dout_aud_busd",
947 CLK_CON_GAT_GOUT_AUD_ABOX_ACLK
, 21, CLK_IGNORE_UNUSED
, 0),
948 GATE(CLK_GOUT_AUD_GPIO_PCLK
, "gout_aud_gpio_pclk", "dout_aud_busd",
949 CLK_CON_GAT_GOUT_AUD_GPIO_PCLK
, 21, 0, 0),
950 GATE(CLK_GOUT_AUD_PPMU_ACLK
, "gout_aud_ppmu_aclk", "dout_aud_busd",
951 CLK_CON_GAT_GOUT_AUD_PPMU_ACLK
, 21, 0, 0),
952 GATE(CLK_GOUT_AUD_PPMU_PCLK
, "gout_aud_ppmu_pclk", "dout_aud_busd",
953 CLK_CON_GAT_GOUT_AUD_PPMU_PCLK
, 21, 0, 0),
954 GATE(CLK_GOUT_AUD_SYSMMU_CLK
, "gout_aud_sysmmu_clk", "dout_aud_busd",
955 CLK_CON_GAT_GOUT_AUD_SYSMMU_CLK_S1
, 21, 0, 0),
956 GATE(CLK_GOUT_AUD_SYSREG_PCLK
, "gout_aud_sysreg_pclk", "dout_aud_busd",
957 CLK_CON_GAT_GOUT_AUD_SYSREG_PCLK
, 21, 0, 0),
958 GATE(CLK_GOUT_AUD_WDT_PCLK
, "gout_aud_wdt_pclk", "dout_aud_busd",
959 CLK_CON_GAT_GOUT_AUD_WDT_PCLK
, 21, 0, 0),
960 GATE(CLK_GOUT_AUD_TZPC_PCLK
, "gout_aud_tzpc_pclk", "dout_aud_busp",
961 CLK_CON_GAT_GOUT_AUD_TZPC_PCLK
, 21, 0, 0),
962 GATE(CLK_GOUT_AUD_CODEC_MCLK
, "gout_aud_codec_mclk", "dout_aud_mclk",
963 CLK_CON_GAT_GOUT_AUD_CODEC_MCLK
, 21, 0, 0),
964 GATE(CLK_GOUT_AUD_CNT_BCLK
, "gout_aud_cnt_bclk", "dout_aud_cnt",
965 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_CNT
, 21, 0, 0),
966 GATE(CLK_GOUT_AUD_UAIF0_BCLK
, "gout_aud_uaif0_bclk", "mout_aud_uaif0",
967 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF0
, 21, 0, 0),
968 GATE(CLK_GOUT_AUD_UAIF1_BCLK
, "gout_aud_uaif1_bclk", "mout_aud_uaif1",
969 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF1
, 21, 0, 0),
970 GATE(CLK_GOUT_AUD_UAIF2_BCLK
, "gout_aud_uaif2_bclk", "mout_aud_uaif2",
971 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF2
, 21, 0, 0),
972 GATE(CLK_GOUT_AUD_UAIF3_BCLK
, "gout_aud_uaif3_bclk", "mout_aud_uaif3",
973 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF3
, 21, 0, 0),
974 GATE(CLK_GOUT_AUD_UAIF4_BCLK
, "gout_aud_uaif4_bclk", "mout_aud_uaif4",
975 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF4
, 21, 0, 0),
976 GATE(CLK_GOUT_AUD_UAIF5_BCLK
, "gout_aud_uaif5_bclk", "mout_aud_uaif5",
977 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF5
, 21, 0, 0),
978 GATE(CLK_GOUT_AUD_UAIF6_BCLK
, "gout_aud_uaif6_bclk", "mout_aud_uaif6",
979 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_UAIF6
, 21, 0, 0),
980 GATE(CLK_GOUT_AUD_SPDY_BCLK
, "gout_aud_spdy_bclk", "dout_aud_fm",
981 CLK_CON_GAT_GOUT_AUD_ABOX_BCLK_SPDY
, 21, 0, 0),
984 static const struct samsung_cmu_info aud_cmu_info __initconst
= {
985 .pll_clks
= aud_pll_clks
,
986 .nr_pll_clks
= ARRAY_SIZE(aud_pll_clks
),
987 .mux_clks
= aud_mux_clks
,
988 .nr_mux_clks
= ARRAY_SIZE(aud_mux_clks
),
989 .div_clks
= aud_div_clks
,
990 .nr_div_clks
= ARRAY_SIZE(aud_div_clks
),
991 .gate_clks
= aud_gate_clks
,
992 .nr_gate_clks
= ARRAY_SIZE(aud_gate_clks
),
993 .fixed_clks
= aud_fixed_clks
,
994 .nr_fixed_clks
= ARRAY_SIZE(aud_fixed_clks
),
995 .nr_clk_ids
= CLKS_NR_AUD
,
996 .clk_regs
= aud_clk_regs
,
997 .nr_clk_regs
= ARRAY_SIZE(aud_clk_regs
),
998 .clk_name
= "dout_aud",
1001 /* ---- CMU_CMGP ------------------------------------------------------------ */
1003 /* Register Offset definitions for CMU_CMGP (0x11c00000) */
1004 #define CLK_CON_MUX_CLK_CMGP_ADC 0x1000
1005 #define CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP0 0x1004
1006 #define CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP1 0x1008
1007 #define CLK_CON_DIV_DIV_CLK_CMGP_ADC 0x1800
1008 #define CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP0 0x1804
1009 #define CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP1 0x1808
1010 #define CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S0 0x200c
1011 #define CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S1 0x2010
1012 #define CLK_CON_GAT_GOUT_CMGP_GPIO_PCLK 0x2018
1013 #define CLK_CON_GAT_GOUT_CMGP_SYSREG_CMGP_PCLK 0x2040
1014 #define CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_IPCLK 0x2044
1015 #define CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_PCLK 0x2048
1016 #define CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_IPCLK 0x204c
1017 #define CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_PCLK 0x2050
1019 static const unsigned long cmgp_clk_regs
[] __initconst
= {
1020 CLK_CON_MUX_CLK_CMGP_ADC
,
1021 CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP0
,
1022 CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP1
,
1023 CLK_CON_DIV_DIV_CLK_CMGP_ADC
,
1024 CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP0
,
1025 CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP1
,
1026 CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S0
,
1027 CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S1
,
1028 CLK_CON_GAT_GOUT_CMGP_GPIO_PCLK
,
1029 CLK_CON_GAT_GOUT_CMGP_SYSREG_CMGP_PCLK
,
1030 CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_IPCLK
,
1031 CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_PCLK
,
1032 CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_IPCLK
,
1033 CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_PCLK
,
1036 /* List of parent clocks for Muxes in CMU_CMGP */
1037 PNAME(mout_cmgp_usi0_p
) = { "clk_rco_cmgp", "gout_clkcmu_cmgp_bus" };
1038 PNAME(mout_cmgp_usi1_p
) = { "clk_rco_cmgp", "gout_clkcmu_cmgp_bus" };
1039 PNAME(mout_cmgp_adc_p
) = { "oscclk", "dout_cmgp_adc" };
1041 static const struct samsung_fixed_rate_clock cmgp_fixed_clks
[] __initconst
= {
1042 FRATE(CLK_RCO_CMGP
, "clk_rco_cmgp", NULL
, 0, 49152000),
1045 static const struct samsung_mux_clock cmgp_mux_clks
[] __initconst
= {
1046 MUX(CLK_MOUT_CMGP_ADC
, "mout_cmgp_adc", mout_cmgp_adc_p
,
1047 CLK_CON_MUX_CLK_CMGP_ADC
, 0, 1),
1048 MUX_F(CLK_MOUT_CMGP_USI0
, "mout_cmgp_usi0", mout_cmgp_usi0_p
,
1049 CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP0
, 0, 1, CLK_SET_RATE_PARENT
, 0),
1050 MUX_F(CLK_MOUT_CMGP_USI1
, "mout_cmgp_usi1", mout_cmgp_usi1_p
,
1051 CLK_CON_MUX_MUX_CLK_CMGP_USI_CMGP1
, 0, 1, CLK_SET_RATE_PARENT
, 0),
1054 static const struct samsung_div_clock cmgp_div_clks
[] __initconst
= {
1055 DIV(CLK_DOUT_CMGP_ADC
, "dout_cmgp_adc", "gout_clkcmu_cmgp_bus",
1056 CLK_CON_DIV_DIV_CLK_CMGP_ADC
, 0, 4),
1057 DIV_F(CLK_DOUT_CMGP_USI0
, "dout_cmgp_usi0", "mout_cmgp_usi0",
1058 CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP0
, 0, 5, CLK_SET_RATE_PARENT
, 0),
1059 DIV_F(CLK_DOUT_CMGP_USI1
, "dout_cmgp_usi1", "mout_cmgp_usi1",
1060 CLK_CON_DIV_DIV_CLK_CMGP_USI_CMGP1
, 0, 5, CLK_SET_RATE_PARENT
, 0),
1063 static const struct samsung_gate_clock cmgp_gate_clks
[] __initconst
= {
1064 GATE(CLK_GOUT_CMGP_ADC_S0_PCLK
, "gout_adc_s0_pclk",
1065 "gout_clkcmu_cmgp_bus",
1066 CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S0
, 21, 0, 0),
1067 GATE(CLK_GOUT_CMGP_ADC_S1_PCLK
, "gout_adc_s1_pclk",
1068 "gout_clkcmu_cmgp_bus",
1069 CLK_CON_GAT_GOUT_CMGP_ADC_PCLK_S1
, 21, 0, 0),
1070 /* TODO: Should be enabled in GPIO driver (or made CLK_IS_CRITICAL) */
1071 GATE(CLK_GOUT_CMGP_GPIO_PCLK
, "gout_gpio_cmgp_pclk",
1072 "gout_clkcmu_cmgp_bus",
1073 CLK_CON_GAT_GOUT_CMGP_GPIO_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1074 GATE(CLK_GOUT_CMGP_USI0_IPCLK
, "gout_cmgp_usi0_ipclk", "dout_cmgp_usi0",
1075 CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_IPCLK
, 21, CLK_SET_RATE_PARENT
, 0),
1076 GATE(CLK_GOUT_CMGP_USI0_PCLK
, "gout_cmgp_usi0_pclk",
1077 "gout_clkcmu_cmgp_bus",
1078 CLK_CON_GAT_GOUT_CMGP_USI_CMGP0_PCLK
, 21, 0, 0),
1079 GATE(CLK_GOUT_CMGP_USI1_IPCLK
, "gout_cmgp_usi1_ipclk", "dout_cmgp_usi1",
1080 CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_IPCLK
, 21, CLK_SET_RATE_PARENT
, 0),
1081 GATE(CLK_GOUT_CMGP_USI1_PCLK
, "gout_cmgp_usi1_pclk",
1082 "gout_clkcmu_cmgp_bus",
1083 CLK_CON_GAT_GOUT_CMGP_USI_CMGP1_PCLK
, 21, 0, 0),
1084 GATE(CLK_GOUT_SYSREG_CMGP_PCLK
, "gout_sysreg_cmgp_pclk",
1085 "gout_clkcmu_cmgp_bus",
1086 CLK_CON_GAT_GOUT_CMGP_SYSREG_CMGP_PCLK
, 21, 0, 0),
1089 static const struct samsung_cmu_info cmgp_cmu_info __initconst
= {
1090 .mux_clks
= cmgp_mux_clks
,
1091 .nr_mux_clks
= ARRAY_SIZE(cmgp_mux_clks
),
1092 .div_clks
= cmgp_div_clks
,
1093 .nr_div_clks
= ARRAY_SIZE(cmgp_div_clks
),
1094 .gate_clks
= cmgp_gate_clks
,
1095 .nr_gate_clks
= ARRAY_SIZE(cmgp_gate_clks
),
1096 .fixed_clks
= cmgp_fixed_clks
,
1097 .nr_fixed_clks
= ARRAY_SIZE(cmgp_fixed_clks
),
1098 .nr_clk_ids
= CLKS_NR_CMGP
,
1099 .clk_regs
= cmgp_clk_regs
,
1100 .nr_clk_regs
= ARRAY_SIZE(cmgp_clk_regs
),
1101 .clk_name
= "gout_clkcmu_cmgp_bus",
1104 /* ---- CMU_CPUCL0 ---------------------------------------------------------- */
1106 /* Register Offset definitions for CMU_CPUCL0 (0x10900000) */
1107 #define PLL_LOCKTIME_PLL_CPUCL0 0x0000
1108 #define PLL_CON0_PLL_CPUCL0 0x0100
1109 #define PLL_CON1_PLL_CPUCL0 0x0104
1110 #define PLL_CON3_PLL_CPUCL0 0x010c
1111 #define PLL_CON0_MUX_CLKCMU_CPUCL0_DBG_USER 0x0600
1112 #define PLL_CON0_MUX_CLKCMU_CPUCL0_SWITCH_USER 0x0610
1113 #define CLK_CON_MUX_MUX_CLK_CPUCL0_PLL 0x100c
1114 #define CLK_CON_DIV_DIV_CLK_CLUSTER0_ACLK 0x1800
1115 #define CLK_CON_DIV_DIV_CLK_CLUSTER0_ATCLK 0x1808
1116 #define CLK_CON_DIV_DIV_CLK_CLUSTER0_PCLKDBG 0x180c
1117 #define CLK_CON_DIV_DIV_CLK_CLUSTER0_PERIPHCLK 0x1810
1118 #define CLK_CON_DIV_DIV_CLK_CPUCL0_CMUREF 0x1814
1119 #define CLK_CON_DIV_DIV_CLK_CPUCL0_CPU 0x1818
1120 #define CLK_CON_DIV_DIV_CLK_CPUCL0_PCLK 0x181c
1121 #define CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_ATCLK 0x2000
1122 #define CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PCLK 0x2004
1123 #define CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PERIPHCLK 0x2008
1124 #define CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_SCLK 0x200c
1125 #define CLK_CON_GAT_CLK_CPUCL0_CMU_CPUCL0_PCLK 0x2010
1126 #define CLK_CON_GAT_GATE_CLK_CPUCL0_CPU 0x2020
1128 static const unsigned long cpucl0_clk_regs
[] __initconst
= {
1129 PLL_LOCKTIME_PLL_CPUCL0
,
1130 PLL_CON0_PLL_CPUCL0
,
1131 PLL_CON1_PLL_CPUCL0
,
1132 PLL_CON3_PLL_CPUCL0
,
1133 PLL_CON0_MUX_CLKCMU_CPUCL0_DBG_USER
,
1134 PLL_CON0_MUX_CLKCMU_CPUCL0_SWITCH_USER
,
1135 CLK_CON_MUX_MUX_CLK_CPUCL0_PLL
,
1136 CLK_CON_DIV_DIV_CLK_CLUSTER0_ACLK
,
1137 CLK_CON_DIV_DIV_CLK_CLUSTER0_ATCLK
,
1138 CLK_CON_DIV_DIV_CLK_CLUSTER0_PCLKDBG
,
1139 CLK_CON_DIV_DIV_CLK_CLUSTER0_PERIPHCLK
,
1140 CLK_CON_DIV_DIV_CLK_CPUCL0_CMUREF
,
1141 CLK_CON_DIV_DIV_CLK_CPUCL0_CPU
,
1142 CLK_CON_DIV_DIV_CLK_CPUCL0_PCLK
,
1143 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_ATCLK
,
1144 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PCLK
,
1145 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PERIPHCLK
,
1146 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_SCLK
,
1147 CLK_CON_GAT_CLK_CPUCL0_CMU_CPUCL0_PCLK
,
1148 CLK_CON_GAT_GATE_CLK_CPUCL0_CPU
,
1151 /* List of parent clocks for Muxes in CMU_CPUCL0 */
1152 PNAME(mout_pll_cpucl0_p
) = { "oscclk", "fout_cpucl0_pll" };
1153 PNAME(mout_cpucl0_switch_user_p
) = { "oscclk", "dout_cpucl0_switch" };
1154 PNAME(mout_cpucl0_dbg_user_p
) = { "oscclk", "dout_cpucl0_dbg" };
1155 PNAME(mout_cpucl0_pll_p
) = { "mout_pll_cpucl0",
1156 "mout_cpucl0_switch_user" };
1158 static const struct samsung_pll_rate_table cpu_pll_rates
[] __initconst
= {
1159 PLL_35XX_RATE(26 * MHZ
, 2210000000U, 255, 3, 0),
1160 PLL_35XX_RATE(26 * MHZ
, 2106000000U, 243, 3, 0),
1161 PLL_35XX_RATE(26 * MHZ
, 2002000000U, 231, 3, 0),
1162 PLL_35XX_RATE(26 * MHZ
, 1846000000U, 213, 3, 0),
1163 PLL_35XX_RATE(26 * MHZ
, 1742000000U, 201, 3, 0),
1164 PLL_35XX_RATE(26 * MHZ
, 1586000000U, 183, 3, 0),
1165 PLL_35XX_RATE(26 * MHZ
, 1456000000U, 168, 3, 0),
1166 PLL_35XX_RATE(26 * MHZ
, 1300000000U, 150, 3, 0),
1167 PLL_35XX_RATE(26 * MHZ
, 1157000000U, 267, 3, 1),
1168 PLL_35XX_RATE(26 * MHZ
, 1053000000U, 243, 3, 1),
1169 PLL_35XX_RATE(26 * MHZ
, 949000000U, 219, 3, 1),
1170 PLL_35XX_RATE(26 * MHZ
, 806000000U, 186, 3, 1),
1171 PLL_35XX_RATE(26 * MHZ
, 650000000U, 150, 3, 1),
1172 PLL_35XX_RATE(26 * MHZ
, 546000000U, 252, 3, 2),
1173 PLL_35XX_RATE(26 * MHZ
, 442000000U, 204, 3, 2),
1174 PLL_35XX_RATE(26 * MHZ
, 351000000U, 162, 3, 2),
1175 PLL_35XX_RATE(26 * MHZ
, 247000000U, 114, 3, 2),
1176 PLL_35XX_RATE(26 * MHZ
, 182000000U, 168, 3, 3),
1177 PLL_35XX_RATE(26 * MHZ
, 130000000U, 120, 3, 3),
1180 static const struct samsung_pll_clock cpucl0_pll_clks
[] __initconst
= {
1181 PLL(pll_0822x
, CLK_FOUT_CPUCL0_PLL
, "fout_cpucl0_pll", "oscclk",
1182 PLL_LOCKTIME_PLL_CPUCL0
, PLL_CON3_PLL_CPUCL0
, cpu_pll_rates
),
1185 static const struct samsung_mux_clock cpucl0_mux_clks
[] __initconst
= {
1186 MUX_F(CLK_MOUT_PLL_CPUCL0
, "mout_pll_cpucl0", mout_pll_cpucl0_p
,
1187 PLL_CON0_PLL_CPUCL0
, 4, 1,
1188 CLK_SET_RATE_PARENT
| CLK_RECALC_NEW_RATES
, 0),
1189 MUX_F(CLK_MOUT_CPUCL0_SWITCH_USER
, "mout_cpucl0_switch_user",
1190 mout_cpucl0_switch_user_p
,
1191 PLL_CON0_MUX_CLKCMU_CPUCL0_SWITCH_USER
, 4, 1,
1192 CLK_SET_RATE_PARENT
, 0),
1193 MUX(CLK_MOUT_CPUCL0_DBG_USER
, "mout_cpucl0_dbg_user",
1194 mout_cpucl0_dbg_user_p
,
1195 PLL_CON0_MUX_CLKCMU_CPUCL0_DBG_USER
, 4, 1),
1196 MUX_F(CLK_MOUT_CPUCL0_PLL
, "mout_cpucl0_pll", mout_cpucl0_pll_p
,
1197 CLK_CON_MUX_MUX_CLK_CPUCL0_PLL
, 0, 1, CLK_SET_RATE_PARENT
, 0),
1200 static const struct samsung_div_clock cpucl0_div_clks
[] __initconst
= {
1201 DIV_F(CLK_DOUT_CPUCL0_CPU
, "dout_cpucl0_cpu", "mout_cpucl0_pll",
1202 CLK_CON_DIV_DIV_CLK_CPUCL0_CPU
, 0, 1,
1203 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1204 DIV_F(CLK_DOUT_CPUCL0_CMUREF
, "dout_cpucl0_cmuref", "dout_cpucl0_cpu",
1205 CLK_CON_DIV_DIV_CLK_CPUCL0_CMUREF
, 0, 3,
1206 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1207 DIV_F(CLK_DOUT_CPUCL0_PCLK
, "dout_cpucl0_pclk", "dout_cpucl0_cpu",
1208 CLK_CON_DIV_DIV_CLK_CPUCL0_PCLK
, 0, 4,
1209 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1211 /* EMBEDDED_CMU_CPUCL0 */
1212 DIV_F(CLK_DOUT_CLUSTER0_ACLK
, "dout_cluster0_aclk", "gout_cluster0_cpu",
1213 CLK_CON_DIV_DIV_CLK_CLUSTER0_ACLK
, 0, 4,
1214 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1215 DIV_F(CLK_DOUT_CLUSTER0_ATCLK
, "dout_cluster0_atclk",
1216 "gout_cluster0_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER0_ATCLK
, 0, 4,
1217 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1218 DIV_F(CLK_DOUT_CLUSTER0_PCLKDBG
, "dout_cluster0_pclkdbg",
1219 "gout_cluster0_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER0_PCLKDBG
, 0, 4,
1220 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1221 DIV_F(CLK_DOUT_CLUSTER0_PERIPHCLK
, "dout_cluster0_periphclk",
1222 "gout_cluster0_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER0_PERIPHCLK
, 0, 4,
1223 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1226 static const struct samsung_gate_clock cpucl0_gate_clks
[] __initconst
= {
1227 GATE(CLK_GOUT_CPUCL0_CMU_CPUCL0_PCLK
, "gout_cpucl0_cmu_cpucl0_pclk",
1229 CLK_CON_GAT_CLK_CPUCL0_CMU_CPUCL0_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1231 /* EMBEDDED_CMU_CPUCL0 */
1232 GATE(CLK_GOUT_CLUSTER0_CPU
, "gout_cluster0_cpu", "dout_cpucl0_cpu",
1233 CLK_CON_GAT_GATE_CLK_CPUCL0_CPU
, 21, CLK_IGNORE_UNUSED
, 0),
1234 GATE(CLK_GOUT_CLUSTER0_SCLK
, "gout_cluster0_sclk", "gout_cluster0_cpu",
1235 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_SCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1236 GATE(CLK_GOUT_CLUSTER0_ATCLK
, "gout_cluster0_atclk",
1237 "dout_cluster0_atclk",
1238 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_ATCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1239 GATE(CLK_GOUT_CLUSTER0_PERIPHCLK
, "gout_cluster0_periphclk",
1240 "dout_cluster0_periphclk",
1241 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PERIPHCLK
, 21,
1242 CLK_IGNORE_UNUSED
, 0),
1243 GATE(CLK_GOUT_CLUSTER0_PCLK
, "gout_cluster0_pclk",
1244 "dout_cluster0_pclkdbg",
1245 CLK_CON_GAT_CLK_CPUCL0_CLUSTER0_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1249 * Each parameter is going to be written into the corresponding DIV register. So
1250 * the actual divider value for each parameter will be 1/(param+1). All these
1251 * parameters must be in the range of 0..15, as the divider range for all of
1252 * these DIV clocks is 1..16. The default values for these dividers is
1255 #define E850_CPU_DIV0(aclk, atclk, pclkdbg, periphclk) \
1256 (((aclk) << 16) | ((atclk) << 12) | ((pclkdbg) << 8) | \
1259 static const struct exynos_cpuclk_cfg_data exynos850_cluster_clk_d
[] __initconst
1261 { 2210000, E850_CPU_DIV0(1, 3, 3, 1) },
1262 { 2106000, E850_CPU_DIV0(1, 3, 3, 1) },
1263 { 2002000, E850_CPU_DIV0(1, 3, 3, 1) },
1264 { 1846000, E850_CPU_DIV0(1, 3, 3, 1) },
1265 { 1742000, E850_CPU_DIV0(1, 3, 3, 1) },
1266 { 1586000, E850_CPU_DIV0(1, 3, 3, 1) },
1267 { 1456000, E850_CPU_DIV0(1, 3, 3, 1) },
1268 { 1300000, E850_CPU_DIV0(1, 3, 3, 1) },
1269 { 1157000, E850_CPU_DIV0(1, 3, 3, 1) },
1270 { 1053000, E850_CPU_DIV0(1, 3, 3, 1) },
1271 { 949000, E850_CPU_DIV0(1, 3, 3, 1) },
1272 { 806000, E850_CPU_DIV0(1, 3, 3, 1) },
1273 { 650000, E850_CPU_DIV0(1, 3, 3, 1) },
1274 { 546000, E850_CPU_DIV0(1, 3, 3, 1) },
1275 { 442000, E850_CPU_DIV0(1, 3, 3, 1) },
1276 { 351000, E850_CPU_DIV0(1, 3, 3, 1) },
1277 { 247000, E850_CPU_DIV0(1, 3, 3, 1) },
1278 { 182000, E850_CPU_DIV0(1, 3, 3, 1) },
1279 { 130000, E850_CPU_DIV0(1, 3, 3, 1) },
1283 static const struct samsung_cpu_clock cpucl0_cpu_clks
[] __initconst
= {
1284 CPU_CLK(CLK_CLUSTER0_SCLK
, "cluster0_clk", CLK_MOUT_PLL_CPUCL0
,
1285 CLK_MOUT_CPUCL0_SWITCH_USER
, 0, 0x0, CPUCLK_LAYOUT_E850_CL0
,
1286 exynos850_cluster_clk_d
),
1289 static const struct samsung_cmu_info cpucl0_cmu_info __initconst
= {
1290 .pll_clks
= cpucl0_pll_clks
,
1291 .nr_pll_clks
= ARRAY_SIZE(cpucl0_pll_clks
),
1292 .mux_clks
= cpucl0_mux_clks
,
1293 .nr_mux_clks
= ARRAY_SIZE(cpucl0_mux_clks
),
1294 .div_clks
= cpucl0_div_clks
,
1295 .nr_div_clks
= ARRAY_SIZE(cpucl0_div_clks
),
1296 .gate_clks
= cpucl0_gate_clks
,
1297 .nr_gate_clks
= ARRAY_SIZE(cpucl0_gate_clks
),
1298 .cpu_clks
= cpucl0_cpu_clks
,
1299 .nr_cpu_clks
= ARRAY_SIZE(cpucl0_cpu_clks
),
1300 .nr_clk_ids
= CLKS_NR_CPUCL0
,
1301 .clk_regs
= cpucl0_clk_regs
,
1302 .nr_clk_regs
= ARRAY_SIZE(cpucl0_clk_regs
),
1303 .clk_name
= "dout_cpucl0_switch",
1304 .manual_plls
= true,
1307 static void __init
exynos850_cmu_cpucl0_init(struct device_node
*np
)
1309 exynos_arm64_register_cmu(NULL
, np
, &cpucl0_cmu_info
);
1312 /* Register CMU_CPUCL0 early, as CPU clocks should be available ASAP */
1313 CLK_OF_DECLARE(exynos850_cmu_cpucl0
, "samsung,exynos850-cmu-cpucl0",
1314 exynos850_cmu_cpucl0_init
);
1316 /* ---- CMU_CPUCL1 ---------------------------------------------------------- */
1318 /* Register Offset definitions for CMU_CPUCL1 (0x10800000) */
1319 #define PLL_LOCKTIME_PLL_CPUCL1 0x0000
1320 #define PLL_CON0_PLL_CPUCL1 0x0100
1321 #define PLL_CON1_PLL_CPUCL1 0x0104
1322 #define PLL_CON3_PLL_CPUCL1 0x010c
1323 #define PLL_CON0_MUX_CLKCMU_CPUCL1_DBG_USER 0x0600
1324 #define PLL_CON0_MUX_CLKCMU_CPUCL1_SWITCH_USER 0x0610
1325 #define CLK_CON_MUX_MUX_CLK_CPUCL1_PLL 0x1000
1326 #define CLK_CON_DIV_DIV_CLK_CLUSTER1_ACLK 0x1800
1327 #define CLK_CON_DIV_DIV_CLK_CLUSTER1_ATCLK 0x1808
1328 #define CLK_CON_DIV_DIV_CLK_CLUSTER1_PCLKDBG 0x180c
1329 #define CLK_CON_DIV_DIV_CLK_CLUSTER1_PERIPHCLK 0x1810
1330 #define CLK_CON_DIV_DIV_CLK_CPUCL1_CMUREF 0x1814
1331 #define CLK_CON_DIV_DIV_CLK_CPUCL1_CPU 0x1818
1332 #define CLK_CON_DIV_DIV_CLK_CPUCL1_PCLK 0x181c
1333 #define CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_ATCLK 0x2000
1334 #define CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PCLK 0x2004
1335 #define CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PERIPHCLK 0x2008
1336 #define CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_SCLK 0x200c
1337 #define CLK_CON_GAT_CLK_CPUCL1_CMU_CPUCL1_PCLK 0x2010
1338 #define CLK_CON_GAT_GATE_CLK_CPUCL1_CPU 0x2020
1340 static const unsigned long cpucl1_clk_regs
[] __initconst
= {
1341 PLL_LOCKTIME_PLL_CPUCL1
,
1342 PLL_CON0_PLL_CPUCL1
,
1343 PLL_CON1_PLL_CPUCL1
,
1344 PLL_CON3_PLL_CPUCL1
,
1345 PLL_CON0_MUX_CLKCMU_CPUCL1_DBG_USER
,
1346 PLL_CON0_MUX_CLKCMU_CPUCL1_SWITCH_USER
,
1347 CLK_CON_MUX_MUX_CLK_CPUCL1_PLL
,
1348 CLK_CON_DIV_DIV_CLK_CLUSTER1_ACLK
,
1349 CLK_CON_DIV_DIV_CLK_CLUSTER1_ATCLK
,
1350 CLK_CON_DIV_DIV_CLK_CLUSTER1_PCLKDBG
,
1351 CLK_CON_DIV_DIV_CLK_CLUSTER1_PERIPHCLK
,
1352 CLK_CON_DIV_DIV_CLK_CPUCL1_CMUREF
,
1353 CLK_CON_DIV_DIV_CLK_CPUCL1_CPU
,
1354 CLK_CON_DIV_DIV_CLK_CPUCL1_PCLK
,
1355 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_ATCLK
,
1356 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PCLK
,
1357 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PERIPHCLK
,
1358 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_SCLK
,
1359 CLK_CON_GAT_CLK_CPUCL1_CMU_CPUCL1_PCLK
,
1360 CLK_CON_GAT_GATE_CLK_CPUCL1_CPU
,
1363 /* List of parent clocks for Muxes in CMU_CPUCL0 */
1364 PNAME(mout_pll_cpucl1_p
) = { "oscclk", "fout_cpucl1_pll" };
1365 PNAME(mout_cpucl1_switch_user_p
) = { "oscclk", "dout_cpucl1_switch" };
1366 PNAME(mout_cpucl1_dbg_user_p
) = { "oscclk", "dout_cpucl1_dbg" };
1367 PNAME(mout_cpucl1_pll_p
) = { "mout_pll_cpucl1",
1368 "mout_cpucl1_switch_user" };
1370 static const struct samsung_pll_clock cpucl1_pll_clks
[] __initconst
= {
1371 PLL(pll_0822x
, CLK_FOUT_CPUCL1_PLL
, "fout_cpucl1_pll", "oscclk",
1372 PLL_LOCKTIME_PLL_CPUCL1
, PLL_CON3_PLL_CPUCL1
, cpu_pll_rates
),
1375 static const struct samsung_mux_clock cpucl1_mux_clks
[] __initconst
= {
1376 MUX_F(CLK_MOUT_PLL_CPUCL1
, "mout_pll_cpucl1", mout_pll_cpucl1_p
,
1377 PLL_CON0_PLL_CPUCL1
, 4, 1,
1378 CLK_SET_RATE_PARENT
| CLK_RECALC_NEW_RATES
, 0),
1379 MUX_F(CLK_MOUT_CPUCL1_SWITCH_USER
, "mout_cpucl1_switch_user",
1380 mout_cpucl1_switch_user_p
,
1381 PLL_CON0_MUX_CLKCMU_CPUCL1_SWITCH_USER
, 4, 1,
1382 CLK_SET_RATE_PARENT
, 0),
1383 MUX(CLK_MOUT_CPUCL1_DBG_USER
, "mout_cpucl1_dbg_user",
1384 mout_cpucl1_dbg_user_p
,
1385 PLL_CON0_MUX_CLKCMU_CPUCL1_DBG_USER
, 4, 1),
1386 MUX_F(CLK_MOUT_CPUCL1_PLL
, "mout_cpucl1_pll", mout_cpucl1_pll_p
,
1387 CLK_CON_MUX_MUX_CLK_CPUCL1_PLL
, 0, 1, CLK_SET_RATE_PARENT
, 0),
1390 static const struct samsung_div_clock cpucl1_div_clks
[] __initconst
= {
1391 DIV_F(CLK_DOUT_CPUCL1_CPU
, "dout_cpucl1_cpu", "mout_cpucl1_pll",
1392 CLK_CON_DIV_DIV_CLK_CPUCL1_CPU
, 0, 1,
1393 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1394 DIV_F(CLK_DOUT_CPUCL1_CMUREF
, "dout_cpucl1_cmuref", "dout_cpucl1_cpu",
1395 CLK_CON_DIV_DIV_CLK_CPUCL1_CMUREF
, 0, 3,
1396 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1397 DIV_F(CLK_DOUT_CPUCL1_PCLK
, "dout_cpucl1_pclk", "dout_cpucl1_cpu",
1398 CLK_CON_DIV_DIV_CLK_CPUCL1_PCLK
, 0, 4,
1399 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1401 /* EMBEDDED_CMU_CPUCL1 */
1402 DIV_F(CLK_DOUT_CLUSTER1_ACLK
, "dout_cluster1_aclk", "gout_cluster1_cpu",
1403 CLK_CON_DIV_DIV_CLK_CLUSTER1_ACLK
, 0, 4,
1404 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1405 DIV_F(CLK_DOUT_CLUSTER1_ATCLK
, "dout_cluster1_atclk",
1406 "gout_cluster1_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER1_ATCLK
, 0, 4,
1407 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1408 DIV_F(CLK_DOUT_CLUSTER1_PCLKDBG
, "dout_cluster1_pclkdbg",
1409 "gout_cluster1_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER1_PCLKDBG
, 0, 4,
1410 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1411 DIV_F(CLK_DOUT_CLUSTER1_PERIPHCLK
, "dout_cluster1_periphclk",
1412 "gout_cluster1_cpu", CLK_CON_DIV_DIV_CLK_CLUSTER1_PERIPHCLK
, 0, 4,
1413 CLK_GET_RATE_NOCACHE
, CLK_DIVIDER_READ_ONLY
),
1416 static const struct samsung_gate_clock cpucl1_gate_clks
[] __initconst
= {
1417 GATE(CLK_GOUT_CPUCL1_CMU_CPUCL1_PCLK
, "gout_cpucl1_cmu_cpucl1_pclk",
1419 CLK_CON_GAT_CLK_CPUCL1_CMU_CPUCL1_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1421 /* EMBEDDED_CMU_CPUCL1 */
1422 GATE(CLK_GOUT_CLUSTER1_CPU
, "gout_cluster1_cpu", "dout_cpucl1_cpu",
1423 CLK_CON_GAT_GATE_CLK_CPUCL1_CPU
, 21, CLK_IGNORE_UNUSED
, 0),
1424 GATE(CLK_GOUT_CLUSTER1_SCLK
, "gout_cluster1_sclk", "gout_cluster1_cpu",
1425 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_SCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1426 GATE(CLK_GOUT_CLUSTER1_ATCLK
, "gout_cluster1_atclk",
1427 "dout_cluster1_atclk",
1428 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_ATCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1429 GATE(CLK_GOUT_CLUSTER1_PERIPHCLK
, "gout_cluster1_periphclk",
1430 "dout_cluster1_periphclk",
1431 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PERIPHCLK
, 21,
1432 CLK_IGNORE_UNUSED
, 0),
1433 GATE(CLK_GOUT_CLUSTER1_PCLK
, "gout_cluster1_pclk",
1434 "dout_cluster1_pclkdbg",
1435 CLK_CON_GAT_CLK_CPUCL1_CLUSTER1_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1438 static const struct samsung_cpu_clock cpucl1_cpu_clks
[] __initconst
= {
1439 CPU_CLK(CLK_CLUSTER1_SCLK
, "cluster1_clk", CLK_MOUT_PLL_CPUCL1
,
1440 CLK_MOUT_CPUCL1_SWITCH_USER
, 0, 0x0, CPUCLK_LAYOUT_E850_CL1
,
1441 exynos850_cluster_clk_d
),
1444 static const struct samsung_cmu_info cpucl1_cmu_info __initconst
= {
1445 .pll_clks
= cpucl1_pll_clks
,
1446 .nr_pll_clks
= ARRAY_SIZE(cpucl1_pll_clks
),
1447 .mux_clks
= cpucl1_mux_clks
,
1448 .nr_mux_clks
= ARRAY_SIZE(cpucl1_mux_clks
),
1449 .div_clks
= cpucl1_div_clks
,
1450 .nr_div_clks
= ARRAY_SIZE(cpucl1_div_clks
),
1451 .gate_clks
= cpucl1_gate_clks
,
1452 .nr_gate_clks
= ARRAY_SIZE(cpucl1_gate_clks
),
1453 .cpu_clks
= cpucl1_cpu_clks
,
1454 .nr_cpu_clks
= ARRAY_SIZE(cpucl1_cpu_clks
),
1455 .nr_clk_ids
= CLKS_NR_CPUCL1
,
1456 .clk_regs
= cpucl1_clk_regs
,
1457 .nr_clk_regs
= ARRAY_SIZE(cpucl1_clk_regs
),
1458 .clk_name
= "dout_cpucl1_switch",
1459 .manual_plls
= true,
1462 static void __init
exynos850_cmu_cpucl1_init(struct device_node
*np
)
1464 exynos_arm64_register_cmu(NULL
, np
, &cpucl1_cmu_info
);
1467 /* Register CMU_CPUCL1 early, as CPU clocks should be available ASAP */
1468 CLK_OF_DECLARE(exynos850_cmu_cpucl1
, "samsung,exynos850-cmu-cpucl1",
1469 exynos850_cmu_cpucl1_init
);
1471 /* ---- CMU_G3D ------------------------------------------------------------- */
1473 /* Register Offset definitions for CMU_G3D (0x11400000) */
1474 #define PLL_LOCKTIME_PLL_G3D 0x0000
1475 #define PLL_CON0_PLL_G3D 0x0100
1476 #define PLL_CON3_PLL_G3D 0x010c
1477 #define PLL_CON0_MUX_CLKCMU_G3D_SWITCH_USER 0x0600
1478 #define CLK_CON_MUX_MUX_CLK_G3D_BUSD 0x1000
1479 #define CLK_CON_DIV_DIV_CLK_G3D_BUSP 0x1804
1480 #define CLK_CON_GAT_CLK_G3D_CMU_G3D_PCLK 0x2000
1481 #define CLK_CON_GAT_CLK_G3D_GPU_CLK 0x2004
1482 #define CLK_CON_GAT_GOUT_G3D_TZPC_PCLK 0x200c
1483 #define CLK_CON_GAT_GOUT_G3D_GRAY2BIN_CLK 0x2010
1484 #define CLK_CON_GAT_GOUT_G3D_BUSD_CLK 0x2024
1485 #define CLK_CON_GAT_GOUT_G3D_BUSP_CLK 0x2028
1486 #define CLK_CON_GAT_GOUT_G3D_SYSREG_PCLK 0x202c
1488 static const unsigned long g3d_clk_regs
[] __initconst
= {
1489 PLL_LOCKTIME_PLL_G3D
,
1492 PLL_CON0_MUX_CLKCMU_G3D_SWITCH_USER
,
1493 CLK_CON_MUX_MUX_CLK_G3D_BUSD
,
1494 CLK_CON_DIV_DIV_CLK_G3D_BUSP
,
1495 CLK_CON_GAT_CLK_G3D_CMU_G3D_PCLK
,
1496 CLK_CON_GAT_CLK_G3D_GPU_CLK
,
1497 CLK_CON_GAT_GOUT_G3D_TZPC_PCLK
,
1498 CLK_CON_GAT_GOUT_G3D_GRAY2BIN_CLK
,
1499 CLK_CON_GAT_GOUT_G3D_BUSD_CLK
,
1500 CLK_CON_GAT_GOUT_G3D_BUSP_CLK
,
1501 CLK_CON_GAT_GOUT_G3D_SYSREG_PCLK
,
1504 /* List of parent clocks for Muxes in CMU_G3D */
1505 PNAME(mout_g3d_pll_p
) = { "oscclk", "fout_g3d_pll" };
1506 PNAME(mout_g3d_switch_user_p
) = { "oscclk", "dout_g3d_switch" };
1507 PNAME(mout_g3d_busd_p
) = { "mout_g3d_pll", "mout_g3d_switch_user" };
1510 * Do not provide PLL table to PLL_G3D, as MANUAL_PLL_CTRL bit is not set
1511 * for that PLL by default, so set_rate operation would fail.
1513 static const struct samsung_pll_clock g3d_pll_clks
[] __initconst
= {
1514 PLL(pll_0818x
, CLK_FOUT_G3D_PLL
, "fout_g3d_pll", "oscclk",
1515 PLL_LOCKTIME_PLL_G3D
, PLL_CON3_PLL_G3D
, NULL
),
1518 static const struct samsung_mux_clock g3d_mux_clks
[] __initconst
= {
1519 MUX(CLK_MOUT_G3D_PLL
, "mout_g3d_pll", mout_g3d_pll_p
,
1520 PLL_CON0_PLL_G3D
, 4, 1),
1521 MUX(CLK_MOUT_G3D_SWITCH_USER
, "mout_g3d_switch_user",
1522 mout_g3d_switch_user_p
,
1523 PLL_CON0_MUX_CLKCMU_G3D_SWITCH_USER
, 4, 1),
1524 MUX(CLK_MOUT_G3D_BUSD
, "mout_g3d_busd", mout_g3d_busd_p
,
1525 CLK_CON_MUX_MUX_CLK_G3D_BUSD
, 0, 1),
1528 static const struct samsung_div_clock g3d_div_clks
[] __initconst
= {
1529 DIV(CLK_DOUT_G3D_BUSP
, "dout_g3d_busp", "mout_g3d_busd",
1530 CLK_CON_DIV_DIV_CLK_G3D_BUSP
, 0, 3),
1533 static const struct samsung_gate_clock g3d_gate_clks
[] __initconst
= {
1534 GATE(CLK_GOUT_G3D_CMU_G3D_PCLK
, "gout_g3d_cmu_g3d_pclk",
1536 CLK_CON_GAT_CLK_G3D_CMU_G3D_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1537 GATE(CLK_GOUT_G3D_GPU_CLK
, "gout_g3d_gpu_clk", "mout_g3d_busd",
1538 CLK_CON_GAT_CLK_G3D_GPU_CLK
, 21, 0, 0),
1539 GATE(CLK_GOUT_G3D_TZPC_PCLK
, "gout_g3d_tzpc_pclk", "dout_g3d_busp",
1540 CLK_CON_GAT_GOUT_G3D_TZPC_PCLK
, 21, 0, 0),
1541 GATE(CLK_GOUT_G3D_GRAY2BIN_CLK
, "gout_g3d_gray2bin_clk",
1543 CLK_CON_GAT_GOUT_G3D_GRAY2BIN_CLK
, 21, 0, 0),
1544 GATE(CLK_GOUT_G3D_BUSD_CLK
, "gout_g3d_busd_clk", "mout_g3d_busd",
1545 CLK_CON_GAT_GOUT_G3D_BUSD_CLK
, 21, 0, 0),
1546 GATE(CLK_GOUT_G3D_BUSP_CLK
, "gout_g3d_busp_clk", "dout_g3d_busp",
1547 CLK_CON_GAT_GOUT_G3D_BUSP_CLK
, 21, 0, 0),
1548 GATE(CLK_GOUT_G3D_SYSREG_PCLK
, "gout_g3d_sysreg_pclk", "dout_g3d_busp",
1549 CLK_CON_GAT_GOUT_G3D_SYSREG_PCLK
, 21, 0, 0),
1552 static const struct samsung_cmu_info g3d_cmu_info __initconst
= {
1553 .pll_clks
= g3d_pll_clks
,
1554 .nr_pll_clks
= ARRAY_SIZE(g3d_pll_clks
),
1555 .mux_clks
= g3d_mux_clks
,
1556 .nr_mux_clks
= ARRAY_SIZE(g3d_mux_clks
),
1557 .div_clks
= g3d_div_clks
,
1558 .nr_div_clks
= ARRAY_SIZE(g3d_div_clks
),
1559 .gate_clks
= g3d_gate_clks
,
1560 .nr_gate_clks
= ARRAY_SIZE(g3d_gate_clks
),
1561 .nr_clk_ids
= CLKS_NR_G3D
,
1562 .clk_regs
= g3d_clk_regs
,
1563 .nr_clk_regs
= ARRAY_SIZE(g3d_clk_regs
),
1564 .clk_name
= "dout_g3d_switch",
1567 /* ---- CMU_HSI ------------------------------------------------------------- */
1569 /* Register Offset definitions for CMU_HSI (0x13400000) */
1570 #define PLL_CON0_MUX_CLKCMU_HSI_BUS_USER 0x0600
1571 #define PLL_CON0_MUX_CLKCMU_HSI_MMC_CARD_USER 0x0610
1572 #define PLL_CON0_MUX_CLKCMU_HSI_USB20DRD_USER 0x0620
1573 #define CLK_CON_MUX_MUX_CLK_HSI_RTC 0x1000
1574 #define CLK_CON_GAT_CLK_HSI_CMU_HSI_PCLK 0x2000
1575 #define CLK_CON_GAT_HSI_USB20DRD_TOP_I_RTC_CLK__ALV 0x2008
1576 #define CLK_CON_GAT_HSI_USB20DRD_TOP_I_REF_CLK_50 0x200c
1577 #define CLK_CON_GAT_HSI_USB20DRD_TOP_I_PHY_REFCLK_26 0x2010
1578 #define CLK_CON_GAT_GOUT_HSI_GPIO_HSI_PCLK 0x2018
1579 #define CLK_CON_GAT_GOUT_HSI_MMC_CARD_I_ACLK 0x2024
1580 #define CLK_CON_GAT_GOUT_HSI_MMC_CARD_SDCLKIN 0x2028
1581 #define CLK_CON_GAT_GOUT_HSI_PPMU_ACLK 0x202c
1582 #define CLK_CON_GAT_GOUT_HSI_PPMU_PCLK 0x2030
1583 #define CLK_CON_GAT_GOUT_HSI_SYSREG_HSI_PCLK 0x2038
1584 #define CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_ACLK_PHYCTRL_20 0x203c
1585 #define CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_BUS_CLK_EARLY 0x2040
1587 static const unsigned long hsi_clk_regs
[] __initconst
= {
1588 PLL_CON0_MUX_CLKCMU_HSI_BUS_USER
,
1589 PLL_CON0_MUX_CLKCMU_HSI_MMC_CARD_USER
,
1590 PLL_CON0_MUX_CLKCMU_HSI_USB20DRD_USER
,
1591 CLK_CON_MUX_MUX_CLK_HSI_RTC
,
1592 CLK_CON_GAT_CLK_HSI_CMU_HSI_PCLK
,
1593 CLK_CON_GAT_HSI_USB20DRD_TOP_I_RTC_CLK__ALV
,
1594 CLK_CON_GAT_HSI_USB20DRD_TOP_I_REF_CLK_50
,
1595 CLK_CON_GAT_HSI_USB20DRD_TOP_I_PHY_REFCLK_26
,
1596 CLK_CON_GAT_GOUT_HSI_GPIO_HSI_PCLK
,
1597 CLK_CON_GAT_GOUT_HSI_MMC_CARD_I_ACLK
,
1598 CLK_CON_GAT_GOUT_HSI_MMC_CARD_SDCLKIN
,
1599 CLK_CON_GAT_GOUT_HSI_PPMU_ACLK
,
1600 CLK_CON_GAT_GOUT_HSI_PPMU_PCLK
,
1601 CLK_CON_GAT_GOUT_HSI_SYSREG_HSI_PCLK
,
1602 CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_ACLK_PHYCTRL_20
,
1603 CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_BUS_CLK_EARLY
,
1606 /* List of parent clocks for Muxes in CMU_HSI */
1607 PNAME(mout_hsi_bus_user_p
) = { "oscclk", "dout_hsi_bus" };
1608 PNAME(mout_hsi_mmc_card_user_p
) = { "oscclk", "dout_hsi_mmc_card" };
1609 PNAME(mout_hsi_usb20drd_user_p
) = { "oscclk", "dout_hsi_usb20drd" };
1610 PNAME(mout_hsi_rtc_p
) = { "rtcclk", "oscclk" };
1612 static const struct samsung_mux_clock hsi_mux_clks
[] __initconst
= {
1613 MUX(CLK_MOUT_HSI_BUS_USER
, "mout_hsi_bus_user", mout_hsi_bus_user_p
,
1614 PLL_CON0_MUX_CLKCMU_HSI_BUS_USER
, 4, 1),
1615 MUX_F(CLK_MOUT_HSI_MMC_CARD_USER
, "mout_hsi_mmc_card_user",
1616 mout_hsi_mmc_card_user_p
, PLL_CON0_MUX_CLKCMU_HSI_MMC_CARD_USER
,
1617 4, 1, CLK_SET_RATE_PARENT
, 0),
1618 MUX(CLK_MOUT_HSI_USB20DRD_USER
, "mout_hsi_usb20drd_user",
1619 mout_hsi_usb20drd_user_p
, PLL_CON0_MUX_CLKCMU_HSI_USB20DRD_USER
,
1621 MUX(CLK_MOUT_HSI_RTC
, "mout_hsi_rtc", mout_hsi_rtc_p
,
1622 CLK_CON_MUX_MUX_CLK_HSI_RTC
, 0, 1),
1625 static const struct samsung_gate_clock hsi_gate_clks
[] __initconst
= {
1626 /* TODO: Should be enabled in corresponding driver */
1627 GATE(CLK_GOUT_HSI_CMU_HSI_PCLK
, "gout_hsi_cmu_hsi_pclk",
1628 "mout_hsi_bus_user",
1629 CLK_CON_GAT_CLK_HSI_CMU_HSI_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1630 GATE(CLK_GOUT_USB_RTC_CLK
, "gout_usb_rtc", "mout_hsi_rtc",
1631 CLK_CON_GAT_HSI_USB20DRD_TOP_I_RTC_CLK__ALV
, 21, 0, 0),
1632 GATE(CLK_GOUT_USB_REF_CLK
, "gout_usb_ref", "mout_hsi_usb20drd_user",
1633 CLK_CON_GAT_HSI_USB20DRD_TOP_I_REF_CLK_50
, 21, 0, 0),
1634 GATE(CLK_GOUT_USB_PHY_REF_CLK
, "gout_usb_phy_ref", "oscclk",
1635 CLK_CON_GAT_HSI_USB20DRD_TOP_I_PHY_REFCLK_26
, 21, 0, 0),
1636 /* TODO: Should be enabled in GPIO driver (or made CLK_IS_CRITICAL) */
1637 GATE(CLK_GOUT_GPIO_HSI_PCLK
, "gout_gpio_hsi_pclk", "mout_hsi_bus_user",
1638 CLK_CON_GAT_GOUT_HSI_GPIO_HSI_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1639 GATE(CLK_GOUT_MMC_CARD_ACLK
, "gout_mmc_card_aclk", "mout_hsi_bus_user",
1640 CLK_CON_GAT_GOUT_HSI_MMC_CARD_I_ACLK
, 21, 0, 0),
1641 GATE(CLK_GOUT_MMC_CARD_SDCLKIN
, "gout_mmc_card_sdclkin",
1642 "mout_hsi_mmc_card_user",
1643 CLK_CON_GAT_GOUT_HSI_MMC_CARD_SDCLKIN
, 21, CLK_SET_RATE_PARENT
, 0),
1644 GATE(CLK_GOUT_HSI_PPMU_ACLK
, "gout_hsi_ppmu_aclk", "mout_hsi_bus_user",
1645 CLK_CON_GAT_GOUT_HSI_PPMU_ACLK
, 21, 0, 0),
1646 GATE(CLK_GOUT_HSI_PPMU_PCLK
, "gout_hsi_ppmu_pclk", "mout_hsi_bus_user",
1647 CLK_CON_GAT_GOUT_HSI_PPMU_PCLK
, 21, 0, 0),
1648 GATE(CLK_GOUT_SYSREG_HSI_PCLK
, "gout_sysreg_hsi_pclk",
1649 "mout_hsi_bus_user",
1650 CLK_CON_GAT_GOUT_HSI_SYSREG_HSI_PCLK
, 21, 0, 0),
1651 GATE(CLK_GOUT_USB_PHY_ACLK
, "gout_usb_phy_aclk", "mout_hsi_bus_user",
1652 CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_ACLK_PHYCTRL_20
, 21, 0, 0),
1653 GATE(CLK_GOUT_USB_BUS_EARLY_CLK
, "gout_usb_bus_early",
1654 "mout_hsi_bus_user",
1655 CLK_CON_GAT_GOUT_HSI_USB20DRD_TOP_BUS_CLK_EARLY
, 21, 0, 0),
1658 static const struct samsung_cmu_info hsi_cmu_info __initconst
= {
1659 .mux_clks
= hsi_mux_clks
,
1660 .nr_mux_clks
= ARRAY_SIZE(hsi_mux_clks
),
1661 .gate_clks
= hsi_gate_clks
,
1662 .nr_gate_clks
= ARRAY_SIZE(hsi_gate_clks
),
1663 .nr_clk_ids
= CLKS_NR_HSI
,
1664 .clk_regs
= hsi_clk_regs
,
1665 .nr_clk_regs
= ARRAY_SIZE(hsi_clk_regs
),
1666 .clk_name
= "dout_hsi_bus",
1669 /* ---- CMU_IS -------------------------------------------------------------- */
1671 #define PLL_CON0_MUX_CLKCMU_IS_BUS_USER 0x0600
1672 #define PLL_CON0_MUX_CLKCMU_IS_GDC_USER 0x0610
1673 #define PLL_CON0_MUX_CLKCMU_IS_ITP_USER 0x0620
1674 #define PLL_CON0_MUX_CLKCMU_IS_VRA_USER 0x0630
1675 #define CLK_CON_DIV_DIV_CLK_IS_BUSP 0x1800
1676 #define CLK_CON_GAT_CLK_IS_CMU_IS_PCLK 0x2000
1677 #define CLK_CON_GAT_GOUT_IS_CSIS0_ACLK 0x2040
1678 #define CLK_CON_GAT_GOUT_IS_CSIS1_ACLK 0x2044
1679 #define CLK_CON_GAT_GOUT_IS_CSIS2_ACLK 0x2048
1680 #define CLK_CON_GAT_GOUT_IS_TZPC_PCLK 0x204c
1681 #define CLK_CON_GAT_GOUT_IS_CLK_CSIS_DMA 0x2050
1682 #define CLK_CON_GAT_GOUT_IS_CLK_GDC 0x2054
1683 #define CLK_CON_GAT_GOUT_IS_CLK_IPP 0x2058
1684 #define CLK_CON_GAT_GOUT_IS_CLK_ITP 0x205c
1685 #define CLK_CON_GAT_GOUT_IS_CLK_MCSC 0x2060
1686 #define CLK_CON_GAT_GOUT_IS_CLK_VRA 0x2064
1687 #define CLK_CON_GAT_GOUT_IS_PPMU_IS0_ACLK 0x2074
1688 #define CLK_CON_GAT_GOUT_IS_PPMU_IS0_PCLK 0x2078
1689 #define CLK_CON_GAT_GOUT_IS_PPMU_IS1_ACLK 0x207c
1690 #define CLK_CON_GAT_GOUT_IS_PPMU_IS1_PCLK 0x2080
1691 #define CLK_CON_GAT_GOUT_IS_SYSMMU_IS0_CLK_S1 0x2098
1692 #define CLK_CON_GAT_GOUT_IS_SYSMMU_IS1_CLK_S1 0x209c
1693 #define CLK_CON_GAT_GOUT_IS_SYSREG_PCLK 0x20a0
1695 static const unsigned long is_clk_regs
[] __initconst
= {
1696 PLL_CON0_MUX_CLKCMU_IS_BUS_USER
,
1697 PLL_CON0_MUX_CLKCMU_IS_GDC_USER
,
1698 PLL_CON0_MUX_CLKCMU_IS_ITP_USER
,
1699 PLL_CON0_MUX_CLKCMU_IS_VRA_USER
,
1700 CLK_CON_DIV_DIV_CLK_IS_BUSP
,
1701 CLK_CON_GAT_CLK_IS_CMU_IS_PCLK
,
1702 CLK_CON_GAT_GOUT_IS_CSIS0_ACLK
,
1703 CLK_CON_GAT_GOUT_IS_CSIS1_ACLK
,
1704 CLK_CON_GAT_GOUT_IS_CSIS2_ACLK
,
1705 CLK_CON_GAT_GOUT_IS_TZPC_PCLK
,
1706 CLK_CON_GAT_GOUT_IS_CLK_CSIS_DMA
,
1707 CLK_CON_GAT_GOUT_IS_CLK_GDC
,
1708 CLK_CON_GAT_GOUT_IS_CLK_IPP
,
1709 CLK_CON_GAT_GOUT_IS_CLK_ITP
,
1710 CLK_CON_GAT_GOUT_IS_CLK_MCSC
,
1711 CLK_CON_GAT_GOUT_IS_CLK_VRA
,
1712 CLK_CON_GAT_GOUT_IS_PPMU_IS0_ACLK
,
1713 CLK_CON_GAT_GOUT_IS_PPMU_IS0_PCLK
,
1714 CLK_CON_GAT_GOUT_IS_PPMU_IS1_ACLK
,
1715 CLK_CON_GAT_GOUT_IS_PPMU_IS1_PCLK
,
1716 CLK_CON_GAT_GOUT_IS_SYSMMU_IS0_CLK_S1
,
1717 CLK_CON_GAT_GOUT_IS_SYSMMU_IS1_CLK_S1
,
1718 CLK_CON_GAT_GOUT_IS_SYSREG_PCLK
,
1721 /* List of parent clocks for Muxes in CMU_IS */
1722 PNAME(mout_is_bus_user_p
) = { "oscclk", "dout_is_bus" };
1723 PNAME(mout_is_itp_user_p
) = { "oscclk", "dout_is_itp" };
1724 PNAME(mout_is_vra_user_p
) = { "oscclk", "dout_is_vra" };
1725 PNAME(mout_is_gdc_user_p
) = { "oscclk", "dout_is_gdc" };
1727 static const struct samsung_mux_clock is_mux_clks
[] __initconst
= {
1728 MUX(CLK_MOUT_IS_BUS_USER
, "mout_is_bus_user", mout_is_bus_user_p
,
1729 PLL_CON0_MUX_CLKCMU_IS_BUS_USER
, 4, 1),
1730 MUX(CLK_MOUT_IS_ITP_USER
, "mout_is_itp_user", mout_is_itp_user_p
,
1731 PLL_CON0_MUX_CLKCMU_IS_ITP_USER
, 4, 1),
1732 MUX(CLK_MOUT_IS_VRA_USER
, "mout_is_vra_user", mout_is_vra_user_p
,
1733 PLL_CON0_MUX_CLKCMU_IS_VRA_USER
, 4, 1),
1734 MUX(CLK_MOUT_IS_GDC_USER
, "mout_is_gdc_user", mout_is_gdc_user_p
,
1735 PLL_CON0_MUX_CLKCMU_IS_GDC_USER
, 4, 1),
1738 static const struct samsung_div_clock is_div_clks
[] __initconst
= {
1739 DIV(CLK_DOUT_IS_BUSP
, "dout_is_busp", "mout_is_bus_user",
1740 CLK_CON_DIV_DIV_CLK_IS_BUSP
, 0, 2),
1743 static const struct samsung_gate_clock is_gate_clks
[] __initconst
= {
1744 /* TODO: Should be enabled in IS driver */
1745 GATE(CLK_GOUT_IS_CMU_IS_PCLK
, "gout_is_cmu_is_pclk", "dout_is_busp",
1746 CLK_CON_GAT_CLK_IS_CMU_IS_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
1747 GATE(CLK_GOUT_IS_CSIS0_ACLK
, "gout_is_csis0_aclk", "mout_is_bus_user",
1748 CLK_CON_GAT_GOUT_IS_CSIS0_ACLK
, 21, 0, 0),
1749 GATE(CLK_GOUT_IS_CSIS1_ACLK
, "gout_is_csis1_aclk", "mout_is_bus_user",
1750 CLK_CON_GAT_GOUT_IS_CSIS1_ACLK
, 21, 0, 0),
1751 GATE(CLK_GOUT_IS_CSIS2_ACLK
, "gout_is_csis2_aclk", "mout_is_bus_user",
1752 CLK_CON_GAT_GOUT_IS_CSIS2_ACLK
, 21, 0, 0),
1753 GATE(CLK_GOUT_IS_TZPC_PCLK
, "gout_is_tzpc_pclk", "dout_is_busp",
1754 CLK_CON_GAT_GOUT_IS_TZPC_PCLK
, 21, 0, 0),
1755 GATE(CLK_GOUT_IS_CSIS_DMA_CLK
, "gout_is_csis_dma_clk",
1757 CLK_CON_GAT_GOUT_IS_CLK_CSIS_DMA
, 21, 0, 0),
1758 GATE(CLK_GOUT_IS_GDC_CLK
, "gout_is_gdc_clk", "mout_is_gdc_user",
1759 CLK_CON_GAT_GOUT_IS_CLK_GDC
, 21, 0, 0),
1760 GATE(CLK_GOUT_IS_IPP_CLK
, "gout_is_ipp_clk", "mout_is_bus_user",
1761 CLK_CON_GAT_GOUT_IS_CLK_IPP
, 21, 0, 0),
1762 GATE(CLK_GOUT_IS_ITP_CLK
, "gout_is_itp_clk", "mout_is_itp_user",
1763 CLK_CON_GAT_GOUT_IS_CLK_ITP
, 21, 0, 0),
1764 GATE(CLK_GOUT_IS_MCSC_CLK
, "gout_is_mcsc_clk", "mout_is_itp_user",
1765 CLK_CON_GAT_GOUT_IS_CLK_MCSC
, 21, 0, 0),
1766 GATE(CLK_GOUT_IS_VRA_CLK
, "gout_is_vra_clk", "mout_is_vra_user",
1767 CLK_CON_GAT_GOUT_IS_CLK_VRA
, 21, 0, 0),
1768 GATE(CLK_GOUT_IS_PPMU_IS0_ACLK
, "gout_is_ppmu_is0_aclk",
1770 CLK_CON_GAT_GOUT_IS_PPMU_IS0_ACLK
, 21, 0, 0),
1771 GATE(CLK_GOUT_IS_PPMU_IS0_PCLK
, "gout_is_ppmu_is0_pclk", "dout_is_busp",
1772 CLK_CON_GAT_GOUT_IS_PPMU_IS0_PCLK
, 21, 0, 0),
1773 GATE(CLK_GOUT_IS_PPMU_IS1_ACLK
, "gout_is_ppmu_is1_aclk",
1775 CLK_CON_GAT_GOUT_IS_PPMU_IS1_ACLK
, 21, 0, 0),
1776 GATE(CLK_GOUT_IS_PPMU_IS1_PCLK
, "gout_is_ppmu_is1_pclk", "dout_is_busp",
1777 CLK_CON_GAT_GOUT_IS_PPMU_IS1_PCLK
, 21, 0, 0),
1778 GATE(CLK_GOUT_IS_SYSMMU_IS0_CLK
, "gout_is_sysmmu_is0_clk",
1780 CLK_CON_GAT_GOUT_IS_SYSMMU_IS0_CLK_S1
, 21, 0, 0),
1781 GATE(CLK_GOUT_IS_SYSMMU_IS1_CLK
, "gout_is_sysmmu_is1_clk",
1783 CLK_CON_GAT_GOUT_IS_SYSMMU_IS1_CLK_S1
, 21, 0, 0),
1784 GATE(CLK_GOUT_IS_SYSREG_PCLK
, "gout_is_sysreg_pclk", "dout_is_busp",
1785 CLK_CON_GAT_GOUT_IS_SYSREG_PCLK
, 21, 0, 0),
1788 static const struct samsung_cmu_info is_cmu_info __initconst
= {
1789 .mux_clks
= is_mux_clks
,
1790 .nr_mux_clks
= ARRAY_SIZE(is_mux_clks
),
1791 .div_clks
= is_div_clks
,
1792 .nr_div_clks
= ARRAY_SIZE(is_div_clks
),
1793 .gate_clks
= is_gate_clks
,
1794 .nr_gate_clks
= ARRAY_SIZE(is_gate_clks
),
1795 .nr_clk_ids
= CLKS_NR_IS
,
1796 .clk_regs
= is_clk_regs
,
1797 .nr_clk_regs
= ARRAY_SIZE(is_clk_regs
),
1798 .clk_name
= "dout_is_bus",
1801 /* ---- CMU_MFCMSCL --------------------------------------------------------- */
1803 #define PLL_CON0_MUX_CLKCMU_MFCMSCL_JPEG_USER 0x0600
1804 #define PLL_CON0_MUX_CLKCMU_MFCMSCL_M2M_USER 0x0610
1805 #define PLL_CON0_MUX_CLKCMU_MFCMSCL_MCSC_USER 0x0620
1806 #define PLL_CON0_MUX_CLKCMU_MFCMSCL_MFC_USER 0x0630
1807 #define CLK_CON_DIV_DIV_CLK_MFCMSCL_BUSP 0x1800
1808 #define CLK_CON_GAT_CLK_MFCMSCL_CMU_MFCMSCL_PCLK 0x2000
1809 #define CLK_CON_GAT_GOUT_MFCMSCL_TZPC_PCLK 0x2038
1810 #define CLK_CON_GAT_GOUT_MFCMSCL_JPEG_ACLK 0x203c
1811 #define CLK_CON_GAT_GOUT_MFCMSCL_M2M_ACLK 0x2048
1812 #define CLK_CON_GAT_GOUT_MFCMSCL_MCSC_I_CLK 0x204c
1813 #define CLK_CON_GAT_GOUT_MFCMSCL_MFC_ACLK 0x2050
1814 #define CLK_CON_GAT_GOUT_MFCMSCL_PPMU_ACLK 0x2054
1815 #define CLK_CON_GAT_GOUT_MFCMSCL_PPMU_PCLK 0x2058
1816 #define CLK_CON_GAT_GOUT_MFCMSCL_SYSMMU_CLK_S1 0x2074
1817 #define CLK_CON_GAT_GOUT_MFCMSCL_SYSREG_PCLK 0x2078
1819 static const unsigned long mfcmscl_clk_regs
[] __initconst
= {
1820 PLL_CON0_MUX_CLKCMU_MFCMSCL_JPEG_USER
,
1821 PLL_CON0_MUX_CLKCMU_MFCMSCL_M2M_USER
,
1822 PLL_CON0_MUX_CLKCMU_MFCMSCL_MCSC_USER
,
1823 PLL_CON0_MUX_CLKCMU_MFCMSCL_MFC_USER
,
1824 CLK_CON_DIV_DIV_CLK_MFCMSCL_BUSP
,
1825 CLK_CON_GAT_CLK_MFCMSCL_CMU_MFCMSCL_PCLK
,
1826 CLK_CON_GAT_GOUT_MFCMSCL_TZPC_PCLK
,
1827 CLK_CON_GAT_GOUT_MFCMSCL_JPEG_ACLK
,
1828 CLK_CON_GAT_GOUT_MFCMSCL_M2M_ACLK
,
1829 CLK_CON_GAT_GOUT_MFCMSCL_MCSC_I_CLK
,
1830 CLK_CON_GAT_GOUT_MFCMSCL_MFC_ACLK
,
1831 CLK_CON_GAT_GOUT_MFCMSCL_PPMU_ACLK
,
1832 CLK_CON_GAT_GOUT_MFCMSCL_PPMU_PCLK
,
1833 CLK_CON_GAT_GOUT_MFCMSCL_SYSMMU_CLK_S1
,
1834 CLK_CON_GAT_GOUT_MFCMSCL_SYSREG_PCLK
,
1837 /* List of parent clocks for Muxes in CMU_MFCMSCL */
1838 PNAME(mout_mfcmscl_mfc_user_p
) = { "oscclk", "dout_mfcmscl_mfc" };
1839 PNAME(mout_mfcmscl_m2m_user_p
) = { "oscclk", "dout_mfcmscl_m2m" };
1840 PNAME(mout_mfcmscl_mcsc_user_p
) = { "oscclk", "dout_mfcmscl_mcsc" };
1841 PNAME(mout_mfcmscl_jpeg_user_p
) = { "oscclk", "dout_mfcmscl_jpeg" };
1843 static const struct samsung_mux_clock mfcmscl_mux_clks
[] __initconst
= {
1844 MUX(CLK_MOUT_MFCMSCL_MFC_USER
, "mout_mfcmscl_mfc_user",
1845 mout_mfcmscl_mfc_user_p
,
1846 PLL_CON0_MUX_CLKCMU_MFCMSCL_MFC_USER
, 4, 1),
1847 MUX(CLK_MOUT_MFCMSCL_M2M_USER
, "mout_mfcmscl_m2m_user",
1848 mout_mfcmscl_m2m_user_p
,
1849 PLL_CON0_MUX_CLKCMU_MFCMSCL_M2M_USER
, 4, 1),
1850 MUX(CLK_MOUT_MFCMSCL_MCSC_USER
, "mout_mfcmscl_mcsc_user",
1851 mout_mfcmscl_mcsc_user_p
,
1852 PLL_CON0_MUX_CLKCMU_MFCMSCL_MCSC_USER
, 4, 1),
1853 MUX(CLK_MOUT_MFCMSCL_JPEG_USER
, "mout_mfcmscl_jpeg_user",
1854 mout_mfcmscl_jpeg_user_p
,
1855 PLL_CON0_MUX_CLKCMU_MFCMSCL_JPEG_USER
, 4, 1),
1858 static const struct samsung_div_clock mfcmscl_div_clks
[] __initconst
= {
1859 DIV(CLK_DOUT_MFCMSCL_BUSP
, "dout_mfcmscl_busp", "mout_mfcmscl_mfc_user",
1860 CLK_CON_DIV_DIV_CLK_MFCMSCL_BUSP
, 0, 3),
1863 static const struct samsung_gate_clock mfcmscl_gate_clks
[] __initconst
= {
1864 /* TODO: Should be enabled in MFC driver */
1865 GATE(CLK_GOUT_MFCMSCL_CMU_MFCMSCL_PCLK
, "gout_mfcmscl_cmu_mfcmscl_pclk",
1866 "dout_mfcmscl_busp", CLK_CON_GAT_CLK_MFCMSCL_CMU_MFCMSCL_PCLK
,
1867 21, CLK_IGNORE_UNUSED
, 0),
1868 GATE(CLK_GOUT_MFCMSCL_TZPC_PCLK
, "gout_mfcmscl_tzpc_pclk",
1869 "dout_mfcmscl_busp", CLK_CON_GAT_GOUT_MFCMSCL_TZPC_PCLK
,
1871 GATE(CLK_GOUT_MFCMSCL_JPEG_ACLK
, "gout_mfcmscl_jpeg_aclk",
1872 "mout_mfcmscl_jpeg_user", CLK_CON_GAT_GOUT_MFCMSCL_JPEG_ACLK
,
1874 GATE(CLK_GOUT_MFCMSCL_M2M_ACLK
, "gout_mfcmscl_m2m_aclk",
1875 "mout_mfcmscl_m2m_user", CLK_CON_GAT_GOUT_MFCMSCL_M2M_ACLK
,
1877 GATE(CLK_GOUT_MFCMSCL_MCSC_CLK
, "gout_mfcmscl_mcsc_clk",
1878 "mout_mfcmscl_mcsc_user", CLK_CON_GAT_GOUT_MFCMSCL_MCSC_I_CLK
,
1880 GATE(CLK_GOUT_MFCMSCL_MFC_ACLK
, "gout_mfcmscl_mfc_aclk",
1881 "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_MFC_ACLK
,
1883 GATE(CLK_GOUT_MFCMSCL_PPMU_ACLK
, "gout_mfcmscl_ppmu_aclk",
1884 "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_PPMU_ACLK
,
1886 GATE(CLK_GOUT_MFCMSCL_PPMU_PCLK
, "gout_mfcmscl_ppmu_pclk",
1887 "dout_mfcmscl_busp", CLK_CON_GAT_GOUT_MFCMSCL_PPMU_PCLK
,
1889 GATE(CLK_GOUT_MFCMSCL_SYSMMU_CLK
, "gout_mfcmscl_sysmmu_clk",
1890 "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_SYSMMU_CLK_S1
,
1892 GATE(CLK_GOUT_MFCMSCL_SYSREG_PCLK
, "gout_mfcmscl_sysreg_pclk",
1893 "dout_mfcmscl_busp", CLK_CON_GAT_GOUT_MFCMSCL_SYSREG_PCLK
,
1897 static const struct samsung_cmu_info mfcmscl_cmu_info __initconst
= {
1898 .mux_clks
= mfcmscl_mux_clks
,
1899 .nr_mux_clks
= ARRAY_SIZE(mfcmscl_mux_clks
),
1900 .div_clks
= mfcmscl_div_clks
,
1901 .nr_div_clks
= ARRAY_SIZE(mfcmscl_div_clks
),
1902 .gate_clks
= mfcmscl_gate_clks
,
1903 .nr_gate_clks
= ARRAY_SIZE(mfcmscl_gate_clks
),
1904 .nr_clk_ids
= CLKS_NR_MFCMSCL
,
1905 .clk_regs
= mfcmscl_clk_regs
,
1906 .nr_clk_regs
= ARRAY_SIZE(mfcmscl_clk_regs
),
1907 .clk_name
= "dout_mfcmscl_mfc",
1910 /* ---- CMU_PERI ------------------------------------------------------------ */
1912 /* Register Offset definitions for CMU_PERI (0x10030000) */
1913 #define PLL_CON0_MUX_CLKCMU_PERI_BUS_USER 0x0600
1914 #define PLL_CON0_MUX_CLKCMU_PERI_HSI2C_USER 0x0610
1915 #define PLL_CON0_MUX_CLKCMU_PERI_SPI_USER 0x0620
1916 #define PLL_CON0_MUX_CLKCMU_PERI_UART_USER 0x0630
1917 #define CLK_CON_DIV_DIV_CLK_PERI_HSI2C_0 0x1800
1918 #define CLK_CON_DIV_DIV_CLK_PERI_HSI2C_1 0x1804
1919 #define CLK_CON_DIV_DIV_CLK_PERI_HSI2C_2 0x1808
1920 #define CLK_CON_DIV_DIV_CLK_PERI_SPI_0 0x180c
1921 #define CLK_CON_GAT_GATE_CLK_PERI_HSI2C_0 0x200c
1922 #define CLK_CON_GAT_GATE_CLK_PERI_HSI2C_1 0x2010
1923 #define CLK_CON_GAT_GATE_CLK_PERI_HSI2C_2 0x2014
1924 #define CLK_CON_GAT_GOUT_PERI_BUSIF_TMU_PCLK 0x2018
1925 #define CLK_CON_GAT_GOUT_PERI_GPIO_PERI_PCLK 0x2020
1926 #define CLK_CON_GAT_GOUT_PERI_HSI2C_0_IPCLK 0x2024
1927 #define CLK_CON_GAT_GOUT_PERI_HSI2C_0_PCLK 0x2028
1928 #define CLK_CON_GAT_GOUT_PERI_HSI2C_1_IPCLK 0x202c
1929 #define CLK_CON_GAT_GOUT_PERI_HSI2C_1_PCLK 0x2030
1930 #define CLK_CON_GAT_GOUT_PERI_HSI2C_2_IPCLK 0x2034
1931 #define CLK_CON_GAT_GOUT_PERI_HSI2C_2_PCLK 0x2038
1932 #define CLK_CON_GAT_GOUT_PERI_I2C_0_PCLK 0x203c
1933 #define CLK_CON_GAT_GOUT_PERI_I2C_1_PCLK 0x2040
1934 #define CLK_CON_GAT_GOUT_PERI_I2C_2_PCLK 0x2044
1935 #define CLK_CON_GAT_GOUT_PERI_I2C_3_PCLK 0x2048
1936 #define CLK_CON_GAT_GOUT_PERI_I2C_4_PCLK 0x204c
1937 #define CLK_CON_GAT_GOUT_PERI_I2C_5_PCLK 0x2050
1938 #define CLK_CON_GAT_GOUT_PERI_I2C_6_PCLK 0x2054
1939 #define CLK_CON_GAT_GOUT_PERI_MCT_PCLK 0x205c
1940 #define CLK_CON_GAT_GOUT_PERI_PWM_MOTOR_PCLK 0x2064
1941 #define CLK_CON_GAT_GOUT_PERI_SPI_0_IPCLK 0x209c
1942 #define CLK_CON_GAT_GOUT_PERI_SPI_0_PCLK 0x20a0
1943 #define CLK_CON_GAT_GOUT_PERI_SYSREG_PERI_PCLK 0x20a4
1944 #define CLK_CON_GAT_GOUT_PERI_UART_IPCLK 0x20a8
1945 #define CLK_CON_GAT_GOUT_PERI_UART_PCLK 0x20ac
1946 #define CLK_CON_GAT_GOUT_PERI_WDT_0_PCLK 0x20b0
1947 #define CLK_CON_GAT_GOUT_PERI_WDT_1_PCLK 0x20b4
1949 static const unsigned long peri_clk_regs
[] __initconst
= {
1950 PLL_CON0_MUX_CLKCMU_PERI_BUS_USER
,
1951 PLL_CON0_MUX_CLKCMU_PERI_HSI2C_USER
,
1952 PLL_CON0_MUX_CLKCMU_PERI_SPI_USER
,
1953 PLL_CON0_MUX_CLKCMU_PERI_UART_USER
,
1954 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_0
,
1955 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_1
,
1956 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_2
,
1957 CLK_CON_DIV_DIV_CLK_PERI_SPI_0
,
1958 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_0
,
1959 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_1
,
1960 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_2
,
1961 CLK_CON_GAT_GOUT_PERI_BUSIF_TMU_PCLK
,
1962 CLK_CON_GAT_GOUT_PERI_GPIO_PERI_PCLK
,
1963 CLK_CON_GAT_GOUT_PERI_HSI2C_0_IPCLK
,
1964 CLK_CON_GAT_GOUT_PERI_HSI2C_0_PCLK
,
1965 CLK_CON_GAT_GOUT_PERI_HSI2C_1_IPCLK
,
1966 CLK_CON_GAT_GOUT_PERI_HSI2C_1_PCLK
,
1967 CLK_CON_GAT_GOUT_PERI_HSI2C_2_IPCLK
,
1968 CLK_CON_GAT_GOUT_PERI_HSI2C_2_PCLK
,
1969 CLK_CON_GAT_GOUT_PERI_I2C_0_PCLK
,
1970 CLK_CON_GAT_GOUT_PERI_I2C_1_PCLK
,
1971 CLK_CON_GAT_GOUT_PERI_I2C_2_PCLK
,
1972 CLK_CON_GAT_GOUT_PERI_I2C_3_PCLK
,
1973 CLK_CON_GAT_GOUT_PERI_I2C_4_PCLK
,
1974 CLK_CON_GAT_GOUT_PERI_I2C_5_PCLK
,
1975 CLK_CON_GAT_GOUT_PERI_I2C_6_PCLK
,
1976 CLK_CON_GAT_GOUT_PERI_MCT_PCLK
,
1977 CLK_CON_GAT_GOUT_PERI_PWM_MOTOR_PCLK
,
1978 CLK_CON_GAT_GOUT_PERI_SPI_0_IPCLK
,
1979 CLK_CON_GAT_GOUT_PERI_SPI_0_PCLK
,
1980 CLK_CON_GAT_GOUT_PERI_SYSREG_PERI_PCLK
,
1981 CLK_CON_GAT_GOUT_PERI_UART_IPCLK
,
1982 CLK_CON_GAT_GOUT_PERI_UART_PCLK
,
1983 CLK_CON_GAT_GOUT_PERI_WDT_0_PCLK
,
1984 CLK_CON_GAT_GOUT_PERI_WDT_1_PCLK
,
1987 /* List of parent clocks for Muxes in CMU_PERI */
1988 PNAME(mout_peri_bus_user_p
) = { "oscclk", "dout_peri_bus" };
1989 PNAME(mout_peri_uart_user_p
) = { "oscclk", "dout_peri_uart" };
1990 PNAME(mout_peri_hsi2c_user_p
) = { "oscclk", "dout_peri_ip" };
1991 PNAME(mout_peri_spi_user_p
) = { "oscclk", "dout_peri_ip" };
1993 static const struct samsung_mux_clock peri_mux_clks
[] __initconst
= {
1994 MUX(CLK_MOUT_PERI_BUS_USER
, "mout_peri_bus_user", mout_peri_bus_user_p
,
1995 PLL_CON0_MUX_CLKCMU_PERI_BUS_USER
, 4, 1),
1996 MUX(CLK_MOUT_PERI_UART_USER
, "mout_peri_uart_user",
1997 mout_peri_uart_user_p
, PLL_CON0_MUX_CLKCMU_PERI_UART_USER
, 4, 1),
1998 MUX(CLK_MOUT_PERI_HSI2C_USER
, "mout_peri_hsi2c_user",
1999 mout_peri_hsi2c_user_p
, PLL_CON0_MUX_CLKCMU_PERI_HSI2C_USER
, 4, 1),
2000 MUX_F(CLK_MOUT_PERI_SPI_USER
, "mout_peri_spi_user",
2001 mout_peri_spi_user_p
, PLL_CON0_MUX_CLKCMU_PERI_SPI_USER
, 4, 1,
2002 CLK_SET_RATE_PARENT
, 0),
2005 static const struct samsung_div_clock peri_div_clks
[] __initconst
= {
2006 DIV(CLK_DOUT_PERI_HSI2C0
, "dout_peri_hsi2c0", "gout_peri_hsi2c0",
2007 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_0
, 0, 5),
2008 DIV(CLK_DOUT_PERI_HSI2C1
, "dout_peri_hsi2c1", "gout_peri_hsi2c1",
2009 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_1
, 0, 5),
2010 DIV(CLK_DOUT_PERI_HSI2C2
, "dout_peri_hsi2c2", "gout_peri_hsi2c2",
2011 CLK_CON_DIV_DIV_CLK_PERI_HSI2C_2
, 0, 5),
2012 DIV_F(CLK_DOUT_PERI_SPI0
, "dout_peri_spi0", "mout_peri_spi_user",
2013 CLK_CON_DIV_DIV_CLK_PERI_SPI_0
, 0, 5, CLK_SET_RATE_PARENT
, 0),
2016 static const struct samsung_gate_clock peri_gate_clks
[] __initconst
= {
2017 GATE(CLK_GOUT_PERI_HSI2C0
, "gout_peri_hsi2c0", "mout_peri_hsi2c_user",
2018 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_0
, 21, 0, 0),
2019 GATE(CLK_GOUT_PERI_HSI2C1
, "gout_peri_hsi2c1", "mout_peri_hsi2c_user",
2020 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_1
, 21, 0, 0),
2021 GATE(CLK_GOUT_PERI_HSI2C2
, "gout_peri_hsi2c2", "mout_peri_hsi2c_user",
2022 CLK_CON_GAT_GATE_CLK_PERI_HSI2C_2
, 21, 0, 0),
2023 GATE(CLK_GOUT_HSI2C0_IPCLK
, "gout_hsi2c0_ipclk", "dout_peri_hsi2c0",
2024 CLK_CON_GAT_GOUT_PERI_HSI2C_0_IPCLK
, 21, 0, 0),
2025 GATE(CLK_GOUT_HSI2C0_PCLK
, "gout_hsi2c0_pclk", "mout_peri_bus_user",
2026 CLK_CON_GAT_GOUT_PERI_HSI2C_0_PCLK
, 21, 0, 0),
2027 GATE(CLK_GOUT_HSI2C1_IPCLK
, "gout_hsi2c1_ipclk", "dout_peri_hsi2c1",
2028 CLK_CON_GAT_GOUT_PERI_HSI2C_1_IPCLK
, 21, 0, 0),
2029 GATE(CLK_GOUT_HSI2C1_PCLK
, "gout_hsi2c1_pclk", "mout_peri_bus_user",
2030 CLK_CON_GAT_GOUT_PERI_HSI2C_1_PCLK
, 21, 0, 0),
2031 GATE(CLK_GOUT_HSI2C2_IPCLK
, "gout_hsi2c2_ipclk", "dout_peri_hsi2c2",
2032 CLK_CON_GAT_GOUT_PERI_HSI2C_2_IPCLK
, 21, 0, 0),
2033 GATE(CLK_GOUT_HSI2C2_PCLK
, "gout_hsi2c2_pclk", "mout_peri_bus_user",
2034 CLK_CON_GAT_GOUT_PERI_HSI2C_2_PCLK
, 21, 0, 0),
2035 GATE(CLK_GOUT_I2C0_PCLK
, "gout_i2c0_pclk", "mout_peri_bus_user",
2036 CLK_CON_GAT_GOUT_PERI_I2C_0_PCLK
, 21, 0, 0),
2037 GATE(CLK_GOUT_I2C1_PCLK
, "gout_i2c1_pclk", "mout_peri_bus_user",
2038 CLK_CON_GAT_GOUT_PERI_I2C_1_PCLK
, 21, 0, 0),
2039 GATE(CLK_GOUT_I2C2_PCLK
, "gout_i2c2_pclk", "mout_peri_bus_user",
2040 CLK_CON_GAT_GOUT_PERI_I2C_2_PCLK
, 21, 0, 0),
2041 GATE(CLK_GOUT_I2C3_PCLK
, "gout_i2c3_pclk", "mout_peri_bus_user",
2042 CLK_CON_GAT_GOUT_PERI_I2C_3_PCLK
, 21, 0, 0),
2043 GATE(CLK_GOUT_I2C4_PCLK
, "gout_i2c4_pclk", "mout_peri_bus_user",
2044 CLK_CON_GAT_GOUT_PERI_I2C_4_PCLK
, 21, 0, 0),
2045 GATE(CLK_GOUT_I2C5_PCLK
, "gout_i2c5_pclk", "mout_peri_bus_user",
2046 CLK_CON_GAT_GOUT_PERI_I2C_5_PCLK
, 21, 0, 0),
2047 GATE(CLK_GOUT_I2C6_PCLK
, "gout_i2c6_pclk", "mout_peri_bus_user",
2048 CLK_CON_GAT_GOUT_PERI_I2C_6_PCLK
, 21, 0, 0),
2049 GATE(CLK_GOUT_MCT_PCLK
, "gout_mct_pclk", "mout_peri_bus_user",
2050 CLK_CON_GAT_GOUT_PERI_MCT_PCLK
, 21, 0, 0),
2051 GATE(CLK_GOUT_PWM_MOTOR_PCLK
, "gout_pwm_motor_pclk",
2052 "mout_peri_bus_user",
2053 CLK_CON_GAT_GOUT_PERI_PWM_MOTOR_PCLK
, 21, 0, 0),
2054 GATE(CLK_GOUT_SPI0_IPCLK
, "gout_spi0_ipclk", "dout_peri_spi0",
2055 CLK_CON_GAT_GOUT_PERI_SPI_0_IPCLK
, 21, CLK_SET_RATE_PARENT
, 0),
2056 GATE(CLK_GOUT_SPI0_PCLK
, "gout_spi0_pclk", "mout_peri_bus_user",
2057 CLK_CON_GAT_GOUT_PERI_SPI_0_PCLK
, 21, 0, 0),
2058 GATE(CLK_GOUT_SYSREG_PERI_PCLK
, "gout_sysreg_peri_pclk",
2059 "mout_peri_bus_user",
2060 CLK_CON_GAT_GOUT_PERI_SYSREG_PERI_PCLK
, 21, 0, 0),
2061 GATE(CLK_GOUT_UART_IPCLK
, "gout_uart_ipclk", "mout_peri_uart_user",
2062 CLK_CON_GAT_GOUT_PERI_UART_IPCLK
, 21, 0, 0),
2063 GATE(CLK_GOUT_UART_PCLK
, "gout_uart_pclk", "mout_peri_bus_user",
2064 CLK_CON_GAT_GOUT_PERI_UART_PCLK
, 21, 0, 0),
2065 GATE(CLK_GOUT_WDT0_PCLK
, "gout_wdt0_pclk", "mout_peri_bus_user",
2066 CLK_CON_GAT_GOUT_PERI_WDT_0_PCLK
, 21, 0, 0),
2067 GATE(CLK_GOUT_WDT1_PCLK
, "gout_wdt1_pclk", "mout_peri_bus_user",
2068 CLK_CON_GAT_GOUT_PERI_WDT_1_PCLK
, 21, 0, 0),
2069 /* TODO: Should be enabled in GPIO driver (or made CLK_IS_CRITICAL) */
2070 GATE(CLK_GOUT_GPIO_PERI_PCLK
, "gout_gpio_peri_pclk",
2071 "mout_peri_bus_user",
2072 CLK_CON_GAT_GOUT_PERI_GPIO_PERI_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
2073 GATE(CLK_GOUT_BUSIF_TMU_PCLK
, "gout_busif_tmu_pclk",
2074 "mout_peri_bus_user",
2075 CLK_CON_GAT_GOUT_PERI_BUSIF_TMU_PCLK
, 21, 0, 0),
2078 static const struct samsung_cmu_info peri_cmu_info __initconst
= {
2079 .mux_clks
= peri_mux_clks
,
2080 .nr_mux_clks
= ARRAY_SIZE(peri_mux_clks
),
2081 .div_clks
= peri_div_clks
,
2082 .nr_div_clks
= ARRAY_SIZE(peri_div_clks
),
2083 .gate_clks
= peri_gate_clks
,
2084 .nr_gate_clks
= ARRAY_SIZE(peri_gate_clks
),
2085 .nr_clk_ids
= CLKS_NR_PERI
,
2086 .clk_regs
= peri_clk_regs
,
2087 .nr_clk_regs
= ARRAY_SIZE(peri_clk_regs
),
2088 .clk_name
= "dout_peri_bus",
2091 static void __init
exynos850_cmu_peri_init(struct device_node
*np
)
2093 exynos_arm64_register_cmu(NULL
, np
, &peri_cmu_info
);
2096 /* Register CMU_PERI early, as it's needed for MCT timer */
2097 CLK_OF_DECLARE(exynos850_cmu_peri
, "samsung,exynos850-cmu-peri",
2098 exynos850_cmu_peri_init
);
2100 /* ---- CMU_CORE ------------------------------------------------------------ */
2102 /* Register Offset definitions for CMU_CORE (0x12000000) */
2103 #define PLL_CON0_MUX_CLKCMU_CORE_BUS_USER 0x0600
2104 #define PLL_CON0_MUX_CLKCMU_CORE_CCI_USER 0x0610
2105 #define PLL_CON0_MUX_CLKCMU_CORE_MMC_EMBD_USER 0x0620
2106 #define PLL_CON0_MUX_CLKCMU_CORE_SSS_USER 0x0630
2107 #define CLK_CON_MUX_MUX_CLK_CORE_GIC 0x1000
2108 #define CLK_CON_DIV_DIV_CLK_CORE_BUSP 0x1800
2109 #define CLK_CON_GAT_GOUT_CORE_CCI_550_ACLK 0x2038
2110 #define CLK_CON_GAT_GOUT_CORE_GIC_CLK 0x2040
2111 #define CLK_CON_GAT_GOUT_CORE_GPIO_CORE_PCLK 0x2044
2112 #define CLK_CON_GAT_GOUT_CORE_MMC_EMBD_I_ACLK 0x20e8
2113 #define CLK_CON_GAT_GOUT_CORE_MMC_EMBD_SDCLKIN 0x20ec
2114 #define CLK_CON_GAT_GOUT_CORE_PDMA_ACLK 0x20f0
2115 #define CLK_CON_GAT_GOUT_CORE_SPDMA_ACLK 0x2124
2116 #define CLK_CON_GAT_GOUT_CORE_SSS_I_ACLK 0x2128
2117 #define CLK_CON_GAT_GOUT_CORE_SSS_I_PCLK 0x212c
2118 #define CLK_CON_GAT_GOUT_CORE_SYSREG_CORE_PCLK 0x2130
2120 static const unsigned long core_clk_regs
[] __initconst
= {
2121 PLL_CON0_MUX_CLKCMU_CORE_BUS_USER
,
2122 PLL_CON0_MUX_CLKCMU_CORE_CCI_USER
,
2123 PLL_CON0_MUX_CLKCMU_CORE_MMC_EMBD_USER
,
2124 PLL_CON0_MUX_CLKCMU_CORE_SSS_USER
,
2125 CLK_CON_MUX_MUX_CLK_CORE_GIC
,
2126 CLK_CON_DIV_DIV_CLK_CORE_BUSP
,
2127 CLK_CON_GAT_GOUT_CORE_CCI_550_ACLK
,
2128 CLK_CON_GAT_GOUT_CORE_GIC_CLK
,
2129 CLK_CON_GAT_GOUT_CORE_GPIO_CORE_PCLK
,
2130 CLK_CON_GAT_GOUT_CORE_MMC_EMBD_I_ACLK
,
2131 CLK_CON_GAT_GOUT_CORE_MMC_EMBD_SDCLKIN
,
2132 CLK_CON_GAT_GOUT_CORE_PDMA_ACLK
,
2133 CLK_CON_GAT_GOUT_CORE_SPDMA_ACLK
,
2134 CLK_CON_GAT_GOUT_CORE_SSS_I_ACLK
,
2135 CLK_CON_GAT_GOUT_CORE_SSS_I_PCLK
,
2136 CLK_CON_GAT_GOUT_CORE_SYSREG_CORE_PCLK
,
2139 /* List of parent clocks for Muxes in CMU_CORE */
2140 PNAME(mout_core_bus_user_p
) = { "oscclk", "dout_core_bus" };
2141 PNAME(mout_core_cci_user_p
) = { "oscclk", "dout_core_cci" };
2142 PNAME(mout_core_mmc_embd_user_p
) = { "oscclk", "dout_core_mmc_embd" };
2143 PNAME(mout_core_sss_user_p
) = { "oscclk", "dout_core_sss" };
2144 PNAME(mout_core_gic_p
) = { "dout_core_busp", "oscclk" };
2146 static const struct samsung_mux_clock core_mux_clks
[] __initconst
= {
2147 MUX(CLK_MOUT_CORE_BUS_USER
, "mout_core_bus_user", mout_core_bus_user_p
,
2148 PLL_CON0_MUX_CLKCMU_CORE_BUS_USER
, 4, 1),
2149 MUX(CLK_MOUT_CORE_CCI_USER
, "mout_core_cci_user", mout_core_cci_user_p
,
2150 PLL_CON0_MUX_CLKCMU_CORE_CCI_USER
, 4, 1),
2151 MUX_F(CLK_MOUT_CORE_MMC_EMBD_USER
, "mout_core_mmc_embd_user",
2152 mout_core_mmc_embd_user_p
, PLL_CON0_MUX_CLKCMU_CORE_MMC_EMBD_USER
,
2153 4, 1, CLK_SET_RATE_PARENT
, 0),
2154 MUX(CLK_MOUT_CORE_SSS_USER
, "mout_core_sss_user", mout_core_sss_user_p
,
2155 PLL_CON0_MUX_CLKCMU_CORE_SSS_USER
, 4, 1),
2156 MUX(CLK_MOUT_CORE_GIC
, "mout_core_gic", mout_core_gic_p
,
2157 CLK_CON_MUX_MUX_CLK_CORE_GIC
, 0, 1),
2160 static const struct samsung_div_clock core_div_clks
[] __initconst
= {
2161 DIV(CLK_DOUT_CORE_BUSP
, "dout_core_busp", "mout_core_bus_user",
2162 CLK_CON_DIV_DIV_CLK_CORE_BUSP
, 0, 2),
2165 static const struct samsung_gate_clock core_gate_clks
[] __initconst
= {
2166 /* CCI (interconnect) clock must be always running */
2167 GATE(CLK_GOUT_CCI_ACLK
, "gout_cci_aclk", "mout_core_cci_user",
2168 CLK_CON_GAT_GOUT_CORE_CCI_550_ACLK
, 21, CLK_IS_CRITICAL
, 0),
2169 /* GIC (interrupt controller) clock must be always running */
2170 GATE(CLK_GOUT_GIC_CLK
, "gout_gic_clk", "mout_core_gic",
2171 CLK_CON_GAT_GOUT_CORE_GIC_CLK
, 21, CLK_IS_CRITICAL
, 0),
2172 GATE(CLK_GOUT_MMC_EMBD_ACLK
, "gout_mmc_embd_aclk", "dout_core_busp",
2173 CLK_CON_GAT_GOUT_CORE_MMC_EMBD_I_ACLK
, 21, 0, 0),
2174 GATE(CLK_GOUT_MMC_EMBD_SDCLKIN
, "gout_mmc_embd_sdclkin",
2175 "mout_core_mmc_embd_user", CLK_CON_GAT_GOUT_CORE_MMC_EMBD_SDCLKIN
,
2176 21, CLK_SET_RATE_PARENT
, 0),
2177 GATE(CLK_GOUT_PDMA_CORE_ACLK
, "gout_pdma_core_aclk",
2178 "mout_core_bus_user", CLK_CON_GAT_GOUT_CORE_PDMA_ACLK
, 21, 0, 0),
2179 GATE(CLK_GOUT_SPDMA_CORE_ACLK
, "gout_spdma_core_aclk",
2180 "mout_core_bus_user", CLK_CON_GAT_GOUT_CORE_SPDMA_ACLK
, 21, 0, 0),
2181 GATE(CLK_GOUT_SSS_ACLK
, "gout_sss_aclk", "mout_core_sss_user",
2182 CLK_CON_GAT_GOUT_CORE_SSS_I_ACLK
, 21, 0, 0),
2183 GATE(CLK_GOUT_SSS_PCLK
, "gout_sss_pclk", "dout_core_busp",
2184 CLK_CON_GAT_GOUT_CORE_SSS_I_PCLK
, 21, 0, 0),
2185 /* TODO: Should be enabled in GPIO driver (or made CLK_IS_CRITICAL) */
2186 GATE(CLK_GOUT_GPIO_CORE_PCLK
, "gout_gpio_core_pclk", "dout_core_busp",
2187 CLK_CON_GAT_GOUT_CORE_GPIO_CORE_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
2188 GATE(CLK_GOUT_SYSREG_CORE_PCLK
, "gout_sysreg_core_pclk",
2190 CLK_CON_GAT_GOUT_CORE_SYSREG_CORE_PCLK
, 21, 0, 0),
2193 static const struct samsung_cmu_info core_cmu_info __initconst
= {
2194 .mux_clks
= core_mux_clks
,
2195 .nr_mux_clks
= ARRAY_SIZE(core_mux_clks
),
2196 .div_clks
= core_div_clks
,
2197 .nr_div_clks
= ARRAY_SIZE(core_div_clks
),
2198 .gate_clks
= core_gate_clks
,
2199 .nr_gate_clks
= ARRAY_SIZE(core_gate_clks
),
2200 .nr_clk_ids
= CLKS_NR_CORE
,
2201 .clk_regs
= core_clk_regs
,
2202 .nr_clk_regs
= ARRAY_SIZE(core_clk_regs
),
2203 .clk_name
= "dout_core_bus",
2206 /* ---- CMU_DPU ------------------------------------------------------------- */
2208 /* Register Offset definitions for CMU_DPU (0x13000000) */
2209 #define PLL_CON0_MUX_CLKCMU_DPU_USER 0x0600
2210 #define CLK_CON_DIV_DIV_CLK_DPU_BUSP 0x1800
2211 #define CLK_CON_GAT_CLK_DPU_CMU_DPU_PCLK 0x2004
2212 #define CLK_CON_GAT_GOUT_DPU_ACLK_DECON0 0x2010
2213 #define CLK_CON_GAT_GOUT_DPU_ACLK_DMA 0x2014
2214 #define CLK_CON_GAT_GOUT_DPU_ACLK_DPP 0x2018
2215 #define CLK_CON_GAT_GOUT_DPU_PPMU_ACLK 0x2028
2216 #define CLK_CON_GAT_GOUT_DPU_PPMU_PCLK 0x202c
2217 #define CLK_CON_GAT_GOUT_DPU_SMMU_CLK 0x2038
2218 #define CLK_CON_GAT_GOUT_DPU_SYSREG_PCLK 0x203c
2220 static const unsigned long dpu_clk_regs
[] __initconst
= {
2221 PLL_CON0_MUX_CLKCMU_DPU_USER
,
2222 CLK_CON_DIV_DIV_CLK_DPU_BUSP
,
2223 CLK_CON_GAT_CLK_DPU_CMU_DPU_PCLK
,
2224 CLK_CON_GAT_GOUT_DPU_ACLK_DECON0
,
2225 CLK_CON_GAT_GOUT_DPU_ACLK_DMA
,
2226 CLK_CON_GAT_GOUT_DPU_ACLK_DPP
,
2227 CLK_CON_GAT_GOUT_DPU_PPMU_ACLK
,
2228 CLK_CON_GAT_GOUT_DPU_PPMU_PCLK
,
2229 CLK_CON_GAT_GOUT_DPU_SMMU_CLK
,
2230 CLK_CON_GAT_GOUT_DPU_SYSREG_PCLK
,
2233 /* List of parent clocks for Muxes in CMU_DPU */
2234 PNAME(mout_dpu_user_p
) = { "oscclk", "dout_dpu" };
2236 static const struct samsung_mux_clock dpu_mux_clks
[] __initconst
= {
2237 MUX(CLK_MOUT_DPU_USER
, "mout_dpu_user", mout_dpu_user_p
,
2238 PLL_CON0_MUX_CLKCMU_DPU_USER
, 4, 1),
2241 static const struct samsung_div_clock dpu_div_clks
[] __initconst
= {
2242 DIV(CLK_DOUT_DPU_BUSP
, "dout_dpu_busp", "mout_dpu_user",
2243 CLK_CON_DIV_DIV_CLK_DPU_BUSP
, 0, 3),
2246 static const struct samsung_gate_clock dpu_gate_clks
[] __initconst
= {
2247 /* TODO: Should be enabled in DSIM driver */
2248 GATE(CLK_GOUT_DPU_CMU_DPU_PCLK
, "gout_dpu_cmu_dpu_pclk",
2250 CLK_CON_GAT_CLK_DPU_CMU_DPU_PCLK
, 21, CLK_IGNORE_UNUSED
, 0),
2251 GATE(CLK_GOUT_DPU_DECON0_ACLK
, "gout_dpu_decon0_aclk", "mout_dpu_user",
2252 CLK_CON_GAT_GOUT_DPU_ACLK_DECON0
, 21, 0, 0),
2253 GATE(CLK_GOUT_DPU_DMA_ACLK
, "gout_dpu_dma_aclk", "mout_dpu_user",
2254 CLK_CON_GAT_GOUT_DPU_ACLK_DMA
, 21, 0, 0),
2255 GATE(CLK_GOUT_DPU_DPP_ACLK
, "gout_dpu_dpp_aclk", "mout_dpu_user",
2256 CLK_CON_GAT_GOUT_DPU_ACLK_DPP
, 21, 0, 0),
2257 GATE(CLK_GOUT_DPU_PPMU_ACLK
, "gout_dpu_ppmu_aclk", "mout_dpu_user",
2258 CLK_CON_GAT_GOUT_DPU_PPMU_ACLK
, 21, 0, 0),
2259 GATE(CLK_GOUT_DPU_PPMU_PCLK
, "gout_dpu_ppmu_pclk", "dout_dpu_busp",
2260 CLK_CON_GAT_GOUT_DPU_PPMU_PCLK
, 21, 0, 0),
2261 GATE(CLK_GOUT_DPU_SMMU_CLK
, "gout_dpu_smmu_clk", "mout_dpu_user",
2262 CLK_CON_GAT_GOUT_DPU_SMMU_CLK
, 21, 0, 0),
2263 GATE(CLK_GOUT_DPU_SYSREG_PCLK
, "gout_dpu_sysreg_pclk", "dout_dpu_busp",
2264 CLK_CON_GAT_GOUT_DPU_SYSREG_PCLK
, 21, 0, 0),
2267 static const struct samsung_cmu_info dpu_cmu_info __initconst
= {
2268 .mux_clks
= dpu_mux_clks
,
2269 .nr_mux_clks
= ARRAY_SIZE(dpu_mux_clks
),
2270 .div_clks
= dpu_div_clks
,
2271 .nr_div_clks
= ARRAY_SIZE(dpu_div_clks
),
2272 .gate_clks
= dpu_gate_clks
,
2273 .nr_gate_clks
= ARRAY_SIZE(dpu_gate_clks
),
2274 .nr_clk_ids
= CLKS_NR_DPU
,
2275 .clk_regs
= dpu_clk_regs
,
2276 .nr_clk_regs
= ARRAY_SIZE(dpu_clk_regs
),
2277 .clk_name
= "dout_dpu",
2280 /* ---- platform_driver ----------------------------------------------------- */
2282 static int __init
exynos850_cmu_probe(struct platform_device
*pdev
)
2284 const struct samsung_cmu_info
*info
;
2285 struct device
*dev
= &pdev
->dev
;
2287 info
= of_device_get_match_data(dev
);
2288 exynos_arm64_register_cmu(dev
, dev
->of_node
, info
);
2293 static const struct of_device_id exynos850_cmu_of_match
[] = {
2295 .compatible
= "samsung,exynos850-cmu-apm",
2296 .data
= &apm_cmu_info
,
2298 .compatible
= "samsung,exynos850-cmu-aud",
2299 .data
= &aud_cmu_info
,
2301 .compatible
= "samsung,exynos850-cmu-cmgp",
2302 .data
= &cmgp_cmu_info
,
2304 .compatible
= "samsung,exynos850-cmu-g3d",
2305 .data
= &g3d_cmu_info
,
2307 .compatible
= "samsung,exynos850-cmu-hsi",
2308 .data
= &hsi_cmu_info
,
2310 .compatible
= "samsung,exynos850-cmu-is",
2311 .data
= &is_cmu_info
,
2313 .compatible
= "samsung,exynos850-cmu-mfcmscl",
2314 .data
= &mfcmscl_cmu_info
,
2316 .compatible
= "samsung,exynos850-cmu-core",
2317 .data
= &core_cmu_info
,
2319 .compatible
= "samsung,exynos850-cmu-dpu",
2320 .data
= &dpu_cmu_info
,
2325 static struct platform_driver exynos850_cmu_driver __refdata
= {
2327 .name
= "exynos850-cmu",
2328 .of_match_table
= exynos850_cmu_of_match
,
2329 .suppress_bind_attrs
= true,
2331 .probe
= exynos850_cmu_probe
,
2334 static int __init
exynos850_cmu_init(void)
2336 return platform_driver_register(&exynos850_cmu_driver
);
2338 core_initcall(exynos850_cmu_init
);