ceph: fix page invalidation deadlock
authorSage Weil <sage@newdream.net>
Thu, 12 Nov 2009 23:07:24 +0000 (15:07 -0800)
committerSage Weil <sage@newdream.net>
Thu, 12 Nov 2009 23:57:05 +0000 (15:57 -0800)
We occasionally want to make a best-effort attempt to invalidate cache
pages without fear of blocking.  If this fails, we fall back to an async
invalidate in another thread.

Use invalidate_mapping_pages instead of invalidate_inode_page2, as that
will skip locked pages, and not deadlock.

Signed-off-by: Sage Weil <sage@newdream.net>
fs/ceph/caps.c

index d8132b6e770d0740515291276ad6112a1b6aa2ae..9dd110602cdaf42b8bf421fae622a75b49555ed9 100644 (file)
@@ -1440,7 +1440,7 @@ retry_locked:
 
                dout("check_caps trying to invalidate on %p\n", inode);
                spin_unlock(&inode->i_lock);
-               ret = invalidate_inode_pages2(&inode->i_data);
+               ret = invalidate_mapping_pages(&inode->i_data, 0, -1);
                spin_lock(&inode->i_lock);
                if (ret == 0 && invalidating_gen == ci->i_rdcache_gen) {
                        /* success. */
@@ -2180,7 +2180,7 @@ restart:
                spin_unlock(&inode->i_lock);
                tried_invalidate = 1;
 
-               ret = invalidate_inode_pages2(&inode->i_data);
+               ret = invalidate_mapping_pages(&inode->i_data, 0, -1);
                spin_lock(&inode->i_lock);
                if (ret < 0) {
                        /* there were locked pages.. invalidate later