UBUNTU: SAUCE: async_populate_rootfs: move rootfs init earlier
authorAndy Whitcroft <apw@canonical.com>
Wed, 23 Dec 2009 16:43:07 +0000 (16:43 +0000)
committerLeann Ogasawara <leann.ogasawara@canonical.com>
Mon, 28 Mar 2011 13:48:24 +0000 (06:48 -0700)
Check to see if the machine has more than one active CPU, if it does
then it is worth starting the decode of the rootfs earlier.

Signed-off-by: Andy Whitcroft <apw@canonical.com>

include/asm-generic/vmlinux.lds.h
include/linux/init.h
init/initramfs.c

index fe77e33..fe3d30d 100644 (file)
        *(.initcall0s.init)                                             \
        *(.initcall1.init)                                              \
        *(.initcall1s.init)                                             \
+       *(.initcallearlyrootfs.init)                                    \
        *(.initcall2.init)                                              \
        *(.initcall2s.init)                                             \
        *(.initcall3.init)                                              \
index a92ba8e..f6a7d36 100644 (file)
@@ -195,6 +195,7 @@ extern int initcall_debug;
 
 #define core_initcall(fn)              __define_initcall("1",fn,1)
 #define core_initcall_sync(fn)         __define_initcall("1s",fn,1s)
+#define earlyrootfs_initcall(fn)       __define_initcall("earlyrootfs",fn,rootfs)
 #define postcore_initcall(fn)          __define_initcall("2",fn,2)
 #define postcore_initcall_sync(fn)     __define_initcall("2s",fn,2s)
 #define arch_initcall(fn)              __define_initcall("3",fn,3)
index 22712f9..1ecfa05 100644 (file)
@@ -612,9 +612,22 @@ static void __init async_populate_rootfs(void)
        return;
 }
 
+static int __initdata rootfs_populated;
+
+static int __init populate_rootfs_early(void)
+{
+       if (num_online_cpus() > 1) {
+               rootfs_populated = 1;
+               async_schedule_domain(async_populate_rootfs, NULL,
+                                               &populate_rootfs_domain);
+       }
+}
 static int __init populate_rootfs(void)
 {
-       async_schedule_domain(async_populate_rootfs, NULL, &populate_rootfs_domain);
+       if (!rootfs_populated)
+               async_schedule_domain(async_populate_rootfs, NULL,
+                                               &populate_rootfs_domain);
 }
 
+earlyrootfs_initcall(populate_rootfs_early);
 rootfs_initcall(populate_rootfs);