diff options
author | Andy Adamson <andros@netapp.com> | 2011-01-05 21:04:24 -0500 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2011-01-06 14:46:23 -0500 |
commit | 4b5b3ba16be1b195d2e1161746637acd4b9fed4f (patch) | |
tree | 6e58eb24836d73b8fd756d9dff7199a88a9ebafe | |
parent | 64c2ce8b72eceec4030b04bca32d098b3d1431bb (diff) |
SUNRPC move svc_drop to caller of svc_process_common
The NFSv4.1 shared back channel does not need to call svc_drop because the
callback service never outlives the single connection it services, and it
reuses it's buffers and keeps the trasport.
Signed-off-by: Andy Adamson <andros@netapp.com>
Acked-by: Bruce Fields <bfields@redhat.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r-- | net/sunrpc/svc.c | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/net/sunrpc/svc.c b/net/sunrpc/svc.c index 6359c42c4941..606d182895a9 100644 --- a/net/sunrpc/svc.c +++ b/net/sunrpc/svc.c | |||
@@ -1147,7 +1147,6 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv) | |||
1147 | dropit: | 1147 | dropit: |
1148 | svc_authorise(rqstp); /* doesn't hurt to call this twice */ | 1148 | svc_authorise(rqstp); /* doesn't hurt to call this twice */ |
1149 | dprintk("svc: svc_process dropit\n"); | 1149 | dprintk("svc: svc_process dropit\n"); |
1150 | svc_drop(rqstp); | ||
1151 | return 0; | 1150 | return 0; |
1152 | 1151 | ||
1153 | err_short_len: | 1152 | err_short_len: |
@@ -1218,7 +1217,6 @@ svc_process(struct svc_rqst *rqstp) | |||
1218 | struct kvec *resv = &rqstp->rq_res.head[0]; | 1217 | struct kvec *resv = &rqstp->rq_res.head[0]; |
1219 | struct svc_serv *serv = rqstp->rq_server; | 1218 | struct svc_serv *serv = rqstp->rq_server; |
1220 | u32 dir; | 1219 | u32 dir; |
1221 | int error; | ||
1222 | 1220 | ||
1223 | /* | 1221 | /* |
1224 | * Setup response xdr_buf. | 1222 | * Setup response xdr_buf. |
@@ -1246,11 +1244,13 @@ svc_process(struct svc_rqst *rqstp) | |||
1246 | return 0; | 1244 | return 0; |
1247 | } | 1245 | } |
1248 | 1246 | ||
1249 | error = svc_process_common(rqstp, argv, resv); | 1247 | /* Returns 1 for send, 0 for drop */ |
1250 | if (error <= 0) | 1248 | if (svc_process_common(rqstp, argv, resv)) |
1251 | return error; | 1249 | return svc_send(rqstp); |
1252 | 1250 | else { | |
1253 | return svc_send(rqstp); | 1251 | svc_drop(rqstp); |
1252 | return 0; | ||
1253 | } | ||
1254 | } | 1254 | } |
1255 | 1255 | ||
1256 | #if defined(CONFIG_NFS_V4_1) | 1256 | #if defined(CONFIG_NFS_V4_1) |
@@ -1264,7 +1264,6 @@ bc_svc_process(struct svc_serv *serv, struct rpc_rqst *req, | |||
1264 | { | 1264 | { |
1265 | struct kvec *argv = &rqstp->rq_arg.head[0]; | 1265 | struct kvec *argv = &rqstp->rq_arg.head[0]; |
1266 | struct kvec *resv = &rqstp->rq_res.head[0]; | 1266 | struct kvec *resv = &rqstp->rq_res.head[0]; |
1267 | int error; | ||
1268 | 1267 | ||
1269 | /* Build the svc_rqst used by the common processing routine */ | 1268 | /* Build the svc_rqst used by the common processing routine */ |
1270 | rqstp->rq_xprt = serv->bc_xprt; | 1269 | rqstp->rq_xprt = serv->bc_xprt; |
@@ -1292,12 +1291,15 @@ bc_svc_process(struct svc_serv *serv, struct rpc_rqst *req, | |||
1292 | svc_getu32(argv); /* XID */ | 1291 | svc_getu32(argv); /* XID */ |
1293 | svc_getnl(argv); /* CALLDIR */ | 1292 | svc_getnl(argv); /* CALLDIR */ |
1294 | 1293 | ||
1295 | error = svc_process_common(rqstp, argv, resv); | 1294 | /* Returns 1 for send, 0 for drop */ |
1296 | if (error <= 0) | 1295 | if (svc_process_common(rqstp, argv, resv)) { |
1297 | return error; | 1296 | memcpy(&req->rq_snd_buf, &rqstp->rq_res, |
1298 | 1297 | sizeof(req->rq_snd_buf)); | |
1299 | memcpy(&req->rq_snd_buf, &rqstp->rq_res, sizeof(req->rq_snd_buf)); | 1298 | return bc_send(req); |
1300 | return bc_send(req); | 1299 | } else { |
1300 | /* Nothing to do to drop request */ | ||
1301 | return 0; | ||
1302 | } | ||
1301 | } | 1303 | } |
1302 | EXPORT_SYMBOL(bc_svc_process); | 1304 | EXPORT_SYMBOL(bc_svc_process); |
1303 | #endif /* CONFIG_NFS_V4_1 */ | 1305 | #endif /* CONFIG_NFS_V4_1 */ |