]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
mds: check parent inode's versionlock when propagating rstats
authorYan, Zheng <zheng.z.yan@intel.com>
Mon, 19 Nov 2012 02:43:41 +0000 (10:43 +0800)
committerSage Weil <sage@inktank.com>
Tue, 27 Nov 2012 05:14:44 +0000 (21:14 -0800)
To propagate rstats to one level up, we need lock both parent
inode's nestlock and versionlock.

Signed-off-by: Yan, Zheng <zheng.z.yan@intel.com>
src/mds/MDCache.cc

index 5027469f095563675d0be25f00e0150c743af683..993cbcf5ad78b9abba4970dc5f35534e28066c11 100644 (file)
@@ -1917,7 +1917,8 @@ void MDCache::predirty_journal_parents(Mutation *mut, EMetaBlob *blob,
     // rstat
     if (!primary_dn) {
       // don't update parent this pass
-    } else if (!linkunlink && !parent->inode->nestlock.can_wrlock(-1)) {
+    } else if (!linkunlink && !(parent->inode->nestlock.can_wrlock(-1) &&
+                               parent->inode->versionlock.can_wrlock())) {
       dout(20) << " unwritable parent nestlock " << parent->inode->nestlock
               << ", marking dirty rstat on " << *cur << dendl;
       cur->mark_dirty_rstat();