summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/network/core/host.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/src/network/core/host.cpp b/src/network/core/host.cpp
index e1469e069..87f92d1fd 100644
--- a/src/network/core/host.cpp
+++ b/src/network/core/host.cpp
@@ -7,6 +7,7 @@
#include "../../stdafx.h"
#include "../../debug.h"
#include "os_abstraction.h"
+#include "../../core/alloc_func.hpp"
/**
* Internal implementation for finding the broadcast IPs.
@@ -117,15 +118,15 @@ static int NetworkFindBroadcastIPsInternal(uint32 *broadcast, int limit) // Win3
if (sock == INVALID_SOCKET) return 0;
DWORD len = 0;
- INTERFACE_INFO ifo[MAX_INTERFACES];
- memset(&ifo[0], 0, sizeof(ifo));
- if ((WSAIoctl(sock, SIO_GET_INTERFACE_LIST, NULL, 0, &ifo[0], sizeof(ifo), &len, NULL, NULL)) != 0) {
+ INTERFACE_INFO *ifo = AllocaM(INTERFACE_INFO, limit);
+ memset(ifo, 0, limit * sizeof(*ifo));
+ if ((WSAIoctl(sock, SIO_GET_INTERFACE_LIST, NULL, 0, &ifo[0], limit * sizeof(*ifo), &len, NULL, NULL)) != 0) {
closesocket(sock);
- return;
+ return 0;
}
int index = 0;
- for (int j = 0; j < len / sizeof(*ifo) && index != limit; j++) {
+ for (uint j = 0; j < len / sizeof(*ifo) && index != limit; j++) {
if (ifo[j].iiFlags & IFF_LOOPBACK) continue;
if (!(ifo[j].iiFlags & IFF_BROADCAST)) continue;