mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-02-09 13:57:27 +03:00
qemu_capabilities: Don't leak @str in virQEMUCapsLoadMachines()
If parsing "maxCpus" attribute of <machine/> element fails an error is printed but the corresponding string is not freed. While it is very unlikely to happen (parsed XML is not user provided and we are the ones generating it), it is possible. Instead of freeing the variable in the error path explicitly, let's declare it as g_autofree. And while I'm at it, let's bring it into the loop where it's used. Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
e3d60f761c
commit
71609477a2
@ -4012,7 +4012,6 @@ virQEMUCapsLoadMachines(virQEMUCapsAccelPtr caps,
|
||||
{
|
||||
g_autofree char *xpath = g_strdup_printf("./machine[@type='%s']", typeStr);
|
||||
g_autofree xmlNodePtr *nodes = NULL;
|
||||
char *str = NULL;
|
||||
size_t i;
|
||||
int n;
|
||||
|
||||
@ -4029,6 +4028,8 @@ virQEMUCapsLoadMachines(virQEMUCapsAccelPtr caps,
|
||||
caps->machineTypes = g_new0(virQEMUCapsMachineType, caps->nmachineTypes);
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
g_autofree char *str = NULL;
|
||||
|
||||
if (!(caps->machineTypes[i].name = virXMLPropString(nodes[i], "name"))) {
|
||||
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||
_("missing machine name in QEMU capabilities cache"));
|
||||
|
Loading…
x
Reference in New Issue
Block a user