|
@@ -1173,6 +1173,37 @@ rpcrdma_buffer_destroy(struct rpcrdma_buffer *buf)
|
|
|
kfree(buf->rb_pool);
|
|
|
}
|
|
|
|
|
|
+struct rpcrdma_mw *
|
|
|
+rpcrdma_get_mw(struct rpcrdma_xprt *r_xprt)
|
|
|
+{
|
|
|
+ struct rpcrdma_buffer *buf = &r_xprt->rx_buf;
|
|
|
+ struct rpcrdma_mw *mw = NULL;
|
|
|
+ unsigned long flags;
|
|
|
+
|
|
|
+ spin_lock_irqsave(&buf->rb_lock, flags);
|
|
|
+ if (!list_empty(&buf->rb_mws)) {
|
|
|
+ mw = list_first_entry(&buf->rb_mws,
|
|
|
+ struct rpcrdma_mw, mw_list);
|
|
|
+ list_del_init(&mw->mw_list);
|
|
|
+ }
|
|
|
+ spin_unlock_irqrestore(&buf->rb_lock, flags);
|
|
|
+
|
|
|
+ if (!mw)
|
|
|
+ pr_err("RPC: %s: no MWs available\n", __func__);
|
|
|
+ return mw;
|
|
|
+}
|
|
|
+
|
|
|
+void
|
|
|
+rpcrdma_put_mw(struct rpcrdma_xprt *r_xprt, struct rpcrdma_mw *mw)
|
|
|
+{
|
|
|
+ struct rpcrdma_buffer *buf = &r_xprt->rx_buf;
|
|
|
+ unsigned long flags;
|
|
|
+
|
|
|
+ spin_lock_irqsave(&buf->rb_lock, flags);
|
|
|
+ list_add_tail(&mw->mw_list, &buf->rb_mws);
|
|
|
+ spin_unlock_irqrestore(&buf->rb_lock, flags);
|
|
|
+}
|
|
|
+
|
|
|
/* "*mw" can be NULL when rpcrdma_buffer_get_mrs() fails, leaving
|
|
|
* some req segments uninitialized.
|
|
|
*/
|