aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-imx/imx51-dt.c
diff options
context:
space:
mode:
authorShawn Guo <shawn.guo@linaro.org>2013-05-09 21:13:44 -0400
committerShawn Guo <shawn.guo@linaro.org>2013-06-17 03:45:10 -0400
commit18cb680f1a003a1a1ec0e6097d7b763516a27f04 (patch)
treef9ef6d5b1fe540a4bb070fcbd1a222c11458afb1 /arch/arm/mach-imx/imx51-dt.c
parent24a83fe4b039ef3779efd6b1fc88ee020e8af52f (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.c3
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
22static void __init imx51_dt_init(void) 23static 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}