Author: aconway
Date: Thu Jan  5 22:47:06 2012
New Revision: 1227882

URL: http://svn.apache.org/viewvc?rev=1227882&view=rev
Log:
QPID-3603: Fix initialization race in QueueReplicator.

Was core dumping occasionally due to QueueReplicator being deleted before
it was initialized.

Modified:
    qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.cpp
    qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.h

Modified: qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.cpp
URL: 
http://svn.apache.org/viewvc/qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.cpp?rev=1227882&r1=1227881&r2=1227882&view=diff
==============================================================================
--- qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.cpp (original)
+++ qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.cpp Thu Jan  5 
22:47:06 2012
@@ -78,7 +78,7 @@ void QueueReplicator::activate() {
         false,              // dynamic
         0,                  // sync?
         // Include shared_ptr to self to ensure we not deleted before 
initializeBridge is called.
-        boost::bind(&QueueReplicator::initializeBridge, this, _1, _2)
+        boost::bind(&QueueReplicator::initializeBridge, this, _1, _2, self)
     );
 }
 
@@ -91,7 +91,9 @@ void QueueReplicator::deactivate() {
 }
 
 // Called in a broker connection thread when the bridge is created.
-void QueueReplicator::initializeBridge(Bridge& bridge, SessionHandler& 
sessionHandler) {
+// shared_ptr to self ensures we are not deleted before initializeBridge is 
called.
+void QueueReplicator::initializeBridge(Bridge& bridge, SessionHandler& 
sessionHandler,
+                                       boost::shared_ptr<QueueReplicator> 
/*self*/) {
     sys::Mutex::ScopedLock l(lock);
 
     framing::AMQP_ServerProxy peer(sessionHandler.out);

Modified: qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.h
URL: 
http://svn.apache.org/viewvc/qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.h?rev=1227882&r1=1227881&r2=1227882&view=diff
==============================================================================
--- qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.h (original)
+++ qpid/branches/qpid-3603/qpid/cpp/src/qpid/ha/QueueReplicator.h Thu Jan  5 
22:47:06 2012
@@ -70,7 +70,8 @@ class QueueReplicator : public broker::E
     bool isBound(boost::shared_ptr<broker::Queue>, const std::string* const, 
const framing::FieldTable* const);
 
   private:
-    void initializeBridge(broker::Bridge& bridge, broker::SessionHandler& 
sessionHandler);
+    void initializeBridge(broker::Bridge& bridge, broker::SessionHandler& 
sessionHandler,
+                          boost::shared_ptr<QueueReplicator> self);
     void dequeue(framing::SequenceNumber, const sys::Mutex::ScopedLock&);
 
     std::string logPrefix;



---------------------------------------------------------------------
Apache Qpid - AMQP Messaging Implementation
Project:      http://qpid.apache.org
Use/Interact: mailto:[email protected]

Reply via email to