2 * r8a7778 Core CPG Clocks
4 * Copyright (C) 2014 Ulrich Hecht
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
11 #include <linux/clk-provider.h>
12 #include <linux/clk/shmobile.h>
13 #include <linux/of_address.h>
14 #include <linux/slab.h>
17 struct clk_onecell_data data
;
22 /* PLL multipliers per bits 11, 12, and 18 of MODEMR */
24 unsigned long plla_mult
;
25 unsigned long pllb_mult
;
26 } r8a7778_rates
[] __initconst
= {
36 /* Clock dividers per bits 1 and 2 of MODEMR */
40 } r8a7778_divs
[6] __initconst
= {
41 { "b", { 12, 12, 16, 18 } },
42 { "out", { 12, 12, 16, 18 } },
43 { "p", { 16, 12, 16, 12 } },
44 { "s", { 4, 3, 4, 3 } },
45 { "s1", { 8, 6, 8, 6 } },
48 static u32 cpg_mode_rates __initdata
;
49 static u32 cpg_mode_divs __initdata
;
51 static struct clk
* __init
52 r8a7778_cpg_register_clock(struct device_node
*np
, struct r8a7778_cpg
*cpg
,
55 if (!strcmp(name
, "plla")) {
56 return clk_register_fixed_factor(NULL
, "plla",
57 of_clk_get_parent_name(np
, 0), 0,
58 r8a7778_rates
[cpg_mode_rates
].plla_mult
, 1);
59 } else if (!strcmp(name
, "pllb")) {
60 return clk_register_fixed_factor(NULL
, "pllb",
61 of_clk_get_parent_name(np
, 0), 0,
62 r8a7778_rates
[cpg_mode_rates
].pllb_mult
, 1);
66 for (i
= 0; i
< ARRAY_SIZE(r8a7778_divs
); i
++) {
67 if (!strcmp(name
, r8a7778_divs
[i
].name
)) {
68 return clk_register_fixed_factor(NULL
,
71 r8a7778_divs
[i
].div
[cpg_mode_divs
]);
76 return ERR_PTR(-EINVAL
);
80 static void __init
r8a7778_cpg_clocks_init(struct device_node
*np
)
82 struct r8a7778_cpg
*cpg
;
87 num_clks
= of_property_count_strings(np
, "clock-output-names");
89 pr_err("%s: failed to count clocks\n", __func__
);
93 cpg
= kzalloc(sizeof(*cpg
), GFP_KERNEL
);
94 clks
= kcalloc(num_clks
, sizeof(*clks
), GFP_KERNEL
);
95 if (cpg
== NULL
|| clks
== NULL
) {
96 /* We're leaking memory on purpose, there's no point in cleaning
97 * up as the system won't boot anyway.
102 spin_lock_init(&cpg
->lock
);
104 cpg
->data
.clks
= clks
;
105 cpg
->data
.clk_num
= num_clks
;
107 cpg
->reg
= of_iomap(np
, 0);
108 if (WARN_ON(cpg
->reg
== NULL
))
111 for (i
= 0; i
< num_clks
; ++i
) {
115 of_property_read_string_index(np
, "clock-output-names", i
,
118 clk
= r8a7778_cpg_register_clock(np
, cpg
, name
);
120 pr_err("%s: failed to register %s %s clock (%ld)\n",
121 __func__
, np
->name
, name
, PTR_ERR(clk
));
123 cpg
->data
.clks
[i
] = clk
;
126 of_clk_add_provider(np
, of_clk_src_onecell_get
, &cpg
->data
);
128 cpg_mstp_add_clk_domain(np
);
131 CLK_OF_DECLARE(r8a7778_cpg_clks
, "renesas,r8a7778-cpg-clocks",
132 r8a7778_cpg_clocks_init
);
134 void __init
r8a7778_clocks_init(u32 mode
)
136 BUG_ON(!(mode
& BIT(19)));
138 cpg_mode_rates
= (!!(mode
& BIT(18)) << 2) |
139 (!!(mode
& BIT(12)) << 1) |
140 (!!(mode
& BIT(11)));
141 cpg_mode_divs
= (!!(mode
& BIT(2)) << 1) |