xref: /linux/drivers/clk/samsung/clk-exynos850.c (revision 79b918aa)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (C) 2021 Linaro Ltd.
4  * Author: Sam Protsenko <semen.protsenko@linaro.org>
5  *
6  * Common Clock Framework support for Exynos850 SoC.
7  */
8 
9 #include <linux/clk.h>
10 #include <linux/clk-provider.h>
11 #include <linux/of.h>
12 #include <linux/platform_device.h>
13 
14 #include <dt-bindings/clock/exynos850.h>
15 
16 #include "clk.h"
17 #include "clk-cpu.h"
18 #include "clk-exynos-arm64.h"
19 
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)
34 
35 /* ---- CMU_TOP ------------------------------------------------------------- */
36 
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
131 
132 static const unsigned long top_clk_regs[] __initconst = {
133 	PLL_LOCKTIME_PLL_MMC,
134 	PLL_LOCKTIME_PLL_SHARED0,
135 	PLL_LOCKTIME_PLL_SHARED1,
136 	PLL_CON0_PLL_MMC,
137 	PLL_CON3_PLL_MMC,
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,
226 };
227 
228 /*
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.
231  */
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,
236 	    NULL),
237 	PLL(pll_0822x, CLK_FOUT_SHARED1_PLL, "fout_shared1_pll", "oscclk",
238 	    PLL_LOCKTIME_PLL_SHARED1, PLL_CON3_PLL_SHARED1,
239 	    NULL),
240 	PLL(pll_0831x, CLK_FOUT_MMC_PLL, "fout_mmc_pll", "oscclk",
241 	    PLL_LOCKTIME_PLL_MMC, PLL_CON3_PLL_MMC, NULL),
242 };
243 
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" };
310 
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),
319 
320 	/* APM */
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),
323 
324 	/* AUD */
325 	MUX(CLK_MOUT_AUD, "mout_aud", mout_aud_p,
326 	    CLK_CON_MUX_MUX_CLKCMU_AUD, 0, 2),
327 
328 	/* CORE */
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),
337 
338 	/* CPUCL0 */
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),
343 
344 	/* CPUCL1 */
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),
349 
350 	/* DPU */
351 	MUX(CLK_MOUT_DPU, "mout_dpu", mout_dpu_p,
352 	    CLK_CON_MUX_MUX_CLKCMU_DPU, 0, 2),
353 
354 	/* G3D */
355 	MUX(CLK_MOUT_G3D_SWITCH, "mout_g3d_switch", mout_g3d_switch_p,
356 	    CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH, 0, 2),
357 
358 	/* HSI */
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),
365 
366 	/* IS */
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),
375 
376 	/* MFCMSCL */
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),
385 
386 	/* PERI */
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),
393 };
394 
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),
409 
410 	/* APM */
411 	DIV(CLK_DOUT_CLKCMU_APM_BUS, "dout_clkcmu_apm_bus",
412 	    "gout_clkcmu_apm_bus", CLK_CON_DIV_CLKCMU_APM_BUS, 0, 3),
413 
414 	/* AUD */
415 	DIV(CLK_DOUT_AUD, "dout_aud", "gout_aud",
416 	    CLK_CON_DIV_CLKCMU_AUD, 0, 4),
417 
418 	/* CORE */
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),
427 
428 	/* CPUCL0 */
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),
433 
434 	/* CPUCL1 */
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),
439 
440 	/* DPU */
441 	DIV(CLK_DOUT_DPU, "dout_dpu", "gout_dpu",
442 	    CLK_CON_DIV_CLKCMU_DPU, 0, 4),
443 
444 	/* G3D */
445 	DIV(CLK_DOUT_G3D_SWITCH, "dout_g3d_switch", "gout_g3d_switch",
446 	    CLK_CON_DIV_CLKCMU_G3D_SWITCH, 0, 3),
447 
448 	/* HSI */
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),
455 
456 	/* IS */
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),
465 
466 	/* MFCMSCL */
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),
475 
476 	/* PERI */
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),
483 };
484 
485 static const struct samsung_gate_clock top_gate_clks[] __initconst = {
486 	/* CORE */
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),
495 
496 	/* APM */
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),
499 
500 	/* AUD */
501 	GATE(CLK_GOUT_AUD, "gout_aud", "mout_aud",
502 	     CLK_CON_GAT_GATE_CLKCMU_AUD, 21, 0, 0),
503 
504 	/* CPUCL0 */
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),
509 
510 	/* CPUCL1 */
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),
515 
516 	/* DPU */
517 	GATE(CLK_GOUT_DPU, "gout_dpu", "mout_dpu",
518 	     CLK_CON_GAT_GATE_CLKCMU_DPU, 21, 0, 0),
519 
520 	/* G3D */
521 	GATE(CLK_GOUT_G3D_SWITCH, "gout_g3d_switch", "mout_g3d_switch",
522 	     CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH, 21, 0, 0),
523 
524 	/* HSI */
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),
531 
532 	/* IS */
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),
542 
543 	/* MFCMSCL */
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),
553 
554 	/* PERI */
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),
561 };
562 
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),
575 };
576 
exynos850_cmu_top_init(struct device_node * np)577 static void __init exynos850_cmu_top_init(struct device_node *np)
578 {
579 	exynos_arm64_register_cmu(NULL, np, &top_cmu_info);
580 }
581 
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);
585 
586 /* ---- CMU_APM ------------------------------------------------------------- */
587 
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
609 
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,
631 };
632 
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" };
642 
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),
648 };
649 
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),
665 };
666 
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),
675 };
676 
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,
696 	     0),
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),
701 };
702 
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",
716 };
717 
718 /* ---- CMU_AUD ------------------------------------------------------------- */
719 
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
774 
775 static const unsigned long aud_clk_regs[] __initconst = {
776 	PLL_LOCKTIME_PLL_AUD,
777 	PLL_CON0_PLL_AUD,
778 	PLL_CON3_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,
830 };
831 
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" };
846 
847 /*
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.
850  */
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),
854 };
855 
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),
865 };
866 
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),
895 };
896 
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",
909 	    "mout_aud_cpu_hch",
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),
933 };
934 
935 static const struct samsung_gate_clock aud_gate_clks[] __initconst = {
936 	GATE(CLK_GOUT_AUD_CMU_AUD_PCLK, "gout_aud_cmu_aud_pclk",
937 	     "dout_aud_busd",
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),
982 };
983 
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",
999 };
1000 
1001 /* ---- CMU_CMGP ------------------------------------------------------------ */
1002 
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
1018 
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,
1034 };
1035 
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" };
1040 
1041 static const struct samsung_fixed_rate_clock cmgp_fixed_clks[] __initconst = {
1042 	FRATE(CLK_RCO_CMGP, "clk_rco_cmgp", NULL, 0, 49152000),
1043 };
1044 
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),
1052 };
1053 
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),
1061 };
1062 
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),
1087 };
1088 
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",
1102 };
1103 
1104 /* ---- CMU_CPUCL0 ---------------------------------------------------------- */
1105 
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
1127 
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,
1149 };
1150 
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" };
1157 
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),
1178 };
1179 
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),
1183 };
1184 
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),
1198 };
1199 
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),
1210 
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),
1224 };
1225 
1226 static const struct samsung_gate_clock cpucl0_gate_clks[] __initconst = {
1227 	GATE(CLK_GOUT_CPUCL0_CMU_CPUCL0_PCLK, "gout_cpucl0_cmu_cpucl0_pclk",
1228 	     "dout_cpucl0_pclk",
1229 	     CLK_CON_GAT_CLK_CPUCL0_CMU_CPUCL0_PCLK, 21, CLK_IGNORE_UNUSED, 0),
1230 
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),
1246 };
1247 
1248 /*
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
1253  * (1, 3, 3, 1).
1254  */
1255 #define E850_CPU_DIV0(aclk, atclk, pclkdbg, periphclk) \
1256 	(((aclk) << 16) | ((atclk) << 12) | ((pclkdbg) << 8) | \
1257 	 ((periphclk) << 4))
1258 
1259 static const struct exynos_cpuclk_cfg_data exynos850_cluster_clk_d[] __initconst
1260 = {
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) },
1280 	{ 0 }
1281 };
1282 
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),
1287 };
1288 
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,
1305 };
1306 
exynos850_cmu_cpucl0_init(struct device_node * np)1307 static void __init exynos850_cmu_cpucl0_init(struct device_node *np)
1308 {
1309 	exynos_arm64_register_cmu(NULL, np, &cpucl0_cmu_info);
1310 }
1311 
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);
1315 
1316 /* ---- CMU_CPUCL1 ---------------------------------------------------------- */
1317 
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
1339 
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,
1361 };
1362 
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" };
1369 
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),
1373 };
1374 
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),
1388 };
1389 
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),
1400 
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),
1414 };
1415 
1416 static const struct samsung_gate_clock cpucl1_gate_clks[] __initconst = {
1417 	GATE(CLK_GOUT_CPUCL1_CMU_CPUCL1_PCLK, "gout_cpucl1_cmu_cpucl1_pclk",
1418 	     "dout_cpucl1_pclk",
1419 	     CLK_CON_GAT_CLK_CPUCL1_CMU_CPUCL1_PCLK, 21, CLK_IGNORE_UNUSED, 0),
1420 
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),
1436 };
1437 
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),
1442 };
1443 
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,
1460 };
1461 
exynos850_cmu_cpucl1_init(struct device_node * np)1462 static void __init exynos850_cmu_cpucl1_init(struct device_node *np)
1463 {
1464 	exynos_arm64_register_cmu(NULL, np, &cpucl1_cmu_info);
1465 }
1466 
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);
1470 
1471 /* ---- CMU_G3D ------------------------------------------------------------- */
1472 
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
1487 
1488 static const unsigned long g3d_clk_regs[] __initconst = {
1489 	PLL_LOCKTIME_PLL_G3D,
1490 	PLL_CON0_PLL_G3D,
1491 	PLL_CON3_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,
1502 };
1503 
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" };
1508 
1509 /*
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.
1512  */
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),
1516 };
1517 
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),
1526 };
1527 
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),
1531 };
1532 
1533 static const struct samsung_gate_clock g3d_gate_clks[] __initconst = {
1534 	GATE(CLK_GOUT_G3D_CMU_G3D_PCLK, "gout_g3d_cmu_g3d_pclk",
1535 	     "dout_g3d_busp",
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",
1542 	     "mout_g3d_busd",
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),
1550 };
1551 
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",
1565 };
1566 
1567 /* ---- CMU_HSI ------------------------------------------------------------- */
1568 
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
1586 
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,
1604 };
1605 
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" };
1611 
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,
1620 	    4, 1),
1621 	MUX(CLK_MOUT_HSI_RTC, "mout_hsi_rtc", mout_hsi_rtc_p,
1622 	    CLK_CON_MUX_MUX_CLK_HSI_RTC, 0, 1),
1623 };
1624 
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),
1656 };
1657 
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",
1667 };
1668 
1669 /* ---- CMU_IS -------------------------------------------------------------- */
1670 
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
1694 
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,
1719 };
1720 
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" };
1726 
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),
1736 };
1737 
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),
1741 };
1742 
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",
1756 	     "mout_is_bus_user",
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",
1769 	     "mout_is_bus_user",
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",
1774 	     "mout_is_itp_user",
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",
1779 	     "mout_is_bus_user",
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",
1782 	     "mout_is_itp_user",
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),
1786 };
1787 
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",
1799 };
1800 
1801 /* ---- CMU_MFCMSCL --------------------------------------------------------- */
1802 
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
1818 
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,
1835 };
1836 
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" };
1842 
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),
1856 };
1857 
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),
1861 };
1862 
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,
1870 	     21, 0, 0),
1871 	GATE(CLK_GOUT_MFCMSCL_JPEG_ACLK, "gout_mfcmscl_jpeg_aclk",
1872 	     "mout_mfcmscl_jpeg_user", CLK_CON_GAT_GOUT_MFCMSCL_JPEG_ACLK,
1873 	     21, 0, 0),
1874 	GATE(CLK_GOUT_MFCMSCL_M2M_ACLK, "gout_mfcmscl_m2m_aclk",
1875 	     "mout_mfcmscl_m2m_user", CLK_CON_GAT_GOUT_MFCMSCL_M2M_ACLK,
1876 	     21, 0, 0),
1877 	GATE(CLK_GOUT_MFCMSCL_MCSC_CLK, "gout_mfcmscl_mcsc_clk",
1878 	     "mout_mfcmscl_mcsc_user", CLK_CON_GAT_GOUT_MFCMSCL_MCSC_I_CLK,
1879 	     21, 0, 0),
1880 	GATE(CLK_GOUT_MFCMSCL_MFC_ACLK, "gout_mfcmscl_mfc_aclk",
1881 	     "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_MFC_ACLK,
1882 	     21, 0, 0),
1883 	GATE(CLK_GOUT_MFCMSCL_PPMU_ACLK, "gout_mfcmscl_ppmu_aclk",
1884 	     "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_PPMU_ACLK,
1885 	     21, 0, 0),
1886 	GATE(CLK_GOUT_MFCMSCL_PPMU_PCLK, "gout_mfcmscl_ppmu_pclk",
1887 	     "dout_mfcmscl_busp", CLK_CON_GAT_GOUT_MFCMSCL_PPMU_PCLK,
1888 	     21, 0, 0),
1889 	GATE(CLK_GOUT_MFCMSCL_SYSMMU_CLK, "gout_mfcmscl_sysmmu_clk",
1890 	     "mout_mfcmscl_mfc_user", CLK_CON_GAT_GOUT_MFCMSCL_SYSMMU_CLK_S1,
1891 	     21, 0, 0),
1892 	GATE(CLK_GOUT_MFCMSCL_SYSREG_PCLK, "gout_mfcmscl_sysreg_pclk",
1893 	     "dout_mfcmscl_busp", CLK_CON_GAT_GOUT_MFCMSCL_SYSREG_PCLK,
1894 	     21, 0, 0),
1895 };
1896 
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",
1908 };
1909 
1910 /* ---- CMU_PERI ------------------------------------------------------------ */
1911 
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
1948 
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,
1985 };
1986 
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" };
1992 
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),
2003 };
2004 
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),
2014 };
2015 
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),
2076 };
2077 
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",
2089 };
2090 
exynos850_cmu_peri_init(struct device_node * np)2091 static void __init exynos850_cmu_peri_init(struct device_node *np)
2092 {
2093 	exynos_arm64_register_cmu(NULL, np, &peri_cmu_info);
2094 }
2095 
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);
2099 
2100 /* ---- CMU_CORE ------------------------------------------------------------ */
2101 
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
2119 
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,
2137 };
2138 
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" };
2145 
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),
2158 };
2159 
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),
2163 };
2164 
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",
2189 	     "dout_core_busp",
2190 	     CLK_CON_GAT_GOUT_CORE_SYSREG_CORE_PCLK, 21, 0, 0),
2191 };
2192 
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",
2204 };
2205 
2206 /* ---- CMU_DPU ------------------------------------------------------------- */
2207 
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
2219 
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,
2231 };
2232 
2233 /* List of parent clocks for Muxes in CMU_DPU */
2234 PNAME(mout_dpu_user_p)		= { "oscclk", "dout_dpu" };
2235 
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),
2239 };
2240 
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),
2244 };
2245 
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",
2249 	     "dout_dpu_busp",
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),
2265 };
2266 
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",
2278 };
2279 
2280 /* ---- platform_driver ----------------------------------------------------- */
2281 
exynos850_cmu_probe(struct platform_device * pdev)2282 static int __init exynos850_cmu_probe(struct platform_device *pdev)
2283 {
2284 	const struct samsung_cmu_info *info;
2285 	struct device *dev = &pdev->dev;
2286 
2287 	info = of_device_get_match_data(dev);
2288 	exynos_arm64_register_cmu(dev, dev->of_node, info);
2289 
2290 	return 0;
2291 }
2292 
2293 static const struct of_device_id exynos850_cmu_of_match[] = {
2294 	{
2295 		.compatible = "samsung,exynos850-cmu-apm",
2296 		.data = &apm_cmu_info,
2297 	}, {
2298 		.compatible = "samsung,exynos850-cmu-aud",
2299 		.data = &aud_cmu_info,
2300 	}, {
2301 		.compatible = "samsung,exynos850-cmu-cmgp",
2302 		.data = &cmgp_cmu_info,
2303 	}, {
2304 		.compatible = "samsung,exynos850-cmu-g3d",
2305 		.data = &g3d_cmu_info,
2306 	}, {
2307 		.compatible = "samsung,exynos850-cmu-hsi",
2308 		.data = &hsi_cmu_info,
2309 	}, {
2310 		.compatible = "samsung,exynos850-cmu-is",
2311 		.data = &is_cmu_info,
2312 	}, {
2313 		.compatible = "samsung,exynos850-cmu-mfcmscl",
2314 		.data = &mfcmscl_cmu_info,
2315 	}, {
2316 		.compatible = "samsung,exynos850-cmu-core",
2317 		.data = &core_cmu_info,
2318 	}, {
2319 		.compatible = "samsung,exynos850-cmu-dpu",
2320 		.data = &dpu_cmu_info,
2321 	}, {
2322 	},
2323 };
2324 
2325 static struct platform_driver exynos850_cmu_driver __refdata = {
2326 	.driver	= {
2327 		.name = "exynos850-cmu",
2328 		.of_match_table = exynos850_cmu_of_match,
2329 		.suppress_bind_attrs = true,
2330 	},
2331 	.probe = exynos850_cmu_probe,
2332 };
2333 
exynos850_cmu_init(void)2334 static int __init exynos850_cmu_init(void)
2335 {
2336 	return platform_driver_register(&exynos850_cmu_driver);
2337 }
2338 core_initcall(exynos850_cmu_init);
2339