[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v7 11/13] scsi/scsi_bus: Add scsi_device_get
From: |
Maxim Levitsky |
Subject: |
[PATCH v7 11/13] scsi/scsi_bus: Add scsi_device_get |
Date: |
Tue, 6 Oct 2020 15:39:02 +0300 |
Add scsi_device_get which finds the scsi device
and takes a reference to it.
Suggested-by: Stefan Hajnoczi <stefanha@gmail.com>
Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com>
Message-Id: <20200913160259.32145-8-mlevitsk@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
---
hw/scsi/scsi-bus.c | 11 +++++++++++
include/hw/scsi/scsi.h | 1 +
2 files changed, 12 insertions(+)
diff --git a/hw/scsi/scsi-bus.c b/hw/scsi/scsi-bus.c
index 7599113efe..eda8cb7e70 100644
--- a/hw/scsi/scsi-bus.c
+++ b/hw/scsi/scsi-bus.c
@@ -73,6 +73,17 @@ SCSIDevice *scsi_device_find(SCSIBus *bus, int channel, int
id, int lun)
return do_scsi_device_find(bus, channel, id, lun, false);
}
+SCSIDevice *scsi_device_get(SCSIBus *bus, int channel, int id, int lun)
+{
+ SCSIDevice *d;
+ RCU_READ_LOCK_GUARD();
+ d = do_scsi_device_find(bus, channel, id, lun, false);
+ if (d) {
+ object_ref(d);
+ }
+ return d;
+}
+
static void scsi_device_realize(SCSIDevice *s, Error **errp)
{
SCSIDeviceClass *sc = SCSI_DEVICE_GET_CLASS(s);
diff --git a/include/hw/scsi/scsi.h b/include/hw/scsi/scsi.h
index 7a55cdbd74..09fa5c9d2a 100644
--- a/include/hw/scsi/scsi.h
+++ b/include/hw/scsi/scsi.h
@@ -190,6 +190,7 @@ int scsi_device_get_sense(SCSIDevice *dev, uint8_t *buf,
int len, bool fixed);
int scsi_SG_IO_FROM_DEV(BlockBackend *blk, uint8_t *cmd, uint8_t cmd_size,
uint8_t *buf, uint8_t buf_size);
SCSIDevice *scsi_device_find(SCSIBus *bus, int channel, int target, int lun);
+SCSIDevice *scsi_device_get(SCSIBus *bus, int channel, int target, int lun);
/* scsi-generic.c. */
extern const SCSIReqOps scsi_generic_req_ops;
--
2.26.2
- [PATCH v7 03/13] qtest: switch users back to qtest_qmp_receive, (continued)
- [PATCH v7 03/13] qtest: switch users back to qtest_qmp_receive, Maxim Levitsky, 2020/10/06
- [PATCH v7 04/13] qdev: add "check if address free" callback for buses, Maxim Levitsky, 2020/10/06
- [PATCH v7 05/13] scsi: switch to bus->check_address, Maxim Levitsky, 2020/10/06
- [PATCH v7 06/13] scsi/scsi_bus: switch search direction in scsi_device_find, Maxim Levitsky, 2020/10/06
- [PATCH v7 07/13] device_core: use drain_call_rcu in in qmp_device_add, Maxim Levitsky, 2020/10/06
- [PATCH v7 08/13] device-core: use RCU for list of children of a bus, Maxim Levitsky, 2020/10/06
- [PATCH v7 09/13] device-core: use atomic_set on .realized property, Maxim Levitsky, 2020/10/06
- [PATCH v7 10/13] scsi/scsi-bus: scsi_device_find: don't return unrealized devices, Maxim Levitsky, 2020/10/06
- [PATCH v7 11/13] scsi/scsi_bus: Add scsi_device_get,
Maxim Levitsky <=
- [PATCH v7 12/13] virtio-scsi: use scsi_device_get, Maxim Levitsky, 2020/10/06
- [PATCH v7 13/13] scsi/scsi_bus: fix races in REPORT LUNS, Maxim Levitsky, 2020/10/06
- Re: [PATCH v7 00/13] Fix scsi devices plug/unplug races w.r.t virtio-scsi iothread, no-reply, 2020/10/06