arm: don't use module_init in non-modular mach-vexpress/spc.c code
authorPaul Gortmaker <paul.gortmaker@windriver.com>
Sat, 2 May 2015 00:05:49 +0000 (20:05 -0400)
committerPaul Gortmaker <paul.gortmaker@windriver.com>
Tue, 16 Jun 2015 18:12:29 +0000 (14:12 -0400)
The spc.o is built for ARCH_VEXPRESS_SPC -- which is bool, and hence
this code is either present or absent.  It will never be modular,
so using module_init as an alias for __initcall can be somewhat
misleading.

Fix this up now, so that we can relocate module_init from
init.h into module.h in the future.  If we don't do this, we'd
have to add module.h to obviously non-modular code, and that
would be a worse thing.

Note that direct use of __initcall is discouraged, vs. one
of the priority categorized subgroups.  As __initcall gets
mapped onto device_initcall, our use of device_initcall
directly in this change means that the runtime impact is
zero -- it will remain at level 6 in initcall ordering.

Cc: Russell King <linux@arm.linux.org.uk>
Cc: linux-arm-kernel@lists.infradead.org
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
arch/arm/mach-vexpress/spc.c

index f61158c6ce7185a3b30ef396116a7fc2d74b3c72..5766ce2be32bbd28452c95ea9e43e92de0f4dcb0 100644 (file)
@@ -589,4 +589,4 @@ static int __init ve_spc_clk_init(void)
        platform_device_register_simple("vexpress-spc-cpufreq", -1, NULL, 0);
        return 0;
 }
-module_init(ve_spc_clk_init);
+device_initcall(ve_spc_clk_init);