|
|
ae23c9 |
From 35bdd02a4c49dffc4fe6daccf6ba505f5c1a3bcd Mon Sep 17 00:00:00 2001
|
|
|
ae23c9 |
From: Fam Zheng <famz@redhat.com>
|
|
|
ae23c9 |
Date: Fri, 29 Jun 2018 06:11:46 +0200
|
|
|
ae23c9 |
Subject: [PATCH 172/268] iscsi: Query and save device designator when opening
|
|
|
ae23c9 |
|
|
|
ae23c9 |
RH-Author: Fam Zheng <famz@redhat.com>
|
|
|
ae23c9 |
Message-id: <20180629061153.12687-7-famz@redhat.com>
|
|
|
ae23c9 |
Patchwork-id: 81157
|
|
|
ae23c9 |
O-Subject: [RHEL-7.6 qemu-kvm-rhev PATCH v2 06/13] iscsi: Query and save device designator when opening
|
|
|
ae23c9 |
Bugzilla: 1482537
|
|
|
ae23c9 |
RH-Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
ae23c9 |
RH-Acked-by: Max Reitz <mreitz@redhat.com>
|
|
|
ae23c9 |
RH-Acked-by: Kevin Wolf <kwolf@redhat.com>
|
|
|
ae23c9 |
|
|
|
ae23c9 |
The device designator data returned in INQUIRY command will be useful to
|
|
|
ae23c9 |
fill in source/target fields during copy offloading. Do this when
|
|
|
ae23c9 |
connecting to the target and save the data for later use.
|
|
|
ae23c9 |
|
|
|
ae23c9 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
ae23c9 |
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
ae23c9 |
Message-id: 20180601092648.24614-7-famz@redhat.com
|
|
|
ae23c9 |
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
ae23c9 |
(cherry picked from commit cc9743c236cce8a35449e3ef67140287b68bb705)
|
|
|
ae23c9 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
ae23c9 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
ae23c9 |
---
|
|
|
ae23c9 |
block/iscsi.c | 41 +++++++++++++++++++++++++++++++++++++++++
|
|
|
ae23c9 |
1 file changed, 41 insertions(+)
|
|
|
ae23c9 |
|
|
|
ae23c9 |
diff --git a/block/iscsi.c b/block/iscsi.c
|
|
|
ae23c9 |
index 1705187..a1a0044 100644
|
|
|
ae23c9 |
--- a/block/iscsi.c
|
|
|
ae23c9 |
+++ b/block/iscsi.c
|
|
|
ae23c9 |
@@ -69,6 +69,7 @@ typedef struct IscsiLun {
|
|
|
ae23c9 |
QemuMutex mutex;
|
|
|
ae23c9 |
struct scsi_inquiry_logical_block_provisioning lbp;
|
|
|
ae23c9 |
struct scsi_inquiry_block_limits bl;
|
|
|
ae23c9 |
+ struct scsi_inquiry_device_designator *dd;
|
|
|
ae23c9 |
unsigned char *zeroblock;
|
|
|
ae23c9 |
/* The allocmap tracks which clusters (pages) on the iSCSI target are
|
|
|
ae23c9 |
* allocated and which are not. In case a target returns zeros for
|
|
|
ae23c9 |
@@ -1737,6 +1738,30 @@ static QemuOptsList runtime_opts = {
|
|
|
ae23c9 |
},
|
|
|
ae23c9 |
};
|
|
|
ae23c9 |
|
|
|
ae23c9 |
+static void iscsi_save_designator(IscsiLun *lun,
|
|
|
ae23c9 |
+ struct scsi_inquiry_device_identification *inq_di)
|
|
|
ae23c9 |
+{
|
|
|
ae23c9 |
+ struct scsi_inquiry_device_designator *desig, *copy = NULL;
|
|
|
ae23c9 |
+
|
|
|
ae23c9 |
+ for (desig = inq_di->designators; desig; desig = desig->next) {
|
|
|
ae23c9 |
+ if (desig->association ||
|
|
|
ae23c9 |
+ desig->designator_type > SCSI_DESIGNATOR_TYPE_NAA) {
|
|
|
ae23c9 |
+ continue;
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ /* NAA works better than T10 vendor ID based designator. */
|
|
|
ae23c9 |
+ if (!copy || copy->designator_type < desig->designator_type) {
|
|
|
ae23c9 |
+ copy = desig;
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ if (copy) {
|
|
|
ae23c9 |
+ lun->dd = g_new(struct scsi_inquiry_device_designator, 1);
|
|
|
ae23c9 |
+ *lun->dd = *copy;
|
|
|
ae23c9 |
+ lun->dd->next = NULL;
|
|
|
ae23c9 |
+ lun->dd->designator = g_malloc(copy->designator_length);
|
|
|
ae23c9 |
+ memcpy(lun->dd->designator, copy->designator, copy->designator_length);
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+}
|
|
|
ae23c9 |
+
|
|
|
ae23c9 |
static int iscsi_open(BlockDriverState *bs, QDict *options, int flags,
|
|
|
ae23c9 |
Error **errp)
|
|
|
ae23c9 |
{
|
|
|
ae23c9 |
@@ -1904,6 +1929,7 @@ static int iscsi_open(BlockDriverState *bs, QDict *options, int flags,
|
|
|
ae23c9 |
struct scsi_task *inq_task;
|
|
|
ae23c9 |
struct scsi_inquiry_logical_block_provisioning *inq_lbp;
|
|
|
ae23c9 |
struct scsi_inquiry_block_limits *inq_bl;
|
|
|
ae23c9 |
+ struct scsi_inquiry_device_identification *inq_di;
|
|
|
ae23c9 |
switch (inq_vpd->pages[i]) {
|
|
|
ae23c9 |
case SCSI_INQUIRY_PAGECODE_LOGICAL_BLOCK_PROVISIONING:
|
|
|
ae23c9 |
inq_task = iscsi_do_inquiry(iscsilun->iscsi, iscsilun->lun, 1,
|
|
|
ae23c9 |
@@ -1929,6 +1955,17 @@ static int iscsi_open(BlockDriverState *bs, QDict *options, int flags,
|
|
|
ae23c9 |
sizeof(struct scsi_inquiry_block_limits));
|
|
|
ae23c9 |
scsi_free_scsi_task(inq_task);
|
|
|
ae23c9 |
break;
|
|
|
ae23c9 |
+ case SCSI_INQUIRY_PAGECODE_DEVICE_IDENTIFICATION:
|
|
|
ae23c9 |
+ inq_task = iscsi_do_inquiry(iscsilun->iscsi, iscsilun->lun, 1,
|
|
|
ae23c9 |
+ SCSI_INQUIRY_PAGECODE_DEVICE_IDENTIFICATION,
|
|
|
ae23c9 |
+ (void **) &inq_di, errp);
|
|
|
ae23c9 |
+ if (inq_task == NULL) {
|
|
|
ae23c9 |
+ ret = -EINVAL;
|
|
|
ae23c9 |
+ goto out;
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ iscsi_save_designator(iscsilun, inq_di);
|
|
|
ae23c9 |
+ scsi_free_scsi_task(inq_task);
|
|
|
ae23c9 |
+ break;
|
|
|
ae23c9 |
default:
|
|
|
ae23c9 |
break;
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
@@ -1985,6 +2022,10 @@ static void iscsi_close(BlockDriverState *bs)
|
|
|
ae23c9 |
iscsi_logout_sync(iscsi);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
iscsi_destroy_context(iscsi);
|
|
|
ae23c9 |
+ if (iscsilun->dd) {
|
|
|
ae23c9 |
+ g_free(iscsilun->dd->designator);
|
|
|
ae23c9 |
+ g_free(iscsilun->dd);
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
g_free(iscsilun->zeroblock);
|
|
|
ae23c9 |
iscsi_allocmap_free(iscsilun);
|
|
|
ae23c9 |
qemu_mutex_destroy(&iscsilun->mutex);
|
|
|
ae23c9 |
--
|
|
|
ae23c9 |
1.8.3.1
|
|
|
ae23c9 |
|