mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 15:27:47 +00:00
cpu: Introduce cpuModelIsAllowed internal API
The API can be used to check if the model is on the supported models list, which needs to be done in several places.
This commit is contained in:
parent
642261a866
commit
16c6b60cbd
@ -442,3 +442,20 @@ cpuHasFeature(virArch arch,
|
|||||||
|
|
||||||
return driver->hasFeature(data, feature);
|
return driver->hasFeature(data, feature);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
cpuModelIsAllowed(const char *model,
|
||||||
|
const char **models,
|
||||||
|
unsigned int nmodels)
|
||||||
|
{
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
if (!models || !nmodels)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
for (i = 0; i < nmodels; i++) {
|
||||||
|
if (models[i] && STREQ(models[i], model))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
@ -163,4 +163,9 @@ cpuHasFeature(virArch arch,
|
|||||||
const char *feature);
|
const char *feature);
|
||||||
|
|
||||||
|
|
||||||
|
bool
|
||||||
|
cpuModelIsAllowed(const char *model,
|
||||||
|
const char **models,
|
||||||
|
unsigned int nmodels);
|
||||||
|
|
||||||
#endif /* __VIR_CPU_H__ */
|
#endif /* __VIR_CPU_H__ */
|
||||||
|
@ -123,21 +123,12 @@ genericBaseline(virCPUDefPtr *cpus,
|
|||||||
unsigned int count;
|
unsigned int count;
|
||||||
unsigned int i, j;
|
unsigned int i, j;
|
||||||
|
|
||||||
if (models) {
|
if (!cpuModelIsAllowed(cpus[0]->model, models, nmodels)) {
|
||||||
bool found = false;
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
for (i = 0; i < nmodels; i++) {
|
_("CPU model %s is not supported by hypervisor"),
|
||||||
if (STREQ(cpus[0]->model, models[i])) {
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found) {
|
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
||||||
_("CPU model '%s' is not support by hypervisor"),
|
|
||||||
cpus[0]->model);
|
cpus[0]->model);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (VIR_ALLOC(cpu) < 0 ||
|
if (VIR_ALLOC(cpu) < 0 ||
|
||||||
!(cpu->model = strdup(cpus[0]->model)) ||
|
!(cpu->model = strdup(cpus[0]->model)) ||
|
||||||
|
@ -1317,16 +1317,7 @@ x86Decode(virCPUDefPtr cpu,
|
|||||||
|
|
||||||
candidate = map->models;
|
candidate = map->models;
|
||||||
while (candidate != NULL) {
|
while (candidate != NULL) {
|
||||||
bool allowed = (models == NULL);
|
if (!cpuModelIsAllowed(candidate->name, models, nmodels)) {
|
||||||
|
|
||||||
for (i = 0; i < nmodels; i++) {
|
|
||||||
if (models && models[i] && STREQ(models[i], candidate->name)) {
|
|
||||||
allowed = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!allowed) {
|
|
||||||
if (preferred && STREQ(candidate->name, preferred)) {
|
if (preferred && STREQ(candidate->name, preferred)) {
|
||||||
if (cpu->fallback != VIR_CPU_FALLBACK_ALLOW) {
|
if (cpu->fallback != VIR_CPU_FALLBACK_ALLOW) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
Loading…
Reference in New Issue
Block a user