Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-8]: src/sys/arch/x86/x86 Pull up the following revisions, request...
details: https://anonhg.NetBSD.org/src/rev/73527ac8024c
branches: netbsd-8
changeset: 851549:73527ac8024c
user: martin <martin%NetBSD.org@localhost>
date: Mon Apr 02 08:43:58 2018 +0000
description:
Pull up the following revisions, requested by maxv in ticket #683:
sys/arch/x86/x86/svs.c 1.15-1.17
Fix sysctl type, should be bool.
Use EOPNOTSUPP instead of EINVAL.
Improve the detection. Future generations of Intel CPUs will have a bit to
say they are not affected by Meltdown.
diffstat:
sys/arch/x86/x86/svs.c | 27 ++++++++++++++++++++++-----
1 files changed, 22 insertions(+), 5 deletions(-)
diffs (65 lines):
diff -r de75de4b110a -r 73527ac8024c sys/arch/x86/x86/svs.c
--- a/sys/arch/x86/x86/svs.c Sun Apr 01 09:02:51 2018 +0000
+++ b/sys/arch/x86/x86/svs.c Mon Apr 02 08:43:58 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: svs.c,v 1.14.2.2 2018/03/22 16:59:04 martin Exp $ */
+/* $NetBSD: svs.c,v 1.14.2.3 2018/04/02 08:43:58 martin Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: svs.c,v 1.14.2.2 2018/03/22 16:59:04 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: svs.c,v 1.14.2.3 2018/04/02 08:43:58 martin Exp $");
#include "opt_svs.h"
@@ -720,9 +720,10 @@
sysctl_machdep_svs_enabled(SYSCTLFN_ARGS)
{
struct sysctlnode node;
- int error, val;
+ int error;
+ bool val;
- val = *(int *)rnode->sysctl_data;
+ val = *(bool *)rnode->sysctl_data;
node = *rnode;
node.sysctl_data = &val;
@@ -732,7 +733,10 @@
return error;
if (val == 1) {
- error = EINVAL;
+ if (svs_enabled)
+ error = 0;
+ else
+ error = EOPNOTSUPP;
} else {
if (svs_enabled)
error = svs_disable();
@@ -746,8 +750,21 @@
void
svs_init(void)
{
+ uint64_t msr;
+
if (cpu_vendor != CPUVENDOR_INTEL) {
return;
}
+ if (cpu_info_primary.ci_feat_val[7] & CPUID_SEF_ARCH_CAP) {
+ msr = rdmsr(MSR_IA32_ARCH_CAPABILITIES);
+ if (msr & IA32_ARCH_RDCL_NO) {
+ /*
+ * The processor indicates it is not vulnerable to the
+ * Rogue Data Cache Load (Meltdown) flaw.
+ */
+ return;
+ }
+ }
+
svs_enable();
}
Home |
Main Index |
Thread Index |
Old Index