Borislav Petkov 899b6e
From: Peter Zijlstra <peterz@infradead.org>
Borislav Petkov 899b6e
Date: Tue, 14 Jun 2022 23:15:56 +0200
Borislav Petkov 899b6e
Subject: x86/bugs: Split spectre_v2_select_mitigation() and
Borislav Petkov 899b6e
 spectre_v2_user_select_mitigation()
Borislav Petkov 899b6e
Git-commit: 166115c08a9b0b846b783088808a27d739be6e8d
Borislav Petkov d06c64
Patch-mainline: v5.19-rc4
Borislav Petkov 899b6e
References: bsc#1199657 CVE-2022-29900 CVE-2022-29901
Borislav Petkov 899b6e
Borislav Petkov 899b6e
retbleed will depend on spectre_v2, while spectre_v2_user depends on
Borislav Petkov 899b6e
retbleed. Break this cycle.
Borislav Petkov 899b6e
Borislav Petkov 899b6e
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Borislav Petkov 899b6e
Signed-off-by: Borislav Petkov <bp@suse.de>
Borislav Petkov 899b6e
Reviewed-by: Josh Poimboeuf <jpoimboe@kernel.org>
Borislav Petkov 899b6e
Signed-off-by: Borislav Petkov <bp@suse.de>
Borislav Petkov 899b6e
---
Borislav Petkov 899b6e
 arch/x86/kernel/cpu/bugs.c | 25 +++++++++++++++++--------
Borislav Petkov 899b6e
 1 file changed, 17 insertions(+), 8 deletions(-)
Borislav Petkov 899b6e
Borislav Petkov 899b6e
diff --git a/arch/x86/kernel/cpu/bugs.c b/arch/x86/kernel/cpu/bugs.c
Borislav Petkov 899b6e
index 2d7896493220..c546a9e4ed17 100644
Borislav Petkov 899b6e
--- a/arch/x86/kernel/cpu/bugs.c
Borislav Petkov 899b6e
+++ b/arch/x86/kernel/cpu/bugs.c
Borislav Petkov 899b6e
@@ -37,8 +37,9 @@
Borislav Petkov 899b6e
 #include "cpu.h"
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
 static void __init spectre_v1_select_mitigation(void);
Borislav Petkov 899b6e
-static void __init retbleed_select_mitigation(void);
Borislav Petkov 899b6e
 static void __init spectre_v2_select_mitigation(void);
Borislav Petkov 899b6e
+static void __init retbleed_select_mitigation(void);
Borislav Petkov 899b6e
+static void __init spectre_v2_user_select_mitigation(void);
Borislav Petkov 899b6e
 static void __init ssb_select_mitigation(void);
Borislav Petkov 899b6e
 static void __init l1tf_select_mitigation(void);
Borislav Petkov 899b6e
 static void __init mds_select_mitigation(void);
Borislav Petkov 899b6e
@@ -145,13 +146,19 @@ void __init check_bugs(void)
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
 	/* Select the proper CPU mitigations before patching alternatives: */
Borislav Petkov 899b6e
 	spectre_v1_select_mitigation();
Borislav Petkov 899b6e
+	spectre_v2_select_mitigation();
Borislav Petkov 899b6e
+	/*
Borislav Petkov 899b6e
+	 * retbleed_select_mitigation() relies on the state set by
Borislav Petkov 899b6e
+	 * spectre_v2_select_mitigation(); specifically it wants to know about
Borislav Petkov 899b6e
+	 * spectre_v2=ibrs.
Borislav Petkov 899b6e
+	 */
Borislav Petkov 899b6e
 	retbleed_select_mitigation();
Borislav Petkov 899b6e
 	/*
Borislav Petkov 899b6e
-	 * spectre_v2_select_mitigation() relies on the state set by
Borislav Petkov 899b6e
+	 * spectre_v2_user_select_mitigation() relies on the state set by
Borislav Petkov 899b6e
 	 * retbleed_select_mitigation(); specifically the STIBP selection is
Borislav Petkov 899b6e
 	 * forced for UNRET.
Borislav Petkov 899b6e
 	 */
