nfs: handle NFSv3 -EKEYEXPIRED errors as we would -EJUKEBOX
We're using -EKEYEXPIRED to indicate that a krb5 credcache contains an expired ticket and that we should have the NFS layer retry the RPC call instead of returning an error back to the caller. Handle this as we would an -EJUKEBOX error return. Signed-off-by: Jeff Layton <jlayton@redhat.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
parent
2c6434888c
commit
b68d69b8c6
1 changed files with 5 additions and 4 deletions
|
@ -22,14 +22,14 @@
|
||||||
|
|
||||||
#define NFSDBG_FACILITY NFSDBG_PROC
|
#define NFSDBG_FACILITY NFSDBG_PROC
|
||||||
|
|
||||||
/* A wrapper to handle the EJUKEBOX error message */
|
/* A wrapper to handle the EJUKEBOX and EKEYEXPIRED error messages */
|
||||||
static int
|
static int
|
||||||
nfs3_rpc_wrapper(struct rpc_clnt *clnt, struct rpc_message *msg, int flags)
|
nfs3_rpc_wrapper(struct rpc_clnt *clnt, struct rpc_message *msg, int flags)
|
||||||
{
|
{
|
||||||
int res;
|
int res;
|
||||||
do {
|
do {
|
||||||
res = rpc_call_sync(clnt, msg, flags);
|
res = rpc_call_sync(clnt, msg, flags);
|
||||||
if (res != -EJUKEBOX)
|
if (res != -EJUKEBOX && res != -EKEYEXPIRED)
|
||||||
break;
|
break;
|
||||||
schedule_timeout_killable(NFS_JUKEBOX_RETRY_TIME);
|
schedule_timeout_killable(NFS_JUKEBOX_RETRY_TIME);
|
||||||
res = -ERESTARTSYS;
|
res = -ERESTARTSYS;
|
||||||
|
@ -42,9 +42,10 @@ nfs3_rpc_wrapper(struct rpc_clnt *clnt, struct rpc_message *msg, int flags)
|
||||||
static int
|
static int
|
||||||
nfs3_async_handle_jukebox(struct rpc_task *task, struct inode *inode)
|
nfs3_async_handle_jukebox(struct rpc_task *task, struct inode *inode)
|
||||||
{
|
{
|
||||||
if (task->tk_status != -EJUKEBOX)
|
if (task->tk_status != -EJUKEBOX && task->tk_status != -EKEYEXPIRED)
|
||||||
return 0;
|
return 0;
|
||||||
nfs_inc_stats(inode, NFSIOS_DELAY);
|
if (task->tk_status == -EJUKEBOX)
|
||||||
|
nfs_inc_stats(inode, NFSIOS_DELAY);
|
||||||
task->tk_status = 0;
|
task->tk_status = 0;
|
||||||
rpc_restart_call(task);
|
rpc_restart_call(task);
|
||||||
rpc_delay(task, NFS_JUKEBOX_RETRY_TIME);
|
rpc_delay(task, NFS_JUKEBOX_RETRY_TIME);
|
||||||
|
|
Loading…
Reference in a new issue