From: Yan, Zheng Date: Sun, 6 Jan 2013 01:15:55 +0000 (+0800) Subject: mds: properly set error_dentry for discover reply X-Git-Tag: v0.57~88^2~24 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=659d1a39458fdc2b73ad2d3512d1ea2ce6f7566d;p=ceph.git mds: properly set error_dentry for discover reply If MDCache::handle_discover() receives an 'discover path' request but can not find the base inode. It should properly set the 'error_dentry' to make sure MDCache::handle_discover_reply() checks correct object's wait queue. Signed-off-by: Yan, Zheng --- diff --git a/src/mds/MDCache.cc b/src/mds/MDCache.cc index 9557436bb9dd..adcf8c1ef28e 100644 --- a/src/mds/MDCache.cc +++ b/src/mds/MDCache.cc @@ -8644,6 +8644,8 @@ void MDCache::handle_discover(MDiscover *dis) dout(7) << "handle_discover mds." << from << " don't have base ino " << dis->get_base_ino() << "." << snapid << dendl; + if (!dis->wants_base_dir() && dis->get_want().depth() > 0) + reply->set_error_dentry(dis->get_dentry(0)); reply->set_flag_error_dir(); } else if (dis->wants_base_dir()) { dout(7) << "handle_discover mds." << from