Borislav Petkov 899b6e
-	spectre_v2_select_mitigation();
Borislav Petkov 899b6e
+	spectre_v2_user_select_mitigation();
Borislav Petkov 899b6e
 	ssb_select_mitigation();
Borislav Petkov 899b6e
 	l1tf_select_mitigation();
Borislav Petkov 899b6e
 	md_clear_select_mitigation();
Borislav Petkov 899b6e
@@ -1013,13 +1020,15 @@ static void __init spec_v2_user_print_cond(const char *reason, bool secure)
Borislav Petkov 899b6e
 		pr_info("spectre_v2_user=%s forced on command line.\n", reason);
Borislav Petkov 899b6e
 }
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
+static __ro_after_init enum spectre_v2_mitigation_cmd spectre_v2_cmd;
Borislav Petkov 899b6e
+
Borislav Petkov 899b6e
 static enum spectre_v2_user_cmd __init
Borislav Petkov 899b6e
-spectre_v2_parse_user_cmdline(enum spectre_v2_mitigation_cmd v2_cmd)
Borislav Petkov 899b6e
+spectre_v2_parse_user_cmdline(void)
Borislav Petkov 899b6e
 {
Borislav Petkov 899b6e
 	char arg[20];
Borislav Petkov 899b6e
 	int ret, i;
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
-	switch (v2_cmd) {
Borislav Petkov 899b6e
+	switch (spectre_v2_cmd) {
Borislav Petkov 899b6e
 	case SPECTRE_V2_CMD_NONE:
Borislav Petkov 899b6e
 		return SPECTRE_V2_USER_CMD_NONE;
Borislav Petkov 899b6e
 	case SPECTRE_V2_CMD_FORCE:
Borislav Petkov 899b6e
@@ -1054,7 +1063,7 @@ static inline bool spectre_v2_in_ibrs_mode(enum spectre_v2_mitigation mode)
Borislav Petkov 899b6e
 }
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
 static void __init
Borislav Petkov 899b6e
-spectre_v2_user_select_mitigation(enum spectre_v2_mitigation_cmd v2_cmd)
Borislav Petkov 899b6e
+spectre_v2_user_select_mitigation(void)
Borislav Petkov 899b6e
 {
Borislav Petkov 899b6e
 	enum spectre_v2_user_mitigation mode = SPECTRE_V2_USER_NONE;
Borislav Petkov 899b6e
 	bool smt_possible = IS_ENABLED(CONFIG_SMP);
Borislav Petkov 899b6e
@@ -1067,7 +1076,7 @@ spectre_v2_user_select_mitigation(enum spectre_v2_mitigation_cmd v2_cmd)
Borislav Petkov 899b6e
 	    cpu_smt_control == CPU_SMT_NOT_SUPPORTED)
Borislav Petkov 899b6e
 		smt_possible = false;
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
-	cmd = spectre_v2_parse_user_cmdline(v2_cmd);
Borislav Petkov 899b6e
+	cmd = spectre_v2_parse_user_cmdline();
Borislav Petkov 899b6e
 	switch (cmd) {
Borislav Petkov 899b6e
 	case SPECTRE_V2_USER_CMD_NONE:
Borislav Petkov 899b6e
 		goto set_mode;
Borislav Petkov 899b6e
@@ -1391,7 +1400,7 @@ static void __init spectre_v2_select_mitigation(void)
Borislav Petkov 899b6e
 	}
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
 	/* Set up IBPB and STIBP depending on the general spectre V2 command */
Borislav Petkov 899b6e
-	spectre_v2_user_select_mitigation(cmd);
Borislav Petkov 899b6e
+	spectre_v2_cmd = cmd;
Borislav Petkov 899b6e
 }
Borislav Petkov 899b6e
 
Borislav Petkov 899b6e
 static void update_stibp_msr(void * __unused)
Borislav Petkov 899b6e