ceph: delay umount until all mds requests drop inode+dentry refs
authorSage Weil <sage@newdream.net>
Mon, 21 Jun 2010 23:12:26 +0000 (16:12 -0700)
committerSage Weil <sage@newdream.net>
Mon, 21 Jun 2010 23:11:50 +0000 (16:11 -0700)
commit17c688c3dfffc274c87be00033da0050bb6eefc0
tree1b1586253abf6850c9746235462d71e14e57f243
parentd69ed05a80f23b25f06e73af9b7e701ce4900edc
ceph: delay umount until all mds requests drop inode+dentry refs

This fixes a race between handle_reply finishing an mds request, signalling
completion, and then dropping the request structing and its dentry+inode
refs, and pre_umount function waiting for requests to finish before
letting the vfs tear down the dcache.  If umount was delayed waiting for
mds requests, we could race and BUG in shrink_dcache_for_umount_subtree
because of a slow dput.

This delays umount until the msgr queue flushes, which means handle_reply
will exit and will have dropped the ceph_mds_request struct.  I'm assuming
the VFS has already ensured that its calls have all completed and those
request refs have thus been dropped as well (I haven't seen that race, at
least).

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