diff options
author | Cong Meng | 2012-06-20 08:47:10 +0200 |
---|---|---|
committer | Paolo Bonzini | 2012-07-27 08:25:25 +0200 |
commit | 350e6e419902991b073b313aa65b240d1024d57e (patch) | |
tree | e861b44b5180fd4f21b24b3890ba6326d9825cb4 /hw/scsi-bus.c | |
parent | scsi: add tracepoint for scsi_req_cancel (diff) | |
download | qemu-350e6e419902991b073b313aa65b240d1024d57e.tar.gz qemu-350e6e419902991b073b313aa65b240d1024d57e.tar.xz qemu-350e6e419902991b073b313aa65b240d1024d57e.zip |
scsi: introduce hotplug() and hot_unplug() interfaces for SCSI bus
Add two interfaces hotplug() and hot_unplug() to scsi bus info.
The scsi bus can implement these two interfaces to signal the HBA driver
of guest kernel to add/remove the scsi device in question.
Signed-off-by: Sen Wang <senwang@linux.vnet.ibm.com>
Signed-off-by: Cong Meng <mc@linux.vnet.ibm.com>
[ Fixed braces and indentation - Paolo ]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'hw/scsi-bus.c')
-rw-r--r-- | hw/scsi-bus.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/hw/scsi-bus.c b/hw/scsi-bus.c index 543d9d2649..6ee0c10028 100644 --- a/hw/scsi-bus.c +++ b/hw/scsi-bus.c @@ -186,6 +186,10 @@ static int scsi_qdev_init(DeviceState *qdev) dev); } + if (bus->info->hotplug) { + bus->info->hotplug(bus, dev); + } + err: return rc; } @@ -1650,6 +1654,17 @@ static int get_scsi_requests(QEMUFile *f, void *pv, size_t size) return 0; } +static int scsi_qdev_unplug(DeviceState *qdev) +{ + SCSIDevice *dev = SCSI_DEVICE(qdev); + SCSIBus *bus = DO_UPCAST(SCSIBus, qbus, dev->qdev.parent_bus); + + if (bus->info->hot_unplug) { + bus->info->hot_unplug(bus, dev); + } + return qdev_simple_unplug_cb(qdev); +} + static const VMStateInfo vmstate_info_scsi_requests = { .name = "scsi-requests", .get = get_scsi_requests, @@ -1686,7 +1701,7 @@ static void scsi_device_class_init(ObjectClass *klass, void *data) DeviceClass *k = DEVICE_CLASS(klass); k->bus_type = TYPE_SCSI_BUS; k->init = scsi_qdev_init; - k->unplug = qdev_simple_unplug_cb; + k->unplug = scsi_qdev_unplug; k->exit = scsi_qdev_exit; k->props = scsi_props; } |