Commit da2f132d authored by Mike Christie's avatar Mike Christie Committed by Martin K. Petersen

scsi: iscsi: Clean up bound endpoints during shutdown

In the next patch we allow drivers to drive session removal during
shutdown. In this case iscsid will not be running, so we need to detect
bound endpoints and disconnect them. This moves the bound ep check so we
now always check.

Link: https://lore.kernel.org/r/20220616222738.5722-4-michael.christie@oracle.comTested-by: default avatarNilesh Javali <njavali@marvell.com>
Reviewed-by: default avatarNilesh Javali <njavali@marvell.com>
Signed-off-by: default avatarMike Christie <michael.christie@oracle.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 3328333b
...@@ -2260,6 +2260,16 @@ static void iscsi_if_disconnect_bound_ep(struct iscsi_cls_conn *conn, ...@@ -2260,6 +2260,16 @@ static void iscsi_if_disconnect_bound_ep(struct iscsi_cls_conn *conn,
static int iscsi_if_stop_conn(struct iscsi_cls_conn *conn, int flag) static int iscsi_if_stop_conn(struct iscsi_cls_conn *conn, int flag)
{ {
ISCSI_DBG_TRANS_CONN(conn, "iscsi if conn stop.\n"); ISCSI_DBG_TRANS_CONN(conn, "iscsi if conn stop.\n");
/*
* For offload, iscsid may not know about the ep like when iscsid is
* restarted or for kernel based session shutdown iscsid is not even
* up. For these cases, we do the disconnect now.
*/
mutex_lock(&conn->ep_mutex);
if (conn->ep)
iscsi_if_disconnect_bound_ep(conn, conn->ep, true);
mutex_unlock(&conn->ep_mutex);
/* /*
* If this is a termination we have to call stop_conn with that flag * If this is a termination we have to call stop_conn with that flag
* so the correct states get set. If we haven't run the work yet try to * so the correct states get set. If we haven't run the work yet try to
...@@ -2269,16 +2279,6 @@ static int iscsi_if_stop_conn(struct iscsi_cls_conn *conn, int flag) ...@@ -2269,16 +2279,6 @@ static int iscsi_if_stop_conn(struct iscsi_cls_conn *conn, int flag)
cancel_work_sync(&conn->cleanup_work); cancel_work_sync(&conn->cleanup_work);
iscsi_stop_conn(conn, flag); iscsi_stop_conn(conn, flag);
} else { } else {
/*
* For offload, when iscsid is restarted it won't know about
* existing endpoints so it can't do a ep_disconnect. We clean
* it up here for userspace.
*/
mutex_lock(&conn->ep_mutex);
if (conn->ep)
iscsi_if_disconnect_bound_ep(conn, conn->ep, true);
mutex_unlock(&conn->ep_mutex);
/* /*
* Figure out if it was the kernel or userspace initiating this. * Figure out if it was the kernel or userspace initiating this.
*/ */
......
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