]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
x86/bugs: Clarify that syscall hardening isn't a BHI mitigation
authorJosh Poimboeuf <jpoimboe@kernel.org>
Thu, 11 Apr 2024 05:40:48 +0000 (22:40 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 Apr 2024 09:15:17 +0000 (11:15 +0200)
commit 5f882f3b0a8bf0788d5a0ee44b1191de5319bb8a upstream.

While syscall hardening helps prevent some BHI attacks, there's still
other low-hanging fruit remaining.  Don't classify it as a mitigation
and make it clear that the system may still be vulnerable if it doesn't
have a HW or SW mitigation enabled.

Fixes: ec9404e40e8f ("x86/bhi: Add BHI mitigation knob")
Signed-off-by: Josh Poimboeuf <jpoimboe@kernel.org>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Sean Christopherson <seanjc@google.com>
Link: https://lore.kernel.org/r/b5951dae3fdee7f1520d5136a27be3bdfe95f88b.1712813475.git.jpoimboe@kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Documentation/admin-guide/hw-vuln/spectre.rst
Documentation/admin-guide/kernel-parameters.txt
arch/x86/kernel/cpu/bugs.c

index 06b27317638ae5db8450b6a3535d2cdce56fabc2..22492b75ff42a447f6dfb755056896e00e9d4008 100644 (file)
@@ -441,10 +441,10 @@ The possible values in this file are:
    - System is protected by BHI_DIS_S
  * - BHI: SW loop, KVM SW loop
    - System is protected by software clearing sequence
- * - BHI: Syscall hardening
-   - Syscalls are hardened against BHI
- * - BHI: Syscall hardening, KVM: SW loop
-   - System is protected from userspace attacks by syscall hardening; KVM is protected by software clearing sequence
+ * - BHI: Vulnerable
+   - System is vulnerable to BHI
+ * - BHI: Vulnerable, KVM: SW loop
+   - System is vulnerable; KVM is protected by software clearing sequence
 
 Full mitigation might require a microcode update from the CPU
 vendor. When the necessary microcode is not available, the kernel will
@@ -711,8 +711,7 @@ For user space mitigation:
        spectre_bhi=
 
                [X86] Control mitigation of Branch History Injection
-               (BHI) vulnerability. Syscalls are hardened against BHI
-               regardless of this setting. This setting affects the deployment
+               (BHI) vulnerability.  This setting affects the deployment
                of the HW BHI control and the SW BHB clearing sequence.
 
                on
index 0c63b64304c9d382320810394e610558a7c2e610..2ff2e5056c9759770852875cbb86033cafa210f3 100644 (file)
                        See Documentation/admin-guide/laptops/sonypi.rst
 
        spectre_bhi=    [X86] Control mitigation of Branch History Injection
-                       (BHI) vulnerability. Syscalls are hardened against BHI
-                       reglardless of this setting. This setting affects the
+                       (BHI) vulnerability.  This setting affects the
                        deployment of the HW BHI control and the SW BHB
                        clearing sequence.
 
index 0a40b4a7de2c30b56a42f58139bae931e2ecabb4..dafb854603f00ac529dc52fbbc13e60f77e3e643 100644 (file)
@@ -2797,10 +2797,10 @@ static const char *spectre_bhi_state(void)
                return "; BHI: SW loop, KVM: SW loop";
        else if (boot_cpu_has(X86_FEATURE_RETPOLINE) && rrsba_disabled)
                return "; BHI: Retpoline";
-       else if  (boot_cpu_has(X86_FEATURE_CLEAR_BHB_LOOP_ON_VMEXIT))
-               return "; BHI: Syscall hardening, KVM: SW loop";
+       else if (boot_cpu_has(X86_FEATURE_CLEAR_BHB_LOOP_ON_VMEXIT))
+               return "; BHI: Vulnerable, KVM: SW loop";
 
-       return "; BHI: Vulnerable (Syscall hardening enabled)";
+       return "; BHI: Vulnerable";
 }
 
 static ssize_t spectre_v2_show_state(char *buf)