提交 0861080f 编写于 作者: J Jiri Denemark

conf: Add usability blockers to virDomainCapsCPUModel

When a hypervisor marks a CPU model as unusable on the current host, it
may also give us a list of features which prevent the model from being
usable. Storing this list in virDomainCapsCPUModel will help the CPU
driver with creating a host-model CPU configuration.
Signed-off-by: NJiri Denemark <jdenemar@redhat.com>
Reviewed-by: NJohn Ferlan <jferlan@redhat.com>
上级 ef04596d
...@@ -163,7 +163,8 @@ virDomainCapsCPUModelsCopy(virDomainCapsCPUModelsPtr old) ...@@ -163,7 +163,8 @@ virDomainCapsCPUModelsCopy(virDomainCapsCPUModelsPtr old)
for (i = 0; i < old->nmodels; i++) { for (i = 0; i < old->nmodels; i++) {
if (virDomainCapsCPUModelsAdd(cpuModels, if (virDomainCapsCPUModelsAdd(cpuModels,
old->models[i].name, -1, old->models[i].name, -1,
old->models[i].usable) < 0) old->models[i].usable,
old->models[i].blockers) < 0)
goto error; goto error;
} }
...@@ -195,7 +196,8 @@ virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr old, ...@@ -195,7 +196,8 @@ virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr old,
if (virDomainCapsCPUModelsAdd(cpuModels, if (virDomainCapsCPUModelsAdd(cpuModels,
old->models[i].name, -1, old->models[i].name, -1,
old->models[i].usable) < 0) old->models[i].usable,
old->models[i].blockers) < 0)
goto error; goto error;
} }
...@@ -210,7 +212,8 @@ virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr old, ...@@ -210,7 +212,8 @@ virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr old,
int int
virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels, virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels,
char **name, char **name,
virDomainCapsCPUUsable usable) virDomainCapsCPUUsable usable,
char ***blockers)
{ {
if (VIR_RESIZE_N(cpuModels->models, cpuModels->nmodels_max, if (VIR_RESIZE_N(cpuModels->models, cpuModels->nmodels_max,
cpuModels->nmodels, 1) < 0) cpuModels->nmodels, 1) < 0)
...@@ -218,6 +221,10 @@ virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels, ...@@ -218,6 +221,10 @@ virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels,
cpuModels->models[cpuModels->nmodels].usable = usable; cpuModels->models[cpuModels->nmodels].usable = usable;
VIR_STEAL_PTR(cpuModels->models[cpuModels->nmodels].name, *name); VIR_STEAL_PTR(cpuModels->models[cpuModels->nmodels].name, *name);
if (blockers)
VIR_STEAL_PTR(cpuModels->models[cpuModels->nmodels].blockers, *blockers);
cpuModels->nmodels++; cpuModels->nmodels++;
return 0; return 0;
} }
...@@ -227,20 +234,27 @@ int ...@@ -227,20 +234,27 @@ int
virDomainCapsCPUModelsAdd(virDomainCapsCPUModelsPtr cpuModels, virDomainCapsCPUModelsAdd(virDomainCapsCPUModelsPtr cpuModels,
const char *name, const char *name,
ssize_t nameLen, ssize_t nameLen,
virDomainCapsCPUUsable usable) virDomainCapsCPUUsable usable,
char **blockers)
{ {
char *copy = NULL; char *nameCopy = NULL;
char **blockersCopy = NULL;
if (VIR_STRNDUP(nameCopy, name, nameLen) < 0)
goto error;
if (VIR_STRNDUP(copy, name, nameLen) < 0) if (virStringListCopy(&blockersCopy, (const char **)blockers) < 0)
goto error; goto error;
if (virDomainCapsCPUModelsAddSteal(cpuModels, &copy, usable) < 0) if (virDomainCapsCPUModelsAddSteal(cpuModels, &nameCopy,
usable, &blockersCopy) < 0)
goto error; goto error;
return 0; return 0;
error: error:
VIR_FREE(copy); VIR_FREE(nameCopy);
virStringListFree(blockersCopy);
return -1; return -1;
} }
......
...@@ -116,6 +116,7 @@ typedef virDomainCapsCPUModel *virDomainCapsCPUModelPtr; ...@@ -116,6 +116,7 @@ typedef virDomainCapsCPUModel *virDomainCapsCPUModelPtr;
struct _virDomainCapsCPUModel { struct _virDomainCapsCPUModel {
char *name; char *name;
virDomainCapsCPUUsable usable; virDomainCapsCPUUsable usable;
char **blockers; /* NULL-terminated list of usability blockers */
}; };
typedef struct _virDomainCapsCPUModels virDomainCapsCPUModels; typedef struct _virDomainCapsCPUModels virDomainCapsCPUModels;
...@@ -171,11 +172,13 @@ virDomainCapsCPUModelsPtr virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr ...@@ -171,11 +172,13 @@ virDomainCapsCPUModelsPtr virDomainCapsCPUModelsFilter(virDomainCapsCPUModelsPtr
const char **blacklist); const char **blacklist);
int virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels, int virDomainCapsCPUModelsAddSteal(virDomainCapsCPUModelsPtr cpuModels,
char **name, char **name,
virDomainCapsCPUUsable usable); virDomainCapsCPUUsable usable,
char ***blockers);
int virDomainCapsCPUModelsAdd(virDomainCapsCPUModelsPtr cpuModels, int virDomainCapsCPUModelsAdd(virDomainCapsCPUModelsPtr cpuModels,
const char *name, const char *name,
ssize_t nameLen, ssize_t nameLen,
virDomainCapsCPUUsable usable); virDomainCapsCPUUsable usable,
char **blockers);
# define VIR_DOMAIN_CAPS_ENUM_SET(capsEnum, ...) \ # define VIR_DOMAIN_CAPS_ENUM_SET(capsEnum, ...) \
do { \ do { \
......
...@@ -796,7 +796,7 @@ virQEMUCapsParseX86Models(const char *output, ...@@ -796,7 +796,7 @@ virQEMUCapsParseX86Models(const char *output,
} }
if (virDomainCapsCPUModelsAdd(cpus, p, len, if (virDomainCapsCPUModelsAdd(cpus, p, len,
VIR_DOMCAPS_CPU_USABLE_UNKNOWN) < 0) VIR_DOMCAPS_CPU_USABLE_UNKNOWN, NULL) < 0)
goto error; goto error;
} while ((p = next)); } while ((p = next));
...@@ -854,7 +854,7 @@ virQEMUCapsParsePPCModels(const char *output, ...@@ -854,7 +854,7 @@ virQEMUCapsParsePPCModels(const char *output,
continue; continue;
if (virDomainCapsCPUModelsAdd(cpus, p, t - p - 1, if (virDomainCapsCPUModelsAdd(cpus, p, t - p - 1,
VIR_DOMCAPS_CPU_USABLE_UNKNOWN) < 0) VIR_DOMCAPS_CPU_USABLE_UNKNOWN, NULL) < 0)
goto error; goto error;
} while ((p = next)); } while ((p = next));
...@@ -2526,7 +2526,7 @@ virQEMUCapsAddCPUDefinitions(virQEMUCapsPtr qemuCaps, ...@@ -2526,7 +2526,7 @@ virQEMUCapsAddCPUDefinitions(virQEMUCapsPtr qemuCaps,
} }
for (i = 0; i < count; i++) { for (i = 0; i < count; i++) {
if (virDomainCapsCPUModelsAdd(cpus, name[i], -1, usable) < 0) if (virDomainCapsCPUModelsAdd(cpus, name[i], -1, usable, NULL) < 0)
return -1; return -1;
} }
...@@ -3007,7 +3007,8 @@ virQEMUCapsProbeQMPCPUDefinitions(virQEMUCapsPtr qemuCaps, ...@@ -3007,7 +3007,8 @@ virQEMUCapsProbeQMPCPUDefinitions(virQEMUCapsPtr qemuCaps,
else if (cpus[i]->usable == VIR_TRISTATE_BOOL_NO) else if (cpus[i]->usable == VIR_TRISTATE_BOOL_NO)
usable = VIR_DOMCAPS_CPU_USABLE_NO; usable = VIR_DOMCAPS_CPU_USABLE_NO;
if (virDomainCapsCPUModelsAddSteal(models, &cpus[i]->name, usable) < 0) if (virDomainCapsCPUModelsAddSteal(models, &cpus[i]->name, usable,
NULL) < 0)
goto cleanup; goto cleanup;
} }
...@@ -3770,7 +3771,7 @@ virQEMUCapsLoadCPUModels(virQEMUCapsPtr qemuCaps, ...@@ -3770,7 +3771,7 @@ virQEMUCapsLoadCPUModels(virQEMUCapsPtr qemuCaps,
goto cleanup; goto cleanup;
} }
if (virDomainCapsCPUModelsAddSteal(cpus, &str, usable) < 0) if (virDomainCapsCPUModelsAddSteal(cpus, &str, usable, NULL) < 0)
goto cleanup; goto cleanup;
} }
......
...@@ -88,11 +88,11 @@ fillAllCaps(virDomainCapsPtr domCaps) ...@@ -88,11 +88,11 @@ fillAllCaps(virDomainCapsPtr domCaps)
cpu->hostModel = virCPUDefCopy(&host); cpu->hostModel = virCPUDefCopy(&host);
if (!(cpu->custom = virDomainCapsCPUModelsNew(3)) || if (!(cpu->custom = virDomainCapsCPUModelsNew(3)) ||
virDomainCapsCPUModelsAdd(cpu->custom, "Model1", -1, virDomainCapsCPUModelsAdd(cpu->custom, "Model1", -1,
VIR_DOMCAPS_CPU_USABLE_UNKNOWN) < 0 || VIR_DOMCAPS_CPU_USABLE_UNKNOWN, NULL) < 0 ||
virDomainCapsCPUModelsAdd(cpu->custom, "Model2", -1, virDomainCapsCPUModelsAdd(cpu->custom, "Model2", -1,
VIR_DOMCAPS_CPU_USABLE_NO) < 0 || VIR_DOMCAPS_CPU_USABLE_NO, NULL) < 0 ||
virDomainCapsCPUModelsAdd(cpu->custom, "Model3", -1, virDomainCapsCPUModelsAdd(cpu->custom, "Model3", -1,
VIR_DOMCAPS_CPU_USABLE_YES) < 0) VIR_DOMCAPS_CPU_USABLE_YES, NULL) < 0)
return -1; return -1;
disk->supported = true; disk->supported = true;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册