ARM: highbank: call highbank_pm_init from .init_machine
authorRob Herring <rob.herring@calxeda.com>
Mon, 17 Sep 2012 14:55:12 +0000 (09:55 -0500)
committerOlof Johansson <olof@lixom.net>
Fri, 21 Sep 2012 05:58:17 +0000 (22:58 -0700)
Being a module_init call, highbank_pm_init will cause problem with
multi-platform build running on other platforms.  Call it from
.init_machine instead.

Reported-by: Shawn Guo <shawn.guo@linaro.org>
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Signed-off-by: Olof Johansson <olof@lixom.net>
arch/arm/mach-highbank/core.h
arch/arm/mach-highbank/highbank.c
arch/arm/mach-highbank/pm.c

index 141ed5171826acbc3caa6a1b7e843f2737361f65..8b9fb1a46a915c1aca8c6041006d80f99dd7d417 100644 (file)
@@ -8,4 +8,10 @@ extern void highbank_lluart_map_io(void);
 static inline void highbank_lluart_map_io(void) {}
 #endif
 
+#ifdef CONFIG_PM_SLEEP
+extern void highbank_pm_init(void);
+#else
+static inline void highbank_pm_init(void) {}
+#endif
+
 extern void highbank_smc1(int fn, int arg);
index d75b0a78d88ab94a85512cc3de2116ea3a710743..f376c26cb0e162420f5caa0fe3c4ca233ee690d3 100644 (file)
@@ -152,6 +152,7 @@ static void highbank_power_off(void)
 static void __init highbank_init(void)
 {
        pm_power_off = highbank_power_off;
+       highbank_pm_init();
 
        of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
 }
index 33b3beb899820c46a17859176a065ce70de5544a..de866f21331f4ed4c2258723ccbd9b24f1886eb7 100644 (file)
@@ -47,9 +47,7 @@ static const struct platform_suspend_ops highbank_pm_ops = {
        .valid = suspend_valid_only_mem,
 };
 
-static int __init highbank_pm_init(void)
+void __init highbank_pm_init(void)
 {
        suspend_set_ops(&highbank_pm_ops);
-       return 0;
 }
-module_init(highbank_pm_init);