diff options
author | Shawn Guo <shawn.guo@linaro.org> | 2013-05-09 21:13:44 -0400 |
---|---|---|
committer | Shawn Guo <shawn.guo@linaro.org> | 2013-06-17 03:45:10 -0400 |
commit | 18cb680f1a003a1a1ec0e6097d7b763516a27f04 (patch) | |
tree | f9ef6d5b1fe540a4bb070fcbd1a222c11458afb1 /arch/arm/mach-imx/imx51-dt.c | |
parent | 24a83fe4b039ef3779efd6b1fc88ee020e8af52f (diff) |
ARM: imx: move clk_prepare() out from mxc_restart()
It's inappropriate to call clk_prepare() in mxc_restart(), because the
restart routine could be called in atomic context. Move clk_get() and
clk_prepare() into mxc_arch_reset_init() and only have the atomic part
clk_enable() be called in mxc_restart().
As a result, mxc_arch_reset_init() needs to be called after clk gets
initialized.
While there, it also changes printk(KERN_ERR ...) to pr_err() and adds
__init annotation for mxc_arch_reset_init().
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
Diffstat (limited to 'arch/arm/mach-imx/imx51-dt.c')
-rw-r--r-- | arch/arm/mach-imx/imx51-dt.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/arm/mach-imx/imx51-dt.c b/arch/arm/mach-imx/imx51-dt.c index ab24cc322111..55f47a0f98c0 100644 --- a/arch/arm/mach-imx/imx51-dt.c +++ b/arch/arm/mach-imx/imx51-dt.c | |||
@@ -17,12 +17,15 @@ | |||
17 | #include <asm/mach/time.h> | 17 | #include <asm/mach/time.h> |
18 | 18 | ||
19 | #include "common.h" | 19 | #include "common.h" |
20 | #include "hardware.h" | ||
20 | #include "mx51.h" | 21 | #include "mx51.h" |
21 | 22 | ||
22 | static void __init imx51_dt_init(void) | 23 | static void __init imx51_dt_init(void) |
23 | { | 24 | { |
24 | struct platform_device_info devinfo = { .name = "cpufreq-cpu0", }; | 25 | struct platform_device_info devinfo = { .name = "cpufreq-cpu0", }; |
25 | 26 | ||
27 | mxc_arch_reset_init(MX51_IO_ADDRESS(MX51_WDOG1_BASE_ADDR)); | ||
28 | |||
26 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); | 29 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); |
27 | platform_device_register_full(&devinfo); | 30 | platform_device_register_full(&devinfo); |
28 | } | 31 | } |