Commit 4a295bae authored by Sagi Grimberg's avatar Sagi Grimberg Committed by Nicholas Bellinger

iser-target: Centralize completion elements to a context

A pre-step before going to a single CQ.
Also this makes the code a little more simple to
read.
Signed-off-by: default avatarSagi Grimberg <sagig@mellanox.com>
Signed-off-by: default avatarNicholas Bellinger <nab@linux-iscsi.org>
parent b0a191e7
This diff is collapsed.
...@@ -159,23 +159,33 @@ struct isert_conn { ...@@ -159,23 +159,33 @@ struct isert_conn {
#define ISERT_MAX_CQ 64 #define ISERT_MAX_CQ 64
struct isert_cq_desc { /**
* struct isert_comp - iSER completion context
*
* @device: pointer to device handle
* @rx_cq: RX completion queue
* @tx_cq: TX completion queue
* @active_qps: Number of active QPs attached
* to completion context
* @rx_work: RX work handle
* @tx_work: TX work handle
*/
struct isert_comp {
struct isert_device *device; struct isert_device *device;
int cq_index; struct ib_cq *rx_cq;
struct work_struct cq_rx_work; struct ib_cq *tx_cq;
struct work_struct cq_tx_work; int active_qps;
struct work_struct rx_work;
struct work_struct tx_work;
}; };
struct isert_device { struct isert_device {
int use_fastreg; int use_fastreg;
bool pi_capable; bool pi_capable;
int cqs_used;
int refcount; int refcount;
int cq_active_qps[ISERT_MAX_CQ];
struct ib_device *ib_device; struct ib_device *ib_device;
struct ib_cq *dev_rx_cq[ISERT_MAX_CQ]; struct isert_comp *comps;
struct ib_cq *dev_tx_cq[ISERT_MAX_CQ]; int comps_used;
struct isert_cq_desc *cq_desc;
struct list_head dev_node; struct list_head dev_node;
struct ib_device_attr dev_attr; struct ib_device_attr dev_attr;
int (*reg_rdma_mem)(struct iscsi_conn *conn, int (*reg_rdma_mem)(struct iscsi_conn *conn,
......
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