clk: berlin: prepare simple-mfd conversion
authorAntoine Tenart <antoine.tenart@free-electrons.com>
Fri, 15 May 2015 23:40:15 +0000 (01:40 +0200)
committerSebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Mon, 18 May 2015 16:10:09 +0000 (18:10 +0200)
Prepare conversion of berlin clk drivers to a simple-mfd sub-node by
checking for parent node compatible. If parent node is "syscon" compatible
use it for of_iomap instead of the own node.

Signed-off-by: Antoine Tenart <antoine.tenart@free-electrons.com>
Acked-by: Stephen Boyd <sboyd@codeaurora.org>
Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
drivers/clk/berlin/bg2.c
drivers/clk/berlin/bg2q.c

index 515fb133495cc9a7cfafdccd815cffef8ec39767..d8e57097518b06bff3cd6e3d94a1933086ca6c46 100644 (file)
@@ -502,11 +502,15 @@ static const struct berlin2_gate_data bg2_gates[] __initconst = {
 
 static void __init berlin2_clock_setup(struct device_node *np)
 {
+       struct device_node *parent_np = of_get_parent(np);
        const char *parent_names[9];
        struct clk *clk;
        u8 avpll_flags = 0;
        int n;
 
+       if (of_device_is_compatible(parent_np, "syscon"))
+               np = parent_np;
+
        gbase = of_iomap(np, 0);
        if (!gbase)
                return;
@@ -689,3 +693,5 @@ CLK_OF_DECLARE(berlin2_clock, "marvell,berlin2-chip-ctrl",
               berlin2_clock_setup);
 CLK_OF_DECLARE(berlin2cd_clock, "marvell,berlin2cd-chip-ctrl",
               berlin2_clock_setup);
+CLK_OF_DECLARE(berlin2_clk, "marvell,berlin2-clk",
+              berlin2_clock_setup);
index 440ef81ab15c4ba8d9f70947db7e5a0d144a97a4..638a649ebed737a2faf188a4995e1c2c50c40a05 100644 (file)
@@ -290,10 +290,14 @@ static const struct berlin2_gate_data bg2q_gates[] __initconst = {
 
 static void __init berlin2q_clock_setup(struct device_node *np)
 {
+       struct device_node *parent_np = of_get_parent(np);
        const char *parent_names[9];
        struct clk *clk;
        int n;
 
+       if (of_device_is_compatible(parent_np, "syscon"))
+               np = parent_np;
+
        gbase = of_iomap(np, 0);
        if (!gbase) {
                pr_err("%s: Unable to map global base\n", np->full_name);
@@ -386,3 +390,5 @@ bg2q_fail:
 }
 CLK_OF_DECLARE(berlin2q_clock, "marvell,berlin2q-chip-ctrl",
               berlin2q_clock_setup);
+CLK_OF_DECLARE(berlin2q_clk, "marvell,berlin2q-clk",
+              berlin2q_clock_setup);