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