mirror of
https://github.com/libvirt/libvirt.git
synced 2025-02-25 18:55:26 -06:00
qemu_conf: Fix double free problem for cfg->firmwares
cfg->firmwares still points to the original memory address after being freed by virFirmwareFreeList(). As cfg get freed, it will be freed again even if cfg->nfirmwares=0 which eventually lead to crash. The patch fix it by setting cfg->firmwares to NULL explicitly after virFirmwareFreeList() returns Signed-off-by: Guoyi Tu<tu.guoyi@h3c.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
0cbcd21b1f
commit
c4f4e195a1
@ -834,6 +834,7 @@ virQEMUDriverConfigLoadNVRAMEntry(virQEMUDriverConfigPtr cfg,
|
||||
VIR_AUTOSTRINGLIST fwList = NULL;
|
||||
|
||||
virFirmwareFreeList(cfg->firmwares, cfg->nfirmwares);
|
||||
cfg->firmwares = NULL;
|
||||
|
||||
if (qemuFirmwareFetchConfigs(&fwList, privileged) < 0)
|
||||
return -1;
|
||||
|
Loading…
Reference in New Issue
Block a user