summaryrefslogtreecommitdiffstats
path: root/drivers/scsi/device_handler
diff options
context:
space:
mode:
authorHannes Reinecke <hare@suse.de>2015-12-01 10:16:58 +0100
committerMartin K. Petersen <martin.petersen@oracle.com>2015-12-02 16:59:01 -0500
commit83ea0e5e3501decac0afdff25bba2ca1e78f79cc (patch)
treebdeced2359c11d6c615f81f3272ef4834d8896bd /drivers/scsi/device_handler
parenta8aa3978588a4fa2d9edabc151adedd97bbed091 (diff)
downloadlinux-stable-83ea0e5e3501decac0afdff25bba2ca1e78f79cc.tar.gz
linux-stable-83ea0e5e3501decac0afdff25bba2ca1e78f79cc.tar.bz2
linux-stable-83ea0e5e3501decac0afdff25bba2ca1e78f79cc.zip
scsi_dh_alua: use scsi_vpd_tpg_id()
Use the common function 'scsi_vpd_tpg_id()' instead of open-coding it in scsi_dh_alua. [mkp: Applied by hand] Signed-off-by: Hannes Reinecke <hare@suse.de> Reviewed-by: Johannes Thumshirn <jthumshirn@suse.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/scsi/device_handler')
-rw-r--r--drivers/scsi/device_handler/scsi_dh_alua.c37
1 files changed, 6 insertions, 31 deletions
diff --git a/drivers/scsi/device_handler/scsi_dh_alua.c b/drivers/scsi/device_handler/scsi_dh_alua.c
index 39654b1703b3..f100cbb7d2e1 100644
--- a/drivers/scsi/device_handler/scsi_dh_alua.c
+++ b/drivers/scsi/device_handler/scsi_dh_alua.c
@@ -322,36 +322,10 @@ static int alua_check_vpd(struct scsi_device *sdev, struct alua_dh_data *h)
{
unsigned char *d;
unsigned char __rcu *vpd_pg83;
+ int rel_port = -1, group_id;
- rcu_read_lock();
- if (!rcu_dereference(sdev->vpd_pg83)) {
- rcu_read_unlock();
- return SCSI_DH_DEV_UNSUPP;
- }
-
- /*
- * Look for the correct descriptor.
- */
- vpd_pg83 = rcu_dereference(sdev->vpd_pg83);
- d = vpd_pg83 + 4;
- while (d < vpd_pg83 + sdev->vpd_pg83_len) {
- switch (d[1] & 0xf) {
- case 0x4:
- /* Relative target port */
- h->rel_port = get_unaligned_be16(&d[6]);
- break;
- case 0x5:
- /* Target port group */
- h->group_id = get_unaligned_be16(&d[6]);
- break;
- default:
- break;
- }
- d += d[3] + 4;
- }
- rcu_read_unlock();
-
- if (h->group_id == -1) {
+ group_id = scsi_vpd_tpg_id(sdev, &rel_port);
+ if (group_id < 0) {
/*
* Internal error; TPGS supported but required
* VPD identification descriptors not present.
@@ -360,10 +334,11 @@ static int alua_check_vpd(struct scsi_device *sdev, struct alua_dh_data *h)
sdev_printk(KERN_INFO, sdev,
"%s: No target port descriptors found\n",
ALUA_DH_NAME);
- h->state = TPGS_STATE_OPTIMIZED;
- h->tpgs = TPGS_MODE_NONE;
return SCSI_DH_DEV_UNSUPP;
}
+ h->state = TPGS_STATE_OPTIMIZED;
+ h->group_id = group_id;
+
sdev_printk(KERN_INFO, sdev,
"%s: port group %02x rel port %02x\n",
ALUA_DH_NAME, h->group_id, h->rel_port);