Commit fe8b9534 authored by Hannes Reinecke's avatar Hannes Reinecke Committed by Martin K. Petersen

scsi_dh_alua: do not fail for unknown VPD identification

Not every device will return a useable VPD identification, but still
might support ALUA. Rather than disable ALUA support we should be
allowing the device identification to be empty and attach individual
ALUA device handler to each devices.

[mkp: Fixed typo reported by Bart]
Reported-by: default avatarPaul Mackerras <paulus@ozlabs.org>
Signed-off-by: default avatarHannes Reinecke <hare@suse.com>
Tested-by: default avatarPaul Mackerras <paulus@ozlabs.org>
Reviewed-by: default avatarBart Van Assche <bart.vanassche@sandisk.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 1b37bd60
...@@ -195,10 +195,13 @@ static struct alua_port_group *alua_find_get_pg(char *id_str, size_t id_size, ...@@ -195,10 +195,13 @@ static struct alua_port_group *alua_find_get_pg(char *id_str, size_t id_size,
{ {
struct alua_port_group *pg; struct alua_port_group *pg;
if (!id_str || !id_size || !strlen(id_str))
return NULL;
list_for_each_entry(pg, &port_group_list, node) { list_for_each_entry(pg, &port_group_list, node) {
if (pg->group_id != group_id) if (pg->group_id != group_id)
continue; continue;
if (pg->device_id_len != id_size) if (!pg->device_id_len || pg->device_id_len != id_size)
continue; continue;
if (strncmp(pg->device_id_str, id_str, id_size)) if (strncmp(pg->device_id_str, id_str, id_size))
continue; continue;
...@@ -232,14 +235,14 @@ static struct alua_port_group *alua_alloc_pg(struct scsi_device *sdev, ...@@ -232,14 +235,14 @@ static struct alua_port_group *alua_alloc_pg(struct scsi_device *sdev,
sizeof(pg->device_id_str)); sizeof(pg->device_id_str));
if (pg->device_id_len <= 0) { if (pg->device_id_len <= 0) {
/* /*
* Internal error: TPGS supported but no device * TPGS supported but no device identification found.
* identifcation found. Disable ALUA support. * Generate private device identification.
*/ */
kfree(pg);
sdev_printk(KERN_INFO, sdev, sdev_printk(KERN_INFO, sdev,
"%s: No device descriptors found\n", "%s: No device descriptors found\n",
ALUA_DH_NAME); ALUA_DH_NAME);
return ERR_PTR(-ENXIO); pg->device_id_str[0] = '\0';
pg->device_id_len = 0;
} }
pg->group_id = group_id; pg->group_id = group_id;
pg->tpgs = tpgs; pg->tpgs = tpgs;
...@@ -354,9 +357,15 @@ static int alua_check_vpd(struct scsi_device *sdev, struct alua_dh_data *h, ...@@ -354,9 +357,15 @@ static int alua_check_vpd(struct scsi_device *sdev, struct alua_dh_data *h,
return SCSI_DH_NOMEM; return SCSI_DH_NOMEM;
return SCSI_DH_DEV_UNSUPP; return SCSI_DH_DEV_UNSUPP;
} }
if (pg->device_id_len)
sdev_printk(KERN_INFO, sdev, sdev_printk(KERN_INFO, sdev,
"%s: device %s port group %x rel port %x\n", "%s: device %s port group %x rel port %x\n",
ALUA_DH_NAME, pg->device_id_str, group_id, rel_port); ALUA_DH_NAME, pg->device_id_str,
group_id, rel_port);
else
sdev_printk(KERN_INFO, sdev,
"%s: port group %x rel port %x\n",
ALUA_DH_NAME, group_id, rel_port);
/* Check for existing port group references */ /* Check for existing port group references */
spin_lock(&h->pg_lock); spin_lock(&h->pg_lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment