aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/sunrpc/xprtrdma/transport.c19
-rw-r--r--net/sunrpc/xprtrdma/xprt_rdma.h6
2 files changed, 13 insertions, 12 deletions
diff --git a/net/sunrpc/xprtrdma/transport.c b/net/sunrpc/xprtrdma/transport.c
index bbd6155d3e34..ee5751326339 100644
--- a/net/sunrpc/xprtrdma/transport.c
+++ b/net/sunrpc/xprtrdma/transport.c
@@ -200,9 +200,9 @@ xprt_rdma_free_addresses(struct rpc_xprt *xprt)
200static void 200static void
201xprt_rdma_connect_worker(struct work_struct *work) 201xprt_rdma_connect_worker(struct work_struct *work)
202{ 202{
203 struct rpcrdma_xprt *r_xprt = 203 struct rpcrdma_xprt *r_xprt = container_of(work, struct rpcrdma_xprt,
204 container_of(work, struct rpcrdma_xprt, rdma_connect.work); 204 rx_connect_worker.work);
205 struct rpc_xprt *xprt = &r_xprt->xprt; 205 struct rpc_xprt *xprt = &r_xprt->rx_xprt;
206 int rc = 0; 206 int rc = 0;
207 207
208 xprt_clear_connected(xprt); 208 xprt_clear_connected(xprt);
@@ -235,7 +235,7 @@ xprt_rdma_destroy(struct rpc_xprt *xprt)
235 235
236 dprintk("RPC: %s: called\n", __func__); 236 dprintk("RPC: %s: called\n", __func__);
237 237
238 cancel_delayed_work_sync(&r_xprt->rdma_connect); 238 cancel_delayed_work_sync(&r_xprt->rx_connect_worker);
239 239
240 xprt_clear_connected(xprt); 240 xprt_clear_connected(xprt);
241 241
@@ -374,7 +374,8 @@ xprt_setup_rdma(struct xprt_create *args)
374 * connection loss notification is async. We also catch connection loss 374 * connection loss notification is async. We also catch connection loss
375 * when reaping receives. 375 * when reaping receives.
376 */ 376 */
377 INIT_DELAYED_WORK(&new_xprt->rdma_connect, xprt_rdma_connect_worker); 377 INIT_DELAYED_WORK(&new_xprt->rx_connect_worker,
378 xprt_rdma_connect_worker);
378 new_ep->rep_func = rpcrdma_conn_func; 379 new_ep->rep_func = rpcrdma_conn_func;
379 new_ep->rep_xprt = xprt; 380 new_ep->rep_xprt = xprt;
380 381
@@ -434,17 +435,17 @@ xprt_rdma_connect(struct rpc_xprt *xprt, struct rpc_task *task)
434 435
435 if (r_xprt->rx_ep.rep_connected != 0) { 436 if (r_xprt->rx_ep.rep_connected != 0) {
436 /* Reconnect */ 437 /* Reconnect */
437 schedule_delayed_work(&r_xprt->rdma_connect, 438 schedule_delayed_work(&r_xprt->rx_connect_worker,
438 xprt->reestablish_timeout); 439 xprt->reestablish_timeout);
439 xprt->reestablish_timeout <<= 1; 440 xprt->reestablish_timeout <<= 1;
440 if (xprt->reestablish_timeout > RPCRDMA_MAX_REEST_TO) 441 if (xprt->reestablish_timeout > RPCRDMA_MAX_REEST_TO)
441 xprt->reestablish_timeout = RPCRDMA_MAX_REEST_TO; 442 xprt->reestablish_timeout = RPCRDMA_MAX_REEST_TO;
442 else if (xprt->reestablish_timeout < RPCRDMA_INIT_REEST_TO) 443 else if (xprt->reestablish_timeout < RPCRDMA_INIT_REEST_TO)
443 xprt->reestablish_timeout = RPCRDMA_INIT_REEST_TO; 444 xprt->reestablish_timeout = RPCRDMA_INIT_REEST_TO;
444 } else { 445 } else {
445 schedule_delayed_work(&r_xprt->rdma_connect, 0); 446 schedule_delayed_work(&r_xprt->rx_connect_worker, 0);
446 if (!RPC_IS_ASYNC(task)) 447 if (!RPC_IS_ASYNC(task))
447 flush_delayed_work(&r_xprt->rdma_connect); 448 flush_delayed_work(&r_xprt->rx_connect_worker);
448 } 449 }
449} 450}
450 451
diff --git a/net/sunrpc/xprtrdma/xprt_rdma.h b/net/sunrpc/xprtrdma/xprt_rdma.h
index b799041b75bf..9a7aab31bf6e 100644
--- a/net/sunrpc/xprtrdma/xprt_rdma.h
+++ b/net/sunrpc/xprtrdma/xprt_rdma.h
@@ -318,16 +318,16 @@ struct rpcrdma_stats {
318 * during unmount. 318 * during unmount.
319 */ 319 */
320struct rpcrdma_xprt { 320struct rpcrdma_xprt {
321 struct rpc_xprt xprt; 321 struct rpc_xprt rx_xprt;
322 struct rpcrdma_ia rx_ia; 322 struct rpcrdma_ia rx_ia;
323 struct rpcrdma_ep rx_ep; 323 struct rpcrdma_ep rx_ep;
324 struct rpcrdma_buffer rx_buf; 324 struct rpcrdma_buffer rx_buf;
325 struct rpcrdma_create_data_internal rx_data; 325 struct rpcrdma_create_data_internal rx_data;
326 struct delayed_work rdma_connect; 326 struct delayed_work rx_connect_worker;
327 struct rpcrdma_stats rx_stats; 327 struct rpcrdma_stats rx_stats;
328}; 328};
329 329
330#define rpcx_to_rdmax(x) container_of(x, struct rpcrdma_xprt, xprt) 330#define rpcx_to_rdmax(x) container_of(x, struct rpcrdma_xprt, rx_xprt)
331#define rpcx_to_rdmad(x) (rpcx_to_rdmax(x)->rx_data) 331#define rpcx_to_rdmad(x) (rpcx_to_rdmax(x)->rx_data)
332 332
333/* Setting this to 0 ensures interoperability with early servers. 333/* Setting this to 0 ensures interoperability with early servers.