aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenny Halevy <bhalevy@panasas.com>2009-04-01 09:23:11 -0400
committerBenny Halevy <bhalevy@panasas.com>2009-06-17 17:11:31 -0400
commit8f975242352e92898dc641ebff0d24808f39848a (patch)
tree5a14be85500e5da33b97f4951efa42abe56cd570
parent9c9f3f5fa62cc4959e4d4d1cf1ec74f2d6ac1197 (diff)
nfs41: create a svc_xprt for nfs41 callback thread and use for incoming callbacks
Signed-off-by: Benny Halevy <bhalevy@panasas.com>
-rw-r--r--fs/nfs/callback.c17
-rw-r--r--net/sunrpc/svc.c1
2 files changed, 17 insertions, 1 deletions
diff --git a/fs/nfs/callback.c b/fs/nfs/callback.c
index 470928898063..37815f3216aa 100644
--- a/fs/nfs/callback.c
+++ b/fs/nfs/callback.c
@@ -185,16 +185,31 @@ nfs41_callback_svc(void *vrqstp)
185struct svc_rqst * 185struct svc_rqst *
186nfs41_callback_up(struct svc_serv *serv, struct rpc_xprt *xprt) 186nfs41_callback_up(struct svc_serv *serv, struct rpc_xprt *xprt)
187{ 187{
188 struct svc_xprt *bc_xprt;
189 struct svc_rqst *rqstp = ERR_PTR(-ENOMEM);
190
191 dprintk("--> %s\n", __func__);
192 /* Create a svc_sock for the service */
193 bc_xprt = svc_sock_create(serv, xprt->prot);
194 if (!bc_xprt)
195 goto out;
196
188 /* 197 /*
189 * Save the svc_serv in the transport so that it can 198 * Save the svc_serv in the transport so that it can
190 * be referenced when the session backchannel is initialized 199 * be referenced when the session backchannel is initialized
191 */ 200 */
201 serv->bc_xprt = bc_xprt;
192 xprt->bc_serv = serv; 202 xprt->bc_serv = serv;
193 203
194 INIT_LIST_HEAD(&serv->sv_cb_list); 204 INIT_LIST_HEAD(&serv->sv_cb_list);
195 spin_lock_init(&serv->sv_cb_lock); 205 spin_lock_init(&serv->sv_cb_lock);
196 init_waitqueue_head(&serv->sv_cb_waitq); 206 init_waitqueue_head(&serv->sv_cb_waitq);
197 return svc_prepare_thread(serv, &serv->sv_pools[0]); 207 rqstp = svc_prepare_thread(serv, &serv->sv_pools[0]);
208 if (IS_ERR(rqstp))
209 svc_sock_destroy(bc_xprt);
210out:
211 dprintk("--> %s return %p\n", __func__, rqstp);
212 return rqstp;
198} 213}
199 214
200static inline int nfs_minorversion_callback_svc_setup(u32 minorversion, 215static inline int nfs_minorversion_callback_svc_setup(u32 minorversion,
diff --git a/net/sunrpc/svc.c b/net/sunrpc/svc.c
index b35048fabe22..6b90ce439c00 100644
--- a/net/sunrpc/svc.c
+++ b/net/sunrpc/svc.c
@@ -1258,6 +1258,7 @@ bc_svc_process(struct svc_serv *serv, struct rpc_rqst *req,
1258 int error; 1258 int error;
1259 1259
1260 /* Build the svc_rqst used by the common processing routine */ 1260 /* Build the svc_rqst used by the common processing routine */
1261 rqstp->rq_xprt = serv->bc_xprt;
1261 rqstp->rq_xid = req->rq_xid; 1262 rqstp->rq_xid = req->rq_xid;
1262 rqstp->rq_prot = req->rq_xprt->prot; 1263 rqstp->rq_prot = req->rq_xprt->prot;
1263 rqstp->rq_server = serv; 1264 rqstp->rq_server = serv;