提交 14c26071 编写于 作者: L Linus Walleij

clk: move the U300 fixed and fixed-factor to DT

This converts the fixed and fixed-factor clocks in the U300
platform to register themselves from the device tree.
Acked-by: NMike Turquette <mturquette@linaro.org>
Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
上级 4cc4f6d1
...@@ -33,6 +33,49 @@ ...@@ -33,6 +33,49 @@
syscon: syscon@c0011000 { syscon: syscon@c0011000 {
compatible = "stericsson,u300-syscon"; compatible = "stericsson,u300-syscon";
reg = <0xc0011000 0x1000>; reg = <0xc0011000 0x1000>;
clk32: app_32_clk@32k {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <32768>;
};
pll13: pll13@13M {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <13000000>;
};
pll208: pll208@208M {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <208000000>;
};
app208: app_208_clk@208M {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clock-div = <1>;
clock-mult = <1>;
clocks = <&pll208>;
};
app104: app_104_clk@104M {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clock-div = <2>;
clock-mult = <1>;
clocks = <&pll208>;
};
app52: app_52_clk@52M {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clock-div = <4>;
clock-mult = <1>;
clocks = <&pll208>;
};
app26: app_26_clk@26M {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clock-div = <2>;
clock-mult = <1>;
clocks = <&app52>;
};
}; };
timer: timer@c0014000 { timer: timer@c0014000 {
...@@ -65,6 +108,7 @@ ...@@ -65,6 +108,7 @@
reg = <0xc0012000 0x1000>; reg = <0xc0012000 0x1000>;
interrupt-parent = <&vicb>; interrupt-parent = <&vicb>;
interrupts = <3>; interrupts = <3>;
clocks = <&clk32>;
}; };
rtc: rtc@c0017000 { rtc: rtc@c0017000 {
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include <linux/io.h> #include <linux/io.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/of.h>
/* APP side SYSCON registers */ /* APP side SYSCON registers */
/* CLK Control Register 16bit (R/W) */ /* CLK Control Register 16bit (R/W) */
...@@ -931,6 +932,17 @@ mclk_clk_register(struct device *dev, const char *name, ...@@ -931,6 +932,17 @@ mclk_clk_register(struct device *dev, const char *name,
return clk; return clk;
} }
static const __initconst struct of_device_id u300_clk_match[] = {
{
.compatible = "fixed-clock",
.data = of_fixed_clk_setup,
},
{
.compatible = "fixed-factor-clock",
.data = of_fixed_factor_clk_setup,
},
};
void __init u300_clk_init(void __iomem *base) void __init u300_clk_init(void __iomem *base)
{ {
u16 val; u16 val;
...@@ -951,26 +963,7 @@ void __init u300_clk_init(void __iomem *base) ...@@ -951,26 +963,7 @@ void __init u300_clk_init(void __iomem *base)
val |= U300_SYSCON_PMCR_PWR_MGNT_ENABLE; val |= U300_SYSCON_PMCR_PWR_MGNT_ENABLE;
writew(val, syscon_vbase + U300_SYSCON_PMCR); writew(val, syscon_vbase + U300_SYSCON_PMCR);
/* These are always available (RTC and PLL13) */ of_clk_init(u300_clk_match);
clk = clk_register_fixed_rate(NULL, "app_32_clk", NULL,
CLK_IS_ROOT, 32768);
/* The watchdog sits directly on the 32 kHz clock */
clk_register_clkdev(clk, NULL, "coh901327_wdog");
clk = clk_register_fixed_rate(NULL, "pll13", NULL,
CLK_IS_ROOT, 13000000);
/* These derive from PLL208 */
clk = clk_register_fixed_rate(NULL, "pll208", NULL,
CLK_IS_ROOT, 208000000);
clk = clk_register_fixed_factor(NULL, "app_208_clk", "pll208",
0, 1, 1);
clk = clk_register_fixed_factor(NULL, "app_104_clk", "pll208",
0, 1, 2);
clk = clk_register_fixed_factor(NULL, "app_52_clk", "pll208",
0, 1, 4);
/* The 52 MHz is divided down to 26 MHz */
clk = clk_register_fixed_factor(NULL, "app_26_clk", "app_52_clk",
0, 1, 2);
/* Directly on the AMBA interconnect */ /* Directly on the AMBA interconnect */
clk = syscon_clk_register(NULL, "cpu_clk", "app_208_clk", 0, true, clk = syscon_clk_register(NULL, "cpu_clk", "app_208_clk", 0, true,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册