|
@@ -63,9 +63,6 @@
|
|
|
# define RPCDBG_FACILITY RPCDBG_TRANS
|
|
|
#endif
|
|
|
|
|
|
-static void rpcrdma_reset_frmrs(struct rpcrdma_ia *);
|
|
|
-static void rpcrdma_reset_fmrs(struct rpcrdma_ia *);
|
|
|
-
|
|
|
/*
|
|
|
* internal functions
|
|
|
*/
|
|
@@ -945,21 +942,9 @@ retry:
|
|
|
rpcrdma_ep_disconnect(ep, ia);
|
|
|
rpcrdma_flush_cqs(ep);
|
|
|
|
|
|
- switch (ia->ri_memreg_strategy) {
|
|
|
- case RPCRDMA_FRMR:
|
|
|
- rpcrdma_reset_frmrs(ia);
|
|
|
- break;
|
|
|
- case RPCRDMA_MTHCAFMR:
|
|
|
- rpcrdma_reset_fmrs(ia);
|
|
|
- break;
|
|
|
- case RPCRDMA_ALLPHYSICAL:
|
|
|
- break;
|
|
|
- default:
|
|
|
- rc = -EIO;
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
xprt = container_of(ia, struct rpcrdma_xprt, rx_ia);
|
|
|
+ ia->ri_ops->ro_reset(xprt);
|
|
|
+
|
|
|
id = rpcrdma_create_id(xprt, ia,
|
|
|
(struct sockaddr *)&xprt->rx_data.addr);
|
|
|
if (IS_ERR(id)) {
|
|
@@ -1289,90 +1274,6 @@ rpcrdma_buffer_destroy(struct rpcrdma_buffer *buf)
|
|
|
kfree(buf->rb_pool);
|
|
|
}
|
|
|
|
|
|
-/* After a disconnect, unmap all FMRs.
|
|
|
- *
|
|
|
- * This is invoked only in the transport connect worker in order
|
|
|
- * to serialize with rpcrdma_register_fmr_external().
|
|
|
- */
|
|
|
-static void
|
|
|
-rpcrdma_reset_fmrs(struct rpcrdma_ia *ia)
|
|
|
-{
|
|
|
- struct rpcrdma_xprt *r_xprt =
|
|
|
- container_of(ia, struct rpcrdma_xprt, rx_ia);
|
|
|
- struct rpcrdma_buffer *buf = &r_xprt->rx_buf;
|
|
|
- struct list_head *pos;
|
|
|
- struct rpcrdma_mw *r;
|
|
|
- LIST_HEAD(l);
|
|
|
- int rc;
|
|
|
-
|
|
|
- list_for_each(pos, &buf->rb_all) {
|
|
|
- r = list_entry(pos, struct rpcrdma_mw, mw_all);
|
|
|
-
|
|
|
- INIT_LIST_HEAD(&l);
|
|
|
- list_add(&r->r.fmr->list, &l);
|
|
|
- rc = ib_unmap_fmr(&l);
|
|
|
- if (rc)
|
|
|
- dprintk("RPC: %s: ib_unmap_fmr failed %i\n",
|
|
|
- __func__, rc);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-/* After a disconnect, a flushed FAST_REG_MR can leave an FRMR in
|
|
|
- * an unusable state. Find FRMRs in this state and dereg / reg
|
|
|
- * each. FRMRs that are VALID and attached to an rpcrdma_req are
|
|
|
- * also torn down.
|
|
|
- *
|
|
|
- * This gives all in-use FRMRs a fresh rkey and leaves them INVALID.
|
|
|
- *
|
|
|
- * This is invoked only in the transport connect worker in order
|
|
|
- * to serialize with rpcrdma_register_frmr_external().
|
|
|
- */
|
|
|
-static void
|
|
|
-rpcrdma_reset_frmrs(struct rpcrdma_ia *ia)
|
|
|
-{
|
|
|
- struct rpcrdma_xprt *r_xprt =
|
|
|
- container_of(ia, struct rpcrdma_xprt, rx_ia);
|
|
|
- struct rpcrdma_buffer *buf = &r_xprt->rx_buf;
|
|
|
- struct list_head *pos;
|
|
|
- struct rpcrdma_mw *r;
|
|
|
- int rc;
|
|
|
-
|
|
|
- list_for_each(pos, &buf->rb_all) {
|
|
|
- r = list_entry(pos, struct rpcrdma_mw, mw_all);
|
|
|
-
|
|
|
- if (r->r.frmr.fr_state == FRMR_IS_INVALID)
|
|
|
- continue;
|
|
|
-
|
|
|
- rc = ib_dereg_mr(r->r.frmr.fr_mr);
|
|
|
- if (rc)
|
|
|
- dprintk("RPC: %s: ib_dereg_mr failed %i\n",
|
|
|
- __func__, rc);
|
|
|
- ib_free_fast_reg_page_list(r->r.frmr.fr_pgl);
|
|
|
-
|
|
|
- r->r.frmr.fr_mr = ib_alloc_fast_reg_mr(ia->ri_pd,
|
|
|
- ia->ri_max_frmr_depth);
|
|
|
- if (IS_ERR(r->r.frmr.fr_mr)) {
|
|
|
- rc = PTR_ERR(r->r.frmr.fr_mr);
|
|
|
- dprintk("RPC: %s: ib_alloc_fast_reg_mr"
|
|
|
- " failed %i\n", __func__, rc);
|
|
|
- continue;
|
|
|
- }
|
|
|
- r->r.frmr.fr_pgl = ib_alloc_fast_reg_page_list(
|
|
|
- ia->ri_id->device,
|
|
|
- ia->ri_max_frmr_depth);
|
|
|
- if (IS_ERR(r->r.frmr.fr_pgl)) {
|
|
|
- rc = PTR_ERR(r->r.frmr.fr_pgl);
|
|
|
- dprintk("RPC: %s: "
|
|
|
- "ib_alloc_fast_reg_page_list "
|
|
|
- "failed %i\n", __func__, rc);
|
|
|
-
|
|
|
- ib_dereg_mr(r->r.frmr.fr_mr);
|
|
|
- continue;
|
|
|
- }
|
|
|
- r->r.frmr.fr_state = FRMR_IS_INVALID;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
/* "*mw" can be NULL when rpcrdma_buffer_get_mrs() fails, leaving
|
|
|
* some req segments uninitialized.
|
|
|
*/
|