]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
svcrdma: De-duplicate completion ID initialization helpers
authorChuck Lever <chuck.lever@oracle.com>
Mon, 11 Dec 2023 15:24:08 +0000 (10:24 -0500)
committerChuck Lever <chuck.lever@oracle.com>
Sun, 7 Jan 2024 22:54:31 +0000 (17:54 -0500)
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
include/linux/sunrpc/svc_rdma.h
net/sunrpc/xprtrdma/svc_rdma_recvfrom.c
net/sunrpc/xprtrdma/svc_rdma_rw.c
net/sunrpc/xprtrdma/svc_rdma_sendto.c

index 051fefde8d518c4a3d1bbd93e6a30db278c3c54a..46f2ce9f810b6cd9e1ef084af73435c2914389d6 100644 (file)
@@ -134,6 +134,30 @@ enum {
 
 #define RPCSVC_MAXPAYLOAD_RDMA RPCSVC_MAXPAYLOAD
 
+/**
+ * svc_rdma_send_cid_init - Initialize a Receive Queue completion ID
+ * @rdma: controlling transport
+ * @cid: completion ID to initialize
+ */
+static inline void svc_rdma_recv_cid_init(struct svcxprt_rdma *rdma,
+                                         struct rpc_rdma_cid *cid)
+{
+       cid->ci_queue_id = rdma->sc_rq_cq->res.id;
+       cid->ci_completion_id = atomic_inc_return(&rdma->sc_completion_ids);
+}
+
+/**
+ * svc_rdma_send_cid_init - Initialize a Send Queue completion ID
+ * @rdma: controlling transport
+ * @cid: completion ID to initialize
+ */
+static inline void svc_rdma_send_cid_init(struct svcxprt_rdma *rdma,
+                                         struct rpc_rdma_cid *cid)
+{
+       cid->ci_queue_id = rdma->sc_sq_cq->res.id;
+       cid->ci_completion_id = atomic_inc_return(&rdma->sc_completion_ids);
+}
+
 /*
  * A chunk context tracks all I/O for moving one Read or Write
  * chunk. This is a set of rdma_rw's that handle data movement
index 392a91dc8a99ae42f63f2ae4b6a7bf1aa49b7c62..ac6351e292c55cb0a7f69c334f2b66fe1cd16487 100644 (file)
@@ -115,13 +115,6 @@ svc_rdma_next_recv_ctxt(struct list_head *list)
                                        rc_list);
 }
 
-static void svc_rdma_recv_cid_init(struct svcxprt_rdma *rdma,
-                                  struct rpc_rdma_cid *cid)
-{
-       cid->ci_queue_id = rdma->sc_rq_cq->res.id;
-       cid->ci_completion_id = atomic_inc_return(&rdma->sc_completion_ids);
-}
-
 static struct svc_rdma_recv_ctxt *
 svc_rdma_recv_ctxt_alloc(struct svcxprt_rdma *rdma)
 {
index 4d2db06ccfd24d4927b50bcc89027ff229027a5e..eab71f3867fa979f056c7ca57572b9d4aabe19b5 100644 (file)
@@ -146,13 +146,6 @@ static int svc_rdma_rw_ctx_init(struct svcxprt_rdma *rdma,
        return ret;
 }
 
-static void svc_rdma_cc_cid_init(struct svcxprt_rdma *rdma,
-                                struct rpc_rdma_cid *cid)
-{
-       cid->ci_queue_id = rdma->sc_sq_cq->res.id;
-       cid->ci_completion_id = atomic_inc_return(&rdma->sc_completion_ids);
-}
-
 /**
  * svc_rdma_cc_init - Initialize an svc_rdma_chunk_ctxt
  * @rdma: controlling transport instance
@@ -161,7 +154,7 @@ static void svc_rdma_cc_cid_init(struct svcxprt_rdma *rdma,
 void svc_rdma_cc_init(struct svcxprt_rdma *rdma,
                      struct svc_rdma_chunk_ctxt *cc)
 {
-       svc_rdma_cc_cid_init(rdma, &cc->cc_cid);
+       svc_rdma_send_cid_init(rdma, &cc->cc_cid);
 
        INIT_LIST_HEAD(&cc->cc_rwctxts);
        cc->cc_sqecount = 0;
index 9571ed4a74d4eea4ab79f5c2e7c2c275f4306e88..c9585e469ca83722e6c07d18fb6d72a8bfffbbd4 100644 (file)
 
 static void svc_rdma_wc_send(struct ib_cq *cq, struct ib_wc *wc);
 
-static void svc_rdma_send_cid_init(struct svcxprt_rdma *rdma,
-                                  struct rpc_rdma_cid *cid)
-{
-       cid->ci_queue_id = rdma->sc_sq_cq->res.id;
-       cid->ci_completion_id = atomic_inc_return(&rdma->sc_completion_ids);
-}
-
 static struct svc_rdma_send_ctxt *
 svc_rdma_send_ctxt_alloc(struct svcxprt_rdma *rdma)
 {