hw/pci/pci.c: Don't leak PCIBus::irq_count[] in pci_bus_irqs()
When calling pci_bus_irqs() multiple times on the same object without calling pci_bus_irqs_cleanup() in between PCIBus::irq_count[] is currently leaked. Let's fix this because Xen will do just that in a few commits, and because calling pci_bus_irqs_cleanup() in between seems fragile and cumbersome. Note that pci_bus_irqs_cleanup() now has to NULL irq_count such that pci_bus_irqs() doesn't do a double free. Signed-off-by: Bernhard Beschow <shentey@gmail.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Tested-by: Chuck Zmudzinski <brchuckz@aol.com> Message-Id: <20230403074124.3925-3-shentey@gmail.com> Signed-off-by: Anthony PERARD <anthony.perard@citrix.com>
This commit is contained in:
parent
27047bd266
commit
c0b59416c0
@ -560,6 +560,7 @@ void pci_bus_irqs(PCIBus *bus, pci_set_irq_fn set_irq,
|
||||
bus->set_irq = set_irq;
|
||||
bus->irq_opaque = irq_opaque;
|
||||
bus->nirq = nirq;
|
||||
g_free(bus->irq_count);
|
||||
bus->irq_count = g_malloc0(nirq * sizeof(bus->irq_count[0]));
|
||||
}
|
||||
|
||||
@ -575,6 +576,7 @@ void pci_bus_irqs_cleanup(PCIBus *bus)
|
||||
bus->irq_opaque = NULL;
|
||||
bus->nirq = 0;
|
||||
g_free(bus->irq_count);
|
||||
bus->irq_count = NULL;
|
||||
}
|
||||
|
||||
PCIBus *pci_register_root_bus(DeviceState *parent, const char *name,
|
||||
|
Loading…
Reference in New Issue
Block a user