From c951ab35070b18f81a9c6c68cfdf11ea802c20fe Mon Sep 17 00:00:00 2001 From: Arvid Norberg Date: Sun, 25 Jan 2009 02:45:31 +0000 Subject: [PATCH] fixed potential problem if there are not enough references to a peer_connection when its disconnected --- src/peer_connection.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/peer_connection.cpp b/src/peer_connection.cpp index d48a5a709..ff7787559 100644 --- a/src/peer_connection.cpp +++ b/src/peer_connection.cpp @@ -2618,6 +2618,10 @@ namespace libtorrent error_code ec; m_socket->close(ec); m_ses.close_connection(this, message); + + // we should only disconnect while we still have + // at least one reference left to the connection + TORRENT_ASSERT(refcount() > 0); } void peer_connection::set_upload_limit(int limit) @@ -3620,6 +3624,10 @@ namespace libtorrent INVARIANT_CHECK; + // keep ourselves alive in until this function exits in + // case we disconnect + boost::intrusive_ptr me(self()); + TORRENT_ASSERT(m_channel_state[download_channel] == peer_info::bw_network); m_channel_state[download_channel] = peer_info::bw_idle; @@ -3911,6 +3919,10 @@ namespace libtorrent INVARIANT_CHECK; + // keep ourselves alive in until this function exits in + // case we disconnect + boost::intrusive_ptr me(self()); + TORRENT_ASSERT(m_channel_state[upload_channel] == peer_info::bw_network); m_send_buffer.pop_front(bytes_transferred);