Commit 7d0c5020 authored by Hendrik Brueckner's avatar Hendrik Brueckner Committed by Martin Schwidefsky

cpufeature: correctly annotate the module init function

A section mismatch warning is reported if an __init annotated function is
specified for module_cpu_feature_match().
Change the module_cpu_feature_match() function and annotate the generated
cpu_feature_match_* function as __init.
Signed-off-by: default avatarHendrik Brueckner <brueckner@linux.vnet.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent 9977e886
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#ifdef CONFIG_GENERIC_CPU_AUTOPROBE #ifdef CONFIG_GENERIC_CPU_AUTOPROBE
#include <linux/init.h>
#include <linux/mod_devicetable.h> #include <linux/mod_devicetable.h>
#include <asm/cpufeature.h> #include <asm/cpufeature.h>
...@@ -43,16 +44,16 @@ ...@@ -43,16 +44,16 @@
* For a list of legal values for 'feature', please consult the file * For a list of legal values for 'feature', please consult the file
* 'asm/cpufeature.h' of your favorite architecture. * 'asm/cpufeature.h' of your favorite architecture.
*/ */
#define module_cpu_feature_match(x, __init) \ #define module_cpu_feature_match(x, __initfunc) \
static struct cpu_feature const cpu_feature_match_ ## x[] = \ static struct cpu_feature const cpu_feature_match_ ## x[] = \
{ { .feature = cpu_feature(x) }, { } }; \ { { .feature = cpu_feature(x) }, { } }; \
MODULE_DEVICE_TABLE(cpu, cpu_feature_match_ ## x); \ MODULE_DEVICE_TABLE(cpu, cpu_feature_match_ ## x); \
\ \
static int cpu_feature_match_ ## x ## _init(void) \ static int __init cpu_feature_match_ ## x ## _init(void) \
{ \ { \
if (!cpu_have_feature(cpu_feature(x))) \ if (!cpu_have_feature(cpu_feature(x))) \
return -ENODEV; \ return -ENODEV; \
return __init(); \ return __initfunc(); \
} \ } \
module_init(cpu_feature_match_ ## x ## _init) module_init(cpu_feature_match_ ## x ## _init)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment