2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
3 * Author: Naveen Krishna Ch <naveenkrishna.ch@gmail.com>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
11 #include <linux/clk.h>
12 #include <linux/clkdev.h>
13 #include <linux/clk-provider.h>
17 #include <dt-bindings/clock/exynos7-clk.h>
19 /* Register Offset definitions for CMU_TOPC (0x10570000) */
20 #define CC_PLL_LOCK 0x0000
21 #define BUS0_PLL_LOCK 0x0004
22 #define BUS1_DPLL_LOCK 0x0008
23 #define MFC_PLL_LOCK 0x000C
24 #define AUD_PLL_LOCK 0x0010
25 #define CC_PLL_CON0 0x0100
26 #define BUS0_PLL_CON0 0x0110
27 #define BUS1_DPLL_CON0 0x0120
28 #define MFC_PLL_CON0 0x0130
29 #define AUD_PLL_CON0 0x0140
30 #define MUX_SEL_TOPC0 0x0200
31 #define MUX_SEL_TOPC1 0x0204
32 #define MUX_SEL_TOPC2 0x0208
33 #define MUX_SEL_TOPC3 0x020C
34 #define DIV_TOPC0 0x0600
35 #define DIV_TOPC1 0x0604
36 #define DIV_TOPC3 0x060C
38 static struct samsung_fixed_factor_clock topc_fixed_factor_clks
[] __initdata
= {
39 FFACTOR(0, "ffac_topc_bus0_pll_div2", "mout_bus0_pll_ctrl", 1, 2, 0),
40 FFACTOR(0, "ffac_topc_bus0_pll_div4",
41 "ffac_topc_bus0_pll_div2", 1, 2, 0),
42 FFACTOR(0, "ffac_topc_bus1_pll_div2", "mout_bus1_pll_ctrl", 1, 2, 0),
43 FFACTOR(0, "ffac_topc_cc_pll_div2", "mout_cc_pll_ctrl", 1, 2, 0),
44 FFACTOR(0, "ffac_topc_mfc_pll_div2", "mout_mfc_pll_ctrl", 1, 2, 0),
47 /* List of parent clocks for Muxes in CMU_TOPC */
48 PNAME(mout_bus0_pll_ctrl_p
) = { "fin_pll", "fout_bus0_pll" };
49 PNAME(mout_bus1_pll_ctrl_p
) = { "fin_pll", "fout_bus1_pll" };
50 PNAME(mout_cc_pll_ctrl_p
) = { "fin_pll", "fout_cc_pll" };
51 PNAME(mout_mfc_pll_ctrl_p
) = { "fin_pll", "fout_mfc_pll" };
53 PNAME(mout_topc_group2
) = { "mout_sclk_bus0_pll_cmuc",
54 "mout_sclk_bus1_pll_cmuc", "mout_sclk_cc_pll_cmuc",
55 "mout_sclk_mfc_pll_cmuc" };
57 PNAME(mout_sclk_bus0_pll_cmuc_p
) = { "mout_bus0_pll_ctrl",
58 "ffac_topc_bus0_pll_div2", "ffac_topc_bus0_pll_div4"};
59 PNAME(mout_sclk_bus1_pll_cmuc_p
) = { "mout_bus1_pll_ctrl",
60 "ffac_topc_bus1_pll_div2"};
61 PNAME(mout_sclk_cc_pll_cmuc_p
) = { "mout_cc_pll_ctrl",
62 "ffac_topc_cc_pll_div2"};
63 PNAME(mout_sclk_mfc_pll_cmuc_p
) = { "mout_mfc_pll_ctrl",
64 "ffac_topc_mfc_pll_div2"};
67 PNAME(mout_sclk_bus0_pll_out_p
) = {"mout_bus0_pll_ctrl",
68 "ffac_topc_bus0_pll_div2"};
70 static unsigned long topc_clk_regs
[] __initdata
= {
90 static struct samsung_mux_clock topc_mux_clks
[] __initdata
= {
91 MUX(0, "mout_bus0_pll_ctrl", mout_bus0_pll_ctrl_p
, MUX_SEL_TOPC0
, 0, 1),
92 MUX(0, "mout_bus1_pll_ctrl", mout_bus1_pll_ctrl_p
, MUX_SEL_TOPC0
, 4, 1),
93 MUX(0, "mout_cc_pll_ctrl", mout_cc_pll_ctrl_p
, MUX_SEL_TOPC0
, 8, 1),
94 MUX(0, "mout_mfc_pll_ctrl", mout_mfc_pll_ctrl_p
, MUX_SEL_TOPC0
, 12, 1),
96 MUX(0, "mout_sclk_bus0_pll_cmuc", mout_sclk_bus0_pll_cmuc_p
,
97 MUX_SEL_TOPC0
, 16, 2),
98 MUX(0, "mout_sclk_bus1_pll_cmuc", mout_sclk_bus1_pll_cmuc_p
,
99 MUX_SEL_TOPC0
, 20, 1),
100 MUX(0, "mout_sclk_cc_pll_cmuc", mout_sclk_cc_pll_cmuc_p
,
101 MUX_SEL_TOPC0
, 24, 1),
102 MUX(0, "mout_sclk_mfc_pll_cmuc", mout_sclk_mfc_pll_cmuc_p
,
103 MUX_SEL_TOPC0
, 28, 1),
105 MUX(0, "mout_sclk_bus0_pll_out", mout_sclk_bus0_pll_out_p
,
106 MUX_SEL_TOPC1
, 16, 1),
108 MUX(0, "mout_aclk_ccore_133", mout_topc_group2
, MUX_SEL_TOPC2
, 4, 2),
110 MUX(0, "mout_aclk_peris_66", mout_topc_group2
, MUX_SEL_TOPC3
, 24, 2),
113 static struct samsung_div_clock topc_div_clks
[] __initdata
= {
114 DIV(DOUT_ACLK_CCORE_133
, "dout_aclk_ccore_133", "mout_aclk_ccore_133",
117 DIV(DOUT_ACLK_PERIS
, "dout_aclk_peris_66", "mout_aclk_peris_66",
120 DIV(DOUT_SCLK_BUS0_PLL
, "dout_sclk_bus0_pll", "mout_sclk_bus0_pll_out",
122 DIV(DOUT_SCLK_BUS1_PLL
, "dout_sclk_bus1_pll", "mout_bus1_pll_ctrl",
124 DIV(DOUT_SCLK_CC_PLL
, "dout_sclk_cc_pll", "mout_cc_pll_ctrl",
126 DIV(DOUT_SCLK_MFC_PLL
, "dout_sclk_mfc_pll", "mout_mfc_pll_ctrl",
130 static struct samsung_pll_clock topc_pll_clks
[] __initdata
= {
131 PLL(pll_1451x
, 0, "fout_bus0_pll", "fin_pll", BUS0_PLL_LOCK
,
132 BUS0_PLL_CON0
, NULL
),
133 PLL(pll_1452x
, 0, "fout_cc_pll", "fin_pll", CC_PLL_LOCK
,
135 PLL(pll_1452x
, 0, "fout_bus1_pll", "fin_pll", BUS1_DPLL_LOCK
,
136 BUS1_DPLL_CON0
, NULL
),
137 PLL(pll_1452x
, 0, "fout_mfc_pll", "fin_pll", MFC_PLL_LOCK
,
139 PLL(pll_1460x
, 0, "fout_aud_pll", "fin_pll", AUD_PLL_LOCK
,
143 static struct samsung_cmu_info topc_cmu_info __initdata
= {
144 .pll_clks
= topc_pll_clks
,
145 .nr_pll_clks
= ARRAY_SIZE(topc_pll_clks
),
146 .mux_clks
= topc_mux_clks
,
147 .nr_mux_clks
= ARRAY_SIZE(topc_mux_clks
),
148 .div_clks
= topc_div_clks
,
149 .nr_div_clks
= ARRAY_SIZE(topc_div_clks
),
150 .fixed_factor_clks
= topc_fixed_factor_clks
,
151 .nr_fixed_factor_clks
= ARRAY_SIZE(topc_fixed_factor_clks
),
152 .nr_clk_ids
= TOPC_NR_CLK
,
153 .clk_regs
= topc_clk_regs
,
154 .nr_clk_regs
= ARRAY_SIZE(topc_clk_regs
),
157 static void __init
exynos7_clk_topc_init(struct device_node
*np
)
159 samsung_cmu_register_one(np
, &topc_cmu_info
);
162 CLK_OF_DECLARE(exynos7_clk_topc
, "samsung,exynos7-clock-topc",
163 exynos7_clk_topc_init
);
165 /* Register Offset definitions for CMU_TOP0 (0x105D0000) */
166 #define MUX_SEL_TOP00 0x0200
167 #define MUX_SEL_TOP01 0x0204
168 #define MUX_SEL_TOP03 0x020C
169 #define MUX_SEL_TOP0_PERIC3 0x023C
170 #define DIV_TOP03 0x060C
171 #define DIV_TOP0_PERIC3 0x063C
172 #define ENABLE_SCLK_TOP0_PERIC3 0x0A3C
174 /* List of parent clocks for Muxes in CMU_TOP0 */
175 PNAME(mout_bus0_pll_p
) = { "fin_pll", "dout_sclk_bus0_pll" };
176 PNAME(mout_bus1_pll_p
) = { "fin_pll", "dout_sclk_bus1_pll" };
177 PNAME(mout_cc_pll_p
) = { "fin_pll", "dout_sclk_cc_pll" };
178 PNAME(mout_mfc_pll_p
) = { "fin_pll", "dout_sclk_mfc_pll" };
180 PNAME(mout_top0_half_bus0_pll_p
) = {"mout_top0_bus0_pll",
181 "ffac_top0_bus0_pll_div2"};
182 PNAME(mout_top0_half_bus1_pll_p
) = {"mout_top0_bus1_pll",
183 "ffac_top0_bus1_pll_div2"};
184 PNAME(mout_top0_half_cc_pll_p
) = {"mout_top0_cc_pll",
185 "ffac_top0_cc_pll_div2"};
186 PNAME(mout_top0_half_mfc_pll_p
) = {"mout_top0_mfc_pll",
187 "ffac_top0_mfc_pll_div2"};
189 PNAME(mout_top0_group1
) = {"mout_top0_half_bus0_pll",
190 "mout_top0_half_bus1_pll", "mout_top0_half_cc_pll",
191 "mout_top0_half_mfc_pll"};
193 static unsigned long top0_clk_regs
[] __initdata
= {
200 ENABLE_SCLK_TOP0_PERIC3
,
203 static struct samsung_mux_clock top0_mux_clks
[] __initdata
= {
204 MUX(0, "mout_top0_mfc_pll", mout_mfc_pll_p
, MUX_SEL_TOP00
, 4, 1),
205 MUX(0, "mout_top0_cc_pll", mout_cc_pll_p
, MUX_SEL_TOP00
, 8, 1),
206 MUX(0, "mout_top0_bus1_pll", mout_bus1_pll_p
, MUX_SEL_TOP00
, 12, 1),
207 MUX(0, "mout_top0_bus0_pll", mout_bus0_pll_p
, MUX_SEL_TOP00
, 16, 1),
209 MUX(0, "mout_top0_half_mfc_pll", mout_top0_half_mfc_pll_p
,
210 MUX_SEL_TOP01
, 4, 1),
211 MUX(0, "mout_top0_half_cc_pll", mout_top0_half_cc_pll_p
,
212 MUX_SEL_TOP01
, 8, 1),
213 MUX(0, "mout_top0_half_bus1_pll", mout_top0_half_bus1_pll_p
,
214 MUX_SEL_TOP01
, 12, 1),
215 MUX(0, "mout_top0_half_bus0_pll", mout_top0_half_bus0_pll_p
,
216 MUX_SEL_TOP01
, 16, 1),
218 MUX(0, "mout_aclk_peric1_66", mout_top0_group1
, MUX_SEL_TOP03
, 12, 2),
219 MUX(0, "mout_aclk_peric0_66", mout_top0_group1
, MUX_SEL_TOP03
, 20, 2),
221 MUX(0, "mout_sclk_uart3", mout_top0_group1
, MUX_SEL_TOP0_PERIC3
, 4, 2),
222 MUX(0, "mout_sclk_uart2", mout_top0_group1
, MUX_SEL_TOP0_PERIC3
, 8, 2),
223 MUX(0, "mout_sclk_uart1", mout_top0_group1
, MUX_SEL_TOP0_PERIC3
, 12, 2),
224 MUX(0, "mout_sclk_uart0", mout_top0_group1
, MUX_SEL_TOP0_PERIC3
, 16, 2),
227 static struct samsung_div_clock top0_div_clks
[] __initdata
= {
228 DIV(DOUT_ACLK_PERIC1
, "dout_aclk_peric1_66", "mout_aclk_peric1_66",
230 DIV(DOUT_ACLK_PERIC0
, "dout_aclk_peric0_66", "mout_aclk_peric0_66",
233 DIV(0, "dout_sclk_uart3", "mout_sclk_uart3", DIV_TOP0_PERIC3
, 4, 4),
234 DIV(0, "dout_sclk_uart2", "mout_sclk_uart2", DIV_TOP0_PERIC3
, 8, 4),
235 DIV(0, "dout_sclk_uart1", "mout_sclk_uart1", DIV_TOP0_PERIC3
, 12, 4),
236 DIV(0, "dout_sclk_uart0", "mout_sclk_uart0", DIV_TOP0_PERIC3
, 16, 4),
239 static struct samsung_gate_clock top0_gate_clks
[] __initdata
= {
240 GATE(CLK_SCLK_UART3
, "sclk_uart3", "dout_sclk_uart3",
241 ENABLE_SCLK_TOP0_PERIC3
, 4, 0, 0),
242 GATE(CLK_SCLK_UART2
, "sclk_uart2", "dout_sclk_uart2",
243 ENABLE_SCLK_TOP0_PERIC3
, 8, 0, 0),
244 GATE(CLK_SCLK_UART1
, "sclk_uart1", "dout_sclk_uart1",
245 ENABLE_SCLK_TOP0_PERIC3
, 12, 0, 0),
246 GATE(CLK_SCLK_UART0
, "sclk_uart0", "dout_sclk_uart0",
247 ENABLE_SCLK_TOP0_PERIC3
, 16, 0, 0),
250 static struct samsung_fixed_factor_clock top0_fixed_factor_clks
[] __initdata
= {
251 FFACTOR(0, "ffac_top0_bus0_pll_div2", "mout_top0_bus0_pll", 1, 2, 0),
252 FFACTOR(0, "ffac_top0_bus1_pll_div2", "mout_top0_bus1_pll", 1, 2, 0),
253 FFACTOR(0, "ffac_top0_cc_pll_div2", "mout_top0_cc_pll", 1, 2, 0),
254 FFACTOR(0, "ffac_top0_mfc_pll_div2", "mout_top0_mfc_pll", 1, 2, 0),
257 static struct samsung_cmu_info top0_cmu_info __initdata
= {
258 .mux_clks
= top0_mux_clks
,
259 .nr_mux_clks
= ARRAY_SIZE(top0_mux_clks
),
260 .div_clks
= top0_div_clks
,
261 .nr_div_clks
= ARRAY_SIZE(top0_div_clks
),
262 .gate_clks
= top0_gate_clks
,
263 .nr_gate_clks
= ARRAY_SIZE(top0_gate_clks
),
264 .fixed_factor_clks
= top0_fixed_factor_clks
,
265 .nr_fixed_factor_clks
= ARRAY_SIZE(top0_fixed_factor_clks
),
266 .nr_clk_ids
= TOP0_NR_CLK
,
267 .clk_regs
= top0_clk_regs
,
268 .nr_clk_regs
= ARRAY_SIZE(top0_clk_regs
),
271 static void __init
exynos7_clk_top0_init(struct device_node
*np
)
273 samsung_cmu_register_one(np
, &top0_cmu_info
);
276 CLK_OF_DECLARE(exynos7_clk_top0
, "samsung,exynos7-clock-top0",
277 exynos7_clk_top0_init
);
279 /* Register Offset definitions for CMU_TOP1 (0x105E0000) */
280 #define MUX_SEL_TOP10 0x0200
281 #define MUX_SEL_TOP11 0x0204
282 #define MUX_SEL_TOP13 0x020C
283 #define MUX_SEL_TOP1_FSYS0 0x0224
284 #define MUX_SEL_TOP1_FSYS1 0x0228
285 #define DIV_TOP13 0x060C
286 #define DIV_TOP1_FSYS0 0x0624
287 #define DIV_TOP1_FSYS1 0x0628
288 #define ENABLE_ACLK_TOP13 0x080C
289 #define ENABLE_SCLK_TOP1_FSYS0 0x0A24
290 #define ENABLE_SCLK_TOP1_FSYS1 0x0A28
292 /* List of parent clocks for Muxes in CMU_TOP1 */
293 PNAME(mout_top1_bus0_pll_p
) = { "fin_pll", "dout_sclk_bus0_pll" };
294 PNAME(mout_top1_bus1_pll_p
) = { "fin_pll", "dout_sclk_bus1_pll_b" };
295 PNAME(mout_top1_cc_pll_p
) = { "fin_pll", "dout_sclk_cc_pll_b" };
296 PNAME(mout_top1_mfc_pll_p
) = { "fin_pll", "dout_sclk_mfc_pll_b" };
298 PNAME(mout_top1_half_bus0_pll_p
) = {"mout_top1_bus0_pll",
299 "ffac_top1_bus0_pll_div2"};
300 PNAME(mout_top1_half_bus1_pll_p
) = {"mout_top1_bus1_pll",
301 "ffac_top1_bus1_pll_div2"};
302 PNAME(mout_top1_half_cc_pll_p
) = {"mout_top1_cc_pll",
303 "ffac_top1_cc_pll_div2"};
304 PNAME(mout_top1_half_mfc_pll_p
) = {"mout_top1_mfc_pll",
305 "ffac_top1_mfc_pll_div2"};
307 PNAME(mout_top1_group1
) = {"mout_top1_half_bus0_pll",
308 "mout_top1_half_bus1_pll", "mout_top1_half_cc_pll",
309 "mout_top1_half_mfc_pll"};
311 static unsigned long top1_clk_regs
[] __initdata
= {
321 ENABLE_SCLK_TOP1_FSYS0
,
322 ENABLE_SCLK_TOP1_FSYS1
,
325 static struct samsung_mux_clock top1_mux_clks
[] __initdata
= {
326 MUX(0, "mout_top1_mfc_pll", mout_top1_mfc_pll_p
, MUX_SEL_TOP10
, 4, 1),
327 MUX(0, "mout_top1_cc_pll", mout_top1_cc_pll_p
, MUX_SEL_TOP10
, 8, 1),
328 MUX(0, "mout_top1_bus1_pll", mout_top1_bus1_pll_p
,
329 MUX_SEL_TOP10
, 12, 1),
330 MUX(0, "mout_top1_bus0_pll", mout_top1_bus0_pll_p
,
331 MUX_SEL_TOP10
, 16, 1),
333 MUX(0, "mout_top1_half_mfc_pll", mout_top1_half_mfc_pll_p
,
334 MUX_SEL_TOP11
, 4, 1),
335 MUX(0, "mout_top1_half_cc_pll", mout_top1_half_cc_pll_p
,
336 MUX_SEL_TOP11
, 8, 1),
337 MUX(0, "mout_top1_half_bus1_pll", mout_top1_half_bus1_pll_p
,
338 MUX_SEL_TOP11
, 12, 1),
339 MUX(0, "mout_top1_half_bus0_pll", mout_top1_half_bus0_pll_p
,
340 MUX_SEL_TOP11
, 16, 1),
342 MUX(0, "mout_aclk_fsys1_200", mout_top1_group1
, MUX_SEL_TOP13
, 24, 2),
343 MUX(0, "mout_aclk_fsys0_200", mout_top1_group1
, MUX_SEL_TOP13
, 28, 2),
345 MUX(0, "mout_sclk_mmc2", mout_top1_group1
, MUX_SEL_TOP1_FSYS0
, 24, 2),
347 MUX(0, "mout_sclk_mmc1", mout_top1_group1
, MUX_SEL_TOP1_FSYS1
, 24, 2),
348 MUX(0, "mout_sclk_mmc0", mout_top1_group1
, MUX_SEL_TOP1_FSYS1
, 28, 2),
351 static struct samsung_div_clock top1_div_clks
[] __initdata
= {
352 DIV(DOUT_ACLK_FSYS1_200
, "dout_aclk_fsys1_200", "mout_aclk_fsys1_200",
354 DIV(DOUT_ACLK_FSYS0_200
, "dout_aclk_fsys0_200", "mout_aclk_fsys0_200",
357 DIV(DOUT_SCLK_MMC2
, "dout_sclk_mmc2", "mout_sclk_mmc2",
358 DIV_TOP1_FSYS0
, 24, 4),
360 DIV(DOUT_SCLK_MMC1
, "dout_sclk_mmc1", "mout_sclk_mmc1",
361 DIV_TOP1_FSYS1
, 24, 4),
362 DIV(DOUT_SCLK_MMC0
, "dout_sclk_mmc0", "mout_sclk_mmc0",
363 DIV_TOP1_FSYS1
, 28, 4),
366 static struct samsung_gate_clock top1_gate_clks
[] __initdata
= {
367 GATE(CLK_SCLK_MMC2
, "sclk_mmc2", "dout_sclk_mmc2",
368 ENABLE_SCLK_TOP1_FSYS0
, 24, CLK_SET_RATE_PARENT
, 0),
370 GATE(CLK_SCLK_MMC1
, "sclk_mmc1", "dout_sclk_mmc1",
371 ENABLE_SCLK_TOP1_FSYS1
, 24, CLK_SET_RATE_PARENT
, 0),
372 GATE(CLK_SCLK_MMC0
, "sclk_mmc0", "dout_sclk_mmc0",
373 ENABLE_SCLK_TOP1_FSYS1
, 28, CLK_SET_RATE_PARENT
, 0),
376 static struct samsung_fixed_factor_clock top1_fixed_factor_clks
[] __initdata
= {
377 FFACTOR(0, "ffac_top1_bus0_pll_div2", "mout_top1_bus0_pll", 1, 2, 0),
378 FFACTOR(0, "ffac_top1_bus1_pll_div2", "mout_top1_bus1_pll", 1, 2, 0),
379 FFACTOR(0, "ffac_top1_cc_pll_div2", "mout_top1_cc_pll", 1, 2, 0),
380 FFACTOR(0, "ffac_top1_mfc_pll_div2", "mout_top1_mfc_pll", 1, 2, 0),
383 static struct samsung_cmu_info top1_cmu_info __initdata
= {
384 .mux_clks
= top1_mux_clks
,
385 .nr_mux_clks
= ARRAY_SIZE(top1_mux_clks
),
386 .div_clks
= top1_div_clks
,
387 .nr_div_clks
= ARRAY_SIZE(top1_div_clks
),
388 .gate_clks
= top1_gate_clks
,
389 .nr_gate_clks
= ARRAY_SIZE(top1_gate_clks
),
390 .fixed_factor_clks
= top1_fixed_factor_clks
,
391 .nr_fixed_factor_clks
= ARRAY_SIZE(top1_fixed_factor_clks
),
392 .nr_clk_ids
= TOP1_NR_CLK
,
393 .clk_regs
= top1_clk_regs
,
394 .nr_clk_regs
= ARRAY_SIZE(top1_clk_regs
),
397 static void __init
exynos7_clk_top1_init(struct device_node
*np
)
399 samsung_cmu_register_one(np
, &top1_cmu_info
);
402 CLK_OF_DECLARE(exynos7_clk_top1
, "samsung,exynos7-clock-top1",
403 exynos7_clk_top1_init
);
405 /* Register Offset definitions for CMU_CCORE (0x105B0000) */
406 #define MUX_SEL_CCORE 0x0200
407 #define DIV_CCORE 0x0600
408 #define ENABLE_ACLK_CCORE0 0x0800
409 #define ENABLE_ACLK_CCORE1 0x0804
410 #define ENABLE_PCLK_CCORE 0x0900
413 * List of parent clocks for Muxes in CMU_CCORE
415 PNAME(mout_aclk_ccore_133_p
) = { "fin_pll", "dout_aclk_ccore_133" };
417 static unsigned long ccore_clk_regs
[] __initdata
= {
422 static struct samsung_mux_clock ccore_mux_clks
[] __initdata
= {
423 MUX(0, "mout_aclk_ccore_133_user", mout_aclk_ccore_133_p
,
424 MUX_SEL_CCORE
, 1, 1),
427 static struct samsung_gate_clock ccore_gate_clks
[] __initdata
= {
428 GATE(PCLK_RTC
, "pclk_rtc", "mout_aclk_ccore_133_user",
429 ENABLE_PCLK_CCORE
, 8, 0, 0),
432 static struct samsung_cmu_info ccore_cmu_info __initdata
= {
433 .mux_clks
= ccore_mux_clks
,
434 .nr_mux_clks
= ARRAY_SIZE(ccore_mux_clks
),
435 .gate_clks
= ccore_gate_clks
,
436 .nr_gate_clks
= ARRAY_SIZE(ccore_gate_clks
),
437 .nr_clk_ids
= CCORE_NR_CLK
,
438 .clk_regs
= ccore_clk_regs
,
439 .nr_clk_regs
= ARRAY_SIZE(ccore_clk_regs
),
442 static void __init
exynos7_clk_ccore_init(struct device_node
*np
)
444 samsung_cmu_register_one(np
, &ccore_cmu_info
);
447 CLK_OF_DECLARE(exynos7_clk_ccore
, "samsung,exynos7-clock-ccore",
448 exynos7_clk_ccore_init
);
450 /* Register Offset definitions for CMU_PERIC0 (0x13610000) */
451 #define MUX_SEL_PERIC0 0x0200
452 #define ENABLE_PCLK_PERIC0 0x0900
453 #define ENABLE_SCLK_PERIC0 0x0A00
455 /* List of parent clocks for Muxes in CMU_PERIC0 */
456 PNAME(mout_aclk_peric0_66_p
) = { "fin_pll", "dout_aclk_peric0_66" };
457 PNAME(mout_sclk_uart0_p
) = { "fin_pll", "sclk_uart0" };
459 static unsigned long peric0_clk_regs
[] __initdata
= {
465 static struct samsung_mux_clock peric0_mux_clks
[] __initdata
= {
466 MUX(0, "mout_aclk_peric0_66_user", mout_aclk_peric0_66_p
,
467 MUX_SEL_PERIC0
, 0, 1),
468 MUX(0, "mout_sclk_uart0_user", mout_sclk_uart0_p
,
469 MUX_SEL_PERIC0
, 16, 1),
472 static struct samsung_gate_clock peric0_gate_clks
[] __initdata
= {
473 GATE(PCLK_HSI2C0
, "pclk_hsi2c0", "mout_aclk_peric0_66_user",
474 ENABLE_PCLK_PERIC0
, 8, 0, 0),
475 GATE(PCLK_HSI2C1
, "pclk_hsi2c1", "mout_aclk_peric0_66_user",
476 ENABLE_PCLK_PERIC0
, 9, 0, 0),
477 GATE(PCLK_HSI2C4
, "pclk_hsi2c4", "mout_aclk_peric0_66_user",
478 ENABLE_PCLK_PERIC0
, 10, 0, 0),
479 GATE(PCLK_HSI2C5
, "pclk_hsi2c5", "mout_aclk_peric0_66_user",
480 ENABLE_PCLK_PERIC0
, 11, 0, 0),
481 GATE(PCLK_HSI2C9
, "pclk_hsi2c9", "mout_aclk_peric0_66_user",
482 ENABLE_PCLK_PERIC0
, 12, 0, 0),
483 GATE(PCLK_HSI2C10
, "pclk_hsi2c10", "mout_aclk_peric0_66_user",
484 ENABLE_PCLK_PERIC0
, 13, 0, 0),
485 GATE(PCLK_HSI2C11
, "pclk_hsi2c11", "mout_aclk_peric0_66_user",
486 ENABLE_PCLK_PERIC0
, 14, 0, 0),
487 GATE(PCLK_UART0
, "pclk_uart0", "mout_aclk_peric0_66_user",
488 ENABLE_PCLK_PERIC0
, 16, 0, 0),
489 GATE(PCLK_ADCIF
, "pclk_adcif", "mout_aclk_peric0_66_user",
490 ENABLE_PCLK_PERIC0
, 20, 0, 0),
491 GATE(PCLK_PWM
, "pclk_pwm", "mout_aclk_peric0_66_user",
492 ENABLE_PCLK_PERIC0
, 21, 0, 0),
494 GATE(SCLK_UART0
, "sclk_uart0_user", "mout_sclk_uart0_user",
495 ENABLE_SCLK_PERIC0
, 16, 0, 0),
496 GATE(SCLK_PWM
, "sclk_pwm", "fin_pll", ENABLE_SCLK_PERIC0
, 21, 0, 0),
499 static struct samsung_cmu_info peric0_cmu_info __initdata
= {
500 .mux_clks
= peric0_mux_clks
,
501 .nr_mux_clks
= ARRAY_SIZE(peric0_mux_clks
),
502 .gate_clks
= peric0_gate_clks
,
503 .nr_gate_clks
= ARRAY_SIZE(peric0_gate_clks
),
504 .nr_clk_ids
= PERIC0_NR_CLK
,
505 .clk_regs
= peric0_clk_regs
,
506 .nr_clk_regs
= ARRAY_SIZE(peric0_clk_regs
),
509 static void __init
exynos7_clk_peric0_init(struct device_node
*np
)
511 samsung_cmu_register_one(np
, &peric0_cmu_info
);
514 /* Register Offset definitions for CMU_PERIC1 (0x14C80000) */
515 #define MUX_SEL_PERIC10 0x0200
516 #define MUX_SEL_PERIC11 0x0204
517 #define ENABLE_PCLK_PERIC1 0x0900
518 #define ENABLE_SCLK_PERIC10 0x0A00
520 CLK_OF_DECLARE(exynos7_clk_peric0
, "samsung,exynos7-clock-peric0",
521 exynos7_clk_peric0_init
);
523 /* List of parent clocks for Muxes in CMU_PERIC1 */
524 PNAME(mout_aclk_peric1_66_p
) = { "fin_pll", "dout_aclk_peric1_66" };
525 PNAME(mout_sclk_uart1_p
) = { "fin_pll", "sclk_uart1" };
526 PNAME(mout_sclk_uart2_p
) = { "fin_pll", "sclk_uart2" };
527 PNAME(mout_sclk_uart3_p
) = { "fin_pll", "sclk_uart3" };
529 static unsigned long peric1_clk_regs
[] __initdata
= {
536 static struct samsung_mux_clock peric1_mux_clks
[] __initdata
= {
537 MUX(0, "mout_aclk_peric1_66_user", mout_aclk_peric1_66_p
,
538 MUX_SEL_PERIC10
, 0, 1),
540 MUX(0, "mout_sclk_uart1_user", mout_sclk_uart1_p
,
541 MUX_SEL_PERIC11
, 20, 1),
542 MUX(0, "mout_sclk_uart2_user", mout_sclk_uart2_p
,
543 MUX_SEL_PERIC11
, 24, 1),
544 MUX(0, "mout_sclk_uart3_user", mout_sclk_uart3_p
,
545 MUX_SEL_PERIC11
, 28, 1),
548 static struct samsung_gate_clock peric1_gate_clks
[] __initdata
= {
549 GATE(PCLK_HSI2C2
, "pclk_hsi2c2", "mout_aclk_peric1_66_user",
550 ENABLE_PCLK_PERIC1
, 4, 0, 0),
551 GATE(PCLK_HSI2C3
, "pclk_hsi2c3", "mout_aclk_peric1_66_user",
552 ENABLE_PCLK_PERIC1
, 5, 0, 0),
553 GATE(PCLK_HSI2C6
, "pclk_hsi2c6", "mout_aclk_peric1_66_user",
554 ENABLE_PCLK_PERIC1
, 6, 0, 0),
555 GATE(PCLK_HSI2C7
, "pclk_hsi2c7", "mout_aclk_peric1_66_user",
556 ENABLE_PCLK_PERIC1
, 7, 0, 0),
557 GATE(PCLK_HSI2C8
, "pclk_hsi2c8", "mout_aclk_peric1_66_user",
558 ENABLE_PCLK_PERIC1
, 8, 0, 0),
559 GATE(PCLK_UART1
, "pclk_uart1", "mout_aclk_peric1_66_user",
560 ENABLE_PCLK_PERIC1
, 9, 0, 0),
561 GATE(PCLK_UART2
, "pclk_uart2", "mout_aclk_peric1_66_user",
562 ENABLE_PCLK_PERIC1
, 10, 0, 0),
563 GATE(PCLK_UART3
, "pclk_uart3", "mout_aclk_peric1_66_user",
564 ENABLE_PCLK_PERIC1
, 11, 0, 0),
566 GATE(SCLK_UART1
, "sclk_uart1_user", "mout_sclk_uart1_user",
567 ENABLE_SCLK_PERIC10
, 9, 0, 0),
568 GATE(SCLK_UART2
, "sclk_uart2_user", "mout_sclk_uart2_user",
569 ENABLE_SCLK_PERIC10
, 10, 0, 0),
570 GATE(SCLK_UART3
, "sclk_uart3_user", "mout_sclk_uart3_user",
571 ENABLE_SCLK_PERIC10
, 11, 0, 0),
574 static struct samsung_cmu_info peric1_cmu_info __initdata
= {
575 .mux_clks
= peric1_mux_clks
,
576 .nr_mux_clks
= ARRAY_SIZE(peric1_mux_clks
),
577 .gate_clks
= peric1_gate_clks
,
578 .nr_gate_clks
= ARRAY_SIZE(peric1_gate_clks
),
579 .nr_clk_ids
= PERIC1_NR_CLK
,
580 .clk_regs
= peric1_clk_regs
,
581 .nr_clk_regs
= ARRAY_SIZE(peric1_clk_regs
),
584 static void __init
exynos7_clk_peric1_init(struct device_node
*np
)
586 samsung_cmu_register_one(np
, &peric1_cmu_info
);
589 CLK_OF_DECLARE(exynos7_clk_peric1
, "samsung,exynos7-clock-peric1",
590 exynos7_clk_peric1_init
);
592 /* Register Offset definitions for CMU_PERIS (0x10040000) */
593 #define MUX_SEL_PERIS 0x0200
594 #define ENABLE_PCLK_PERIS 0x0900
595 #define ENABLE_PCLK_PERIS_SECURE_CHIPID 0x0910
596 #define ENABLE_SCLK_PERIS 0x0A00
597 #define ENABLE_SCLK_PERIS_SECURE_CHIPID 0x0A10
599 /* List of parent clocks for Muxes in CMU_PERIS */
600 PNAME(mout_aclk_peris_66_p
) = { "fin_pll", "dout_aclk_peris_66" };
602 static unsigned long peris_clk_regs
[] __initdata
= {
605 ENABLE_PCLK_PERIS_SECURE_CHIPID
,
607 ENABLE_SCLK_PERIS_SECURE_CHIPID
,
610 static struct samsung_mux_clock peris_mux_clks
[] __initdata
= {
611 MUX(0, "mout_aclk_peris_66_user",
612 mout_aclk_peris_66_p
, MUX_SEL_PERIS
, 0, 1),
615 static struct samsung_gate_clock peris_gate_clks
[] __initdata
= {
616 GATE(PCLK_WDT
, "pclk_wdt", "mout_aclk_peris_66_user",
617 ENABLE_PCLK_PERIS
, 6, 0, 0),
618 GATE(PCLK_TMU
, "pclk_tmu_apbif", "mout_aclk_peris_66_user",
619 ENABLE_PCLK_PERIS
, 10, 0, 0),
621 GATE(PCLK_CHIPID
, "pclk_chipid", "mout_aclk_peris_66_user",
622 ENABLE_PCLK_PERIS_SECURE_CHIPID
, 0, 0, 0),
623 GATE(SCLK_CHIPID
, "sclk_chipid", "fin_pll",
624 ENABLE_SCLK_PERIS_SECURE_CHIPID
, 0, 0, 0),
626 GATE(SCLK_TMU
, "sclk_tmu", "fin_pll", ENABLE_SCLK_PERIS
, 10, 0, 0),
629 static struct samsung_cmu_info peris_cmu_info __initdata
= {
630 .mux_clks
= peris_mux_clks
,
631 .nr_mux_clks
= ARRAY_SIZE(peris_mux_clks
),
632 .gate_clks
= peris_gate_clks
,
633 .nr_gate_clks
= ARRAY_SIZE(peris_gate_clks
),
634 .nr_clk_ids
= PERIS_NR_CLK
,
635 .clk_regs
= peris_clk_regs
,
636 .nr_clk_regs
= ARRAY_SIZE(peris_clk_regs
),
639 static void __init
exynos7_clk_peris_init(struct device_node
*np
)
641 samsung_cmu_register_one(np
, &peris_cmu_info
);
644 CLK_OF_DECLARE(exynos7_clk_peris
, "samsung,exynos7-clock-peris",
645 exynos7_clk_peris_init
);
647 /* Register Offset definitions for CMU_FSYS0 (0x10E90000) */
648 #define MUX_SEL_FSYS00 0x0200
649 #define MUX_SEL_FSYS01 0x0204
650 #define ENABLE_ACLK_FSYS01 0x0804
653 * List of parent clocks for Muxes in CMU_FSYS0
655 PNAME(mout_aclk_fsys0_200_p
) = { "fin_pll", "dout_aclk_fsys0_200" };
656 PNAME(mout_sclk_mmc2_p
) = { "fin_pll", "sclk_mmc2" };
658 static unsigned long fsys0_clk_regs
[] __initdata
= {
664 static struct samsung_mux_clock fsys0_mux_clks
[] __initdata
= {
665 MUX(0, "mout_aclk_fsys0_200_user", mout_aclk_fsys0_200_p
,
666 MUX_SEL_FSYS00
, 24, 1),
668 MUX(0, "mout_sclk_mmc2_user", mout_sclk_mmc2_p
, MUX_SEL_FSYS01
, 24, 1),
671 static struct samsung_gate_clock fsys0_gate_clks
[] __initdata
= {
672 GATE(ACLK_MMC2
, "aclk_mmc2", "mout_aclk_fsys0_200_user",
673 ENABLE_ACLK_FSYS01
, 31, 0, 0),
676 static struct samsung_cmu_info fsys0_cmu_info __initdata
= {
677 .mux_clks
= fsys0_mux_clks
,
678 .nr_mux_clks
= ARRAY_SIZE(fsys0_mux_clks
),
679 .gate_clks
= fsys0_gate_clks
,
680 .nr_gate_clks
= ARRAY_SIZE(fsys0_gate_clks
),
681 .nr_clk_ids
= TOP1_NR_CLK
,
682 .clk_regs
= fsys0_clk_regs
,
683 .nr_clk_regs
= ARRAY_SIZE(fsys0_clk_regs
),
686 static void __init
exynos7_clk_fsys0_init(struct device_node
*np
)
688 samsung_cmu_register_one(np
, &fsys0_cmu_info
);
691 CLK_OF_DECLARE(exynos7_clk_fsys0
, "samsung,exynos7-clock-fsys0",
692 exynos7_clk_fsys0_init
);
694 /* Register Offset definitions for CMU_FSYS1 (0x156E0000) */
695 #define MUX_SEL_FSYS10 0x0200
696 #define MUX_SEL_FSYS11 0x0204
697 #define ENABLE_ACLK_FSYS1 0x0800
700 * List of parent clocks for Muxes in CMU_FSYS1
702 PNAME(mout_aclk_fsys1_200_p
) = { "fin_pll", "dout_aclk_fsys1_200" };
703 PNAME(mout_sclk_mmc0_p
) = { "fin_pll", "sclk_mmc0" };
704 PNAME(mout_sclk_mmc1_p
) = { "fin_pll", "sclk_mmc1" };
706 static unsigned long fsys1_clk_regs
[] __initdata
= {
712 static struct samsung_mux_clock fsys1_mux_clks
[] __initdata
= {
713 MUX(0, "mout_aclk_fsys1_200_user", mout_aclk_fsys1_200_p
,
714 MUX_SEL_FSYS10
, 28, 1),
716 MUX(0, "mout_sclk_mmc1_user", mout_sclk_mmc1_p
, MUX_SEL_FSYS11
, 24, 1),
717 MUX(0, "mout_sclk_mmc0_user", mout_sclk_mmc0_p
, MUX_SEL_FSYS11
, 28, 1),
720 static struct samsung_gate_clock fsys1_gate_clks
[] __initdata
= {
721 GATE(ACLK_MMC1
, "aclk_mmc1", "mout_aclk_fsys1_200_user",
722 ENABLE_ACLK_FSYS1
, 29, 0, 0),
723 GATE(ACLK_MMC0
, "aclk_mmc0", "mout_aclk_fsys1_200_user",
724 ENABLE_ACLK_FSYS1
, 30, 0, 0),
727 static struct samsung_cmu_info fsys1_cmu_info __initdata
= {
728 .mux_clks
= fsys1_mux_clks
,
729 .nr_mux_clks
= ARRAY_SIZE(fsys1_mux_clks
),
730 .gate_clks
= fsys1_gate_clks
,
731 .nr_gate_clks
= ARRAY_SIZE(fsys1_gate_clks
),
732 .nr_clk_ids
= TOP1_NR_CLK
,
733 .clk_regs
= fsys1_clk_regs
,
734 .nr_clk_regs
= ARRAY_SIZE(fsys1_clk_regs
),
737 static void __init
exynos7_clk_fsys1_init(struct device_node
*np
)
739 samsung_cmu_register_one(np
, &fsys1_cmu_info
);
742 CLK_OF_DECLARE(exynos7_clk_fsys1
, "samsung,exynos7-clock-fsys1",
743 exynos7_clk_fsys1_init
);