diff options
author | pav <pav@FreeBSD.org> | 2004-02-08 03:55:21 +0800 |
---|---|---|
committer | pav <pav@FreeBSD.org> | 2004-02-08 03:55:21 +0800 |
commit | fdf8fae27f8d90aef9031ed67f198495385d50ed (patch) | |
tree | 7c15f2437b7d3d6488f92f5211a704f2e570e463 /ftp/prozilla/files | |
parent | 7017ca3369e2d3630f5c5424cdb96606062871ad (diff) | |
download | freebsd-ports-graphics-fdf8fae27f8d90aef9031ed67f198495385d50ed.tar.gz freebsd-ports-graphics-fdf8fae27f8d90aef9031ed67f198495385d50ed.tar.zst freebsd-ports-graphics-fdf8fae27f8d90aef9031ed67f198495385d50ed.zip |
- Workaround lack of reentrant gethostbyname()
PR: ports/60740
Submitted by: maintainer
Diffstat (limited to 'ftp/prozilla/files')
-rw-r--r-- | ftp/prozilla/files/patch-connect.c | 134 |
1 files changed, 118 insertions, 16 deletions
diff --git a/ftp/prozilla/files/patch-connect.c b/ftp/prozilla/files/patch-connect.c index 3c9589aafc3..71c1d863a39 100644 --- a/ftp/prozilla/files/patch-connect.c +++ b/ftp/prozilla/files/patch-connect.c @@ -1,6 +1,10 @@ ---- src/connect.c.orig Fri Aug 17 20:38:25 2001 -+++ src/connect.c Sat Jan 25 19:38:06 2003 -@@ -27,6 +27,7 @@ +--- src/connect.c.ori Fri Aug 17 20:38:25 2001 ++++ src/connect.c Sat Feb 7 02:11:10 2004 +@@ -24,9 +24,11 @@ + #include <stdio.h> + #include <stdlib.h> + #include <unistd.h> ++#include <sys/types.h> #include <sys/socket.h> #include <fcntl.h> #include <netdb.h> @@ -8,22 +12,120 @@ #include <netinet/in.h> #include <netinet/ip.h> #include <netdb.h> -@@ -341,6 +342,8 @@ - struct hostent *hp; - int herr,res; +@@ -42,51 +44,58 @@ + #include "runtime.h" + #include "debug.h" -+#ifndef __FreeBSD__ ++static pthread_mutex_t __thread_safe_lock = PTHREAD_MUTEX_INITIALIZER; + - if (*hstbuflen == 0) + uerr_t connect_to_server(int *sock, char *name, int port, int timeout) + { + unsigned int portnum; ++ char szPort[10]; + int status; +- struct sockaddr_in server; +- struct hostent *hp, hostbuf; + extern int h_errno; + /* int opt; */ + int noblock, flags; + +- char *tmphstbuf; +- size_t hstbuflen = 2048; +- tmphstbuf = kmalloc(hstbuflen); ++ struct addrinfo hints, *res=NULL; ++ struct addrinfo *res0=NULL; ++ int error; ++ ++ memset(&hints, 0, sizeof(hints)); ++ memset(szPort, 0, sizeof(szPort)); ++ sprintf(szPort, "%d", port); ++ hints.ai_family = AF_INET; ++ hints.ai_socktype = SOCK_STREAM; + + assert(name != NULL); + +- portnum = port; +- memset((void *) &server, 0, sizeof(server)); +- + message("Resolving %s", name); + +- hp=k_gethostname (name,&hostbuf,&tmphstbuf,&hstbuflen); +- +- if (hp == NULL) +- { +- message("Failed to resolve %s", name); +- return HOSTERR; +- } ++ pthread_mutex_lock(&__thread_safe_lock); + +- message("Resolved %s !", name); +- +- +- memcpy((void *) &server.sin_addr, hp->h_addr, hp->h_length); +- server.sin_family = hp->h_addrtype; +- server.sin_port = htons(portnum); ++ error = getaddrinfo(name, szPort, &hints, &res); ++ if (error) { ++ message("Failed to resolve %s", name); ++ pthread_mutex_unlock(&__thread_safe_lock); ++ freeaddrinfo(res); ++ return HOSTERR; ++ } ++ ++ message("Resolved %s !", name); ++ ++ res0 = (struct addrinfo *) malloc(sizeof(struct addrinfo)); ++ memcpy(res0, res, sizeof(struct addrinfo)); ++ freeaddrinfo(res); ++ pthread_mutex_unlock(&__thread_safe_lock); + + /* + * create socket + */ +- if ((*sock = socket(AF_INET, SOCK_STREAM, 0)) < 1) ++ if ((*sock = socket(res0->ai_family, res0->ai_socktype, 0)) < 1) { - *hstbuflen = 2048; -@@ -364,5 +367,9 @@ + message("unable to create socket\n"); +- free(tmphstbuf); ++ free(res0); + return CONSOCKERR; + } ++ + /*Experimental */ + flags = fcntl(*sock, F_GETFL, 0); + if (flags != -1) +@@ -96,8 +105,7 @@ + + message("Connecting to server......."); + +- +- status = connect(*sock, (struct sockaddr *) &server, sizeof(server)); ++ status = connect(*sock, res0->ai_addr, res0->ai_addrlen); + + if (status == -1 && noblock != -1 && errno == EINPROGRESS) + { +@@ -135,11 +143,11 @@ + + if (errno == ECONNREFUSED) + { +- free(tmphstbuf); ++ free(res0); + return CONREFUSED; + } else + { +- free(tmphstbuf); ++ free(res0); + return CONERROR; } - if (res) - return NULL; -+#else -+ hp = gethostbyname(host); -+#endif + } else +@@ -156,8 +164,9 @@ + /* setsockopt(*sock, SOL_SOCKET, SO_KEEPALIVE, + * (char *) &opt, (int) sizeof(opt)); + */ + - return hp; + message("Connect OK!"); +- free(tmphstbuf); ++ free(res0); + return NOCONERROR; } + |