diff options
| author | Gordon Sim <gsim@apache.org> | 2008-10-13 20:57:14 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2008-10-13 20:57:14 +0000 |
| commit | 4d0136f757776a1860c0d08e9674cfd18529b586 (patch) | |
| tree | 16e4cd5b41c1a6dbd7505dfc965c73b00e59d309 /qpid/cpp/src | |
| parent | 0afd3e14836ad0f2aa354e453edc7fed0a6a1d9b (diff) | |
| download | qpid-python-4d0136f757776a1860c0d08e9674cfd18529b586.tar.gz | |
Reverted a small part of r703237 as it causes deadlocks under load. Session controls can _not_ be subject to bounds checking on the queue of outgoing frames as is done for commands.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@704245 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src')
| -rw-r--r-- | qpid/cpp/src/qpid/client/SessionImpl.cpp | 18 | ||||
| -rw-r--r-- | qpid/cpp/src/qpid/client/SessionImpl.h | 9 |
2 files changed, 25 insertions, 2 deletions
diff --git a/qpid/cpp/src/qpid/client/SessionImpl.cpp b/qpid/cpp/src/qpid/client/SessionImpl.cpp index 49dd97e324..2d0f83b894 100644 --- a/qpid/cpp/src/qpid/client/SessionImpl.cpp +++ b/qpid/cpp/src/qpid/client/SessionImpl.cpp @@ -59,7 +59,8 @@ SessionImpl::SessionImpl(const std::string& name, shared_ptr<ConnectionImpl> con connectionShared(conn), connectionWeak(conn), weakPtr(false), - proxy(out), + ioHandler(*this), + proxy(ioHandler), nextIn(0), nextOut(0) { @@ -424,9 +425,22 @@ void SessionImpl::handleIn(AMQFrame& frame) // network thread void SessionImpl::handleOut(AMQFrame& frame) // user thread { + sendFrame(frame, true); +} + +void SessionImpl::proxyOut(AMQFrame& frame) // network thread +{ + //Note: this case is treated slightly differently that command + //frames sent by application; session controls should not be + //blocked by bounds checking on the outgoing frame queue. + sendFrame(frame, false); +} + +void SessionImpl::sendFrame(AMQFrame& frame, bool canBlock) +{ boost::shared_ptr<ConnectionImpl> c = connectionWeak.lock(); if (c) { - c->expand(frame.encodedSize(), true); + c->expand(frame.encodedSize(), canBlock); channel.handle(frame); } } diff --git a/qpid/cpp/src/qpid/client/SessionImpl.h b/qpid/cpp/src/qpid/client/SessionImpl.h index 54ace77254..d56566ec14 100644 --- a/qpid/cpp/src/qpid/client/SessionImpl.h +++ b/qpid/cpp/src/qpid/client/SessionImpl.h @@ -137,6 +137,14 @@ private: void handleIn(framing::AMQFrame& frame); void handleOut(framing::AMQFrame& frame); + /** + * Sends session controls. This case is treated slightly + * differently than command frames sent by the application via + * handleOut(); session controlsare not subject to bounds checking + * on the outgoing frame queue. + */ + void proxyOut(framing::AMQFrame& frame); + void sendFrame(framing::AMQFrame& frame, bool canBlock); void deliver(framing::AMQFrame& frame); Future sendCommand(const framing::AMQBody&, const framing::MethodContent* = 0); @@ -185,6 +193,7 @@ private: boost::weak_ptr<ConnectionImpl> connectionWeak; bool weakPtr; + framing::FrameHandler::MemFunRef<SessionImpl, &SessionImpl::proxyOut> ioHandler; framing::ChannelHandler channel; framing::AMQP_ServerProxy::Session proxy; |
