From 23eb8eb48153c908d560e325259c939ad4096a73 Mon Sep 17 00:00:00 2001 From: brain Date: Sat, 7 Oct 2006 11:23:40 +0000 Subject: Fix (we hope!) for the 'internal error processing connection' bug. Thanks to jamie and shadow for enduring this one while we hunted it down. Its complicated, bug one of us for more info if youre really interested. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@5446 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/inspsocket.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/inspsocket.cpp b/src/inspsocket.cpp index eb0ee86c8..4a37b1b04 100644 --- a/src/inspsocket.cpp +++ b/src/inspsocket.cpp @@ -369,7 +369,7 @@ void SocketTimeout::Tick(time_t now) { if (ServerInstance->SE->GetRef(this->sfd) != this->sock) { - ServerInstance->Log(DEBUG,"No FD or socket ref"); + ServerInstance->Log(DEBUG,"Our socket has been deleted before the timeout was reached."); return; } @@ -383,8 +383,12 @@ void SocketTimeout::Tick(time_t now) this->sock->OnTimeout(); this->sock->OnError(I_ERR_TIMEOUT); this->sock->timeout = true; - this->sock->state = I_ERROR; ServerInstance->SE->DelFd(this->sock); + /* NOTE: We must set this AFTER DelFd, as we added + * this socket whilst writeable. This means that we + * must DELETE the socket whilst writeable too! + */ + this->sock->state = I_ERROR; this->sock->Close(); delete this->sock; return; -- cgit v1.2.3