提交 fe8b9534 编写于 作者: H Hannes Reinecke 提交者: 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: NPaul Mackerras <paulus@ozlabs.org>
Signed-off-by: NHannes Reinecke <hare@suse.com>
Tested-by: NPaul Mackerras <paulus@ozlabs.org>
Reviewed-by: NBart Van Assche <bart.vanassche@sandisk.com>
Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 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% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册