summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/client/ConnectionImpl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/src/qpid/client/ConnectionImpl.cpp')
-rw-r--r--cpp/src/qpid/client/ConnectionImpl.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/cpp/src/qpid/client/ConnectionImpl.cpp b/cpp/src/qpid/client/ConnectionImpl.cpp
index 692afaae00..23e312ad72 100644
--- a/cpp/src/qpid/client/ConnectionImpl.cpp
+++ b/cpp/src/qpid/client/ConnectionImpl.cpp
@@ -82,6 +82,7 @@ class IOThread {
int ioThreads;
int connections;
Mutex threadLock;
+ Condition noConnections;
std::vector<Thread> t;
Poller::shared_ptr poller_;
@@ -91,7 +92,7 @@ public:
++connections;
if (!poller_)
poller_.reset(new Poller);
- if (ioThreads < maxIOThreads) {
+ if (ioThreads < connections && ioThreads < maxIOThreads) {
QPID_LOG(debug, "Created IO thread: " << ioThreads);
++ioThreads;
t.push_back( Thread(poller_.get()) );
@@ -101,6 +102,8 @@ public:
void sub() {
ScopedLock<Mutex> l(threadLock);
--connections;
+ if (connections == 0)
+ noConnections.notifyAll();
}
Poller::shared_ptr poller() const {
@@ -124,6 +127,10 @@ public:
// and we can't do that before we're unloaded as we can't
// restart the Poller after shutting it down
~IOThread() {
+ ScopedLock<Mutex> l(threadLock);
+ while (connections > 0) {
+ noConnections.wait(threadLock);
+ }
if (poller_)
poller_->shutdown();
for (int i=0; i<ioThreads; ++i) {