blob: c700f654289e23b6d55b91895363bfb134ac8794 [file] [log] [blame]
Naveen Krishna Ch532abc32014-09-22 10:17:04 +05301/*
2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
3 * Author: Naveen Krishna Ch <naveenkrishna.ch@gmail.com>
4 *
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.
8 *
9*/
10
11#include <linux/clk.h>
12#include <linux/clkdev.h>
13#include <linux/clk-provider.h>
14#include <linux/of.h>
15
16#include "clk.h"
17#include <dt-bindings/clock/exynos7-clk.h>
18
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_TOPC3 0x020C
33#define DIV_TOPC1 0x0604
34#define DIV_TOPC3 0x060C
35
36static struct samsung_fixed_factor_clock topc_fixed_factor_clks[] __initdata = {
37 FFACTOR(0, "ffac_topc_bus0_pll_div2", "mout_bus0_pll_ctrl", 1, 2, 0),
38 FFACTOR(0, "ffac_topc_bus0_pll_div4",
39 "ffac_topc_bus0_pll_div2", 1, 2, 0),
40 FFACTOR(0, "ffac_topc_bus1_pll_div2", "mout_bus1_pll_ctrl", 1, 2, 0),
41 FFACTOR(0, "ffac_topc_cc_pll_div2", "mout_cc_pll_ctrl", 1, 2, 0),
42 FFACTOR(0, "ffac_topc_mfc_pll_div2", "mout_mfc_pll_ctrl", 1, 2, 0),
43};
44
45/* List of parent clocks for Muxes in CMU_TOPC */
46PNAME(mout_bus0_pll_ctrl_p) = { "fin_pll", "fout_bus0_pll" };
47PNAME(mout_bus1_pll_ctrl_p) = { "fin_pll", "fout_bus1_pll" };
48PNAME(mout_cc_pll_ctrl_p) = { "fin_pll", "fout_cc_pll" };
49PNAME(mout_mfc_pll_ctrl_p) = { "fin_pll", "fout_mfc_pll" };
50
51PNAME(mout_topc_group2) = { "mout_sclk_bus0_pll_cmuc",
52 "mout_sclk_bus1_pll_cmuc", "mout_sclk_cc_pll_cmuc",
53 "mout_sclk_mfc_pll_cmuc" };
54
55PNAME(mout_sclk_bus0_pll_cmuc_p) = { "mout_bus0_pll_ctrl",
56 "ffac_topc_bus0_pll_div2", "ffac_topc_bus0_pll_div4"};
57PNAME(mout_sclk_bus1_pll_cmuc_p) = { "mout_bus1_pll_ctrl",
58 "ffac_topc_bus1_pll_div2"};
59PNAME(mout_sclk_cc_pll_cmuc_p) = { "mout_cc_pll_ctrl",
60 "ffac_topc_cc_pll_div2"};
61PNAME(mout_sclk_mfc_pll_cmuc_p) = { "mout_mfc_pll_ctrl",
62 "ffac_topc_mfc_pll_div2"};
63
64
65PNAME(mout_sclk_bus0_pll_out_p) = {"mout_bus0_pll_ctrl",
66 "ffac_topc_bus0_pll_div2"};
67
68static unsigned long topc_clk_regs[] __initdata = {
69 CC_PLL_LOCK,
70 BUS0_PLL_LOCK,
71 BUS1_DPLL_LOCK,
72 MFC_PLL_LOCK,
73 AUD_PLL_LOCK,
74 CC_PLL_CON0,
75 BUS0_PLL_CON0,
76 BUS1_DPLL_CON0,
77 MFC_PLL_CON0,
78 AUD_PLL_CON0,
79 MUX_SEL_TOPC0,
80 MUX_SEL_TOPC1,
81 MUX_SEL_TOPC3,
82 DIV_TOPC1,
83 DIV_TOPC3,
84};
85
86static struct samsung_mux_clock topc_mux_clks[] __initdata = {
87 MUX(0, "mout_bus0_pll_ctrl", mout_bus0_pll_ctrl_p, MUX_SEL_TOPC0, 0, 1),
88 MUX(0, "mout_bus1_pll_ctrl", mout_bus1_pll_ctrl_p, MUX_SEL_TOPC0, 4, 1),
89 MUX(0, "mout_cc_pll_ctrl", mout_cc_pll_ctrl_p, MUX_SEL_TOPC0, 8, 1),
90 MUX(0, "mout_mfc_pll_ctrl", mout_mfc_pll_ctrl_p, MUX_SEL_TOPC0, 12, 1),
91
92 MUX(0, "mout_sclk_bus0_pll_cmuc", mout_sclk_bus0_pll_cmuc_p,
93 MUX_SEL_TOPC0, 16, 2),
94 MUX(0, "mout_sclk_bus1_pll_cmuc", mout_sclk_bus1_pll_cmuc_p,
95 MUX_SEL_TOPC0, 20, 1),
96 MUX(0, "mout_sclk_cc_pll_cmuc", mout_sclk_cc_pll_cmuc_p,
97 MUX_SEL_TOPC0, 24, 1),
98 MUX(0, "mout_sclk_mfc_pll_cmuc", mout_sclk_mfc_pll_cmuc_p,
99 MUX_SEL_TOPC0, 28, 1),
100
101 MUX(0, "mout_sclk_bus0_pll_out", mout_sclk_bus0_pll_out_p,
102 MUX_SEL_TOPC1, 16, 1),
103
104 MUX(0, "mout_aclk_peris_66", mout_topc_group2, MUX_SEL_TOPC3, 24, 2),
105};
106
107static struct samsung_div_clock topc_div_clks[] __initdata = {
108 DIV(DOUT_ACLK_PERIS, "dout_aclk_peris_66", "mout_aclk_peris_66",
109 DIV_TOPC1, 24, 4),
110
111 DIV(DOUT_SCLK_BUS0_PLL, "dout_sclk_bus0_pll", "mout_sclk_bus0_pll_out",
112 DIV_TOPC3, 0, 3),
113 DIV(DOUT_SCLK_BUS1_PLL, "dout_sclk_bus1_pll", "mout_bus1_pll_ctrl",
114 DIV_TOPC3, 8, 3),
115 DIV(DOUT_SCLK_CC_PLL, "dout_sclk_cc_pll", "mout_cc_pll_ctrl",
116 DIV_TOPC3, 12, 3),
117 DIV(DOUT_SCLK_MFC_PLL, "dout_sclk_mfc_pll", "mout_mfc_pll_ctrl",
118 DIV_TOPC3, 16, 3),
119};
120
121static struct samsung_pll_clock topc_pll_clks[] __initdata = {
122 PLL(pll_1451x, 0, "fout_bus0_pll", "fin_pll", BUS0_PLL_LOCK,
123 BUS0_PLL_CON0, NULL),
124 PLL(pll_1452x, 0, "fout_cc_pll", "fin_pll", CC_PLL_LOCK,
125 CC_PLL_CON0, NULL),
126 PLL(pll_1452x, 0, "fout_bus1_pll", "fin_pll", BUS1_DPLL_LOCK,
127 BUS1_DPLL_CON0, NULL),
128 PLL(pll_1452x, 0, "fout_mfc_pll", "fin_pll", MFC_PLL_LOCK,
129 MFC_PLL_CON0, NULL),
130 PLL(pll_1460x, 0, "fout_aud_pll", "fin_pll", AUD_PLL_LOCK,
131 AUD_PLL_CON0, NULL),
132};
133
134static struct samsung_cmu_info topc_cmu_info __initdata = {
135 .pll_clks = topc_pll_clks,
136 .nr_pll_clks = ARRAY_SIZE(topc_pll_clks),
137 .mux_clks = topc_mux_clks,
138 .nr_mux_clks = ARRAY_SIZE(topc_mux_clks),
139 .div_clks = topc_div_clks,
140 .nr_div_clks = ARRAY_SIZE(topc_div_clks),
141 .fixed_factor_clks = topc_fixed_factor_clks,
142 .nr_fixed_factor_clks = ARRAY_SIZE(topc_fixed_factor_clks),
143 .nr_clk_ids = TOPC_NR_CLK,
144 .clk_regs = topc_clk_regs,
145 .nr_clk_regs = ARRAY_SIZE(topc_clk_regs),
146};
147
148static void __init exynos7_clk_topc_init(struct device_node *np)
149{
150 samsung_cmu_register_one(np, &topc_cmu_info);
151}
152
153CLK_OF_DECLARE(exynos7_clk_topc, "samsung,exynos7-clock-topc",
154 exynos7_clk_topc_init);
155
156/* Register Offset definitions for CMU_TOP0 (0x105D0000) */
157#define MUX_SEL_TOP00 0x0200
158#define MUX_SEL_TOP01 0x0204
159#define MUX_SEL_TOP03 0x020C
160#define MUX_SEL_TOP0_PERIC3 0x023C
161#define DIV_TOP03 0x060C
162#define DIV_TOP0_PERIC3 0x063C
163#define ENABLE_SCLK_TOP0_PERIC3 0x0A3C
164
165/* List of parent clocks for Muxes in CMU_TOP0 */
166PNAME(mout_bus0_pll_p) = { "fin_pll", "dout_sclk_bus0_pll" };
167PNAME(mout_bus1_pll_p) = { "fin_pll", "dout_sclk_bus1_pll" };
168PNAME(mout_cc_pll_p) = { "fin_pll", "dout_sclk_cc_pll" };
169PNAME(mout_mfc_pll_p) = { "fin_pll", "dout_sclk_mfc_pll" };
170
171PNAME(mout_top0_half_bus0_pll_p) = {"mout_top0_bus0_pll",
172 "ffac_top0_bus0_pll_div2"};
173PNAME(mout_top0_half_bus1_pll_p) = {"mout_top0_bus1_pll",
174 "ffac_top0_bus1_pll_div2"};
175PNAME(mout_top0_half_cc_pll_p) = {"mout_top0_cc_pll",
176 "ffac_top0_cc_pll_div2"};
177PNAME(mout_top0_half_mfc_pll_p) = {"mout_top0_mfc_pll",
178 "ffac_top0_mfc_pll_div2"};
179
180PNAME(mout_top0_group1) = {"mout_top0_half_bus0_pll",
181 "mout_top0_half_bus1_pll", "mout_top0_half_cc_pll",
182 "mout_top0_half_mfc_pll"};
183
184static unsigned long top0_clk_regs[] __initdata = {
185 MUX_SEL_TOP00,
186 MUX_SEL_TOP01,
187 MUX_SEL_TOP03,
188 MUX_SEL_TOP0_PERIC3,
189 DIV_TOP03,
190 DIV_TOP0_PERIC3,
191 ENABLE_SCLK_TOP0_PERIC3,
192};
193
194static struct samsung_mux_clock top0_mux_clks[] __initdata = {
195 MUX(0, "mout_top0_mfc_pll", mout_mfc_pll_p, MUX_SEL_TOP00, 4, 1),
196 MUX(0, "mout_top0_cc_pll", mout_cc_pll_p, MUX_SEL_TOP00, 8, 1),
197 MUX(0, "mout_top0_bus1_pll", mout_bus1_pll_p, MUX_SEL_TOP00, 12, 1),
198 MUX(0, "mout_top0_bus0_pll", mout_bus0_pll_p, MUX_SEL_TOP00, 16, 1),
199
200 MUX(0, "mout_top0_half_mfc_pll", mout_top0_half_mfc_pll_p,
201 MUX_SEL_TOP01, 4, 1),
202 MUX(0, "mout_top0_half_cc_pll", mout_top0_half_cc_pll_p,
203 MUX_SEL_TOP01, 8, 1),
204 MUX(0, "mout_top0_half_bus1_pll", mout_top0_half_bus1_pll_p,
205 MUX_SEL_TOP01, 12, 1),
206 MUX(0, "mout_top0_half_bus0_pll", mout_top0_half_bus0_pll_p,
207 MUX_SEL_TOP01, 16, 1),
208
209 MUX(0, "mout_aclk_peric1_66", mout_top0_group1, MUX_SEL_TOP03, 12, 2),
210 MUX(0, "mout_aclk_peric0_66", mout_top0_group1, MUX_SEL_TOP03, 20, 2),
211
212 MUX(0, "mout_sclk_uart3", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 4, 2),
213 MUX(0, "mout_sclk_uart2", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 8, 2),
214 MUX(0, "mout_sclk_uart1", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 12, 2),
215 MUX(0, "mout_sclk_uart0", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 16, 2),
216};
217
218static struct samsung_div_clock top0_div_clks[] __initdata = {
219 DIV(DOUT_ACLK_PERIC1, "dout_aclk_peric1_66", "mout_aclk_peric1_66",
220 DIV_TOP03, 12, 6),
221 DIV(DOUT_ACLK_PERIC0, "dout_aclk_peric0_66", "mout_aclk_peric0_66",
222 DIV_TOP03, 20, 6),
223
224 DIV(0, "dout_sclk_uart3", "mout_sclk_uart3", DIV_TOP0_PERIC3, 4, 4),
225 DIV(0, "dout_sclk_uart2", "mout_sclk_uart2", DIV_TOP0_PERIC3, 8, 4),
226 DIV(0, "dout_sclk_uart1", "mout_sclk_uart1", DIV_TOP0_PERIC3, 12, 4),
227 DIV(0, "dout_sclk_uart0", "mout_sclk_uart0", DIV_TOP0_PERIC3, 16, 4),
228};
229
230static struct samsung_gate_clock top0_gate_clks[] __initdata = {
231 GATE(CLK_SCLK_UART3, "sclk_uart3", "dout_sclk_uart3",
232 ENABLE_SCLK_TOP0_PERIC3, 4, 0, 0),
233 GATE(CLK_SCLK_UART2, "sclk_uart2", "dout_sclk_uart2",
234 ENABLE_SCLK_TOP0_PERIC3, 8, 0, 0),
235 GATE(CLK_SCLK_UART1, "sclk_uart1", "dout_sclk_uart1",
236 ENABLE_SCLK_TOP0_PERIC3, 12, 0, 0),
237 GATE(CLK_SCLK_UART0, "sclk_uart0", "dout_sclk_uart0",
238 ENABLE_SCLK_TOP0_PERIC3, 16, 0, 0),
239};
240
241static struct samsung_fixed_factor_clock top0_fixed_factor_clks[] __initdata = {
242 FFACTOR(0, "ffac_top0_bus0_pll_div2", "mout_top0_bus0_pll", 1, 2, 0),
243 FFACTOR(0, "ffac_top0_bus1_pll_div2", "mout_top0_bus1_pll", 1, 2, 0),
244 FFACTOR(0, "ffac_top0_cc_pll_div2", "mout_top0_cc_pll", 1, 2, 0),
245 FFACTOR(0, "ffac_top0_mfc_pll_div2", "mout_top0_mfc_pll", 1, 2, 0),
246};
247
248static struct samsung_cmu_info top0_cmu_info __initdata = {
249 .mux_clks = top0_mux_clks,
250 .nr_mux_clks = ARRAY_SIZE(top0_mux_clks),
251 .div_clks = top0_div_clks,
252 .nr_div_clks = ARRAY_SIZE(top0_div_clks),
253 .gate_clks = top0_gate_clks,
254 .nr_gate_clks = ARRAY_SIZE(top0_gate_clks),
255 .fixed_factor_clks = top0_fixed_factor_clks,
256 .nr_fixed_factor_clks = ARRAY_SIZE(top0_fixed_factor_clks),
257 .nr_clk_ids = TOP0_NR_CLK,
258 .clk_regs = top0_clk_regs,
259 .nr_clk_regs = ARRAY_SIZE(top0_clk_regs),
260};
261
262static void __init exynos7_clk_top0_init(struct device_node *np)
263{
264 samsung_cmu_register_one(np, &top0_cmu_info);
265}
266
267CLK_OF_DECLARE(exynos7_clk_top0, "samsung,exynos7-clock-top0",
268 exynos7_clk_top0_init);
269
270/* Register Offset definitions for CMU_PERIC0 (0x13610000) */
271#define MUX_SEL_PERIC0 0x0200
272#define ENABLE_PCLK_PERIC0 0x0900
273#define ENABLE_SCLK_PERIC0 0x0A00
274
275/* List of parent clocks for Muxes in CMU_PERIC0 */
276PNAME(mout_aclk_peric0_66_p) = { "fin_pll", "dout_aclk_peric0_66" };
277PNAME(mout_sclk_uart0_p) = { "fin_pll", "sclk_uart0" };
278
279static unsigned long peric0_clk_regs[] __initdata = {
280 MUX_SEL_PERIC0,
281 ENABLE_PCLK_PERIC0,
282 ENABLE_SCLK_PERIC0,
283};
284
285static struct samsung_mux_clock peric0_mux_clks[] __initdata = {
286 MUX(0, "mout_aclk_peric0_66_user", mout_aclk_peric0_66_p,
287 MUX_SEL_PERIC0, 0, 1),
288 MUX(0, "mout_sclk_uart0_user", mout_sclk_uart0_p,
289 MUX_SEL_PERIC0, 16, 1),
290};
291
292static struct samsung_gate_clock peric0_gate_clks[] __initdata = {
Naveen Krishna Ch57a2b482014-10-21 11:13:51 +0530293 GATE(PCLK_HSI2C0, "pclk_hsi2c0", "mout_aclk_peric0_66_user",
294 ENABLE_PCLK_PERIC0, 8, 0, 0),
295 GATE(PCLK_HSI2C1, "pclk_hsi2c1", "mout_aclk_peric0_66_user",
296 ENABLE_PCLK_PERIC0, 9, 0, 0),
297 GATE(PCLK_HSI2C4, "pclk_hsi2c4", "mout_aclk_peric0_66_user",
298 ENABLE_PCLK_PERIC0, 10, 0, 0),
299 GATE(PCLK_HSI2C5, "pclk_hsi2c5", "mout_aclk_peric0_66_user",
300 ENABLE_PCLK_PERIC0, 11, 0, 0),
301 GATE(PCLK_HSI2C9, "pclk_hsi2c9", "mout_aclk_peric0_66_user",
302 ENABLE_PCLK_PERIC0, 12, 0, 0),
303 GATE(PCLK_HSI2C10, "pclk_hsi2c10", "mout_aclk_peric0_66_user",
304 ENABLE_PCLK_PERIC0, 13, 0, 0),
305 GATE(PCLK_HSI2C11, "pclk_hsi2c11", "mout_aclk_peric0_66_user",
306 ENABLE_PCLK_PERIC0, 14, 0, 0),
Naveen Krishna Ch532abc32014-09-22 10:17:04 +0530307 GATE(PCLK_UART0, "pclk_uart0", "mout_aclk_peric0_66_user",
308 ENABLE_PCLK_PERIC0, 16, 0, 0),
309
310 GATE(SCLK_UART0, "sclk_uart0_user", "mout_sclk_uart0_user",
311 ENABLE_SCLK_PERIC0, 16, 0, 0),
312};
313
314static struct samsung_cmu_info peric0_cmu_info __initdata = {
315 .mux_clks = peric0_mux_clks,
316 .nr_mux_clks = ARRAY_SIZE(peric0_mux_clks),
317 .gate_clks = peric0_gate_clks,
318 .nr_gate_clks = ARRAY_SIZE(peric0_gate_clks),
319 .nr_clk_ids = PERIC0_NR_CLK,
320 .clk_regs = peric0_clk_regs,
321 .nr_clk_regs = ARRAY_SIZE(peric0_clk_regs),
322};
323
324static void __init exynos7_clk_peric0_init(struct device_node *np)
325{
326 samsung_cmu_register_one(np, &peric0_cmu_info);
327}
328
329/* Register Offset definitions for CMU_PERIC1 (0x14C80000) */
330#define MUX_SEL_PERIC10 0x0200
331#define MUX_SEL_PERIC11 0x0204
332#define ENABLE_PCLK_PERIC1 0x0900
333#define ENABLE_SCLK_PERIC10 0x0A00
334
335CLK_OF_DECLARE(exynos7_clk_peric0, "samsung,exynos7-clock-peric0",
336 exynos7_clk_peric0_init);
337
338/* List of parent clocks for Muxes in CMU_PERIC1 */
339PNAME(mout_aclk_peric1_66_p) = { "fin_pll", "dout_aclk_peric1_66" };
340PNAME(mout_sclk_uart1_p) = { "fin_pll", "sclk_uart1" };
341PNAME(mout_sclk_uart2_p) = { "fin_pll", "sclk_uart2" };
342PNAME(mout_sclk_uart3_p) = { "fin_pll", "sclk_uart3" };
343
344static unsigned long peric1_clk_regs[] __initdata = {
345 MUX_SEL_PERIC10,
346 MUX_SEL_PERIC11,
347 ENABLE_PCLK_PERIC1,
348 ENABLE_SCLK_PERIC10,
349};
350
351static struct samsung_mux_clock peric1_mux_clks[] __initdata = {
352 MUX(0, "mout_aclk_peric1_66_user", mout_aclk_peric1_66_p,
353 MUX_SEL_PERIC10, 0, 1),
354
355 MUX(0, "mout_sclk_uart1_user", mout_sclk_uart1_p,
356 MUX_SEL_PERIC11, 20, 1),
357 MUX(0, "mout_sclk_uart2_user", mout_sclk_uart2_p,
358 MUX_SEL_PERIC11, 24, 1),
359 MUX(0, "mout_sclk_uart3_user", mout_sclk_uart3_p,
360 MUX_SEL_PERIC11, 28, 1),
361};
362
363static struct samsung_gate_clock peric1_gate_clks[] __initdata = {
Naveen Krishna Ch57a2b482014-10-21 11:13:51 +0530364 GATE(PCLK_HSI2C2, "pclk_hsi2c2", "mout_aclk_peric1_66_user",
365 ENABLE_PCLK_PERIC1, 4, 0, 0),
366 GATE(PCLK_HSI2C3, "pclk_hsi2c3", "mout_aclk_peric1_66_user",
367 ENABLE_PCLK_PERIC1, 5, 0, 0),
368 GATE(PCLK_HSI2C6, "pclk_hsi2c6", "mout_aclk_peric1_66_user",
369 ENABLE_PCLK_PERIC1, 6, 0, 0),
370 GATE(PCLK_HSI2C7, "pclk_hsi2c7", "mout_aclk_peric1_66_user",
371 ENABLE_PCLK_PERIC1, 7, 0, 0),
372 GATE(PCLK_HSI2C8, "pclk_hsi2c8", "mout_aclk_peric1_66_user",
373 ENABLE_PCLK_PERIC1, 8, 0, 0),
Naveen Krishna Ch532abc32014-09-22 10:17:04 +0530374 GATE(PCLK_UART1, "pclk_uart1", "mout_aclk_peric1_66_user",
375 ENABLE_PCLK_PERIC1, 9, 0, 0),
376 GATE(PCLK_UART2, "pclk_uart2", "mout_aclk_peric1_66_user",
377 ENABLE_PCLK_PERIC1, 10, 0, 0),
378 GATE(PCLK_UART3, "pclk_uart3", "mout_aclk_peric1_66_user",
379 ENABLE_PCLK_PERIC1, 11, 0, 0),
380
381 GATE(SCLK_UART1, "sclk_uart1_user", "mout_sclk_uart1_user",
382 ENABLE_SCLK_PERIC10, 9, 0, 0),
383 GATE(SCLK_UART2, "sclk_uart2_user", "mout_sclk_uart2_user",
384 ENABLE_SCLK_PERIC10, 10, 0, 0),
385 GATE(SCLK_UART3, "sclk_uart3_user", "mout_sclk_uart3_user",
386 ENABLE_SCLK_PERIC10, 11, 0, 0),
387};
388
389static struct samsung_cmu_info peric1_cmu_info __initdata = {
390 .mux_clks = peric1_mux_clks,
391 .nr_mux_clks = ARRAY_SIZE(peric1_mux_clks),
392 .gate_clks = peric1_gate_clks,
393 .nr_gate_clks = ARRAY_SIZE(peric1_gate_clks),
394 .nr_clk_ids = PERIC1_NR_CLK,
395 .clk_regs = peric1_clk_regs,
396 .nr_clk_regs = ARRAY_SIZE(peric1_clk_regs),
397};
398
399static void __init exynos7_clk_peric1_init(struct device_node *np)
400{
401 samsung_cmu_register_one(np, &peric1_cmu_info);
402}
403
404CLK_OF_DECLARE(exynos7_clk_peric1, "samsung,exynos7-clock-peric1",
405 exynos7_clk_peric1_init);
406
407/* Register Offset definitions for CMU_PERIS (0x10040000) */
408#define MUX_SEL_PERIS 0x0200
409#define ENABLE_PCLK_PERIS_SECURE_CHIPID 0x0910
410#define ENABLE_SCLK_PERIS_SECURE_CHIPID 0x0A10
411
412/* List of parent clocks for Muxes in CMU_PERIS */
413PNAME(mout_aclk_peris_66_p) = { "fin_pll", "dout_aclk_peris_66" };
414
415static unsigned long peris_clk_regs[] __initdata = {
416 MUX_SEL_PERIS,
417 ENABLE_PCLK_PERIS_SECURE_CHIPID,
418 ENABLE_SCLK_PERIS_SECURE_CHIPID,
419};
420
421static struct samsung_mux_clock peris_mux_clks[] __initdata = {
422 MUX(0, "mout_aclk_peris_66_user",
423 mout_aclk_peris_66_p, MUX_SEL_PERIS, 0, 1),
424};
425
426static struct samsung_gate_clock peris_gate_clks[] __initdata = {
427 GATE(PCLK_CHIPID, "pclk_chipid", "mout_aclk_peris_66_user",
428 ENABLE_PCLK_PERIS_SECURE_CHIPID, 0, 0, 0),
429 GATE(SCLK_CHIPID, "sclk_chipid", "fin_pll",
430 ENABLE_SCLK_PERIS_SECURE_CHIPID, 0, 0, 0),
431};
432
433static struct samsung_cmu_info peris_cmu_info __initdata = {
434 .mux_clks = peris_mux_clks,
435 .nr_mux_clks = ARRAY_SIZE(peris_mux_clks),
436 .gate_clks = peris_gate_clks,
437 .nr_gate_clks = ARRAY_SIZE(peris_gate_clks),
438 .nr_clk_ids = PERIS_NR_CLK,
439 .clk_regs = peris_clk_regs,
440 .nr_clk_regs = ARRAY_SIZE(peris_clk_regs),
441};
442
443static void __init exynos7_clk_peris_init(struct device_node *np)
444{
445 samsung_cmu_register_one(np, &peris_cmu_info);
446}
447
448CLK_OF_DECLARE(exynos7_clk_peris, "samsung,exynos7-clock-peris",
449 exynos7_clk_peris_init);