Commit 30158dc9 authored by Suganath prabu Subramani's avatar Suganath prabu Subramani Committed by Martin K. Petersen

mpt3sas: Never block the Enclosure device

Never block the SEP device (i.e. Never invoke the
scsi_internal_device_block() API for SEP device) even for the delay not
responding events. Blocking the SEP device will create a deadlock while
adding any device to the OS.
Signed-off-by: default avatarSuganath prabu Subramani <suganath-prabu.subramani@avagotech.com>
Signed-off-by: default avatarChaitra P B <chaitra.basappa@avagotech.com>
Reviewed-by: default avatarTomas Henzl <thenzl@redhat.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 869817f9
...@@ -398,6 +398,7 @@ struct MPT3SAS_DEVICE { ...@@ -398,6 +398,7 @@ struct MPT3SAS_DEVICE {
u8 configured_lun; u8 configured_lun;
u8 block; u8 block;
u8 tlr_snoop_check; u8 tlr_snoop_check;
u8 ignore_delay_remove;
}; };
#define MPT3_CMD_NOT_USED 0x8000 /* free */ #define MPT3_CMD_NOT_USED 0x8000 /* free */
......
...@@ -1953,6 +1953,14 @@ scsih_slave_configure(struct scsi_device *sdev) ...@@ -1953,6 +1953,14 @@ scsih_slave_configure(struct scsi_device *sdev)
if (sas_device->device_info & MPI2_SAS_DEVICE_INFO_SSP_TARGET) { if (sas_device->device_info & MPI2_SAS_DEVICE_INFO_SSP_TARGET) {
qdepth = MPT3SAS_SAS_QUEUE_DEPTH; qdepth = MPT3SAS_SAS_QUEUE_DEPTH;
ssp_target = 1; ssp_target = 1;
if (sas_device->device_info &
MPI2_SAS_DEVICE_INFO_SEP) {
sdev_printk(KERN_WARNING, sdev,
"set ignore_delay_remove for handle(0x%04x)\n",
sas_device_priv_data->sas_target->handle);
sas_device_priv_data->ignore_delay_remove = 1;
ds = "SES";
} else
ds = "SSP"; ds = "SSP";
} else { } else {
qdepth = MPT3SAS_SATA_QUEUE_DEPTH; qdepth = MPT3SAS_SATA_QUEUE_DEPTH;
...@@ -2943,6 +2951,12 @@ _scsih_block_io_all_device(struct MPT3SAS_ADAPTER *ioc) ...@@ -2943,6 +2951,12 @@ _scsih_block_io_all_device(struct MPT3SAS_ADAPTER *ioc)
continue; continue;
if (sas_device_priv_data->block) if (sas_device_priv_data->block)
continue; continue;
if (sas_device_priv_data->ignore_delay_remove) {
sdev_printk(KERN_INFO, sdev,
"%s skip device_block for SES handle(0x%04x)\n",
__func__, sas_device_priv_data->sas_target->handle);
continue;
}
_scsih_internal_device_block(sdev, sas_device_priv_data); _scsih_internal_device_block(sdev, sas_device_priv_data);
} }
} }
...@@ -2975,6 +2989,12 @@ _scsih_block_io_device(struct MPT3SAS_ADAPTER *ioc, u16 handle) ...@@ -2975,6 +2989,12 @@ _scsih_block_io_device(struct MPT3SAS_ADAPTER *ioc, u16 handle)
continue; continue;
if (sas_device->pend_sas_rphy_add) if (sas_device->pend_sas_rphy_add)
continue; continue;
if (sas_device_priv_data->ignore_delay_remove) {
sdev_printk(KERN_INFO, sdev,
"%s skip device_block for SES handle(0x%04x)\n",
__func__, sas_device_priv_data->sas_target->handle);
continue;
}
_scsih_internal_device_block(sdev, sas_device_priv_data); _scsih_internal_device_block(sdev, sas_device_priv_data);
} }
......
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