]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
Revert "crimson/os/alienstore/alien_log: _flush concurrently" 55288/head
authorSamuel Just <sjust@redhat.com>
Tue, 23 Jan 2024 21:47:27 +0000 (21:47 +0000)
committerSamuel Just <sjust@redhat.com>
Tue, 23 Jan 2024 22:37:36 +0000 (22:37 +0000)
While submitting the log line asyncronously is reasonable,
with this implementation the EntryVector &q parameter does
not necessarily outlive the submission continuation.

This reverts commit 511af83e2747361350b60ce0ce88e67a726d9343.

Fixes: https://tracker.ceph.com/issues/64140
Signed-off-by: Samuel Just <sjust@redhat.com>
src/crimson/os/alienstore/alien_log.cc

index 822b2f3ab5193a925fff0d1b25148cf970eef20f..a0f5b03a5d39d712fdfdb0540cd5188a8d22f55f 100644 (file)
@@ -17,7 +17,8 @@ CnLog::~CnLog() {
 }
 
 void CnLog::_flush(EntryVector& q, bool crash) {
-  std::ignore = seastar::alien::submit_to(inst, shard, [&q] {
+  // XXX: the waiting here will block the thread for an indeterministic peroid
+  seastar::alien::submit_to(inst, shard, [&q] {
     for (auto& it : q) {
       crimson::get_logger(it.m_subsys).log(
         crimson::to_log_level(it.m_prio),
@@ -25,7 +26,7 @@ void CnLog::_flush(EntryVector& q, bool crash) {
         it.strv());
     }
     return seastar::make_ready_future<>();
-  });
+  }).wait();
   q.clear();
   return;
 }