mirror of
https://github.com/qemu/qemu.git
synced 2025-08-09 19:15:32 +00:00
scsi: report parameter changes to HBA drivers
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
aaebacef0a
commit
53200fad0e
@ -1072,6 +1072,16 @@ int scsi_req_parse(SCSICommand *cmd, SCSIDevice *dev, uint8_t *buf)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void scsi_device_report_change(SCSIDevice *dev, SCSISense sense)
|
||||||
|
{
|
||||||
|
SCSIBus *bus = DO_UPCAST(SCSIBus, qbus, dev->qdev.parent_bus);
|
||||||
|
|
||||||
|
scsi_device_set_ua(dev, sense);
|
||||||
|
if (bus->info->change) {
|
||||||
|
bus->info->change(bus, dev, sense);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Predefined sense codes
|
* Predefined sense codes
|
||||||
*/
|
*/
|
||||||
|
@ -1869,6 +1869,7 @@ static void scsi_disk_resize_cb(void *opaque)
|
|||||||
*/
|
*/
|
||||||
if (s->qdev.type == TYPE_DISK) {
|
if (s->qdev.type == TYPE_DISK) {
|
||||||
scsi_device_set_ua(&s->qdev, SENSE_CODE(CAPACITY_CHANGED));
|
scsi_device_set_ua(&s->qdev, SENSE_CODE(CAPACITY_CHANGED));
|
||||||
|
scsi_device_report_change(&s->qdev, SENSE_CODE(CAPACITY_CHANGED));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,6 +133,7 @@ struct SCSIBusInfo {
|
|||||||
void (*cancel)(SCSIRequest *req);
|
void (*cancel)(SCSIRequest *req);
|
||||||
void (*hotplug)(SCSIBus *bus, SCSIDevice *dev);
|
void (*hotplug)(SCSIBus *bus, SCSIDevice *dev);
|
||||||
void (*hot_unplug)(SCSIBus *bus, SCSIDevice *dev);
|
void (*hot_unplug)(SCSIBus *bus, SCSIDevice *dev);
|
||||||
|
void (*change)(SCSIBus *bus, SCSIDevice *dev, SCSISense sense);
|
||||||
QEMUSGList *(*get_sg_list)(SCSIRequest *req);
|
QEMUSGList *(*get_sg_list)(SCSIRequest *req);
|
||||||
|
|
||||||
void (*save_request)(QEMUFile *f, SCSIRequest *req);
|
void (*save_request)(QEMUFile *f, SCSIRequest *req);
|
||||||
@ -242,6 +243,7 @@ void scsi_req_cancel(SCSIRequest *req);
|
|||||||
void scsi_req_retry(SCSIRequest *req);
|
void scsi_req_retry(SCSIRequest *req);
|
||||||
void scsi_device_purge_requests(SCSIDevice *sdev, SCSISense sense);
|
void scsi_device_purge_requests(SCSIDevice *sdev, SCSISense sense);
|
||||||
void scsi_device_set_ua(SCSIDevice *sdev, SCSISense sense);
|
void scsi_device_set_ua(SCSIDevice *sdev, SCSISense sense);
|
||||||
|
void scsi_device_report_change(SCSIDevice *dev, SCSISense sense);
|
||||||
int scsi_device_get_sense(SCSIDevice *dev, uint8_t *buf, int len, bool fixed);
|
int scsi_device_get_sense(SCSIDevice *dev, uint8_t *buf, int len, bool fixed);
|
||||||
SCSIDevice *scsi_device_find(SCSIBus *bus, int channel, int target, int lun);
|
SCSIDevice *scsi_device_find(SCSIBus *bus, int channel, int target, int lun);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user