From: Marcelo Tosatti <[EMAIL PROTECTED]> Record devfn on the BlockDriverState structure to locate for release on hot-removal.
Signed-off-by: Marcelo Tosatti <[EMAIL PROTECTED]> Signed-off-by: Avi Kivity <[EMAIL PROTECTED]> diff --git a/qemu/block_int.h b/qemu/block_int.h index 137000e..2d70cf1 100644 --- a/qemu/block_int.h +++ b/qemu/block_int.h @@ -129,6 +129,8 @@ struct BlockDriverState { int cyls, heads, secs, translation; int type; char device_name[32]; + /* PCI devfn of parent */ + int devfn; BlockDriverState *next; }; diff --git a/qemu/hw/ide.c b/qemu/hw/ide.c index 5c21a8b..36fd983 100644 --- a/qemu/hw/ide.c +++ b/qemu/hw/ide.c @@ -28,6 +28,7 @@ #include "scsi-disk.h" #include "pcmcia.h" #include "block.h" +#include "block_int.h" #include "qemu-timer.h" #include "sysemu.h" #include "ppc_mac.h" @@ -2938,6 +2939,7 @@ void pci_piix3_ide_init(PCIBus *bus, BlockDriverState **hd_table, int devfn, { PCIIDEState *d; uint8_t *pci_conf; + int i; /* register a function 1 of PIIX3 */ d = (PCIIDEState *)pci_register_device(bus, "PIIX3 IDE", @@ -2966,6 +2968,10 @@ void pci_piix3_ide_init(PCIBus *bus, BlockDriverState **hd_table, int devfn, ide_init_ioport(&d->ide_if[0], 0x1f0, 0x3f6); ide_init_ioport(&d->ide_if[2], 0x170, 0x376); + for (i = 0; i < 4; i++) + if (hd_table[i]) + hd_table[i]->devfn = d->dev.devfn; + register_savevm("ide", 0, 1, pci_ide_save, pci_ide_load, d); } diff --git a/qemu/hw/lsi53c895a.c b/qemu/hw/lsi53c895a.c index a08cfd9..52bfc20 100644 --- a/qemu/hw/lsi53c895a.c +++ b/qemu/hw/lsi53c895a.c @@ -13,6 +13,7 @@ #include "hw.h" #include "pci.h" #include "scsi-disk.h" +#include "block_int.h" //#define DEBUG_LSI //#define DEBUG_LSI_REG @@ -1845,6 +1846,7 @@ void lsi_scsi_attach(void *opaque, BlockDriverState *bd, int id) s->scsi_dev[id] = scsi_generic_init(bd, 1, lsi_command_complete, s); if (s->scsi_dev[id] == NULL) s->scsi_dev[id] = scsi_disk_init(bd, 1, lsi_command_complete, s); + bd->devfn = s->pci_dev.devfn; } void *lsi_scsi_init(PCIBus *bus, int devfn) diff --git a/qemu/hw/virtio-blk.c b/qemu/hw/virtio-blk.c index 301b5a1..65a8ab2 100644 --- a/qemu/hw/virtio-blk.c +++ b/qemu/hw/virtio-blk.c @@ -13,6 +13,7 @@ #include "virtio.h" #include "block.h" +#include "block_int.h" #include "pc.h" /* from Linux's linux/virtio_blk.h */ @@ -156,6 +157,7 @@ void *virtio_blk_init(PCIBus *bus, uint16_t vendor, uint16_t device, s->vdev.update_config = virtio_blk_update_config; s->vdev.get_features = virtio_blk_get_features; s->bs = bs; + bs->devfn = s->vdev.pci_dev.devfn; virtio_add_queue(&s->vdev, 128, virtio_blk_handle_output); ------------------------------------------------------------------------- This SF.net email is sponsored by: Microsoft Defy all challenges. Microsoft(R) Visual Studio 2008. http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/ _______________________________________________ kvm-commits mailing list kvm-commits@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/kvm-commits