Commit 24246de7 authored by Mike Christie's avatar Mike Christie Committed by James Bottomley

[SCSI] bnx2i: use common iscsi suspend queue

This just has bnx2i use the iscsi_suspend_queue helper.

The suspend works as follows:

When ep_poll has succeeed iscsid will call conn_bind, the LLD will
then call iscsi_conn_bind which will clear the suspend bit.
When ep_disconnect is called (or if there is a conn error) we set
the suspend bit. For the ep_disconnect case I  added a helper
in the previous kernel that will take the session lock to make sure
iscsi_queuecommand/xmit_task is not running and it will set
the suspend bit.
Signed-off-by: default avatarMike Christie <michaelc@cs.wisc.edu>
Acked-by: default avatarAnil Veerabhadrappa <anilgv@broadcom.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@suse.de>
parent 627511e3
...@@ -232,7 +232,6 @@ struct bnx2i_conn { ...@@ -232,7 +232,6 @@ struct bnx2i_conn {
struct iscsi_cls_conn *cls_conn; struct iscsi_cls_conn *cls_conn;
struct bnx2i_hba *hba; struct bnx2i_hba *hba;
struct completion cmd_cleanup_cmpl; struct completion cmd_cleanup_cmpl;
int is_bound;
u32 iscsi_conn_cid; u32 iscsi_conn_cid;
#define BNX2I_CID_RESERVED 0x5AFF #define BNX2I_CID_RESERVED 0x5AFF
......
...@@ -1161,9 +1161,6 @@ static int bnx2i_task_xmit(struct iscsi_task *task) ...@@ -1161,9 +1161,6 @@ static int bnx2i_task_xmit(struct iscsi_task *task)
struct bnx2i_cmd *cmd = task->dd_data; struct bnx2i_cmd *cmd = task->dd_data;
struct iscsi_cmd *hdr = (struct iscsi_cmd *) task->hdr; struct iscsi_cmd *hdr = (struct iscsi_cmd *) task->hdr;
if (!bnx2i_conn->is_bound)
return -ENOTCONN;
/* /*
* If there is no scsi_cmnd this must be a mgmt task * If there is no scsi_cmnd this must be a mgmt task
*/ */
...@@ -1371,7 +1368,6 @@ static int bnx2i_conn_bind(struct iscsi_cls_session *cls_session, ...@@ -1371,7 +1368,6 @@ static int bnx2i_conn_bind(struct iscsi_cls_session *cls_session,
bnx2i_conn->ep = bnx2i_ep; bnx2i_conn->ep = bnx2i_ep;
bnx2i_conn->iscsi_conn_cid = bnx2i_ep->ep_iscsi_cid; bnx2i_conn->iscsi_conn_cid = bnx2i_ep->ep_iscsi_cid;
bnx2i_conn->fw_cid = bnx2i_ep->ep_cid; bnx2i_conn->fw_cid = bnx2i_ep->ep_cid;
bnx2i_conn->is_bound = 1;
ret_code = bnx2i_bind_conn_to_iscsi_cid(hba, bnx2i_conn, ret_code = bnx2i_bind_conn_to_iscsi_cid(hba, bnx2i_conn,
bnx2i_ep->ep_iscsi_cid); bnx2i_ep->ep_iscsi_cid);
...@@ -1896,9 +1892,7 @@ static void bnx2i_ep_disconnect(struct iscsi_endpoint *ep) ...@@ -1896,9 +1892,7 @@ static void bnx2i_ep_disconnect(struct iscsi_endpoint *ep)
conn = bnx2i_conn->cls_conn->dd_data; conn = bnx2i_conn->cls_conn->dd_data;
session = conn->session; session = conn->session;
spin_lock_bh(&session->lock); iscsi_suspend_queue(conn);
bnx2i_conn->is_bound = 0;
spin_unlock_bh(&session->lock);
} }
hba = bnx2i_ep->hba; hba = bnx2i_ep->hba;
......
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