Commit 15289dc8 authored by Yan, Zheng's avatar Yan, Zheng

ceph: let MDS adjust readdir 'frag'

If readdir 'frag' is adjusted, readdir 'offset' should be reset.
Otherwise some dentries may be lost when readdir and fragmenting
directory happen at the some.

Another way to fix this issue is let MDS adjust readdir 'frag'.
The code that handles MDS reply reset the readdir 'offset' if
the readdir reply is different than the requested one.
Signed-off-by: default avatarYan, Zheng <zheng.z.yan@intel.com>
parent dcd3cc05
...@@ -322,9 +322,6 @@ static int ceph_readdir(struct file *file, struct dir_context *ctx) ...@@ -322,9 +322,6 @@ static int ceph_readdir(struct file *file, struct dir_context *ctx)
fi->last_readdir = NULL; fi->last_readdir = NULL;
} }
/* requery frag tree, as the frag topology may have changed */
frag = ceph_choose_frag(ceph_inode(inode), frag, NULL, NULL);
dout("readdir fetching %llx.%llx frag %x offset '%s'\n", dout("readdir fetching %llx.%llx frag %x offset '%s'\n",
ceph_vinop(inode), frag, fi->last_name); ceph_vinop(inode), frag, fi->last_name);
req = ceph_mdsc_create_request(mdsc, op, USE_AUTH_MDS); req = ceph_mdsc_create_request(mdsc, op, USE_AUTH_MDS);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment