Commit aa611e1b authored by Quinn Tran's avatar Quinn Tran Committed by Stefan Bader

scsi: qla2xxx: Fix unbound sleep in fcport delete path.

BugLink: https://bugs.launchpad.net/bugs/1850454

[ Upstream commit c3b6a1d3 ]

There are instances, though rare, where a LOGO request cannot be sent out
and the thread in free session done can wait indefinitely. Fix this by
putting an upper bound to sleep.

Link: https://lore.kernel.org/r/20190912180918.6436-3-hmadhani@marvell.comSigned-off-by: default avatarQuinn Tran <qutran@marvell.com>
Signed-off-by: default avatarHimanshu Madhani <hmadhani@marvell.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Signed-off-by: default avatarConnor Kuehl <connor.kuehl@canonical.com>
Signed-off-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
parent 8cb02a4e
...@@ -572,6 +572,7 @@ static void qlt_free_session_done(struct work_struct *work) ...@@ -572,6 +572,7 @@ static void qlt_free_session_done(struct work_struct *work)
if (logout_started) { if (logout_started) {
bool traced = false; bool traced = false;
u16 cnt = 0;
while (!ACCESS_ONCE(sess->logout_completed)) { while (!ACCESS_ONCE(sess->logout_completed)) {
if (!traced) { if (!traced) {
...@@ -581,6 +582,9 @@ static void qlt_free_session_done(struct work_struct *work) ...@@ -581,6 +582,9 @@ static void qlt_free_session_done(struct work_struct *work)
traced = true; traced = true;
} }
msleep(100); msleep(100);
cnt++;
if (cnt > 200)
break;
} }
ql_dbg(ql_dbg_tgt_mgt, vha, 0xf087, ql_dbg(ql_dbg_tgt_mgt, vha, 0xf087,
......
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