diff options
author | Linus Walleij <linus.walleij@linaro.org> | 2016-02-24 03:39:11 -0500 |
---|---|---|
committer | Stephen Boyd <sboyd@codeaurora.org> | 2016-02-25 18:03:28 -0500 |
commit | ec7957a6aa0aaf981fb8356dc47a2cdd01cde03c (patch) | |
tree | 58edfc561f433d50764ad55f7005410de9a91fc1 | |
parent | 2da5f5db39010da29efded0f3cf1b7799564d63c (diff) |
clk: versatile: sp810: support reentrance
Despite care take to allocate clocks state containers the
SP810 driver actually just supports creating one instance:
all clocks registered for every instance will end up with the
exact same name and __clk_init() will fail.
Rename the timclken<0> .. timclken<n> to sp810_<instance>_<n>
so every clock on every instance gets a unique name.
This is necessary for the RealView PBA8 which has two SP810
blocks: the second block will not register its clocks unless
every clock on every instance is unique and results in boot
logs like this:
------------[ cut here ]------------
WARNING: CPU: 0 PID: 0 at ../drivers/clk/versatile/clk-sp810.c:137
clk_sp810_of_setup+0x110/0x154()
Modules linked in:
CPU: 0 PID: 0 Comm: swapper/0 Not tainted
4.5.0-rc2-00030-g352718fc39f6-dirty #225
Hardware name: ARM RealView Machine (Device Tree Support)
[<c00167f8>] (unwind_backtrace) from [<c0013204>]
(show_stack+0x10/0x14)
[<c0013204>] (show_stack) from [<c01a049c>]
(dump_stack+0x84/0x9c)
[<c01a049c>] (dump_stack) from [<c0024990>]
(warn_slowpath_common+0x74/0xb0)
[<c0024990>] (warn_slowpath_common) from [<c0024a68>]
(warn_slowpath_null+0x1c/0x24)
[<c0024a68>] (warn_slowpath_null) from [<c051eb44>]
(clk_sp810_of_setup+0x110/0x154)
[<c051eb44>] (clk_sp810_of_setup) from [<c051e3a4>]
(of_clk_init+0x12c/0x1c8)
[<c051e3a4>] (of_clk_init) from [<c0504714>]
(time_init+0x20/0x2c)
[<c0504714>] (time_init) from [<c0501b18>]
(start_kernel+0x244/0x3c4)
[<c0501b18>] (start_kernel) from [<7000807c>] (0x7000807c)
---[ end trace cb88537fdc8fa200 ]---
Cc: Michael Turquette <mturquette@baylibre.com>
Cc: Pawel Moll <pawel.moll@arm.com>
Fixes: 6e973d2c4385 "clk: vexpress: Add separate SP810 driver"
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
-rw-r--r-- | drivers/clk/versatile/clk-sp810.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/clk/versatile/clk-sp810.c b/drivers/clk/versatile/clk-sp810.c index e78755e0ef78..1fe1e8d970cf 100644 --- a/drivers/clk/versatile/clk-sp810.c +++ b/drivers/clk/versatile/clk-sp810.c | |||
@@ -92,6 +92,7 @@ static void __init clk_sp810_of_setup(struct device_node *node) | |||
92 | int num = ARRAY_SIZE(parent_names); | 92 | int num = ARRAY_SIZE(parent_names); |
93 | char name[12]; | 93 | char name[12]; |
94 | struct clk_init_data init; | 94 | struct clk_init_data init; |
95 | static int instance; | ||
95 | int i; | 96 | int i; |
96 | bool deprecated; | 97 | bool deprecated; |
97 | 98 | ||
@@ -117,7 +118,7 @@ static void __init clk_sp810_of_setup(struct device_node *node) | |||
117 | deprecated = !of_find_property(node, "assigned-clock-parents", NULL); | 118 | deprecated = !of_find_property(node, "assigned-clock-parents", NULL); |
118 | 119 | ||
119 | for (i = 0; i < ARRAY_SIZE(sp810->timerclken); i++) { | 120 | for (i = 0; i < ARRAY_SIZE(sp810->timerclken); i++) { |
120 | snprintf(name, ARRAY_SIZE(name), "timerclken%d", i); | 121 | snprintf(name, sizeof(name), "sp810_%d_%d", instance, i); |
121 | 122 | ||
122 | sp810->timerclken[i].sp810 = sp810; | 123 | sp810->timerclken[i].sp810 = sp810; |
123 | sp810->timerclken[i].channel = i; | 124 | sp810->timerclken[i].channel = i; |
@@ -138,5 +139,6 @@ static void __init clk_sp810_of_setup(struct device_node *node) | |||
138 | } | 139 | } |
139 | 140 | ||
140 | of_clk_add_provider(node, clk_sp810_timerclken_of_get, sp810); | 141 | of_clk_add_provider(node, clk_sp810_timerclken_of_get, sp810); |
142 | instance++; | ||
141 | } | 143 | } |
142 | CLK_OF_DECLARE(sp810, "arm,sp810", clk_sp810_of_setup); | 144 | CLK_OF_DECLARE(sp810, "arm,sp810", clk_sp810_of_setup); |