mirror of https://github.com/xemu-project/xemu.git
Add pci_bus_reset() function.
To reset internal irq handling data structures. Signed-off-by: Gleb Natapov <gleb@redhat.com> Signed-off-by: Yaniv Kamay <ykamay@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
efeea6d048
commit
6eaa684746
16
hw/pci.c
16
hw/pci.c
|
@ -87,6 +87,21 @@ static int pcibus_load(QEMUFile *f, void *opaque, int version_id)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void pci_bus_reset(void *opaque)
|
||||||
|
{
|
||||||
|
PCIBus *bus = (PCIBus *)opaque;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < bus->nirq; i++) {
|
||||||
|
bus->irq_count[i] = 0;
|
||||||
|
}
|
||||||
|
for (i = 0; i < 256; i++) {
|
||||||
|
if (bus->devices[i])
|
||||||
|
memset(bus->devices[i]->irq_state, 0,
|
||||||
|
sizeof(bus->devices[i]->irq_state));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
PCIBus *pci_register_bus(DeviceState *parent, const char *name,
|
PCIBus *pci_register_bus(DeviceState *parent, const char *name,
|
||||||
pci_set_irq_fn set_irq, pci_map_irq_fn map_irq,
|
pci_set_irq_fn set_irq, pci_map_irq_fn map_irq,
|
||||||
qemu_irq *pic, int devfn_min, int nirq)
|
qemu_irq *pic, int devfn_min, int nirq)
|
||||||
|
@ -105,6 +120,7 @@ PCIBus *pci_register_bus(DeviceState *parent, const char *name,
|
||||||
bus->next = first_bus;
|
bus->next = first_bus;
|
||||||
first_bus = bus;
|
first_bus = bus;
|
||||||
register_savevm("PCIBUS", nbus++, 1, pcibus_save, pcibus_load, bus);
|
register_savevm("PCIBUS", nbus++, 1, pcibus_save, pcibus_load, bus);
|
||||||
|
qemu_register_reset(pci_bus_reset, 0, bus);
|
||||||
return bus;
|
return bus;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue