Commit 67dd4830 authored by Trond Myklebust's avatar Trond Myklebust Committed by Anna Schumaker

NFSv4: Mark the lock and open stateids as invalid after freeing them

Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
Tested-by: default avatarOleg Drokin <green@linuxhacker.ru>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent b134fc4a
...@@ -2560,6 +2560,7 @@ static int nfs41_check_expired_locks(struct nfs4_state *state) ...@@ -2560,6 +2560,7 @@ static int nfs41_check_expired_locks(struct nfs4_state *state)
if (status == -NFS4ERR_EXPIRED || if (status == -NFS4ERR_EXPIRED ||
status == -NFS4ERR_BAD_STATEID) { status == -NFS4ERR_BAD_STATEID) {
clear_bit(NFS_LOCK_INITIALIZED, &lsp->ls_flags); clear_bit(NFS_LOCK_INITIALIZED, &lsp->ls_flags);
lsp->ls_stateid.type = NFS4_INVALID_STATEID_TYPE;
if (!recover_lost_locks) if (!recover_lost_locks)
set_bit(NFS_LOCK_LOST, &lsp->ls_flags); set_bit(NFS_LOCK_LOST, &lsp->ls_flags);
} else if (status != NFS_OK) { } else if (status != NFS_OK) {
...@@ -2605,6 +2606,7 @@ static int nfs41_check_open_stateid(struct nfs4_state *state) ...@@ -2605,6 +2606,7 @@ static int nfs41_check_open_stateid(struct nfs4_state *state)
clear_bit(NFS_O_WRONLY_STATE, &state->flags); clear_bit(NFS_O_WRONLY_STATE, &state->flags);
clear_bit(NFS_O_RDWR_STATE, &state->flags); clear_bit(NFS_O_RDWR_STATE, &state->flags);
clear_bit(NFS_OPEN_STATE, &state->flags); clear_bit(NFS_OPEN_STATE, &state->flags);
stateid->type = NFS4_INVALID_STATEID_TYPE;
} }
return status; return status;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment