From: Samuel Just Date: Sat, 10 Jan 2015 01:00:17 +0000 (-0800) Subject: ReplicatedPG::wait_for_unreadable_object: use prep_object_replica_pushes instead... X-Git-Tag: v0.93~128^2~7 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=f5134c8b95909a4292fd0222f2a46ef567ce08cb;p=ceph.git ReplicatedPG::wait_for_unreadable_object: use prep_object_replica_pushes instead of recover_missing if not missing Signed-off-by: Samuel Just --- diff --git a/src/osd/ReplicatedPG.cc b/src/osd/ReplicatedPG.cc index 576e646615f8..2332cd2c4fc9 100644 --- a/src/osd/ReplicatedPG.cc +++ b/src/osd/ReplicatedPG.cc @@ -423,7 +423,11 @@ void ReplicatedPG::wait_for_unreadable_object( } else { dout(7) << "missing " << soid << " v " << v << ", recovering." << dendl; PGBackend::RecoveryHandle *h = pgbackend->open_recovery_op(); - recover_missing(soid, v, cct->_conf->osd_client_op_priority, h); + if (is_missing_object(soid)) { + recover_missing(soid, v, cct->_conf->osd_client_op_priority, h); + } else { + prep_object_replica_pushes(soid, v, h); + } pgbackend->run_recovery_op(h, cct->_conf->osd_client_op_priority); } waiting_for_unreadable_object[soid].push_back(op);