From 87521fc8eff52fc4bc3bbb5a0ac80d81634bc1e0 Mon Sep 17 00:00:00 2001 From: Stef Walter Date: Tue, 28 Nov 2006 01:54:16 +0000 Subject: Fixed asynchronous resolving on FreeBSD --- common/async-resolver.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'common/async-resolver.c') diff --git a/common/async-resolver.c b/common/async-resolver.c index cf92c86..284a486 100644 --- a/common/async-resolver.c +++ b/common/async-resolver.c @@ -109,6 +109,7 @@ typedef struct _resolve_request { char hostname[256]; char servname[256]; + struct addrinfo hints; async_resolve_callback cb; void *arg; @@ -164,7 +165,7 @@ resolver_thread(void* arg) /* The actual resolve */ req->gaierr = getaddrinfo(req->hostname, req->servname[0] ? req->servname : NULL, - NULL, &req->ai); + &req->hints, &req->ai); req->errn = errno; /* A timeout */ @@ -255,7 +256,7 @@ async_resolver_init() void async_resolver_queue(const char* hostname, const char* servname, - async_resolve_callback cb, void* arg) + struct addrinfo* hints, async_resolve_callback cb, void* arg) { resolve_request* req; resolve_request* r; @@ -287,6 +288,9 @@ async_resolver_queue(const char* hostname, const char* servname, strncpy(req->servname, servname, sizeof(req->servname)); req->servname[sizeof(req->servname) - 1] = 0; + if(hints) + memcpy(&(req->hints), hints, sizeof(req->hints)); + /* Append the result to requests */ pthread_mutex_lock(&res_mutex); -- cgit v1.2.3