diff options
| author | Petr Baudis <pasky@suse.cz> | 2006-07-01 23:56:26 +0200 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-07-01 17:09:26 -0700 | 
| commit | ac3bc6c1d1f549f6809d8a7d29bcaed302f3c193 (patch) | |
| tree | 2bcf9974fbf89dcb0389fbf496a553dbb2f26c7b | |
| parent | c64ea8521bc81b52da45d3deb3a419928d4b6b29 (diff) | |
| download | git-ac3bc6c1d1f549f6809d8a7d29bcaed302f3c193.tar.gz | |
Fix errno usage in connect.c
errno was used after it could've been modified by a subsequent library call.
Spotted by Morten Welinder.
Signed-off-by: Petr Baudis <pasky@suse.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>
| -rw-r--r-- | connect.c | 18 | 
1 files changed, 12 insertions, 6 deletions
| @@ -328,7 +328,7 @@ static enum protocol get_protocol(const char *name)   */  static int git_tcp_connect_sock(char *host)  { -	int sockfd = -1; +	int sockfd = -1, saved_errno = 0;  	char *colon, *end;  	const char *port = STR(DEFAULT_GIT_PORT);  	struct addrinfo hints, *ai0, *ai; @@ -362,9 +362,12 @@ static int git_tcp_connect_sock(char *host)  	for (ai0 = ai; ai; ai = ai->ai_next) {  		sockfd = socket(ai->ai_family,  				ai->ai_socktype, ai->ai_protocol); -		if (sockfd < 0) +		if (sockfd < 0) { +			saved_errno = errno;  			continue; +		}  		if (connect(sockfd, ai->ai_addr, ai->ai_addrlen) < 0) { +			saved_errno = errno;  			close(sockfd);  			sockfd = -1;  			continue; @@ -375,7 +378,7 @@ static int git_tcp_connect_sock(char *host)  	freeaddrinfo(ai0);  	if (sockfd < 0) -		die("unable to connect a socket (%s)", strerror(errno)); +		die("unable to connect a socket (%s)", strerror(saved_errno));  	return sockfd;  } @@ -387,7 +390,7 @@ static int git_tcp_connect_sock(char *host)   */  static int git_tcp_connect_sock(char *host)  { -	int sockfd = -1; +	int sockfd = -1, saved_errno = 0;  	char *colon, *end;  	char *port = STR(DEFAULT_GIT_PORT), *ep;  	struct hostent *he; @@ -426,8 +429,10 @@ static int git_tcp_connect_sock(char *host)  	for (ap = he->h_addr_list; *ap; ap++) {  		sockfd = socket(he->h_addrtype, SOCK_STREAM, 0); -		if (sockfd < 0) +		if (sockfd < 0) { +			saved_errno = errno;  			continue; +		}  		memset(&sa, 0, sizeof sa);  		sa.sin_family = he->h_addrtype; @@ -435,6 +440,7 @@ static int git_tcp_connect_sock(char *host)  		memcpy(&sa.sin_addr, *ap, he->h_length);  		if (connect(sockfd, (struct sockaddr *)&sa, sizeof sa) < 0) { +			saved_errno = errno;  			close(sockfd);  			sockfd = -1;  			continue; @@ -443,7 +449,7 @@ static int git_tcp_connect_sock(char *host)  	}  	if (sockfd < 0) -		die("unable to connect a socket (%s)", strerror(errno)); +		die("unable to connect a socket (%s)", strerror(saved_errno));  	return sockfd;  } | 
