mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-27 18:03:50 +03:00
iotune: setting an invalid value now reports error
When trying to set an invalid value into iotune element, standard behavior was to not report any error, rather to reset all affected subelements of the iotune element back to 0 which results in ignoring those particular subelements by XML generator. Patch further examines the return code of the virXPathULongLong function and in case of an invalid non-integer value raises an error. Fixed to preserve consistency with invalid value checking of other elements. Resolves https://bugzilla.redhat.com/show_bug.cgi?id=1131811
This commit is contained in:
parent
adfdb8d5bd
commit
d60c33c6b5
@ -5416,6 +5416,7 @@ virDomainDiskDefParseXML(virDomainXMLOptionPtr xmlopt,
|
|||||||
char *mirrorType = NULL;
|
char *mirrorType = NULL;
|
||||||
int expected_secret_usage = -1;
|
int expected_secret_usage = -1;
|
||||||
int auth_secret_usage = -1;
|
int auth_secret_usage = -1;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
if (!(def = virDomainDiskDefNew()))
|
if (!(def = virDomainDiskDefNew()))
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -5644,39 +5645,69 @@ virDomainDiskDefParseXML(virDomainXMLOptionPtr xmlopt,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
} else if (xmlStrEqual(cur->name, BAD_CAST "iotune")) {
|
} else if (xmlStrEqual(cur->name, BAD_CAST "iotune")) {
|
||||||
if (virXPathULongLong("string(./iotune/total_bytes_sec)",
|
ret = virXPathULongLong("string(./iotune/total_bytes_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.total_bytes_sec) < 0) {
|
&def->blkdeviotune.total_bytes_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("total throughput limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.total_bytes_sec = 0;
|
def->blkdeviotune.total_bytes_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virXPathULongLong("string(./iotune/read_bytes_sec)",
|
ret = virXPathULongLong("string(./iotune/read_bytes_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.read_bytes_sec) < 0) {
|
&def->blkdeviotune.read_bytes_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("read throughput limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.read_bytes_sec = 0;
|
def->blkdeviotune.read_bytes_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virXPathULongLong("string(./iotune/write_bytes_sec)",
|
ret = virXPathULongLong("string(./iotune/write_bytes_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.write_bytes_sec) < 0) {
|
&def->blkdeviotune.write_bytes_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("write throughput limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.write_bytes_sec = 0;
|
def->blkdeviotune.write_bytes_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virXPathULongLong("string(./iotune/total_iops_sec)",
|
ret = virXPathULongLong("string(./iotune/total_iops_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.total_iops_sec) < 0) {
|
&def->blkdeviotune.total_iops_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("total I/O operations limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.total_iops_sec = 0;
|
def->blkdeviotune.total_iops_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virXPathULongLong("string(./iotune/read_iops_sec)",
|
ret = virXPathULongLong("string(./iotune/read_iops_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.read_iops_sec) < 0) {
|
&def->blkdeviotune.read_iops_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("read I/O operations limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.read_iops_sec = 0;
|
def->blkdeviotune.read_iops_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virXPathULongLong("string(./iotune/write_iops_sec)",
|
ret = virXPathULongLong("string(./iotune/write_iops_sec)",
|
||||||
ctxt,
|
ctxt,
|
||||||
&def->blkdeviotune.write_iops_sec) < 0) {
|
&def->blkdeviotune.write_iops_sec);
|
||||||
|
if (ret == -2) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("write I/O operations limit must be an integer"));
|
||||||
|
goto error;
|
||||||
|
} else if (ret < 0) {
|
||||||
def->blkdeviotune.write_iops_sec = 0;
|
def->blkdeviotune.write_iops_sec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user