summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2010-04-16 21:58:02 +0200
committerSage Weil <sage@newdream.net>2010-05-18 00:25:27 +0200
commit1b7facc41b42c2ab904b2f88b64b1f8ca0ca6cb7 (patch)
tree43203661dfe2675979e32a477d598d0f7559c8ee /fs
parentceph: skip set_dentry_offset work if directory not I_COMPLETE (diff)
downloadlinux-1b7facc41b42c2ab904b2f88b64b1f8ca0ca6cb7.tar.xz
linux-1b7facc41b42c2ab904b2f88b64b1f8ca0ca6cb7.zip
ceph: don't clobber i_max_offset on already complete dir
This can screw up offsets assigned to new dentries and break dcache readdir results. Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs')
-rw-r--r--fs/ceph/inode.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c
index 49a0935c4390..aa22a0bce52f 100644
--- a/fs/ceph/inode.c
+++ b/fs/ceph/inode.c
@@ -675,7 +675,8 @@ static int fill_inode(struct inode *inode,
/* set dir completion flag? */
if (ci->i_files == 0 && ci->i_subdirs == 0 &&
ceph_snap(inode) == CEPH_NOSNAP &&
- (le32_to_cpu(info->cap.caps) & CEPH_CAP_FILE_SHARED)) {
+ (le32_to_cpu(info->cap.caps) & CEPH_CAP_FILE_SHARED) &&
+ (ci->i_ceph_flags & CEPH_I_COMPLETE) == 0) {
dout(" marking %p complete (empty)\n", inode);
ci->i_ceph_flags |= CEPH_I_COMPLETE;
ci->i_max_offset = 2;