[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 3/9] util: Add i386 CPUINFO_ATOMIC_VMOVDQU
|
From: |
Richard Henderson |
|
Subject: |
[PATCH 3/9] util: Add i386 CPUINFO_ATOMIC_VMOVDQU |
|
Date: |
Wed, 17 May 2023 21:40:52 -0700 |
Add a bit to indicate when VMOVDQU is also atomic if aligned.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
include/host/i386/cpuinfo.h | 1 +
util/cpuinfo-i386.c | 4 +++-
2 files changed, 4 insertions(+), 1 deletion(-)
diff --git a/include/host/i386/cpuinfo.h b/include/host/i386/cpuinfo.h
index e6f7461378..a6537123cf 100644
--- a/include/host/i386/cpuinfo.h
+++ b/include/host/i386/cpuinfo.h
@@ -25,6 +25,7 @@
#define CPUINFO_AVX512DQ (1u << 14)
#define CPUINFO_AVX512VBMI2 (1u << 15)
#define CPUINFO_ATOMIC_VMOVDQA (1u << 16)
+#define CPUINFO_ATOMIC_VMOVDQU (1u << 17)
/* Initialized with a constructor. */
extern unsigned cpuinfo;
diff --git a/util/cpuinfo-i386.c b/util/cpuinfo-i386.c
index cb9475c688..b72374362f 100644
--- a/util/cpuinfo-i386.c
+++ b/util/cpuinfo-i386.c
@@ -77,8 +77,10 @@ unsigned __attribute__((constructor)) cpuinfo_init(void)
* See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=104688
*/
__cpuid(0, a, b, c, d);
- if (c == signature_INTEL_ecx || c == signature_AMD_ecx) {
+ if (c == signature_INTEL_ecx) {
info |= CPUINFO_ATOMIC_VMOVDQA;
+ } else if (c == signature_AMD_ecx) {
+ info |= CPUINFO_ATOMIC_VMOVDQA | CPUINFO_ATOMIC_VMOVDQU;
}
}
}
--
2.34.1
- [PATCH 0/9] Host-specific includes, begin cpuinfo.h, Richard Henderson, 2023/05/18
- [PATCH 1/9] util: Introduce host-specific cpuinfo.h, Richard Henderson, 2023/05/18
- [PATCH 3/9] util: Add i386 CPUINFO_ATOMIC_VMOVDQU,
Richard Henderson <=
- [PATCH 2/9] util: Add cpuinfo-i386.c, Richard Henderson, 2023/05/18
- [PATCH 6/9] migration/xbzrle: Shuffle function order, Richard Henderson, 2023/05/18
- [PATCH 4/9] tcg/i386: Use cpuinfo.h, Richard Henderson, 2023/05/18
- [PATCH 9/9] util: Add cpuinfo-aarch64.c, Richard Henderson, 2023/05/18