Skip to content

Commit

Permalink
Merge pull request ceph#9706 from xiexingguo/xxg-wip-server_dcr
Browse files Browse the repository at this point in the history
mds/server: avoid side-effect of more() method

Reviewed-by: John Spray <[email protected]>
  • Loading branch information
John Spray authored Jun 15, 2016
2 parents f66b8a9 + 7344d97 commit d8d9f83
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 10 deletions.
6 changes: 3 additions & 3 deletions src/mds/Mutation.cc
Original file line number Diff line number Diff line change
Expand Up @@ -194,17 +194,17 @@ MDRequestImpl::More* MDRequestImpl::more()

bool MDRequestImpl::has_more()
{
return _more;
return _more != nullptr;
}

bool MDRequestImpl::has_witnesses()
{
return _more && !_more->witnessed.empty();
return (_more != nullptr) && (!_more->witnessed.empty());
}

bool MDRequestImpl::slave_did_prepare()
{
return more()->slave_commit;
return has_more() && more()->slave_commit;
}

bool MDRequestImpl::did_ino_allocation()
Expand Down
13 changes: 6 additions & 7 deletions src/mds/Server.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1064,15 +1064,15 @@ void Server::early_reply(MDRequestRef& mdr, CInode *tracei, CDentry *tracedn)
}


MClientReply *reply = new MClientReply(mdr->client_request, 0);
MClientReply *reply = new MClientReply(req, 0);
reply->set_unsafe();

// mark xlocks "done", indicating that we are exposing uncommitted changes.
//
//_rename_finish() does not send dentry link/unlink message to replicas.
// so do not set xlocks on dentries "done", the xlocks prevent dentries
// that have projected linkages from getting new replica.
mds->locker->set_xlocks_done(mdr.get(), mdr->client_request->get_op() == CEPH_MDS_OP_RENAME);
mds->locker->set_xlocks_done(mdr.get(), req->get_op() == CEPH_MDS_OP_RENAME);

dout(10) << "early_reply " << reply->get_result()
<< " (" << cpp_strerror(reply->get_result())
Expand All @@ -1085,8 +1085,7 @@ void Server::early_reply(MDRequestRef& mdr, CInode *tracei, CDentry *tracedn)
mdr->cap_releases.erase(tracedn->get_dir()->get_inode()->vino());

set_trace_dist(mdr->session, reply, tracei, tracedn, mdr->snapid,
mdr->client_request->get_dentry_wanted(),
mdr);
req->get_dentry_wanted(), mdr);
}

reply->set_extra_bl(mdr->reply_extra_bl);
Expand All @@ -1095,7 +1094,7 @@ void Server::early_reply(MDRequestRef& mdr, CInode *tracei, CDentry *tracedn)
mdr->did_early_reply = true;

mds->logger->inc(l_mds_reply);
utime_t lat = ceph_clock_now(g_ceph_context) - mdr->client_request->get_recv_stamp();
utime_t lat = ceph_clock_now(g_ceph_context) - req->get_recv_stamp();
mds->logger->tinc(l_mds_reply_latency, lat);
dout(20) << "lat " << lat << dendl;

Expand Down Expand Up @@ -1475,7 +1474,7 @@ void Server::dispatch_client_request(MDRequestRef& mdr)
dout(7) << "dispatch_client_request " << *req << dendl;

// we shouldn't be waiting on anyone.
assert(mdr->more()->waiting_on_slave.empty());
assert(!mdr->has_more() || mdr->more()->waiting_on_slave.empty());

if (req->may_write()) {
if (mdcache->is_readonly()) {
Expand Down Expand Up @@ -2728,7 +2727,7 @@ void Server::handle_client_getattr(MDRequestRef& mdr, bool is_lookup)
mdr->getattr_caps = mask;

mds->balancer->hit_inode(ceph_clock_now(g_ceph_context), ref, META_POP_IRD,
mdr->client_request->get_source().num());
req->get_source().num());

// reply
dout(10) << "reply to stat on " << *req << dendl;
Expand Down

0 comments on commit d8d9f83

Please sign in to comment.