]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
include/linux/init.h: use the stringify operator for the __define_initcall macro
authorMatthew Leach <matthew@mattleach.net>
Thu, 25 Oct 2012 01:14:55 +0000 (12:14 +1100)
committerStephen Rothwell <sfr@canb.auug.org.au>
Fri, 26 Oct 2012 04:05:25 +0000 (15:05 +1100)
Currently the __define_initcall() macro takes three arguments, fn, id and
level.  The level argument is exactly the same as the id argument but
wrapped in quotes.  To overcome this need to specify three arguments to
the __define_initcall macro, where one argument is the stringification of
another, we can just use the stringification macro instead.

Signed-off-by: Matthew Leach <matthew@mattleach.net>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
arch/powerpc/include/asm/machdep.h
include/linux/init.h

index c4231973edd351eacf480dacbdb3d1a529b1b08c..3c82daf8be998a7db1e65d8d3d0479d654c6761b 100644 (file)
@@ -320,28 +320,28 @@ static inline void log_error(char *buf, unsigned int err_type, int fatal)
                ppc_md.log_error(buf, err_type, fatal);
 }
 
-#define __define_machine_initcall(mach,level,fn,id) \
+#define __define_machine_initcall(mach, fn, id) \
        static int __init __machine_initcall_##mach##_##fn(void) { \
                if (machine_is(mach)) return fn(); \
                return 0; \
        } \
