mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 15:27:47 +00:00
virDomainSoundDefParseXML: Use virXMLProp*
This strictens the parser to disallow negative values (interpreted as `UINT_MAX + value + 1`) for attribute `id`. `id` must be greater than 0 and does not benefit from being referable as e.g. "-7" for host audio backend 4294967289, as this value is distinctly out of range for normal use. Additionally, this patch fixes a use of NULL string with printf's %s modifier if the `model` attribute is absent. Signed-off-by: Tim Wiederhake <twiederh@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com> Signed-off-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
241c22a9a5
commit
47896e0ba2
@ -13212,20 +13212,14 @@ virDomainSoundDefParseXML(virDomainXMLOption *xmlopt,
|
||||
{
|
||||
virDomainSoundDef *def;
|
||||
VIR_XPATH_NODE_AUTORESTORE(ctxt)
|
||||
g_autofree char *model = NULL;
|
||||
int modelval;
|
||||
xmlNodePtr audioNode;
|
||||
|
||||
def = g_new0(virDomainSoundDef, 1);
|
||||
ctxt->node = node;
|
||||
|
||||
model = virXMLPropString(node, "model");
|
||||
if ((modelval = virDomainSoundModelTypeFromString(model)) < 0) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||
_("unknown sound model '%s'"), model);
|
||||
if (virXMLPropEnum(node, "model", virDomainSoundModelTypeFromString,
|
||||
VIR_XML_PROP_REQUIRED, &def->model) < 0)
|
||||
goto error;
|
||||
}
|
||||
def->model = modelval;
|
||||
|
||||
if (virDomainSoundModelSupportsCodecs(def)) {
|
||||
int ncodecs;
|
||||
@ -13254,20 +13248,11 @@ virDomainSoundDefParseXML(virDomainXMLOption *xmlopt,
|
||||
|
||||
audioNode = virXPathNode("./audio", ctxt);
|
||||
if (audioNode) {
|
||||
g_autofree char *tmp = NULL;
|
||||
tmp = virXMLPropString(audioNode, "id");
|
||||
if (!tmp) {
|
||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||
_("missing audio 'id' attribute"));
|
||||
if (virXMLPropUInt(audioNode, "id", 10,
|
||||
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||
&def->audioId) < 0)
|
||||
goto error;
|
||||
}
|
||||
if (virStrToLong_ui(tmp, NULL, 10, &def->audioId) < 0 ||
|
||||
def->audioId == 0) {
|
||||
virReportError(VIR_ERR_XML_ERROR,
|
||||
_("Invalid audio 'id' value '%s'"), tmp);
|
||||
goto error;
|
||||
}
|
||||
}
|
||||
|
||||
if (virDomainDeviceInfoParseXML(xmlopt, node, ctxt, &def->info, flags) < 0)
|
||||
goto error;
|
||||
|
Loading…
Reference in New Issue
Block a user