mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 07:42:56 +00:00
lxcSetSchedulerParameters: reverse order of tests; diagnose a failure
* src/lxc/lxc_driver.c (lxcSetSchedulerParameters): Ensure that "->field" is "cpu_shares" before possibly giving a diagnostic about a type for a "cpu_shares" value. Also, virCgroupSetCpuShares could fail without evoking a diagnostic. Add one.
This commit is contained in:
parent
fff6be0cc0
commit
dd1058fa8f
@ -2054,18 +2054,23 @@ static int lxcSetSchedulerParameters(virDomainPtr domain,
|
|||||||
|
|
||||||
for (i = 0; i < nparams; i++) {
|
for (i = 0; i < nparams; i++) {
|
||||||
virSchedParameterPtr param = ¶ms[i];
|
virSchedParameterPtr param = ¶ms[i];
|
||||||
|
|
||||||
|
if (STRNEQ(param->field, "cpu_shares")) {
|
||||||
|
lxcError(VIR_ERR_INVALID_ARG,
|
||||||
|
_("Invalid parameter `%s'"), param->field);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
if (param->type != VIR_DOMAIN_SCHED_FIELD_ULLONG) {
|
if (param->type != VIR_DOMAIN_SCHED_FIELD_ULLONG) {
|
||||||
lxcError(VIR_ERR_INVALID_ARG, "%s",
|
lxcError(VIR_ERR_INVALID_ARG, "%s",
|
||||||
_("Invalid type for cpu_shares tunable, expected a 'ullong'"));
|
_("Invalid type for cpu_shares tunable, expected a 'ullong'"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (STREQ(param->field, "cpu_shares")) {
|
int rc = virCgroupSetCpuShares(group, params[i].value.ul);
|
||||||
if (virCgroupSetCpuShares(group, params[i].value.ul) != 0)
|
if (rc != 0) {
|
||||||
goto cleanup;
|
virReportSystemError(-rc, _("failed to set cpu_shares=%llu"),
|
||||||
} else {
|
params[i].value.ul);
|
||||||
lxcError(VIR_ERR_INVALID_ARG,
|
|
||||||
_("Invalid parameter `%s'"), param->field);
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user