|
|
6ae9ed |
From 780500abda14bb71111592254d01c973d16be320 Mon Sep 17 00:00:00 2001
|
|
|
6ae9ed |
Message-Id: <780500abda14bb71111592254d01c973d16be320@dist-git>
|
|
|
6ae9ed |
From: Jiri Denemark <jdenemar@redhat.com>
|
|
|
6ae9ed |
Date: Tue, 28 Jun 2016 10:51:41 +0200
|
|
|
6ae9ed |
Subject: [PATCH] cpu_x86: Introduce x86FeatureIsMigratable
|
|
|
6ae9ed |
|
|
|
6ae9ed |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
6ae9ed |
(cherry picked from commit dbb14bb0f1316d92c89541fca816c91dce0dc8fb)
|
|
|
6ae9ed |
|
|
|
6ae9ed |
https://bugzilla.redhat.com/show_bug.cgi?id=1365500
|
|
|
6ae9ed |
|
|
|
6ae9ed |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
6ae9ed |
---
|
|
|
6ae9ed |
src/cpu/cpu_x86.c | 37 +++++++++++++++++++++++--------------
|
|
|
6ae9ed |
1 file changed, 23 insertions(+), 14 deletions(-)
|
|
|
6ae9ed |
|
|
|
6ae9ed |
diff --git a/src/cpu/cpu_x86.c b/src/cpu/cpu_x86.c
|
|
|
6ae9ed |
index d9646eb..7bb2bb6 100644
|
|
|
6ae9ed |
--- a/src/cpu/cpu_x86.c
|
|
|
6ae9ed |
+++ b/src/cpu/cpu_x86.c
|
|
|
6ae9ed |
@@ -767,6 +767,22 @@ x86FeatureFindInternal(const char *name)
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
|
|
|
6ae9ed |
|
|
|
6ae9ed |
+static bool
|
|
|
6ae9ed |
+x86FeatureIsMigratable(const char *name,
|
|
|
6ae9ed |
+ void *cpu_map)
|
|
|
6ae9ed |
+{
|
|
|
6ae9ed |
+ virCPUx86MapPtr map = cpu_map;
|
|
|
6ae9ed |
+ size_t i;
|
|
|
6ae9ed |
+
|
|
|
6ae9ed |
+ for (i = 0; i < map->nblockers; i++) {
|
|
|
6ae9ed |
+ if (STREQ(name, map->migrate_blockers[i]->name))
|
|
|
6ae9ed |
+ return false;
|
|
|
6ae9ed |
+ }
|
|
|
6ae9ed |
+
|
|
|
6ae9ed |
+ return true;
|
|
|
6ae9ed |
+}
|
|
|
6ae9ed |
+
|
|
|
6ae9ed |
+
|
|
|
6ae9ed |
static char *
|
|
|
6ae9ed |
x86FeatureNames(virCPUx86MapPtr map,
|
|
|
6ae9ed |
const char *separator,
|
|
|
6ae9ed |
@@ -1801,14 +1817,10 @@ x86Decode(virCPUDefPtr cpu,
|
|
|
6ae9ed |
* features directly */
|
|
|
6ae9ed |
if (flags & VIR_CONNECT_BASELINE_CPU_MIGRATABLE) {
|
|
|
6ae9ed |
for (i = 0; i < cpuModel->nfeatures; i++) {
|
|
|
6ae9ed |
- size_t j;
|
|
|
6ae9ed |
- for (j = 0; j < map->nblockers; j++) {
|
|
|
6ae9ed |
- if (STREQ(map->migrate_blockers[j]->name,
|
|
|
6ae9ed |
- cpuModel->features[i].name)) {
|
|
|
6ae9ed |
- VIR_FREE(cpuModel->features[i].name);
|
|
|
6ae9ed |
- VIR_DELETE_ELEMENT_INPLACE(cpuModel->features, i,
|
|
|
6ae9ed |
- cpuModel->nfeatures);
|
|
|
6ae9ed |
- }
|
|
|
6ae9ed |
+ if (!x86FeatureIsMigratable(cpuModel->features[i].name, map)) {
|
|
|
6ae9ed |
+ VIR_FREE(cpuModel->features[i].name);
|
|
|
6ae9ed |
+ VIR_DELETE_ELEMENT_INPLACE(cpuModel->features, i,
|
|
|
6ae9ed |
+ cpuModel->nfeatures);
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
@@ -2531,12 +2543,9 @@ x86UpdateHostModel(virCPUDefPtr guest,
|
|
|
6ae9ed |
* Note: this only works as long as no CPU model contains non-migratable
|
|
|
6ae9ed |
* features directly */
|
|
|
6ae9ed |
for (i = 0; i < guest->nfeatures; i++) {
|
|
|
6ae9ed |
- size_t j;
|
|
|
6ae9ed |
- for (j = 0; j < map->nblockers; j++) {
|
|
|
6ae9ed |
- if (STREQ(map->migrate_blockers[j]->name, guest->features[i].name)) {
|
|
|
6ae9ed |
- VIR_FREE(guest->features[i].name);
|
|
|
6ae9ed |
- VIR_DELETE_ELEMENT_INPLACE(guest->features, i, guest->nfeatures);
|
|
|
6ae9ed |
- }
|
|
|
6ae9ed |
+ if (!x86FeatureIsMigratable(guest->features[i].name, map)) {
|
|
|
6ae9ed |
+ VIR_FREE(guest->features[i].name);
|
|
|
6ae9ed |
+ VIR_DELETE_ELEMENT_INPLACE(guest->features, i, guest->nfeatures);
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
}
|
|
|
6ae9ed |
for (i = 0; !passthrough && i < oldguest->nfeatures; i++) {
|
|
|
6ae9ed |
--
|
|
|
6ae9ed |
2.9.2
|
|
|
6ae9ed |
|