summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cpp/src/qpid/client/RdmaConnector.cpp3
-rw-r--r--cpp/src/qpid/sys/rdma/RdmaIO.cpp3
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;
}