aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2021-08-09 17:28:08 +0000
committerMark Johnston <markj@FreeBSD.org>2021-08-16 13:01:29 +0000
commited03d05824982738335ea8273b0e5a5f020ba100 (patch)
tree29d04d9ab352b247dd558bec8e65610be902f1f1
parent034eea1ee5dd25c6a3ff2ce544a990fdd04458fb (diff)
downloadsrc-ed03d05824982738335ea8273b0e5a5f020ba100.tar.gz
src-ed03d05824982738335ea8273b0e5a5f020ba100.zip
amd64: Fix output operand specs for the stmxcsr and vmread intrinsics
This does not appear to affect code generation, at least with the default toolchain. Noticed because incorrect output specifications lead to false positives from KMSAN, as the instrumentation uses them to update shadow state for output operands. Reviewed by: kib Sponsored by: The FreeBSD Foundation (cherry picked from commit e54ae8258d6433ad2f2411dbeaa1fde6b817d5ef)
-rw-r--r--sys/amd64/amd64/fpu.c2
-rw-r--r--sys/amd64/vmm/intel/vmx_cpufunc.h5
2 files changed, 3 insertions, 4 deletions
diff --git a/sys/amd64/amd64/fpu.c b/sys/amd64/amd64/fpu.c
index 20e3dd34405d..d7936b3b1922 100644
--- a/sys/amd64/amd64/fpu.c
+++ b/sys/amd64/amd64/fpu.c
@@ -79,7 +79,7 @@ __FBSDID("$FreeBSD$");
#define fxrstor(addr) __asm __volatile("fxrstor %0" : : "m" (*(addr)))
#define fxsave(addr) __asm __volatile("fxsave %0" : "=m" (*(addr)))
#define ldmxcsr(csr) __asm __volatile("ldmxcsr %0" : : "m" (csr))
-#define stmxcsr(addr) __asm __volatile("stmxcsr %0" : : "m" (*(addr)))
+#define stmxcsr(addr) __asm __volatile("stmxcsr %0" : "=m" (*(addr)))
static __inline void
xrstor32(char *addr, uint64_t mask)
diff --git a/sys/amd64/vmm/intel/vmx_cpufunc.h b/sys/amd64/vmm/intel/vmx_cpufunc.h
index 09d6d25a18e0..05ac56290cb9 100644
--- a/sys/amd64/vmm/intel/vmx_cpufunc.h
+++ b/sys/amd64/vmm/intel/vmx_cpufunc.h
@@ -137,10 +137,9 @@ vmread(uint64_t r, uint64_t *addr)
__asm __volatile("vmread %[r], %[addr];"
VMX_SET_ERROR_CODE
- : [error] "=r" (error)
- : [r] "r" (r), [addr] "m" (*addr)
+ : [error] "=r" (error), [addr] "=m" (*addr)
+ : [r] "r" (r)
: "memory");
-
return (error);
}