arch: split MODULE_ARCH_VERMAGIC definitions out to <asm/vermagic.h>
As the bug report [1] pointed out, <linux/vermagic.h> must be included
after <linux/module.h>.
I believe we should not impose any include order restriction. We often
sort include directives alphabetically, but it is just coding style
convention. Technically, we can include header files in any order by
making every header self-contained.
Currently, arch-specific MODULE_ARCH_VERMAGIC is defined in
<asm/module.h>, which is not included from <linux/vermagic.h>.
Hence, the straight-forward fix-up would be as follows:
|--- a/include/linux/vermagic.h
|+++ b/include/linux/vermagic.h
|@@ -1,5 +1,6 @@
| /* SPDX-License-Identifier: GPL-2.0 */
| #include <generated/utsrelease.h>
|+#include <linux/module.h>
|
| /* Simply sanity version stamp for modules. */
| #ifdef CONFIG_SMP
This works enough, but for further cleanups, I split MODULE_ARCH_VERMAGIC
definitions into <asm/vermagic.h>.
With this, <linux/module.h> and <linux/vermagic.h> will be orthogonal,
and the location of MODULE_ARCH_VERMAGIC definitions will be consistent.
For arc and ia64, MODULE_PROC_FAMILY is only used for defining
MODULE_ARCH_VERMAGIC. I squashed it.
For hexagon, nds32, and xtensa, I removed <asm/modules.h> entirely
because they contained nothing but MODULE_ARCH_VERMAGIC definition.
Kbuild will automatically generate <asm/modules.h> at build-time,
wrapping <asm-generic/module.h>.
[1] https://lore.kernel.org/lkml/20200411155623.GA22175@zn.tnic
Reported-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Acked-by: Jessica Yu <jeyu@kernel.org>
2020-04-22 00:13:55 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef _ASM_VERMAGIC_H
|
|
|
|
#define _ASM_VERMAGIC_H
|
|
|
|
|
|
|
|
#ifdef CONFIG_CPU_BMIPS
|
|
|
|
#define MODULE_PROC_FAMILY "BMIPS "
|
|
|
|
#elif defined CONFIG_CPU_MIPS32_R1
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS32_R1 "
|
|
|
|
#elif defined CONFIG_CPU_MIPS32_R2
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS32_R2 "
|
2020-06-04 04:32:21 +08:00
|
|
|
#elif defined CONFIG_CPU_MIPS32_R5
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS32_R5 "
|
arch: split MODULE_ARCH_VERMAGIC definitions out to <asm/vermagic.h>
As the bug report [1] pointed out, <linux/vermagic.h> must be included
after <linux/module.h>.
I believe we should not impose any include order restriction. We often
sort include directives alphabetically, but it is just coding style
convention. Technically, we can include header files in any order by
making every header self-contained.
Currently, arch-specific MODULE_ARCH_VERMAGIC is defined in
<asm/module.h>, which is not included from <linux/vermagic.h>.
Hence, the straight-forward fix-up would be as follows:
|--- a/include/linux/vermagic.h
|+++ b/include/linux/vermagic.h
|@@ -1,5 +1,6 @@
| /* SPDX-License-Identifier: GPL-2.0 */
| #include <generated/utsrelease.h>
|+#include <linux/module.h>
|
| /* Simply sanity version stamp for modules. */
| #ifdef CONFIG_SMP
This works enough, but for further cleanups, I split MODULE_ARCH_VERMAGIC
definitions into <asm/vermagic.h>.
With this, <linux/module.h> and <linux/vermagic.h> will be orthogonal,
and the location of MODULE_ARCH_VERMAGIC definitions will be consistent.
For arc and ia64, MODULE_PROC_FAMILY is only used for defining
MODULE_ARCH_VERMAGIC. I squashed it.
For hexagon, nds32, and xtensa, I removed <asm/modules.h> entirely
because they contained nothing but MODULE_ARCH_VERMAGIC definition.
Kbuild will automatically generate <asm/modules.h> at build-time,
wrapping <asm-generic/module.h>.
[1] https://lore.kernel.org/lkml/20200411155623.GA22175@zn.tnic
Reported-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Acked-by: Jessica Yu <jeyu@kernel.org>
2020-04-22 00:13:55 +08:00
|
|
|
#elif defined CONFIG_CPU_MIPS32_R6
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS32_R6 "
|
|
|
|
#elif defined CONFIG_CPU_MIPS64_R1
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS64_R1 "
|
|
|
|
#elif defined CONFIG_CPU_MIPS64_R2
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS64_R2 "
|
2020-06-04 04:32:21 +08:00
|
|
|
#elif defined CONFIG_CPU_MIPS64_R5
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS64_R5 "
|
arch: split MODULE_ARCH_VERMAGIC definitions out to <asm/vermagic.h>
As the bug report [1] pointed out, <linux/vermagic.h> must be included
after <linux/module.h>.
I believe we should not impose any include order restriction. We often
sort include directives alphabetically, but it is just coding style
convention. Technically, we can include header files in any order by
making every header self-contained.
Currently, arch-specific MODULE_ARCH_VERMAGIC is defined in
<asm/module.h>, which is not included from <linux/vermagic.h>.
Hence, the straight-forward fix-up would be as follows:
|--- a/include/linux/vermagic.h
|+++ b/include/linux/vermagic.h
|@@ -1,5 +1,6 @@
| /* SPDX-License-Identifier: GPL-2.0 */
| #include <generated/utsrelease.h>
|+#include <linux/module.h>
|
| /* Simply sanity version stamp for modules. */
| #ifdef CONFIG_SMP
This works enough, but for further cleanups, I split MODULE_ARCH_VERMAGIC
definitions into <asm/vermagic.h>.
With this, <linux/module.h> and <linux/vermagic.h> will be orthogonal,
and the location of MODULE_ARCH_VERMAGIC definitions will be consistent.
For arc and ia64, MODULE_PROC_FAMILY is only used for defining
MODULE_ARCH_VERMAGIC. I squashed it.
For hexagon, nds32, and xtensa, I removed <asm/modules.h> entirely
because they contained nothing but MODULE_ARCH_VERMAGIC definition.
Kbuild will automatically generate <asm/modules.h> at build-time,
wrapping <asm-generic/module.h>.
[1] https://lore.kernel.org/lkml/20200411155623.GA22175@zn.tnic
Reported-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Acked-by: Jessica Yu <jeyu@kernel.org>
2020-04-22 00:13:55 +08:00
|
|
|
#elif defined CONFIG_CPU_MIPS64_R6
|
|
|
|
#define MODULE_PROC_FAMILY "MIPS64_R6 "
|
|
|
|
#elif defined CONFIG_CPU_R3000
|
|
|
|
#define MODULE_PROC_FAMILY "R3000 "
|
2021-01-13 23:10:07 +08:00
|
|
|
#elif defined CONFIG_CPU_R4300
|
|
|
|
#define MODULE_PROC_FAMILY "R4300 "
|
arch: split MODULE_ARCH_VERMAGIC definitions out to <asm/vermagic.h>
As the bug report [1] pointed out, <linux/vermagic.h> must be included
after <linux/module.h>.
I believe we should not impose any include order restriction. We often
sort include directives alphabetically, but it is just coding style
convention. Technically, we can include header files in any order by
making every header self-contained.
Currently, arch-specific MODULE_ARCH_VERMAGIC is defined in
<asm/module.h>, which is not included from <linux/vermagic.h>.
Hence, the straight-forward fix-up would be as follows:
|--- a/include/linux/vermagic.h
|+++ b/include/linux/vermagic.h
|@@ -1,5 +1,6 @@
| /* SPDX-License-Identifier: GPL-2.0 */
| #include <generated/utsrelease.h>
|+#include <linux/module.h>
|
| /* Simply sanity version stamp for modules. */
| #ifdef CONFIG_SMP
This works enough, but for further cleanups, I split MODULE_ARCH_VERMAGIC
definitions into <asm/vermagic.h>.
With this, <linux/module.h> and <linux/vermagic.h> will be orthogonal,
and the location of MODULE_ARCH_VERMAGIC definitions will be consistent.
For arc and ia64, MODULE_PROC_FAMILY is only used for defining
MODULE_ARCH_VERMAGIC. I squashed it.
For hexagon, nds32, and xtensa, I removed <asm/modules.h> entirely
because they contained nothing but MODULE_ARCH_VERMAGIC definition.
Kbuild will automatically generate <asm/modules.h> at build-time,
wrapping <asm-generic/module.h>.
[1] https://lore.kernel.org/lkml/20200411155623.GA22175@zn.tnic
Reported-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Acked-by: Jessica Yu <jeyu@kernel.org>
2020-04-22 00:13:55 +08:00
|
|
|
#elif defined CONFIG_CPU_R4X00
|
|
|
|
#define MODULE_PROC_FAMILY "R4X00 "
|
|
|
|
#elif defined CONFIG_CPU_TX49XX
|
|
|
|
#define MODULE_PROC_FAMILY "TX49XX "
|
|
|
|
#elif defined CONFIG_CPU_R5000
|
|
|
|
#define MODULE_PROC_FAMILY "R5000 "
|
|
|
|
#elif defined CONFIG_CPU_R5500
|
|
|
|
#define MODULE_PROC_FAMILY "R5500 "
|
|
|
|
#elif defined CONFIG_CPU_NEVADA
|
|
|
|
#define MODULE_PROC_FAMILY "NEVADA "
|
|
|
|
#elif defined CONFIG_CPU_R10000
|
|
|
|
#define MODULE_PROC_FAMILY "R10000 "
|
|
|
|
#elif defined CONFIG_CPU_RM7000
|
|
|
|
#define MODULE_PROC_FAMILY "RM7000 "
|
|
|
|
#elif defined CONFIG_CPU_SB1
|
|
|
|
#define MODULE_PROC_FAMILY "SB1 "
|
|
|
|
#elif defined CONFIG_CPU_LOONGSON32
|
|
|
|
#define MODULE_PROC_FAMILY "LOONGSON32 "
|
|
|
|
#elif defined CONFIG_CPU_LOONGSON2EF
|
|
|
|
#define MODULE_PROC_FAMILY "LOONGSON2EF "
|
|
|
|
#elif defined CONFIG_CPU_LOONGSON64
|
|
|
|
#define MODULE_PROC_FAMILY "LOONGSON64 "
|
|
|
|
#elif defined CONFIG_CPU_CAVIUM_OCTEON
|
|
|
|
#define MODULE_PROC_FAMILY "OCTEON "
|
2020-06-04 04:32:21 +08:00
|
|
|
#elif defined CONFIG_CPU_P5600
|
|
|
|
#define MODULE_PROC_FAMILY "P5600 "
|
arch: split MODULE_ARCH_VERMAGIC definitions out to <asm/vermagic.h>
As the bug report [1] pointed out, <linux/vermagic.h> must be included
after <linux/module.h>.
I believe we should not impose any include order restriction. We often
sort include directives alphabetically, but it is just coding style
convention. Technically, we can include header files in any order by
making every header self-contained.
Currently, arch-specific MODULE_ARCH_VERMAGIC is defined in
<asm/module.h>, which is not included from <linux/vermagic.h>.
Hence, the straight-forward fix-up would be as follows:
|--- a/include/linux/vermagic.h
|+++ b/include/linux/vermagic.h
|@@ -1,5 +1,6 @@
| /* SPDX-License-Identifier: GPL-2.0 */
| #include <generated/utsrelease.h>
|+#include <linux/module.h>
|
| /* Simply sanity version stamp for modules. */
| #ifdef CONFIG_SMP
This works enough, but for further cleanups, I split MODULE_ARCH_VERMAGIC
definitions into <asm/vermagic.h>.
With this, <linux/module.h> and <linux/vermagic.h> will be orthogonal,
and the location of MODULE_ARCH_VERMAGIC definitions will be consistent.
For arc and ia64, MODULE_PROC_FAMILY is only used for defining
MODULE_ARCH_VERMAGIC. I squashed it.
For hexagon, nds32, and xtensa, I removed <asm/modules.h> entirely
because they contained nothing but MODULE_ARCH_VERMAGIC definition.
Kbuild will automatically generate <asm/modules.h> at build-time,
wrapping <asm-generic/module.h>.
[1] https://lore.kernel.org/lkml/20200411155623.GA22175@zn.tnic
Reported-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Acked-by: Jessica Yu <jeyu@kernel.org>
2020-04-22 00:13:55 +08:00
|
|
|
#else
|
|
|
|
#error MODULE_PROC_FAMILY undefined for your processor configuration
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_32BIT
|
|
|
|
#define MODULE_KERNEL_TYPE "32BIT "
|
|
|
|
#elif defined CONFIG_64BIT
|
|
|
|
#define MODULE_KERNEL_TYPE "64BIT "
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define MODULE_ARCH_VERMAGIC \
|
|
|
|
MODULE_PROC_FAMILY MODULE_KERNEL_TYPE
|
|
|
|
|
|
|
|
#endif /* _ASM_VERMAGIC_H */
|