You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
60 lines
1.8 KiB
60 lines
1.8 KiB
4 months ago
|
From 56498baf2eddf072b9dcab7570febc6ce8f58504 Mon Sep 17 00:00:00 2001
|
||
|
From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= <berrange@redhat.com>
|
||
|
Date: Thu, 29 Jun 2023 17:51:03 +0100
|
||
|
Subject: [PATCH] virt-what-cvm: support alternative cpuid leaf ordering
|
||
|
MIME-Version: 1.0
|
||
|
Content-Type: text/plain; charset=UTF-8
|
||
|
Content-Transfer-Encoding: 8bit
|
||
|
|
||
|
The HyperV CPUID leaf for reporting the vendor string has an
|
||
|
alternative ordering of ecx/edx.
|
||
|
|
||
|
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
|
||
|
(cherry picked from commit 15d3e4a92fd9c1490fb6f86b7ab3a2dff8364837)
|
||
|
---
|
||
|
virt-what-cvm.c | 11 +++++++----
|
||
|
1 file changed, 7 insertions(+), 4 deletions(-)
|
||
|
|
||
|
diff --git a/virt-what-cvm.c b/virt-what-cvm.c
|
||
|
index f1847688b..1e7c50bb0 100644
|
||
|
--- a/virt-what-cvm.c
|
||
|
+++ b/virt-what-cvm.c
|
||
|
@@ -209,11 +209,14 @@ cpuid (uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx)
|
||
|
|
||
|
|
||
|
static uint32_t
|
||
|
-cpuid_leaf (uint32_t eax, char *sig)
|
||
|
+cpuid_leaf (uint32_t eax, char *sig, bool swapped)
|
||
|
{
|
||
|
uint32_t *sig32 = (uint32_t *) sig;
|
||
|
|
||
|
- cpuid (&eax, &sig32[0], &sig32[2], &sig32[1]);
|
||
|
+ if (swapped)
|
||
|
+ cpuid (&eax, &sig32[0], &sig32[2], &sig32[1]);
|
||
|
+ else
|
||
|
+ cpuid (&eax, &sig32[0], &sig32[1], &sig32[2]);
|
||
|
sig[12] = 0; /* \0-terminate the string to make string comparison possible */
|
||
|
debug("CPUID sig %s\n", sig);
|
||
|
return eax;
|
||
|
@@ -335,7 +338,7 @@ cpu_sig_intel (void)
|
||
|
return;
|
||
|
|
||
|
memset (sig, 0, sizeof sig);
|
||
|
- cpuid_leaf (CPUID_INTEL_TDX_ENUMERATION, sig);
|
||
|
+ cpuid_leaf (CPUID_INTEL_TDX_ENUMERATION, sig, true);
|
||
|
|
||
|
if (memcmp (sig, CPUID_SIG_INTEL_TDX, sizeof(sig)) == 0)
|
||
|
puts ("intel-tdx");
|
||
|
@@ -368,7 +371,7 @@ cpu_sig (void)
|
||
|
return;
|
||
|
|
||
|
memset (sig, 0, sizeof sig);
|
||
|
- cpuid_leaf (0, sig);
|
||
|
+ cpuid_leaf (0, sig, true);
|
||
|
|
||
|
if (memcmp (sig, CPUID_SIG_AMD, sizeof(sig)) == 0)
|
||
|
cpu_sig_amd ();
|
||
|
--
|
||
|
2.43.0
|
||
|
|