summaryrefslogtreecommitdiff
path: root/net/sunrpc
diff options
context:
space:
mode:
authorTrond Myklebust <Trond.Myklebust@netapp.com>2007-10-01 12:06:48 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2007-10-09 17:20:42 -0400
commit220bcc2afd7011b3e0569fc178331fa983c92c1b (patch)
tree2a9d18da02292c6c6d7b8da7f6dd6a209ea1b57d /net/sunrpc
parentb6e9c713f5c526a85893c6e0ab1d5d6c6f1ab479 (diff)
downloadlinux-3.10-220bcc2afd7011b3e0569fc178331fa983c92c1b.tar.gz
linux-3.10-220bcc2afd7011b3e0569fc178331fa983c92c1b.tar.bz2
linux-3.10-220bcc2afd7011b3e0569fc178331fa983c92c1b.zip
SUNRPC: Don't call xprt_release in call refresh
Call it from call_verify() instead... Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'net/sunrpc')
-rw-r--r--net/sunrpc/clnt.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
index e6a2678ecec..76be83ee4b0 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
@@ -1271,7 +1271,6 @@ call_refresh(struct rpc_task *task)
{
dprint_status(task);
- xprt_release(task); /* Must do to obtain new XID */
task->tk_action = call_refreshresult;
task->tk_status = 0;
task->tk_client->cl_stats->rpcauthrefresh++;
@@ -1389,6 +1388,8 @@ call_verify(struct rpc_task *task)
dprintk("RPC: %5u %s: retry stale creds\n",
task->tk_pid, __FUNCTION__);
rpcauth_invalcred(task);
+ /* Ensure we obtain a new XID! */
+ xprt_release(task);
task->tk_action = call_refresh;
goto out_retry;
case RPC_AUTH_BADCRED: