diff --git a/src/msw/gsocket.c b/src/msw/gsocket.c index dbdbe90fe6..d14313deaa 100644 --- a/src/msw/gsocket.c +++ b/src/msw/gsocket.c @@ -318,6 +318,11 @@ GSocketError GSocket_SetServer(GSocket *sck) ioctlsocket(sck->m_fd, FIONBIO, (u_long FAR *) &arg); _GSocket_Enable_Events(sck); + /* allow a socket to re-bind if the socket is in the TIME_WAIT + state after being previously closed. + */ + setsockopt(sck->m_fd, SOL_SOCKET, SO_REUSEADDR, (const char*)&arg, sizeof(u_long)); + /* Bind to the local address, * retrieve the actual address bound, * and listen up to 5 connections. diff --git a/src/unix/gsocket.c b/src/unix/gsocket.c index a248f1def2..fa9fb9875d 100644 --- a/src/unix/gsocket.c +++ b/src/unix/gsocket.c @@ -669,6 +669,11 @@ GSocketError GSocket_SetNonOriented(GSocket *sck) ioctl(sck->m_fd, FIONBIO, &arg); _GSocket_Enable_Events(sck); + /* allow a socket to re-bind if the socket is in the TIME_WAIT + state after being previously closed. + */ + setsockopt(sck->m_fd, SOL_SOCKET, SO_REUSEADDR, (const char*)&arg, sizeof(u_long)); + /* Bind to the local address, * and retrieve the actual address bound. */