nvmf: Remove pending list for RDMA operations.

The queue depth allowed for incoming commands is set
such that we can do the maximum number of RDMA reads
necessary. There is never a case where a READ will need
to be queued anymore.

Change-Id: I4f7e7f4a59f6358065b82f36a5e22744af210d07
Signed-off-by: Ben Walker <benjamin.walker@intel.com>
This commit is contained in:
Ben Walker 2016-06-27 16:13:49 -07:00
parent 3bf5869912
commit 9efe055ec1
2 changed files with 0 additions and 55 deletions

View File

@ -182,19 +182,12 @@ nvmf_drain_cq(struct spdk_nvmf_conn *conn)
void void
nvmf_rdma_conn_cleanup(struct spdk_nvmf_conn *conn) nvmf_rdma_conn_cleanup(struct spdk_nvmf_conn *conn)
{ {
struct spdk_nvmf_rdma_request *rdma_req;
int rc; int rc;
SPDK_TRACELOG(SPDK_TRACE_DEBUG, "Enter\n"); SPDK_TRACELOG(SPDK_TRACE_DEBUG, "Enter\n");
rdma_destroy_qp(conn->rdma.cm_id); rdma_destroy_qp(conn->rdma.cm_id);
while (!STAILQ_EMPTY(&conn->rdma.pending_rdma_reqs)) {
rdma_req = STAILQ_FIRST(&conn->rdma.pending_rdma_reqs);
STAILQ_REMOVE_HEAD(&conn->rdma.pending_rdma_reqs, link);
STAILQ_INSERT_TAIL(&conn->rdma.rdma_reqs, rdma_req, link);
}
free_rdma_reqs(conn); free_rdma_reqs(conn);
nvmf_drain_cq(conn); nvmf_drain_cq(conn);
@ -256,19 +249,6 @@ nvmf_post_rdma_read(struct spdk_nvmf_conn *conn,
struct spdk_nvmf_rdma_request *rdma_req = get_rdma_req(req); struct spdk_nvmf_rdma_request *rdma_req = get_rdma_req(req);
int rc; int rc;
/*
* Queue the rdma read if it would exceed max outstanding
* RDMA read limit.
*/
if (conn->rdma.pending_rdma_read_count == conn->rdma.queue_depth) {
SPDK_TRACELOG(SPDK_TRACE_RDMA, "Insert rdma read into pending queue: rdma_req %p\n",
rdma_req);
STAILQ_REMOVE(&conn->rdma.rdma_reqs, rdma_req, spdk_nvmf_rdma_request, link);
STAILQ_INSERT_TAIL(&conn->rdma.pending_rdma_reqs, rdma_req, link);
return 0;
}
conn->rdma.pending_rdma_read_count++;
/* temporarily adjust SGE to only copy what the host is prepared to send. */ /* temporarily adjust SGE to only copy what the host is prepared to send. */
rdma_req->bb_sgl.length = req->length; rdma_req->bb_sgl.length = req->length;
@ -592,7 +572,6 @@ nvmf_rdma_connect(struct rdma_cm_event *event)
} }
SPDK_TRACELOG(SPDK_TRACE_DEBUG, "NVMf fabric connection initialized\n"); SPDK_TRACELOG(SPDK_TRACE_DEBUG, "NVMf fabric connection initialized\n");
STAILQ_INIT(&conn->rdma.pending_rdma_reqs);
STAILQ_INIT(&conn->rdma.rdma_reqs); STAILQ_INIT(&conn->rdma.rdma_reqs);
/* Allocate Buffers */ /* Allocate Buffers */
@ -888,32 +867,6 @@ nvmf_rdma_init(void)
return num_devices_found; return num_devices_found;
} }
static int
nvmf_process_pending_rdma(struct spdk_nvmf_conn *conn)
{
struct spdk_nvmf_rdma_request *rdma_req;
int rc;
conn->rdma.pending_rdma_read_count--;
if (!STAILQ_EMPTY(&conn->rdma.pending_rdma_reqs)) {
rdma_req = STAILQ_FIRST(&conn->rdma.pending_rdma_reqs);
STAILQ_REMOVE_HEAD(&conn->rdma.pending_rdma_reqs, link);
STAILQ_INSERT_TAIL(&conn->rdma.rdma_reqs, rdma_req, link);
SPDK_TRACELOG(SPDK_TRACE_RDMA, "Issue rdma read from pending queue: rdma_req %p\n",
rdma_req);
rc = nvmf_post_rdma_read(conn, &rdma_req->req);
if (rc) {
SPDK_ERRLOG("Unable to post pending rdma read descriptor\n");
return -1;
}
}
return 0;
}
static int static int
nvmf_recv(struct spdk_nvmf_conn *conn, struct ibv_wc *wc) nvmf_recv(struct spdk_nvmf_conn *conn, struct ibv_wc *wc)
{ {
@ -1012,12 +965,6 @@ nvmf_check_rdma_completions(struct spdk_nvmf_conn *conn)
SPDK_ERRLOG("request_exec error %d after RDMA Read completion\n", rc); SPDK_ERRLOG("request_exec error %d after RDMA Read completion\n", rc);
return -1; return -1;
} }
rc = nvmf_process_pending_rdma(conn);
if (rc) {
SPDK_ERRLOG("nvmf_process_pending_rdma() failed: %d\n", rc);
return -1;
}
break; break;
case IBV_WC_RECV: case IBV_WC_RECV:

View File

@ -50,8 +50,6 @@ struct spdk_nvmf_rdma_conn {
uint16_t queue_depth; uint16_t queue_depth;
uint8_t pending_rdma_read_count;
STAILQ_HEAD(, spdk_nvmf_rdma_request) pending_rdma_reqs;
STAILQ_HEAD(, spdk_nvmf_rdma_request) rdma_reqs; STAILQ_HEAD(, spdk_nvmf_rdma_request) rdma_reqs;
}; };