diff options
author | Trond Myklebust <trond.myklebust@primarydata.com> | 2016-07-24 17:39:03 +0200 |
---|---|---|
committer | Trond Myklebust <trond.myklebust@primarydata.com> | 2016-07-24 22:16:25 +0200 |
commit | 13bede18de41e2cfe8f67c1cd8b6d10be42ef473 (patch) | |
tree | cd2b5ff352075c581f74b86b493ec05834cc2206 /fs/nfs/pnfs.c | |
parent | pNFS: Clear the layout return tracking on layout reinitialisation (diff) | |
download | linux-13bede18de41e2cfe8f67c1cd8b6d10be42ef473.tar.xz linux-13bede18de41e2cfe8f67c1cd8b6d10be42ef473.zip |
pNFS: Always update the layout stateid if NFS_LAYOUT_INVALID_STID is set
If the layout stateid is invalid, then pnfs_set_layout_stateid() must
always initialise it.
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Diffstat (limited to 'fs/nfs/pnfs.c')
-rw-r--r-- | fs/nfs/pnfs.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index dcccded1aeed..eef844785bc6 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c @@ -762,7 +762,7 @@ pnfs_set_layout_stateid(struct pnfs_layout_hdr *lo, const nfs4_stateid *new, bool update_barrier) { u32 oldseq, newseq, new_barrier; - int empty = list_empty(&lo->plh_segs); + bool empty = !pnfs_layout_is_valid(lo); oldseq = be32_to_cpu(lo->plh_stateid.seqid); newseq = be32_to_cpu(new->seqid); |