[POWERPC] pasemi: Move pasemi_idle_init() to late_initcall()
authorOlof Johansson <olof@lixom.net>
Wed, 5 Sep 2007 02:09:45 +0000 (12:09 +1000)
committerPaul Mackerras <paulus@samba.org>
Thu, 13 Sep 2007 15:33:22 +0000 (01:33 +1000)
Move pasemi_idle_init() to be a late_initcall instead of being called from
setup_arch().  This way the cpufreq driver has a chance to initialize and
save away the boot time astate before we go to idle for the first time.

Signed-off-by: Olof Johansson <olof@lixom.net>
Signed-off-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/platforms/pasemi/idle.c
arch/powerpc/platforms/pasemi/pasemi.h
arch/powerpc/platforms/pasemi/setup.c

index 3c962d5757be797446c5195ff32278929f3489ab..d8e1fcc7851388b51c84b20f77f62638e4189fab 100644 (file)
@@ -72,8 +72,11 @@ static int pasemi_system_reset_exception(struct pt_regs *regs)
        return 1;
 }
 
-void __init pasemi_idle_init(void)
+static int __init pasemi_idle_init(void)
 {
+       if (!machine_is(pasemi))
+               return -ENODEV;
+
 #ifndef CONFIG_PPC_PASEMI_CPUFREQ
        printk(KERN_WARNING "No cpufreq driver, powersavings modes disabled\n");
        current_mode = 0;
@@ -82,7 +85,10 @@ void __init pasemi_idle_init(void)
        ppc_md.system_reset_exception = pasemi_system_reset_exception;
        ppc_md.power_save = modes[current_mode].entry;
        printk(KERN_INFO "Using PA6T idle loop (%s)\n", modes[current_mode].name);
+
+       return 0;
 }
+late_initcall(pasemi_idle_init);
 
 static int __init idle_param(char *p)
 {
index 6fd2fe75a6082437d82bd9d57903feab9e84fe64..516acabb4e96a4151b42e2833e907feb633c6ae2 100644 (file)
@@ -10,8 +10,6 @@ extern void __iomem *pasemi_pci_getcfgaddr(struct pci_dev *dev, int offset);
 
 extern void __init alloc_iobmap_l2(void);
 
-extern void __init pasemi_idle_init(void);
-
 /* Power savings modes, implemented in asm */
 extern void idle_spin(void);
 extern void idle_doze(void);
index fe9a5d631431e09e4285d9fb17a94338372423d3..5ddf40a66ae8f189da5fbc4f7d39bf5c3934a40d 100644 (file)
@@ -115,8 +115,6 @@ void __init pas_setup_arch(void)
        /* Remap SDC register for doing reset */
        /* XXXOJN This should maybe come out of the device tree */
        reset_reg = ioremap(0xfc101100, 4);
-
-       pasemi_idle_init();
 }
 
 static int __init pas_setup_mce_regs(void)