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:
Jiri Denemark 2012-12-19 12:08:32 +01:00
parent 642261a866
commit 16c6b60cbd
4 changed files with 28 additions and 24 deletions

View File

@ -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;
}

View File

@ -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__ */

View File

@ -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)) ||

View File

@ -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,