diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2015-10-24 17:28:32 -0400 |
---|---|---|
committer | Anna Schumaker <Anna.Schumaker@Netapp.com> | 2015-11-02 16:29:13 -0500 |
commit | 76566773a1f1c2295ed901b6f1241cfe10d99029 (patch) | |
tree | 91395d3bb57a2733d6b4a8f3461a759770e83e92 | |
parent | 0f2e3bdab6590a5d8900e7d701e21ac9af19924c (diff) |
NFS: Enable client side NFSv4.1 backchannel to use other transports
Forechannel transports get their own "bc_up" method to create an
endpoint for the backchannel service.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
[Anna Schumaker: Add forward declaration of struct net to xprt.h]
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
-rw-r--r-- | fs/nfs/callback.c | 40 | ||||
-rw-r--r-- | include/linux/sunrpc/xprt.h | 3 | ||||
-rw-r--r-- | net/sunrpc/xprtrdma/backchannel.c | 21 | ||||
-rw-r--r-- | net/sunrpc/xprtrdma/transport.c | 1 | ||||
-rw-r--r-- | net/sunrpc/xprtrdma/xprt_rdma.h | 1 | ||||
-rw-r--r-- | net/sunrpc/xprtsock.c | 12 |
6 files changed, 46 insertions, 32 deletions
diff --git a/fs/nfs/callback.c b/fs/nfs/callback.c index 75f7c0a7538a..a7f2e6e33305 100644 --- a/fs/nfs/callback.c +++ b/fs/nfs/callback.c | |||
@@ -99,17 +99,6 @@ nfs4_callback_up(struct svc_serv *serv) | |||
99 | } | 99 | } |
100 | 100 | ||
101 | #if defined(CONFIG_NFS_V4_1) | 101 | #if defined(CONFIG_NFS_V4_1) |
102 | static int nfs41_callback_up_net(struct svc_serv *serv, struct net *net) | ||
103 | { | ||
104 | /* | ||
105 | * Create an svc_sock for the back channel service that shares the | ||
106 | * fore channel connection. | ||
107 | * Returns the input port (0) and sets the svc_serv bc_xprt on success | ||
108 | */ | ||
109 | return svc_create_xprt(serv, "tcp-bc", net, PF_INET, 0, | ||
110 | SVC_SOCK_ANONYMOUS); | ||
111 | } | ||
112 | |||
113 | /* | 102 | /* |
114 | * The callback service for NFSv4.1 callbacks | 103 | * The callback service for NFSv4.1 callbacks |
115 | */ | 104 | */ |
@@ -184,11 +173,6 @@ static inline void nfs_callback_bc_serv(u32 minorversion, struct rpc_xprt *xprt, | |||
184 | xprt->bc_serv = serv; | 173 | xprt->bc_serv = serv; |
185 | } | 174 | } |
186 | #else | 175 | #else |
187 | static int nfs41_callback_up_net(struct svc_serv *serv, struct net *net) | ||
188 | { | ||
189 | return 0; | ||
190 | } | ||
191 | |||
192 | static void nfs_minorversion_callback_svc_setup(struct svc_serv *serv, | 176 | static void nfs_minorversion_callback_svc_setup(struct svc_serv *serv, |
193 | struct svc_rqst **rqstpp, int (**callback_svc)(void *vrqstp)) | 177 | struct svc_rqst **rqstpp, int (**callback_svc)(void *vrqstp)) |
194 | { | 178 | { |
@@ -259,7 +243,8 @@ static void nfs_callback_down_net(u32 minorversion, struct svc_serv *serv, struc | |||
259 | svc_shutdown_net(serv, net); | 243 | svc_shutdown_net(serv, net); |
260 | } | 244 | } |
261 | 245 | ||
262 | static int nfs_callback_up_net(int minorversion, struct svc_serv *serv, struct net *net) | 246 | static int nfs_callback_up_net(int minorversion, struct svc_serv *serv, |
247 | struct net *net, struct rpc_xprt *xprt) | ||
263 | { | 248 | { |
264 | struct nfs_net *nn = net_generic(net, nfs_net_id); | 249 | struct nfs_net *nn = net_generic(net, nfs_net_id); |
265 | int ret; | 250 | int ret; |
@@ -275,20 +260,11 @@ static int nfs_callback_up_net(int minorversion, struct svc_serv *serv, struct n | |||
275 | goto err_bind; | 260 | goto err_bind; |
276 | } | 261 | } |
277 | 262 | ||
278 | switch (minorversion) { | 263 | ret = -EPROTONOSUPPORT; |
279 | case 0: | 264 | if (minorversion == 0) |
280 | ret = nfs4_callback_up_net(serv, net); | 265 | ret = nfs4_callback_up_net(serv, net); |
281 | break; | 266 | else if (xprt->ops->bc_up) |
282 | case 1: | 267 | ret = xprt->ops->bc_up(serv, net); |
283 | case 2: | ||
284 | ret = nfs41_callback_up_net(serv, net); | ||
285 | break; | ||
286 | default: | ||
287 | printk(KERN_ERR "NFS: unknown callback version: %d\n", | ||
288 | minorversion); | ||
289 | ret = -EINVAL; | ||
290 | break; | ||
291 | } | ||
292 | 268 | ||
293 | if (ret < 0) { | 269 | if (ret < 0) { |
294 | printk(KERN_ERR "NFS: callback service start failed\n"); | 270 | printk(KERN_ERR "NFS: callback service start failed\n"); |
@@ -364,7 +340,7 @@ int nfs_callback_up(u32 minorversion, struct rpc_xprt *xprt) | |||
364 | goto err_create; | 340 | goto err_create; |
365 | } | 341 | } |
366 | 342 | ||
367 | ret = nfs_callback_up_net(minorversion, serv, net); | 343 | ret = nfs_callback_up_net(minorversion, serv, net, xprt); |
368 | if (ret < 0) | 344 | if (ret < 0) |
369 | goto err_net; | 345 | goto err_net; |
370 | 346 | ||
diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h index 82c083946ef0..69ef5b3ab038 100644 --- a/include/linux/sunrpc/xprt.h +++ b/include/linux/sunrpc/xprt.h | |||
@@ -54,6 +54,8 @@ enum rpc_display_format_t { | |||
54 | struct rpc_task; | 54 | struct rpc_task; |
55 | struct rpc_xprt; | 55 | struct rpc_xprt; |
56 | struct seq_file; | 56 | struct seq_file; |
57 | struct svc_serv; | ||
58 | struct net; | ||
57 | 59 | ||
58 | /* | 60 | /* |
59 | * This describes a complete RPC request | 61 | * This describes a complete RPC request |
@@ -138,6 +140,7 @@ struct rpc_xprt_ops { | |||
138 | void (*inject_disconnect)(struct rpc_xprt *xprt); | 140 | void (*inject_disconnect)(struct rpc_xprt *xprt); |
139 | int (*bc_setup)(struct rpc_xprt *xprt, | 141 | int (*bc_setup)(struct rpc_xprt *xprt, |
140 | unsigned int min_reqs); | 142 | unsigned int min_reqs); |
143 | int (*bc_up)(struct svc_serv *serv, struct net *net); | ||
141 | void (*bc_free_rqst)(struct rpc_rqst *rqst); | 144 | void (*bc_free_rqst)(struct rpc_rqst *rqst); |
142 | void (*bc_destroy)(struct rpc_xprt *xprt, | 145 | void (*bc_destroy)(struct rpc_xprt *xprt, |
143 | unsigned int max_reqs); | 146 | unsigned int max_reqs); |
diff --git a/net/sunrpc/xprtrdma/backchannel.c b/net/sunrpc/xprtrdma/backchannel.c index 0b3387fe3f0d..2dcb44f69e53 100644 --- a/net/sunrpc/xprtrdma/backchannel.c +++ b/net/sunrpc/xprtrdma/backchannel.c | |||
@@ -7,6 +7,7 @@ | |||
7 | #include <linux/module.h> | 7 | #include <linux/module.h> |
8 | #include <linux/sunrpc/xprt.h> | 8 | #include <linux/sunrpc/xprt.h> |
9 | #include <linux/sunrpc/svc.h> | 9 | #include <linux/sunrpc/svc.h> |
10 | #include <linux/sunrpc/svc_xprt.h> | ||
10 | 11 | ||
11 | #include "xprt_rdma.h" | 12 | #include "xprt_rdma.h" |
12 | 13 | ||
@@ -174,6 +175,26 @@ out_err: | |||
174 | } | 175 | } |
175 | 176 | ||
176 | /** | 177 | /** |
178 | * xprt_rdma_bc_up - Create transport endpoint for backchannel service | ||
179 | * @serv: server endpoint | ||
180 | * @net: network namespace | ||
181 | * | ||
182 | * The "xprt" is an implied argument: it supplies the name of the | ||
183 | * backchannel transport class. | ||
184 | * | ||
185 | * Returns zero on success, negative errno on failure | ||
186 | */ | ||
187 | int xprt_rdma_bc_up(struct svc_serv *serv, struct net *net) | ||
188 | { | ||
189 | int ret; | ||
190 | |||
191 | ret = svc_create_xprt(serv, "rdma-bc", net, PF_INET, 0, 0); | ||
192 | if (ret < 0) | ||
193 | return ret; | ||
194 | return 0; | ||
195 | } | ||
196 | |||
197 | /** | ||
177 | * rpcrdma_bc_marshal_reply - Send backwards direction reply | 198 | * rpcrdma_bc_marshal_reply - Send backwards direction reply |
178 | * @rqst: buffer containing RPC reply data | 199 | * @rqst: buffer containing RPC reply data |
179 | * | 200 | * |
diff --git a/net/sunrpc/xprtrdma/transport.c b/net/sunrpc/xprtrdma/transport.c index 845278e63be0..8c545f7d7525 100644 --- a/net/sunrpc/xprtrdma/transport.c +++ b/net/sunrpc/xprtrdma/transport.c | |||
@@ -708,6 +708,7 @@ static struct rpc_xprt_ops xprt_rdma_procs = { | |||
708 | .inject_disconnect = xprt_rdma_inject_disconnect, | 708 | .inject_disconnect = xprt_rdma_inject_disconnect, |
709 | #if defined(CONFIG_SUNRPC_BACKCHANNEL) | 709 | #if defined(CONFIG_SUNRPC_BACKCHANNEL) |
710 | .bc_setup = xprt_rdma_bc_setup, | 710 | .bc_setup = xprt_rdma_bc_setup, |
711 | .bc_up = xprt_rdma_bc_up, | ||
711 | .bc_free_rqst = xprt_rdma_bc_free_rqst, | 712 | .bc_free_rqst = xprt_rdma_bc_free_rqst, |
712 | .bc_destroy = xprt_rdma_bc_destroy, | 713 | .bc_destroy = xprt_rdma_bc_destroy, |
713 | #endif | 714 | #endif |
diff --git a/net/sunrpc/xprtrdma/xprt_rdma.h b/net/sunrpc/xprtrdma/xprt_rdma.h index eb87d96e80ca..f8dd17be9f43 100644 --- a/net/sunrpc/xprtrdma/xprt_rdma.h +++ b/net/sunrpc/xprtrdma/xprt_rdma.h | |||
@@ -520,6 +520,7 @@ void xprt_rdma_cleanup(void); | |||
520 | */ | 520 | */ |
521 | #if defined(CONFIG_SUNRPC_BACKCHANNEL) | 521 | #if defined(CONFIG_SUNRPC_BACKCHANNEL) |
522 | int xprt_rdma_bc_setup(struct rpc_xprt *, unsigned int); | 522 | int xprt_rdma_bc_setup(struct rpc_xprt *, unsigned int); |
523 | int xprt_rdma_bc_up(struct svc_serv *, struct net *); | ||
523 | int rpcrdma_bc_post_recv(struct rpcrdma_xprt *, unsigned int); | 524 | int rpcrdma_bc_post_recv(struct rpcrdma_xprt *, unsigned int); |
524 | void rpcrdma_bc_receive_call(struct rpcrdma_xprt *, struct rpcrdma_rep *); | 525 | void rpcrdma_bc_receive_call(struct rpcrdma_xprt *, struct rpcrdma_rep *); |
525 | int rpcrdma_bc_marshal_reply(struct rpc_rqst *); | 526 | int rpcrdma_bc_marshal_reply(struct rpc_rqst *); |
diff --git a/net/sunrpc/xprtsock.c b/net/sunrpc/xprtsock.c index 44a81e4c6783..dc4706711224 100644 --- a/net/sunrpc/xprtsock.c +++ b/net/sunrpc/xprtsock.c | |||
@@ -1306,6 +1306,17 @@ static inline int _xs_tcp_read_data(struct rpc_xprt *xprt, | |||
1306 | xs_tcp_read_reply(xprt, desc) : | 1306 | xs_tcp_read_reply(xprt, desc) : |
1307 | xs_tcp_read_callback(xprt, desc); | 1307 | xs_tcp_read_callback(xprt, desc); |
1308 | } | 1308 | } |
1309 | |||
1310 | static int xs_tcp_bc_up(struct svc_serv *serv, struct net *net) | ||
1311 | { | ||
1312 | int ret; | ||
1313 | |||
1314 | ret = svc_create_xprt(serv, "tcp-bc", net, PF_INET, 0, | ||
1315 | SVC_SOCK_ANONYMOUS); | ||
1316 | if (ret < 0) | ||
1317 | return ret; | ||
1318 | return 0; | ||
1319 | } | ||
1309 | #else | 1320 | #else |
1310 | static inline int _xs_tcp_read_data(struct rpc_xprt *xprt, | 1321 | static inline int _xs_tcp_read_data(struct rpc_xprt *xprt, |
1311 | struct xdr_skb_reader *desc) | 1322 | struct xdr_skb_reader *desc) |
@@ -2582,6 +2593,7 @@ static struct rpc_xprt_ops xs_tcp_ops = { | |||
2582 | .inject_disconnect = xs_inject_disconnect, | 2593 | .inject_disconnect = xs_inject_disconnect, |
2583 | #ifdef CONFIG_SUNRPC_BACKCHANNEL | 2594 | #ifdef CONFIG_SUNRPC_BACKCHANNEL |
2584 | .bc_setup = xprt_setup_bc, | 2595 | .bc_setup = xprt_setup_bc, |
2596 | .bc_up = xs_tcp_bc_up, | ||
2585 | .bc_free_rqst = xprt_free_bc_rqst, | 2597 | .bc_free_rqst = xprt_free_bc_rqst, |
2586 | .bc_destroy = xprt_destroy_bc, | 2598 | .bc_destroy = xprt_destroy_bc, |
2587 | #endif | 2599 | #endif |