diff options
author | Mark Johnston <markj@FreeBSD.org> | 2021-08-09 17:28:08 +0000 |
---|---|---|
committer | Mark Johnston <markj@FreeBSD.org> | 2021-08-09 17:28:08 +0000 |
commit | e54ae8258d6433ad2f2411dbeaa1fde6b817d5ef (patch) | |
tree | 88c85edf039cc221dc0515b4586fb128d476bfd6 | |
parent | e0cc5660351834c999b64c0606c320a2ea474d01 (diff) | |
download | src-e54ae8258d6433ad2f2411dbeaa1fde6b817d5ef.tar.gz src-e54ae8258d6433ad2f2411dbeaa1fde6b817d5ef.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
MFC after: 1 week
Sponsored by: The FreeBSD Foundation
Differential Revision: https://reviews.freebsd.org/D31466
-rw-r--r-- | sys/amd64/amd64/fpu.c | 2 | ||||
-rw-r--r-- | sys/amd64/vmm/intel/vmx_cpufunc.h | 5 |
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); } |