diff options
-rw-r--r-- | cpp/src/qpid/client/RdmaConnector.cpp | 3 | ||||
-rw-r--r-- | cpp/src/qpid/sys/rdma/RdmaIO.cpp | 3 |
2 files changed, 4 insertions, 2 deletions
diff --git a/cpp/src/qpid/client/RdmaConnector.cpp b/cpp/src/qpid/client/RdmaConnector.cpp index f317fb9e4d..83a7191286 100644 --- a/cpp/src/qpid/client/RdmaConnector.cpp +++ b/cpp/src/qpid/client/RdmaConnector.cpp @@ -277,8 +277,9 @@ void RdmaConnector::drained() { QPID_LOG(debug, "RdmaConnector::drained " << identifier); assert(!polling); if (aio) { - aio->stop(boost::bind(&RdmaConnector::stopped, this, aio)); + Rdma::AsynchIO* a = aio; aio = 0; + a->stop(boost::bind(&RdmaConnector::stopped, this, a)); } } diff --git a/cpp/src/qpid/sys/rdma/RdmaIO.cpp b/cpp/src/qpid/sys/rdma/RdmaIO.cpp index a72ed12af7..52de923248 100644 --- a/cpp/src/qpid/sys/rdma/RdmaIO.cpp +++ b/cpp/src/qpid/sys/rdma/RdmaIO.cpp @@ -327,10 +327,11 @@ namespace Rdma { } // If we've got all the write confirmations and we're draining + // We might get deleted in the drained callback so return immediately if (draining) { if (outstandingWrites == 0) { - doDrainedCallback(); draining = false; + doDrainedCallback(); } return; } |