scsi: ibmvfc: Fix I/O hang when port is not mapped
authorBrian King <brking@linux.vnet.ibm.com>
Mon, 19 Sep 2016 13:59:19 +0000 (08:59 -0500)
committerDanny Wood <danwood76@gmail.com>
Tue, 29 Jan 2019 13:14:47 +0000 (13:14 +0000)
commit0df5751b4c0982bab5525b3547e39a959e7886cc
tree5b30900495c87e97f06f775f9c6e3c56301cfea1
parentfa8327bf799edbf473f94bb0d6e8ad28b4e54de1
scsi: ibmvfc: Fix I/O hang when port is not mapped

commit 07d0e9a847401ffd2f09bd450d41644cd090e81d upstream.

If a VFC port gets unmapped in the VIOS, it may not respond with a CRQ
init complete following H_REG_CRQ. If this occurs, we can end up having
called scsi_block_requests and not a resulting unblock until the init
complete happens, which may never occur, and we end up hanging I/O
requests.  This patch ensures the host action stay set to
IBMVFC_HOST_ACTION_TGT_DEL so we move all rports into devloss state and
unblock unless we receive an init complete.

Signed-off-by: Brian King <brking@linux.vnet.ibm.com>
Acked-by: Tyrel Datwyler <tyreld@linux.vnet.ibm.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Willy Tarreau <w@1wt.eu>
drivers/scsi/ibmvscsi/ibmvfc.c