From 5b2da93ad7f12da9810aec90101b6ade12d7a99e Mon Sep 17 00:00:00 2001 From: rsiddharth Date: Sun, 15 Sep 2019 14:18:14 -0400 Subject: nserver/src/nsocket.c: Update get_socket. * nserver/src/nsocket.c (get_socket): Use SO_REUSEADDR to dodge 'address already in use' error. Put all socket related code in the loop. --- nserver/src/nsocket.c | 31 ++++++++++++++++++++----------- 1 file changed, 20 insertions(+), 11 deletions(-) (limited to 'nserver/src') diff --git a/nserver/src/nsocket.c b/nserver/src/nsocket.c index ca36382..f9c9361 100644 --- a/nserver/src/nsocket.c +++ b/nserver/src/nsocket.c @@ -9,6 +9,7 @@ int get_socket() { int sockfd = 0; int rc = 0; + int y = 1; struct addrinfo hints; struct addrinfo *servinfo = NULL; @@ -23,22 +24,30 @@ int get_socket() check(rc == 0, "get_socket: getaddrinfo failed"); // Loop through the addresses and find one that works. - sockfd = 0; - addr = servinfo; - do { + for (addr = servinfo; addr != NULL; sockfd = 0, + addr = addr->ai_next) { sockfd = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol); - if (sockfd > 0) { - break; + if (sockfd < 1) { + continue; } - addr = addr->ai_next; - } while(addr); - check(sockfd > 0, "unable to get socket"); + // dodge the "address already in use" error. + rc = setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, + &y, sizeof(int)); + if (rc != 0) { + continue; + } - // assign name to socket. - rc = bind(sockfd, addr->ai_addr, addr->ai_addrlen); - check(rc == 0, "get_socket: bind failed"); + // assign name to socket. + rc = bind(sockfd, addr->ai_addr, addr->ai_addrlen); + if (rc != 0) { + continue; + } + + break; + } + check(sockfd > 0, "unable to get socket"); // Cleanup. freeaddrinfo(servinfo); -- cgit v1.2.3