From 87b2849fc25e21726c100f0304965e857e819aff Mon Sep 17 00:00:00 2001 From: Jason Dillaman Date: Fri, 29 May 2020 09:22:26 -0400 Subject: [PATCH] librbd: clear pending flush contexts on shut down The IOs are already dispatched but are not cleared from the container. This can result in an assertion failure in the destructor. Signed-off-by: Jason Dillaman --- src/librbd/io/FlushTracker.cc | 1 + 1 file changed, 1 insertion(+) diff --git a/src/librbd/io/FlushTracker.cc b/src/librbd/io/FlushTracker.cc index 0a0e1027e796..b6e2ed658f85 100644 --- a/src/librbd/io/FlushTracker.cc +++ b/src/librbd/io/FlushTracker.cc @@ -37,6 +37,7 @@ void FlushTracker::shut_down() { for (auto& [flush_tid, ctxs] : m_flush_contexts) { flush_ctxs.insert(flush_ctxs.end(), ctxs.begin(), ctxs.end()); } + m_flush_contexts.clear(); locker.unlock(); for (auto ctx : flush_ctxs) { -- 2.47.3