From beef5da970ba9571aa5673b53cad5edb8b065a2b Mon Sep 17 00:00:00 2001 From: rubidium Date: Thu, 2 Apr 2009 23:03:18 +0000 Subject: [PATCH] (svn r15918) -Fix (r15917): comparing IPs sometimes failed due to 'random' data (as spotted by SpComb) --- src/network/core/udp.cpp | 2 ++ src/network/network.cpp | 1 + 2 files changed, 3 insertions(+) diff --git a/src/network/core/udp.cpp b/src/network/core/udp.cpp index 31ae8a4460..110cec2f23 100644 --- a/src/network/core/udp.cpp +++ b/src/network/core/udp.cpp @@ -101,6 +101,8 @@ void NetworkUDPSocketHandler::SendPacket(Packet *p, NetworkAddress *recv) void NetworkUDPSocketHandler::ReceivePackets() { struct sockaddr_storage client_addr; + memset(&client_addr, 0, sizeof(client_addr)); + socklen_t client_len; int nbytes; Packet p(this); diff --git a/src/network/network.cpp b/src/network/network.cpp index e88b7a1f87..ebd10980dc 100644 --- a/src/network/network.cpp +++ b/src/network/network.cpp @@ -480,6 +480,7 @@ static void NetworkAcceptClients() assert(_listensocket != INVALID_SOCKET); for (;;) { + memset(&sin, 0, sizeof(sin)); socklen_t sin_len = sizeof(sin); SOCKET s = accept(_listensocket, (struct sockaddr*)&sin, &sin_len); if (s == INVALID_SOCKET) return;