X-Git-Url: https://www.tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fnet.c;h=82b0ede18ba84e8d0e362856481ff4fe688f26dc;hp=c893f1e41c07c5027eda0b9c2cfca33932007fd0;hb=b47c17bcdeb70b63ad9346dc97ba575597cbd803;hpb=802a50ffcd5f39bfc6424ac841de4e41154092fc diff --git a/src/net.c b/src/net.c index c893f1e4..82b0ede1 100644 --- a/src/net.c +++ b/src/net.c @@ -149,7 +149,8 @@ static int build_fdset(fd_set *readset, fd_set *writeset) max = listen_socket[i].udp; } - FD_SET(device_fd, readset); + if(device_fd >= 0) + FD_SET(device_fd, readset); if(device_fd > max) max = device_fd; @@ -294,7 +295,7 @@ static void check_network_activity(fd_set * readset, fd_set * writeset) cp(); /* check input from kernel */ - if(FD_ISSET(device_fd, readset)) { + if(device_fd >= 0 && FD_ISSET(device_fd, readset)) { if(read_packet(&packet)) { packet.priority = 0; route(myself, &packet); @@ -378,7 +379,13 @@ int main_loop(void) maxfd = build_fdset(&readset, &writeset); +#ifdef HAVE_MINGW + LeaveCriticalSection(&mutex); +#endif r = select(maxfd + 1, &readset, &writeset, NULL, &tv); +#ifdef HAVE_MINGW + EnterCriticalSection(&mutex); +#endif if(r < 0) { if(errno != EINTR && errno != EAGAIN) {