From 3f6d439f202243a1594f2e1b86620af0d342bbe6 Mon Sep 17 00:00:00 2001 From: Sylwester Nawrocki Date: Thu, 27 Mar 2014 11:43:32 +0100 Subject: [PATCH] clk: reverse default clk provider initialization order in of_clk_init() This restores the default clocks registration order as parsed from devicetree, i.e. as before commit 1771b10d605d26ccee771a7fb4b08718 "clk: respect the clock dependencies in of_clk_init", for when there is no explicit parent clock dependencies between clock providers specified in the device tree. It prevents regressions (boot failure, division by 0 errors) on imx and exynos platforms. Signed-off-by: Sylwester Nawrocki Tested-by: Fabio Estevam Signed-off-by: Mike Turquette --- drivers/clk/clk.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c index 1fbcb2b107e7..6b44022753cb 100644 --- a/drivers/clk/clk.c +++ b/drivers/clk/clk.c @@ -2612,7 +2612,7 @@ void __init of_clk_init(const struct of_device_id *matches) parent->clk_init_cb = match->data; parent->np = np; - list_add(&parent->node, &clk_provider_list); + list_add_tail(&parent->node, &clk_provider_list); } while (!list_empty(&clk_provider_list)) {