From: Samuel Just Date: Sun, 4 Feb 2024 22:28:46 +0000 (-0800) Subject: crimson/.../client_request.cc: move message decode check to with_pg X-Git-Tag: v19.1.1~356^2~10 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=ca794dc3666cb51e8eefd55886e537ffc4a6eca4;p=ceph.git crimson/.../client_request.cc: move message decode check to with_pg We only need to do this once, no need to recheck on requeue. Signed-off-by: Samuel Just (cherry picked from commit 10a9a11f5d535044f081964dc6b79813aa9bb624) --- diff --git a/src/crimson/osd/osd_operations/client_request.cc b/src/crimson/osd/osd_operations/client_request.cc index 7c1e7d321cfd..571a6ec64a4d 100644 --- a/src/crimson/osd/osd_operations/client_request.cc +++ b/src/crimson/osd/osd_operations/client_request.cc @@ -105,9 +105,6 @@ seastar::future<> ClientRequest::with_pg_int(Ref pgref) LOG_PREFIX(ClientRequest::with_pg_int); epoch_t same_interval_since = pgref->get_interval_start_epoch(); DEBUGDPP("{}: same_interval_since: {}", *pgref, *this, same_interval_since); - if (m->finish_decode()) { - m->clear_payload(); - } const auto this_instance_id = instance_id++; OperationRef opref{this}; auto instance_handle = get_instance_handle(); @@ -184,6 +181,11 @@ seastar::future<> ClientRequest::with_pg( { shard_services = &_shard_services; pgref->client_request_orderer.add_request(*this); + + if (m->finish_decode()) { + m->clear_payload(); + } + auto ret = on_complete.get_future(); std::ignore = with_pg_int(std::move(pgref)); return ret;