diff options
author | Trond Myklebust <trond.myklebust@hammerspace.com> | 2020-02-27 11:01:12 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2020-04-23 10:30:18 +0200 |
commit | 401876dbcf6be94b31a957ccccb8e028e9d3d9cc (patch) | |
tree | ddc474dec5e740b0cf6c43f93a1f300cade059c3 /fs | |
parent | 65ea19acb0fd2a7d3337d022ebc63f06d66581c7 (diff) | |
download | linux-stable-401876dbcf6be94b31a957ccccb8e028e9d3d9cc.tar.gz linux-stable-401876dbcf6be94b31a957ccccb8e028e9d3d9cc.tar.bz2 linux-stable-401876dbcf6be94b31a957ccccb8e028e9d3d9cc.zip |
NFSv4/pnfs: Return valid stateids in nfs_layout_find_inode_by_stateid()
[ Upstream commit d911c57a19551c6bef116a3b55c6b089901aacb0 ]
Make sure to test the stateid for validity so that we catch instances
where the server may have been reusing stateids in
nfs_layout_find_inode_by_stateid().
Fixes: 7b410d9ce460 ("pNFS: Delay getting the layout header in CB_LAYOUTRECALL handlers")
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/nfs/callback_proc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/nfs/callback_proc.c b/fs/nfs/callback_proc.c index 315967354954..bcc51f131a49 100644 --- a/fs/nfs/callback_proc.c +++ b/fs/nfs/callback_proc.c @@ -130,6 +130,8 @@ static struct inode *nfs_layout_find_inode_by_stateid(struct nfs_client *clp, list_for_each_entry_rcu(server, &clp->cl_superblocks, client_link) { list_for_each_entry(lo, &server->layouts, plh_layouts) { + if (!pnfs_layout_is_valid(lo)) + continue; if (stateid != NULL && !nfs4_stateid_match_other(stateid, &lo->plh_stateid)) continue; |