ceph: only queue async writeback on cap revocation if there is dirty data
authorSage Weil <sage@newdream.net>
Thu, 5 Aug 2010 20:53:18 +0000 (13:53 -0700)
committerSage Weil <sage@newdream.net>
Thu, 5 Aug 2010 20:53:40 +0000 (13:53 -0700)
commit0eb6cd49f6e3ec523787d09cf08d3179be270db4
tree7974963003e0b8ef26fdfb3a8120c6b4b588a01b
parente9d177443134bc4ac1c1393af69e2a8704bcac09
ceph: only queue async writeback on cap revocation if there is dirty data

Normally, if the Fb cap bit is being revoked, we queue an async writeback.
If there is no dirty data but we still hold the cap, this leaves the
client sitting around doing nothing until the cap timeouts expire and the
cap is released on its own (as it would have been without the revocation).

Instead, only queue writeback if the bit is actually used (i.e., we have
dirty data).  If not, we can reply to the revocation immediately.

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