diff options
author | Martin Wilck <mwilck@suse.com> | 2021-05-14 17:32:14 +0200 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2021-05-21 23:06:29 -0400 |
commit | ee8868c5c78f16fb726775741aeab8a233373332 (patch) | |
tree | 9add38ad000c99a58999a73f0cbe33ec780223b1 /drivers/scsi/lpfc/lpfc_nportdisc.c | |
parent | cb9eb11fd57215020c6649bbe884232fb0f80bdd (diff) | |
download | lwn-ee8868c5c78f16fb726775741aeab8a233373332.tar.gz lwn-ee8868c5c78f16fb726775741aeab8a233373332.zip |
scsi: scsi_dh_alua: Retry RTPG on a different path after failure
If an RTPG fails, we can't infer anything wrt. the state of the ports in
the port group except that we were unable to reach the one port on which
the RTPG had failed. "offline" is just a secondary port state, which means
that we can't infer the state of any port in the PG from the failure (in
fact, even the failed port might still be in "active/optimized" primary
port access state).
Therefore, when we encounter an RTPG failure, we should retry the RTPG on a
different port. This avoids falsely setting port states to offline for
unreachable ports. To do this, ports on which an RTPG has failed are
temporarily set to "disabled" to avoid repeating the failed I/O on the same
target port. Once the RTPG has either succeeded on one port or failed on
all ports of the PG, the ports are enabled again.
Link: https://lore.kernel.org/r/20210514153214.5626-1-mwilck@suse.com
Signed-off-by: Martin Wilck <mwilck@suse.com>
Signed-off-by: Hannes Reinecke <hare@suse.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_nportdisc.c')
0 files changed, 0 insertions, 0 deletions