Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/nvmm/x86 The TLB flush IPIs do not respect the IPL, ...
details: https://anonhg.NetBSD.org/src/rev/953198f8e662
branches: trunk
changeset: 973942:953198f8e662
user: maxv <maxv%NetBSD.org@localhost>
date: Sun Jul 19 06:36:37 2020 +0000
description:
The TLB flush IPIs do not respect the IPL, so enforcing IPL_HIGH has no
effect. Disable interrupts earlier instead. This prevents a possible race
against such IPIs.
diffstat:
sys/dev/nvmm/x86/nvmm_x86_svm.c | 22 +++++++++++++++++-----
sys/dev/nvmm/x86/nvmm_x86_svmfunc.S | 10 ++--------
sys/dev/nvmm/x86/nvmm_x86_vmx.c | 22 +++++++++++++++++-----
sys/dev/nvmm/x86/nvmm_x86_vmxfunc.S | 15 ++-------------
4 files changed, 38 insertions(+), 31 deletions(-)
diffs (216 lines):
diff -r cc4c28bf458b -r 953198f8e662 sys/dev/nvmm/x86/nvmm_x86_svm.c
--- a/sys/dev/nvmm/x86/nvmm_x86_svm.c Sun Jul 19 06:31:13 2020 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_svm.c Sun Jul 19 06:36:37 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm_x86_svm.c,v 1.63 2020/07/03 16:09:54 maxv Exp $ */
+/* $NetBSD: nvmm_x86_svm.c,v 1.64 2020/07/19 06:36:37 maxv Exp $ */
/*
* Copyright (c) 2018-2020 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_svm.c,v 1.63 2020/07/03 16:09:54 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_svm.c,v 1.64 2020/07/19 06:36:37 maxv Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -56,6 +56,18 @@
int svm_vmrun(paddr_t, uint64_t *);
+static inline void
+svm_clgi(void)
+{
+ asm volatile ("clgi" ::: "memory");
+}
+
+static inline void
+svm_stgi(void)
+{
+ asm volatile ("stgi" ::: "memory");
+}
+
#define MSR_VM_HSAVE_PA 0xC0010117
/* -------------------------------------------------------------------------- */
@@ -1347,7 +1359,7 @@
struct svm_cpudata *cpudata = vcpu->cpudata;
struct vmcb *vmcb = cpudata->vmcb;
uint64_t machgen;
- int hcpu, s;
+ int hcpu;
if (__predict_false(svm_vcpu_event_commit(vcpu) != 0)) {
return EINVAL;
@@ -1382,11 +1394,11 @@
svm_vmcb_cache_flush(vmcb, VMCB_CTRL_VMCB_CLEAN_I);
}
- s = splhigh();
+ svm_clgi();
machgen = svm_htlb_flush(machdata, cpudata);
svm_vmrun(cpudata->vmcb_pa, cpudata->gprs);
svm_htlb_flush_ack(cpudata, machgen);
- splx(s);
+ svm_stgi();
svm_vmcb_cache_default(vmcb);
diff -r cc4c28bf458b -r 953198f8e662 sys/dev/nvmm/x86/nvmm_x86_svmfunc.S
--- a/sys/dev/nvmm/x86/nvmm_x86_svmfunc.S Sun Jul 19 06:31:13 2020 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_svmfunc.S Sun Jul 19 06:36:37 2020 +0000
@@ -1,7 +1,7 @@
-/* $NetBSD: nvmm_x86_svmfunc.S,v 1.3 2019/04/24 18:45:15 maxv Exp $ */
+/* $NetBSD: nvmm_x86_svmfunc.S,v 1.4 2020/07/19 06:36:37 maxv Exp $ */
/*
- * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * Copyright (c) 2018-2020 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
@@ -136,9 +136,6 @@
/* Save the Host GPRs. */
HOST_SAVE_GPRS
- /* Disable Host interrupts. */
- clgi
-
/* Save the Host TR. */
HOST_SAVE_TR
@@ -189,9 +186,6 @@
/* Restore the Host TR. */
HOST_RESTORE_TR
- /* Enable Host interrupts. */
- stgi
-
/* Restore the Host GPRs. */
HOST_RESTORE_GPRS
diff -r cc4c28bf458b -r 953198f8e662 sys/dev/nvmm/x86/nvmm_x86_vmx.c
--- a/sys/dev/nvmm/x86/nvmm_x86_vmx.c Sun Jul 19 06:31:13 2020 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_vmx.c Sun Jul 19 06:36:37 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nvmm_x86_vmx.c,v 1.63 2020/07/18 20:56:53 maxv Exp $ */
+/* $NetBSD: nvmm_x86_vmx.c,v 1.64 2020/07/19 06:36:37 maxv Exp $ */
/*
* Copyright (c) 2018-2020 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_vmx.c,v 1.63 2020/07/18 20:56:53 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nvmm_x86_vmx.c,v 1.64 2020/07/19 06:36:37 maxv Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -178,6 +178,18 @@
);
}
+static inline void
+vmx_cli(void)
+{
+ asm volatile ("cli" ::: "memory");
+}
+
+static inline void
+vmx_sti(void)
+{
+ asm volatile ("sti" ::: "memory");
+}
+
#define MSR_IA32_FEATURE_CONTROL 0x003A
#define IA32_FEATURE_CONTROL_LOCK __BIT(0)
#define IA32_FEATURE_CONTROL_IN_SMX __BIT(1)
@@ -2043,7 +2055,7 @@
uint64_t exitcode;
uint64_t intstate;
uint64_t machgen;
- int hcpu, s, ret;
+ int hcpu, ret;
bool launched;
vmx_vmcs_enter(vcpu);
@@ -2088,7 +2100,7 @@
cpudata->gtsc_want_update = false;
}
- s = splhigh();
+ vmx_cli();
machgen = vmx_htlb_flush(machdata, cpudata);
lcr2(cpudata->gcr2);
if (launched) {
@@ -2098,7 +2110,7 @@
}
cpudata->gcr2 = rcr2();
vmx_htlb_flush_ack(cpudata, machgen);
- splx(s);
+ vmx_sti();
if (__predict_false(ret != 0)) {
vmx_exit_invalid(exit, -1);
diff -r cc4c28bf458b -r 953198f8e662 sys/dev/nvmm/x86/nvmm_x86_vmxfunc.S
--- a/sys/dev/nvmm/x86/nvmm_x86_vmxfunc.S Sun Jul 19 06:31:13 2020 +0000
+++ b/sys/dev/nvmm/x86/nvmm_x86_vmxfunc.S Sun Jul 19 06:36:37 2020 +0000
@@ -1,7 +1,7 @@
-/* $NetBSD: nvmm_x86_vmxfunc.S,v 1.3 2019/04/27 08:16:19 maxv Exp $ */
+/* $NetBSD: nvmm_x86_vmxfunc.S,v 1.4 2020/07/19 06:36:37 maxv Exp $ */
/*
- * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * Copyright (c) 2018-2020 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
@@ -150,9 +150,6 @@
/* Save the Host GPRs. */
HOST_SAVE_GPRS
- /* Disable Host interrupts. */
- cli
-
/* Save the Host LDT. */
HOST_SAVE_LDT
@@ -174,7 +171,6 @@
/* Failure. */
addq $8,%rsp
HOST_RESTORE_LDT
- sti
HOST_RESTORE_GPRS
movq $-1,%rax
retq
@@ -187,9 +183,6 @@
/* Save the Host GPRs. */
HOST_SAVE_GPRS
- /* Disable Host interrupts. */
- cli
-
/* Save the Host LDT. */
HOST_SAVE_LDT
@@ -211,7 +204,6 @@
/* Failure. */
addq $8,%rsp
HOST_RESTORE_LDT
- sti
HOST_RESTORE_GPRS
movq $-1,%rax
retq
@@ -232,9 +224,6 @@
/* Restore the Host LDT. */
HOST_RESTORE_LDT
- /* Enable Host interrupts. */
- sti
-
/* Restore the Host GPRs. */
HOST_RESTORE_GPRS
Home |
Main Index |
Thread Index |
Old Index