aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ceph/inode.c
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2010-04-15 14:08:49 -0700
committerSage Weil <sage@newdream.net>2010-05-17 15:25:27 -0700
commite8a7498715181ece36130335536e13733a5c3187 (patch)
tree3a8afe3901eecfefd833e024cf6f661c6992a12c /fs/ceph/inode.c
parentf1f2765faedc24f8f2e9fd68521a5ea469801b60 (diff)
downloadkernel_samsung_tuna-e8a7498715181ece36130335536e13733a5c3187.zip
kernel_samsung_tuna-e8a7498715181ece36130335536e13733a5c3187.tar.gz
kernel_samsung_tuna-e8a7498715181ece36130335536e13733a5c3187.tar.bz2
ceph: skip set_dentry_offset work if directory not I_COMPLETE
Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs/ceph/inode.c')
-rw-r--r--fs/ceph/inode.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c
index 913cafd..49a0935 100644
--- a/fs/ceph/inode.c
+++ b/fs/ceph/inode.c
@@ -861,6 +861,10 @@ static void ceph_set_dentry_offset(struct dentry *dn)
di = ceph_dentry(dn);
spin_lock(&inode->i_lock);
+ if ((ceph_inode(inode)->i_ceph_flags & CEPH_I_COMPLETE) == 0) {
+ spin_unlock(&inode->i_lock);
+ return;
+ }
di->offset = ceph_inode(inode)->i_max_offset++;
spin_unlock(&inode->i_lock);