Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/x86/x86 Add support for EnhancedIBRS, a more perfor...
details: https://anonhg.NetBSD.org/src/rev/ee571a95bb91
branches: trunk
changeset: 998711:ee571a95bb91
user: maxv <maxv%NetBSD.org@localhost>
date: Sat Apr 27 10:40:17 2019 +0000
description:
Add support for EnhancedIBRS, a more performant mitigation for SpectreV2,
available on future CPUs (or maybe they already exist now...).
diffstat:
sys/arch/x86/x86/spectre.c | 38 +++++++++++++++++++++++++++++---------
1 files changed, 29 insertions(+), 9 deletions(-)
diffs (95 lines):
diff -r 77891353f4c2 -r ee571a95bb91 sys/arch/x86/x86/spectre.c
--- a/sys/arch/x86/x86/spectre.c Sat Apr 27 09:06:18 2019 +0000
+++ b/sys/arch/x86/x86/spectre.c Sat Apr 27 10:40:17 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: spectre.c,v 1.25 2019/03/23 10:02:05 maxv Exp $ */
+/* $NetBSD: spectre.c,v 1.26 2019/04/27 10:40:17 maxv Exp $ */
/*
* Copyright (c) 2018 NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: spectre.c,v 1.25 2019/03/23 10:02:05 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: spectre.c,v 1.26 2019/04/27 10:40:17 maxv Exp $");
#include "opt_spectre.h"
@@ -54,7 +54,8 @@
enum v2_mitigation {
V2_MITIGATION_NONE,
V2_MITIGATION_AMD_DIS_IND,
- V2_MITIGATION_INTEL_IBRS
+ V2_MITIGATION_INTEL_IBRS,
+ V2_MITIGATION_INTEL_ENHANCED_IBRS
};
enum v4_mitigation {
@@ -102,6 +103,9 @@
case V2_MITIGATION_INTEL_IBRS:
strlcat(name, "[Intel IBRS]", sizeof(name));
break;
+ case V2_MITIGATION_INTEL_ENHANCED_IBRS:
+ strlcat(name, "[Intel Enhanced IBRS]", sizeof(name));
+ break;
default:
panic("%s: impossible", __func__);
}
@@ -116,20 +120,26 @@
{
struct cpu_info *ci = curcpu();
u_int descs[4];
+ uint64_t msr;
if (cpu_vendor == CPUVENDOR_INTEL) {
if (cpuid_level >= 7) {
x86_cpuid(7, descs);
+
+ if (descs[3] & CPUID_SEF_ARCH_CAP) {
+ msr = rdmsr(MSR_IA32_ARCH_CAPABILITIES);
+ if (msr & IA32_ARCH_IBRS_ALL) {
+ v2_mitigation_method =
+ V2_MITIGATION_INTEL_ENHANCED_IBRS;
+ return;
+ }
+ }
+#ifdef __x86_64__
if (descs[3] & CPUID_SEF_IBRS) {
- /* descs[3] = %edx */
-#ifdef __x86_64__
v2_mitigation_method = V2_MITIGATION_INTEL_IBRS;
-#else
- /* IBRS not supported on i386. */
- v2_mitigation_method = V2_MITIGATION_NONE;
-#endif
return;
}
+#endif
}
v2_mitigation_method = V2_MITIGATION_NONE;
} else if (cpu_vendor == CPUVENDOR_AMD) {
@@ -239,6 +249,15 @@
wrmsr(MSR_IA32_SPEC_CTRL, 0);
}
break;
+ case V2_MITIGATION_INTEL_ENHANCED_IBRS:
+ msr = rdmsr(MSR_IA32_SPEC_CTRL);
+ if (enabled) {
+ msr |= IA32_SPEC_CTRL_IBRS;
+ } else {
+ msr &= ~IA32_SPEC_CTRL_IBRS;
+ }
+ wrmsr(MSR_IA32_SPEC_CTRL, msr);
+ break;
case V2_MITIGATION_AMD_DIS_IND:
msr = rdmsr(MSR_IC_CFG);
if (enabled) {
@@ -302,6 +321,7 @@
return EOPNOTSUPP;
case V2_MITIGATION_AMD_DIS_IND:
case V2_MITIGATION_INTEL_IBRS:
+ case V2_MITIGATION_INTEL_ENHANCED_IBRS:
/* Initialize the barriers */
ibrs_cpu_barrier1 = ncpu;
ibrs_cpu_barrier2 = ncpu;
Home |
Main Index |
Thread Index |
Old Index