-       __define_initcall(level,__machine_initcall_##mach##_##fn,id);
-
-#define machine_core_initcall(mach,fn)         __define_machine_initcall(mach,"1",fn,1)
-#define machine_core_initcall_sync(mach,fn)    __define_machine_initcall(mach,"1s",fn,1s)
-#define machine_postcore_initcall(mach,fn)     __define_machine_initcall(mach,"2",fn,2)
-#define machine_postcore_initcall_sync(mach,fn)        __define_machine_initcall(mach,"2s",fn,2s)
-#define machine_arch_initcall(mach,fn)         __define_machine_initcall(mach,"3",fn,3)
-#define machine_arch_initcall_sync(mach,fn)    __define_machine_initcall(mach,"3s",fn,3s)
-#define machine_subsys_initcall(mach,fn)       __define_machine_initcall(mach,"4",fn,4)
-#define machine_subsys_initcall_sync(mach,fn)  __define_machine_initcall(mach,"4s",fn,4s)
-#define machine_fs_initcall(mach,fn)           __define_machine_initcall(mach,"5",fn,5)
-#define machine_fs_initcall_sync(mach,fn)      __define_machine_initcall(mach,"5s",fn,5s)
-#define machine_rootfs_initcall(mach,fn)       __define_machine_initcall(mach,"rootfs",fn,rootfs)
-#define machine_device_initcall(mach,fn)       __define_machine_initcall(mach,"6",fn,6)
-#define machine_device_initcall_sync(mach,fn)  __define_machine_initcall(mach,"6s",fn,6s)
-#define machine_late_initcall(mach,fn)         __define_machine_initcall(mach,"7",fn,7)
-#define machine_late_initcall_sync(mach,fn)    __define_machine_initcall(mach,"7s",fn,7s)
+       __define_initcall(__machine_initcall_##mach##_##fn, id);
+
+#define machine_core_initcall(mach, fn)                __define_machine_initcall(mach, fn, 1)
+#define machine_core_initcall_sync(mach, fn)   __define_machine_initcall(mach, fn, 1s)
+#define machine_postcore_initcall(mach, fn)    __define_machine_initcall(mach, fn, 2)
+#define machine_postcore_initcall_sync(mach, fn)       __define_machine_initcall(mach, fn, 2s)
+#define machine_arch_initcall(mach, fn)                __define_machine_initcall(mach, fn, 3)
+#define machine_arch_initcall_sync(mach, fn)   __define_machine_initcall(mach, fn, 3s)
+#define machine_subsys_initcall(mach, fn)      __define_machine_initcall(mach, fn, 4)
+#define machine_subsys_initcall_sync(mach, fn) __define_machine_initcall(mach, fn, 4s)
+#define machine_fs_initcall(mach, fn)          __define_machine_initcall(mach, fn, 5)
+#define machine_fs_initcall_sync(mach, fn)     __define_machine_initcall(mach, fn, 5s)
+#define machine_rootfs_initcall(mach, fn)      __define_machine_initcall(mach, fn, rootfs)
+#define machine_device_initcall(mach, fn)      __define_machine_initcall(mach, fn, 6)
+#define machine_device_initcall_sync(mach, fn) __define_machine_initcall(mach, fn, 6s)
+#define machine_late_initcall(mach, fn)                __define_machine_initcall(mach, fn, 7)
+#define machine_late_initcall_sync(mach, fn)   __define_machine_initcall(mach, fn, 7s)
 
 #endif /* __KERNEL__ */
 #endif /* _ASM_POWERPC_MACHDEP_H */
index e59041e21df32c279a3a732a70cb6a18b47b10d3..1c2746f35f15cc5acfd55c4c3f8c0ff464444ef3 100644 (file)
@@ -186,16 +186,16 @@ extern bool initcall_debug;
  * can point at the same handler without causing duplicate-symbol build errors.
  */
 
-#define __define_initcall(level,fn,id) \
+#define __define_initcall(fn, id) \
        static initcall_t __initcall_##fn##id __used \
-       __attribute__((__section__(".initcall" level ".init"))) = fn
+       __attribute__((__section__(".initcall" #id ".init"))) = fn
 
 /*
  * Early initcalls run before initializing SMP.
  *
  * Only for built-in code, not modules.
  */
-#define early_initcall(fn)             __define_initcall("early",fn,early)
+#define early_initcall(fn)             __define_initcall(fn, early)
 
 /*
  * A "pure" initcall has no dependencies on anything else, and purely
@@ -204,23 +204,23 @@ extern bool initcall_debug;
  * This only exists for built-in code, not for modules.
  * Keep main.c:initcall_level_names[] in sync.
  */
-#define pure_initcall(fn)              __define_initcall("0",fn,0)
-
-#define core_initcall(fn)              __define_initcall("1",fn,1)
-#define core_initcall_sync(fn)         __define_initcall("1s",fn,1s)
-#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)
-#define arch_initcall_sync(fn)         __define_initcall("3s",fn,3s)
-#define subsys_initcall(fn)            __define_initcall("4",fn,4)
-#define subsys_initcall_sync(fn)       __define_initcall("4s",fn,4s)
-#define fs_initcall(fn)                        __define_initcall("5",fn,5)
-#define fs_initcall_sync(fn)           __define_initcall("5s",fn,5s)
-#define rootfs_initcall(fn)            __define_initcall("rootfs",fn,rootfs)
-#define device_initcall(fn)            __define_initcall("6",fn,6)
-#define device_initcall_sync(fn)       __define_initcall("6s",fn,6s)
-#define late_initcall(fn)              __define_initcall("7",fn,7)
-#define late_initcall_sync(fn)         __define_initcall("7s",fn,7s)
+#define pure_initcall(fn)              __define_initcall(fn, 0)
+
+#define core_initcall(fn)              __define_initcall(fn, 1)
+#define core_initcall_sync(fn)         __define_initcall(fn, 1s)
+#define postcore_initcall(fn)          __define_initcall(fn, 2)
+#define postcore_initcall_sync(fn)     __define_initcall(fn, 2s)
+#define arch_initcall(fn)              __define_initcall(fn, 3)
+#define arch_initcall_sync(fn)         __define_initcall(fn, 3s)
+#define subsys_initcall(fn)            __define_initcall(fn, 4)
+#define subsys_initcall_sync(fn)       __define_initcall(fn, 4s)
+#define fs_initcall(fn)                        __define_initcall(fn, 5)
+#define fs_initcall_sync(fn)           __define_initcall(fn, 5s)
+#define rootfs_initcall(fn)            __define_initcall(fn, rootfs)
+#define device_initcall(fn)            __define_initcall(fn, 6)
+#define device_initcall_sync(fn)       __define_initcall(fn, 6s)
+#define late_initcall(fn)              __define_initcall(fn, 7)
+#define late_initcall_sync(fn)         __define_initcall(fn, 7s)
 
 #define __initcall(fn) device_initcall(fn)