bnx2i: Fix call trace while device reset
The driver waits for command completion event while cleanup of task within the frwd lock and back locks. The frwd lock was still held which caused the call trace while issuing a device reset. Release the frwd lock along with the back lock to avoid waiting in the lock context. Signed-off-by: Nilesh Javali <nilesh.javali@qlogic.com> Reviewed-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <JBottomley@Odin.com>
This commit is contained in:
parent
5fc956c243
commit
35843048e7
@ -1173,8 +1173,10 @@ static void bnx2i_cleanup_task(struct iscsi_task *task)
|
||||
bnx2i_send_cmd_cleanup_req(hba, task->dd_data);
|
||||
|
||||
spin_unlock_bh(&conn->session->back_lock);
|
||||
spin_unlock_bh(&conn->session->frwd_lock);
|
||||
wait_for_completion_timeout(&bnx2i_conn->cmd_cleanup_cmpl,
|
||||
msecs_to_jiffies(ISCSI_CMD_CLEANUP_TIMEOUT));
|
||||
spin_lock_bh(&conn->session->frwd_lock);
|
||||
spin_lock_bh(&conn->session->back_lock);
|
||||
}
|
||||
bnx2i_iscsi_unmap_sg_list(task->dd_data);
|
||||
|
Loading…
Reference in New Issue
Block a user