|
Pablo Greco |
40546a |
From 920ac610bc68ffd7de1ac14c401c7f8c37f3337e Mon Sep 17 00:00:00 2001
|
|
Pablo Greco |
40546a |
Message-Id: <920ac610bc68ffd7de1ac14c401c7f8c37f3337e@dist-git>
|
|
Pablo Greco |
40546a |
From: Jiri Denemark <jdenemar@redhat.com>
|
|
Pablo Greco |
40546a |
Date: Fri, 21 Jun 2019 09:25:36 +0200
|
|
Pablo Greco |
40546a |
Subject: [PATCH] cpu_x86: Make x86cpuidMatchMasked more general
|
|
Pablo Greco |
40546a |
MIME-Version: 1.0
|
|
Pablo Greco |
40546a |
Content-Type: text/plain; charset=UTF-8
|
|
Pablo Greco |
40546a |
Content-Transfer-Encoding: 8bit
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
The function is renamed as virCPUx86DataItemMatchMasked to reflect the
|
|
Pablo Greco |
40546a |
change in parameter types.
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
Pablo Greco |
40546a |
Reviewed-by: Ján Tomko <jtomko@redhat.com>
|
|
Pablo Greco |
40546a |
(cherry picked from commit 2eea67a98eab58b46dbf4275819c06c90bc4c5b6)
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
https://bugzilla.redhat.com/show_bug.cgi?id=1697627
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
Pablo Greco |
40546a |
Message-Id: <7c0a54c618d67d64663eb92d5eeb1d8a2270be16.1561068591.git.jdenemar@redhat.com>
|
|
Pablo Greco |
40546a |
Reviewed-by: Ján Tomko <jtomko@redhat.com>
|
|
Pablo Greco |
40546a |
---
|
|
Pablo Greco |
40546a |
src/cpu/cpu_x86.c | 20 ++++++++++----------
|
|
Pablo Greco |
40546a |
1 file changed, 10 insertions(+), 10 deletions(-)
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
diff --git a/src/cpu/cpu_x86.c b/src/cpu/cpu_x86.c
|
|
Pablo Greco |
40546a |
index 54da9a985c..1bb35ec4e8 100644
|
|
Pablo Greco |
40546a |
--- a/src/cpu/cpu_x86.c
|
|
Pablo Greco |
40546a |
+++ b/src/cpu/cpu_x86.c
|
|
Pablo Greco |
40546a |
@@ -203,13 +203,13 @@ x86cpuidMatch(const virCPUx86CPUID *cpuid1,
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
static bool
|
|
Pablo Greco |
40546a |
-x86cpuidMatchMasked(const virCPUx86CPUID *cpuid,
|
|
Pablo Greco |
40546a |
- const virCPUx86CPUID *mask)
|
|
Pablo Greco |
40546a |
+virCPUx86DataItemMatchMasked(const virCPUx86DataItem *item,
|
|
Pablo Greco |
40546a |
+ const virCPUx86DataItem *mask)
|
|
Pablo Greco |
40546a |
{
|
|
Pablo Greco |
40546a |
- return ((cpuid->eax & mask->eax) == mask->eax &&
|
|
Pablo Greco |
40546a |
- (cpuid->ebx & mask->ebx) == mask->ebx &&
|
|
Pablo Greco |
40546a |
- (cpuid->ecx & mask->ecx) == mask->ecx &&
|
|
Pablo Greco |
40546a |
- (cpuid->edx & mask->edx) == mask->edx);
|
|
Pablo Greco |
40546a |
+ return ((item->cpuid.eax & mask->cpuid.eax) == mask->cpuid.eax &&
|
|
Pablo Greco |
40546a |
+ (item->cpuid.ebx & mask->cpuid.ebx) == mask->cpuid.ebx &&
|
|
Pablo Greco |
40546a |
+ (item->cpuid.ecx & mask->cpuid.ecx) == mask->cpuid.ecx &&
|
|
Pablo Greco |
40546a |
+ (item->cpuid.edx & mask->cpuid.edx) == mask->cpuid.edx);
|
|
Pablo Greco |
40546a |
}
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
@@ -474,7 +474,7 @@ x86DataIsSubset(const virCPUx86Data *data,
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
while ((itemSubset = virCPUx86DataNext(&iter))) {
|
|
Pablo Greco |
40546a |
if (!(item = virCPUx86DataGet(data, itemSubset)) ||
|
|
Pablo Greco |
40546a |
- !x86cpuidMatchMasked(&item->cpuid, &itemSubset->cpuid))
|
|
Pablo Greco |
40546a |
+ !virCPUx86DataItemMatchMasked(item, itemSubset))
|
|
Pablo Greco |
40546a |
return false;
|
|
Pablo Greco |
40546a |
}
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
@@ -515,7 +515,7 @@ x86DataToVendor(const virCPUx86Data *data,
|
|
Pablo Greco |
40546a |
for (i = 0; i < map->nvendors; i++) {
|
|
Pablo Greco |
40546a |
virCPUx86VendorPtr vendor = map->vendors[i];
|
|
Pablo Greco |
40546a |
if ((item = virCPUx86DataGet(data, &vendor->data)) &&
|
|
Pablo Greco |
40546a |
- x86cpuidMatchMasked(&item->cpuid, &vendor->data.cpuid)) {
|
|
Pablo Greco |
40546a |
+ virCPUx86DataItemMatchMasked(item, &vendor->data)) {
|
|
Pablo Greco |
40546a |
virCPUx86DataItemClearBits(item, &vendor->data);
|
|
Pablo Greco |
40546a |
return vendor;
|
|
Pablo Greco |
40546a |
}
|
|
Pablo Greco |
40546a |
@@ -1157,7 +1157,7 @@ x86ModelCompare(virCPUx86ModelPtr model1,
|
|
Pablo Greco |
40546a |
if ((item2 = virCPUx86DataGet(&model2->data, item1))) {
|
|
Pablo Greco |
40546a |
if (x86cpuidMatch(&item1->cpuid, &item2->cpuid))
|
|
Pablo Greco |
40546a |
continue;
|
|
Pablo Greco |
40546a |
- else if (!x86cpuidMatchMasked(&item1->cpuid, &item2->cpuid))
|
|
Pablo Greco |
40546a |
+ else if (!virCPUx86DataItemMatchMasked(item1, item2))
|
|
Pablo Greco |
40546a |
match = SUBSET;
|
|
Pablo Greco |
40546a |
}
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
@@ -1173,7 +1173,7 @@ x86ModelCompare(virCPUx86ModelPtr model1,
|
|
Pablo Greco |
40546a |
if ((item1 = virCPUx86DataGet(&model1->data, item2))) {
|
|
Pablo Greco |
40546a |
if (x86cpuidMatch(&item2->cpuid, &item1->cpuid))
|
|
Pablo Greco |
40546a |
continue;
|
|
Pablo Greco |
40546a |
- else if (!x86cpuidMatchMasked(&item2->cpuid, &item1->cpuid))
|
|
Pablo Greco |
40546a |
+ else if (!virCPUx86DataItemMatchMasked(item2, item1))
|
|
Pablo Greco |
40546a |
match = SUPERSET;
|
|
Pablo Greco |
40546a |
}
|
|
Pablo Greco |
40546a |
|
|
Pablo Greco |
40546a |
--
|
|
Pablo Greco |
40546a |
2.22.0
|
|
Pablo Greco |
40546a |
|