From da141adcad6b59de2691bbf44aacbaf010bda504 Mon Sep 17 00:00:00 2001 From: Ricardo Dias Date: Fri, 23 Nov 2018 15:53:56 +0000 Subject: [PATCH] msg/async: msgr2: check protocol state after fast dispatch Signed-off-by: Ricardo Dias --- src/msg/async/ProtocolV2.cc | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/msg/async/ProtocolV2.cc b/src/msg/async/ProtocolV2.cc index 91acf660ee1..41263a813c8 100644 --- a/src/msg/async/ProtocolV2.cc +++ b/src/msg/async/ProtocolV2.cc @@ -1946,6 +1946,14 @@ CtPtr ProtocolV2::handle_message_complete() { data.clear(); extra.clear(); + // we might have been reused by another connection + // let's check if that is the case + if (state != READY) { + // yes, that was the case, let's do nothing + return nullptr; + } + + if (need_dispatch_writer && connection->is_connected()) { connection->center->dispatch_event_external(connection->write_handler); } -- 2.39.5