Skip to content

Commit 242ec14

Browse files
steffen-maiermartinkpetersen
authored andcommitted
scsi: zfcp: fix scsi_eh host reset with port_forced ERP for non-NPIV FCP devices
Suppose more than one non-NPIV FCP device is active on the same channel. Send I/O to storage and have some of the pending I/O run into a SCSI command timeout, e.g. due to bit errors on the fibre. Now the error situation stops. However, we saw FCP requests continue to timeout in the channel. The abort will be successful, but the subsequent TUR fails. Scsi_eh starts. The LUN reset fails. The target reset fails. The host reset only did an FCP device recovery. However, for non-NPIV FCP devices, this does not close and reopen ports on the SAN-side if other non-NPIV FCP device(s) share the same open ports. In order to resolve the continuing FCP request timeouts, we need to explicitly close and reopen ports on the SAN-side. This was missing since the beginning of zfcp in v2.6.0 history commit ea127f9 ("[PATCH] s390 (7/7): zfcp host adapter."). Note: The FSF requests for forced port reopen could run into FSF request timeouts due to other reasons. This would trigger an internal FCP device recovery. Pending forced port reopen recoveries would get dismissed. So some ports might not get fully reopened during this host reset handler. However, subsequent I/O would trigger the above described escalation and eventually all ports would be forced reopen to resolve any continuing FCP request timeouts due to earlier bit errors. Signed-off-by: Steffen Maier <maier@linux.ibm.com> Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Cc: <stable@vger.kernel.org> #3.0+ Reviewed-by: Jens Remus <jremus@linux.ibm.com> Reviewed-by: Benjamin Block <bblock@linux.ibm.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
1 parent fe67888 commit 242ec14

File tree

3 files changed

+20
-0
lines changed

3 files changed

+20
-0
lines changed

drivers/s390/scsi/zfcp_erp.c

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -624,6 +624,20 @@ static void zfcp_erp_strategy_memwait(struct zfcp_erp_action *erp_action)
624624
add_timer(&erp_action->timer);
625625
}
626626

627+
void zfcp_erp_port_forced_reopen_all(struct zfcp_adapter *adapter,
628+
int clear, char *dbftag)
629+
{
630+
unsigned long flags;
631+
struct zfcp_port *port;
632+
633+
write_lock_irqsave(&adapter->erp_lock, flags);
634+
read_lock(&adapter->port_list_lock);
635+
list_for_each_entry(port, &adapter->port_list, list)
636+
_zfcp_erp_port_forced_reopen(port, clear, dbftag);
637+
read_unlock(&adapter->port_list_lock);
638+
write_unlock_irqrestore(&adapter->erp_lock, flags);
639+
}
640+
627641
static void _zfcp_erp_port_reopen_all(struct zfcp_adapter *adapter,
628642
int clear, char *dbftag)
629643
{

drivers/s390/scsi/zfcp_ext.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -70,6 +70,8 @@ extern void zfcp_erp_port_reopen(struct zfcp_port *port, int clear,
7070
char *dbftag);
7171
extern void zfcp_erp_port_shutdown(struct zfcp_port *, int, char *);
7272
extern void zfcp_erp_port_forced_reopen(struct zfcp_port *, int, char *);
73+
extern void zfcp_erp_port_forced_reopen_all(struct zfcp_adapter *adapter,
74+
int clear, char *dbftag);
7375
extern void zfcp_erp_set_lun_status(struct scsi_device *, u32);
7476
extern void zfcp_erp_clear_lun_status(struct scsi_device *, u32);
7577
extern void zfcp_erp_lun_reopen(struct scsi_device *, int, char *);

drivers/s390/scsi/zfcp_scsi.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -368,6 +368,10 @@ static int zfcp_scsi_eh_host_reset_handler(struct scsi_cmnd *scpnt)
368368
struct zfcp_adapter *adapter = zfcp_sdev->port->adapter;
369369
int ret = SUCCESS, fc_ret;
370370

371+
if (!(adapter->connection_features & FSF_FEATURE_NPIV_MODE)) {
372+
zfcp_erp_port_forced_reopen_all(adapter, 0, "schrh_p");
373+
zfcp_erp_wait(adapter);
374+
}
371375
zfcp_erp_adapter_reopen(adapter, 0, "schrh_1");
372376
zfcp_erp_wait(adapter);
373377
fc_ret = fc_block_scsi_eh(scpnt);

0 commit comments

Comments
 (0)