diff --git a/source/OSSupport/ListenThread.cpp b/source/OSSupport/ListenThread.cpp index 27c77a897..9e2a07f3c 100644 --- a/source/OSSupport/ListenThread.cpp +++ b/source/OSSupport/ListenThread.cpp @@ -205,7 +205,10 @@ void cListenThread::Execute(void) FD_SET(itr->GetSocket(), &fdRead); } // for itr - m_Sockets[] - if (select(Highest + 1, &fdRead, NULL, NULL, NULL) == -1) + timeval tv; // On Linux select() doesn't seem to wake up when socket is closed, so let's kinda busy-wait: + tv.tv_sec = 1; + tv.tv_usec = 0; + if (select(Highest + 1, &fdRead, NULL, NULL, &tv) == -1) { LOG("select(R) call failed in cListenThread: \"%s\"", cSocket::GetLastErrorString().c_str()); continue;