use threadsafe getservbyname_r

This commit is contained in:
rofl0r 2012-07-14 17:59:56 +02:00
parent 71e15e2edd
commit 4b999cdae7

View File

@ -835,11 +835,15 @@ struct hostent *proxy_gethostbyname(const char *name) {
MUTEX_UNLOCK(&internal_ips_lock); MUTEX_UNLOCK(&internal_ips_lock);
return NULL; return NULL;
} }
int proxy_getaddrinfo(const char *node, const char *service, const struct addrinfo *hints, struct addrinfo **res) { int proxy_getaddrinfo(const char *node, const char *service, const struct addrinfo *hints, struct addrinfo **res) {
struct servent *se = NULL; struct servent *se = NULL;
struct hostent *hp = NULL; struct hostent *hp = NULL;
struct sockaddr *sockaddr_space = NULL; struct sockaddr *sockaddr_space = NULL;
struct addrinfo *addrinfo_space = NULL; struct addrinfo *addrinfo_space = NULL;
struct servent se_buf;
char buf[1024];
int port;
// printf("proxy_getaddrinfo node %s service %s\n",node,service); // printf("proxy_getaddrinfo node %s service %s\n",node,service);
addrinfo_space = malloc(sizeof(struct addrinfo)); addrinfo_space = malloc(sizeof(struct addrinfo));
@ -858,13 +862,10 @@ int proxy_getaddrinfo(const char *node, const char *service, const struct addrin
else else
goto err3; goto err3;
} }
if(service) if(service) getservbyname_r(service, NULL, &se_buf, buf, sizeof(buf), &se);
se = getservbyname(service, NULL);
if(!se) { port = se ? se->s_port : htons(atoi(service ? service : "0"));
((struct sockaddr_in *) sockaddr_space)->sin_port = htons(atoi(service ? : "0")); ((struct sockaddr_in *) sockaddr_space)->sin_port = port;
} else
((struct sockaddr_in *) sockaddr_space)->sin_port = se->s_port;
*res = addrinfo_space; *res = addrinfo_space;
(*res)->ai_addr = sockaddr_space; (*res)->ai_addr = sockaddr_space;