Commit c2d46e7b authored by Martin Schwidefsky's avatar Martin Schwidefsky Committed by Greg Kroah-Hartman

s390: correct nospec auto detection init order

[ Upstream commit 6a3d1e81 ]

With CONFIG_EXPOLINE_AUTO=y the call of spectre_v2_auto_early() via
early_initcall is done *after* the early_param functions. This
overwrites any settings done with the nobp/no_spectre_v2/spectre_v2
parameters. The code patching for the kernel is done after the
evaluation of the early parameters but before the early_initcall
is done. The end result is a kernel image that is patched correctly
but the kernel modules are not.

Make sure that the nospec auto detection function is called before the
early parameters are evaluated and before the code patching is done.

Fixes: 6e179d64 ("s390: add automatic detection of the spectre defense")
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 6aa300a0
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
extern int nospec_disable; extern int nospec_disable;
void nospec_init_branches(void); void nospec_init_branches(void);
void nospec_auto_detect(void);
void nospec_revert(s32 *start, s32 *end); void nospec_revert(s32 *start, s32 *end);
#endif /* __ASSEMBLY__ */ #endif /* __ASSEMBLY__ */
......
...@@ -73,7 +73,7 @@ static int __init nospectre_v2_setup_early(char *str) ...@@ -73,7 +73,7 @@ static int __init nospectre_v2_setup_early(char *str)
} }
early_param("nospectre_v2", nospectre_v2_setup_early); early_param("nospectre_v2", nospectre_v2_setup_early);
static int __init spectre_v2_auto_early(void) void __init nospec_auto_detect(void)
{ {
if (IS_ENABLED(CC_USING_EXPOLINE)) { if (IS_ENABLED(CC_USING_EXPOLINE)) {
/* /*
...@@ -88,11 +88,7 @@ static int __init spectre_v2_auto_early(void) ...@@ -88,11 +88,7 @@ static int __init spectre_v2_auto_early(void)
* nobp setting decides what is done, this depends on the * nobp setting decides what is done, this depends on the
* CONFIG_KERNEL_NP option and the nobp/nospec parameters. * CONFIG_KERNEL_NP option and the nobp/nospec parameters.
*/ */
return 0;
} }
#ifdef CONFIG_EXPOLINE_AUTO
early_initcall(spectre_v2_auto_early);
#endif
static int __init spectre_v2_setup_early(char *str) static int __init spectre_v2_setup_early(char *str)
{ {
...@@ -103,7 +99,7 @@ static int __init spectre_v2_setup_early(char *str) ...@@ -103,7 +99,7 @@ static int __init spectre_v2_setup_early(char *str)
if (str && !strncmp(str, "off", 3)) if (str && !strncmp(str, "off", 3))
nospec_disable = 1; nospec_disable = 1;
if (str && !strncmp(str, "auto", 4)) if (str && !strncmp(str, "auto", 4))
spectre_v2_auto_early(); nospec_auto_detect();
return 0; return 0;
} }
early_param("spectre_v2", spectre_v2_setup_early); early_param("spectre_v2", spectre_v2_setup_early);
......
...@@ -846,6 +846,9 @@ void __init setup_arch(char **cmdline_p) ...@@ -846,6 +846,9 @@ void __init setup_arch(char **cmdline_p)
init_mm.end_data = (unsigned long) &_edata; init_mm.end_data = (unsigned long) &_edata;
init_mm.brk = (unsigned long) &_end; init_mm.brk = (unsigned long) &_end;
if (IS_ENABLED(CONFIG_EXPOLINE_AUTO))
nospec_auto_detect();
parse_early_param(); parse_early_param();
os_info_init(); os_info_init();
setup_ipl(); setup_ipl();
......
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