]> git.itanic.dy.fi Git - linux-stable/commitdiff
ceph: fix fscache invalidation
authorJeff Layton <jlayton@kernel.org>
Thu, 21 Jan 2021 23:05:37 +0000 (18:05 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 22 May 2021 09:40:53 +0000 (11:40 +0200)
[ Upstream commit 10a7052c7868bc7bc72d947f5aac6f768928db87 ]

Ensure that we invalidate the fscache whenever we invalidate the
pagecache.

Signed-off-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/ceph/caps.c
fs/ceph/inode.c

index 576d01275bbd727f239ccdda647eba76591c1299..e4fc99afa25a9e205495ad6b270bb37384ddcee6 100644 (file)
@@ -1866,6 +1866,7 @@ static int try_nonblocking_invalidate(struct inode *inode)
        u32 invalidating_gen = ci->i_rdcache_gen;
 
        spin_unlock(&ci->i_ceph_lock);
+       ceph_fscache_invalidate(inode);
        invalidate_mapping_pages(&inode->i_data, 0, -1);
        spin_lock(&ci->i_ceph_lock);
 
index 2462a9a84b9567e0fccd96ad1095e21d9c7a0871..6bd2a6ced22ab0c00c504cd5712db3e07ae4aa1b 100644 (file)
@@ -1912,6 +1912,7 @@ static void ceph_do_invalidate_pages(struct inode *inode)
        orig_gen = ci->i_rdcache_gen;
        spin_unlock(&ci->i_ceph_lock);
 
+       ceph_fscache_invalidate(inode);
        if (invalidate_inode_pages2(inode->i_mapping) < 0) {
                pr_err("invalidate_pages %p fails\n", inode);
        }