summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/libc/asr/asr.c129
-rw-r--r--lib/libc/asr/asr_debug.c18
-rw-r--r--lib/libc/asr/asr_private.h17
-rw-r--r--lib/libc/asr/res_search_async.c13
-rw-r--r--lib/libc/asr/res_send_async.c90
5 files changed, 89 insertions, 178 deletions
diff --git a/lib/libc/asr/asr.c b/lib/libc/asr/asr.c
index f6e8ffc6899..e328e224f82 100644
--- a/lib/libc/asr/asr.c
+++ b/lib/libc/asr/asr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: asr.c,v 1.9 2012/09/07 13:49:43 eric Exp $ */
+/* $OpenBSD: asr.c,v 1.10 2012/09/09 09:42:06 eric Exp $ */
/*
* Copyright (c) 2010-2012 Eric Faurot <eric@openbsd.org>
*
@@ -68,13 +68,14 @@ async_resolver(const char *conf)
static int init = 0;
struct asr *asr;
-#ifdef DEBUG
if (init == 0) {
+#ifdef DEBUG
if (getenv("ASR_DEBUG"))
- asr_debug = 1;
+ asr_debug = stderr;
+#endif
init = 1;
}
-#endif
+
if ((asr = calloc(1, sizeof(*asr))) == NULL)
goto fail;
@@ -161,24 +162,16 @@ async_run(struct async *as, struct async_res *ar)
{
int r, saved_errno = errno;
-#ifdef DEBUG
- asr_printf("asr: async_run(%p, %p) %s ctx=[%p]\n",
- as, ar, asr_querystr(as->as_type), as->as_ctx);
-#endif
+ DPRINT("asr: async_run(%p, %p) %s ctx=[%p]\n", as, ar,
+ asr_querystr(as->as_type), as->as_ctx);
r = as->as_run(as, ar);
-#ifdef DEBUG
- if (asr_debug) {
- asr_printf("asr: async_run(%p, %p) -> %s", as, ar,
- asr_transitionstr(r));
- if (r == ASYNC_COND)
- asr_printf(" fd=%i timeout=%i\n",
- ar->ar_fd, ar->ar_timeout);
- else
- asr_printf("\n");
- fflush(stderr);
- }
-#endif
+ DPRINT("asr: async_run(%p, %p) -> %s", as, ar, asr_transitionstr(r));
+ if (r == ASYNC_COND)
+ DPRINT(" fd=%i timeout=%i\n", ar->ar_fd, ar->ar_timeout);
+ else
+ DPRINT("\n");
+
if (r == ASYNC_DONE)
async_free(as);
@@ -223,10 +216,9 @@ struct async *
async_new(struct asr_ctx *ac, int type)
{
struct async *as;
-#ifdef DEBUG
- asr_printf("asr: async_new(ctx=%p) type=%i refcount=%i\n",
- ac, type, ac->ac_refcount);
-#endif
+
+ DPRINT("asr: async_new(ctx=%p) type=%i refcount=%i\n", ac, type,
+ ac->ac_refcount);
if ((as = calloc(1, sizeof(*as))) == NULL)
return (NULL);
@@ -245,9 +237,7 @@ async_new(struct asr_ctx *ac, int type)
void
async_free(struct async *as)
{
-#ifdef DEBUG
- asr_printf("asr: async_free(%p)\n", as);
-#endif
+ DPRINT("asr: async_free(%p)\n", as);
switch(as->as_type) {
case ASR_SEND:
if (as->as_fd != -1)
@@ -326,15 +316,10 @@ asr_use_resolver(struct asr *asr)
struct asr **priv;
if (asr == NULL) {
- /* Use the thread-local resolver. */
-#ifdef DEBUG
- asr_printf("using thread-local resolver\n");
-#endif
+ DPRINT("using thread-local resolver\n");
priv = _THREAD_PRIVATE(_asr, asr, &_asr);
if (*priv == NULL) {
-#ifdef DEBUG
- asr_printf("setting up thread-local resolver\n");
-#endif
+ DPRINT("setting up thread-local resolver\n");
*priv = async_resolver(NULL);
}
asr = *priv;
@@ -348,10 +333,7 @@ asr_use_resolver(struct asr *asr)
static void
asr_ctx_ref(struct asr_ctx *ac)
{
-#ifdef DEBUG
- asr_printf("asr: asr_ctx_ref(ctx=%p) refcount=%i\n",
- ac, ac->ac_refcount);
-#endif
+ DPRINT("asr: asr_ctx_ref(ctx=%p) refcount=%i\n", ac, ac->ac_refcount);
ac->ac_refcount += 1;
}
@@ -362,10 +344,7 @@ asr_ctx_ref(struct asr_ctx *ac)
void
asr_ctx_unref(struct asr_ctx *ac)
{
-#ifdef DEBUG
- asr_printf("asr: asr_ctx_unref(ctx=%p) refcount=%i\n",
- ac, ac->ac_refcount);
-#endif
+ DPRINT("asr: asr_ctx_unref(ctx=%p) refcount=%i\n", ac, ac->ac_refcount);
if (--ac->ac_refcount)
return;
@@ -407,20 +386,14 @@ asr_check_reload(struct asr *asr)
return;
asr->a_rtime = tp.tv_sec;
-#ifdef DEBUG
- asr_printf("asr: checking for update of \"%s\"\n", asr->a_path);
-#endif
-
+ DPRINT("asr: checking for update of \"%s\"\n", asr->a_path);
if (stat(asr->a_path, &st) == -1 ||
asr->a_mtime == st.st_mtime ||
(ac = asr_ctx_create()) == NULL)
return;
asr->a_mtime = st.st_mtime;
-#ifdef DEBUG
- asr_printf("asr: reloading config file\n");
-#endif
-
+ DPRINT("asr: reloading config file\n");
if (asr_ctx_from_file(ac, asr->a_path) == -1) {
asr_ctx_free(ac);
return;
@@ -705,9 +678,7 @@ asr_ctx_from_file(struct asr_ctx *ac, const char *path)
r = fread(buf, 1, sizeof buf - 1, cf);
if (feof(cf) == 0) {
-#ifdef DEBUG
- asr_printf("asr: config file too long: \"%s\"\n", path);
-#endif
+ DPRINT("asr: config file too long: \"%s\"\n", path);
r = -1;
}
fclose(cf);
@@ -896,17 +867,14 @@ int
asr_iter_db(struct async *as)
{
if (as->as_db_idx >= as->as_ctx->ac_dbcount) {
-#ifdef DEBUG
- asr_printf("asr_iter_db: done\n");
-#endif
+ DPRINT("asr_iter_db: done\n");
return (-1);
}
as->as_db_idx += 1;
as->as_ns_idx = 0;
-#ifdef DEBUG
- asr_printf("asr_iter_db: %i\n", as->as_db_idx);
-#endif
+ DPRINT("asr_iter_db: %i\n", as->as_db_idx);
+
return (0);
}
@@ -928,9 +896,7 @@ asr_iter_ns(struct async *as)
break;
as->as_ns_idx = 0;
as->as_ns_cycles++;
-#ifdef DEBUG
- asr_printf("asr: asr_iter_ns(): cycle %i\n", as->as_ns_cycles);
-#endif
+ DPRINT("asr: asr_iter_ns(): cycle %i\n", as->as_ns_cycles);
}
return (0);
@@ -969,9 +935,7 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
* don't try anything else.
*/
if (strlen(name) && name[strlen(name) - 1] == '.') {
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") fqdn\n", name);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") fqdn\n", name);
as->as_dom_flags |= ASYNC_DOM_FQDN;
as->as_dom_step = DOM_DONE;
return (asr_domcat(name, NULL, buf, len));
@@ -984,10 +948,8 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
if ((as->as_ctx->ac_options & RES_NOALIASES) == 0 &&
asr_ndots(name) == 0 &&
(alias = asr_hostalias(name, buf, len)) != NULL) {
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") is alias "
- "\"%s\"\n", name, alias);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") is alias \"%s\"\n",
+ name, alias);
as->as_dom_flags |= ASYNC_DOM_HOSTALIAS;
as->as_dom_step = DOM_DONE;
return (asr_domcat(alias, NULL, buf, len));
@@ -1004,10 +966,7 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
* in resolv.conf(5).
*/
if ((asr_ndots(name)) >= as->as_ctx->ac_ndots) {
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") ndots\n",
- name);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") ndots\n", name);
as->as_dom_flags |= ASYNC_DOM_NDOTS;
strlcpy(buf, name, len);
return (0);
@@ -1017,11 +976,8 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
case DOM_DOMAIN:
if (as->as_dom_idx < as->as_ctx->ac_domcount) {
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") "
- "domain \"%s\"\n", name,
- as->as_ctx->ac_dom[as->as_dom_idx]);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") domain \"%s\"\n",
+ name, as->as_ctx->ac_dom[as->as_dom_idx]);
as->as_dom_flags |= ASYNC_DOM_DOMAIN;
return (asr_domcat(name,
as->as_ctx->ac_dom[as->as_dom_idx++], buf, len));
@@ -1036,10 +992,7 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
* do it now.
*/
if (!(as->as_dom_flags & ASYNC_DOM_NDOTS)) {
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") as is\n",
- name);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") as is\n", name);
as->as_dom_flags |= ASYNC_DOM_ASIS;
strlcpy(buf, name, len);
return (0);
@@ -1048,9 +1001,7 @@ asr_iter_domain(struct async *as, const char *name, char * buf, size_t len)
case DOM_DONE:
default:
-#ifdef DEBUG
- asr_printf("asr: asr_iter_domain(\"%s\") done\n", name);
-#endif
+ DPRINT("asr: asr_iter_domain(\"%s\") done\n", name);
return (-1);
}
}
@@ -1072,9 +1023,7 @@ asr_hostalias(const char *name, char *abuf, size_t abufsz)
if (file == NULL || issetugid() != 0 || (fp = fopen(file, "r")) == NULL)
return (NULL);
-#ifdef DEBUG
- asr_printf("asr: looking up aliases in \"%s\"\n", file);
-#endif
+ DPRINT("asr: looking up aliases in \"%s\"\n", file);
while ((buf = fgetln(fp, &len)) != NULL) {
if (buf[len - 1] == '\n')
@@ -1085,9 +1034,7 @@ asr_hostalias(const char *name, char *abuf, size_t abufsz)
if (!strcasecmp(tokens[0], name)) {
if (strlcpy(abuf, tokens[1], abufsz) > abufsz)
continue;
-#ifdef DEBUG
- asr_printf("asr: found alias \"%s\"\n", abuf);
-#endif
+ DPRINT("asr: found alias \"%s\"\n", abuf);
fclose(fp);
return (abuf);
}
diff --git a/lib/libc/asr/asr_debug.c b/lib/libc/asr/asr_debug.c
index 0085b9ac3b5..a961101994c 100644
--- a/lib/libc/asr/asr_debug.c
+++ b/lib/libc/asr/asr_debug.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: asr_debug.c,v 1.6 2012/09/05 21:49:12 eric Exp $ */
+/* $OpenBSD: asr_debug.c,v 1.7 2012/09/09 09:42:06 eric Exp $ */
/*
* Copyright (c) 2010-2012 Eric Faurot <eric@openbsd.org>
*
@@ -29,7 +29,7 @@
#include "asr.h"
#include "asr_private.h"
-static void asr_vdebug(const char *, va_list);
+static void asr_printf(const char *, ...);
static char *print_dname(const char *, char *, size_t);
static char *print_host(const struct sockaddr *, char *, size_t);
@@ -306,7 +306,7 @@ struct kv { int code; const char *name; };
static const char* kvlookup(struct kv *, int);
-int asr_debug = 0;
+FILE * asr_debug = NULL;
void
asr_dump(struct asr *a)
@@ -542,19 +542,15 @@ asr_dump_packet(FILE *f, const void *data, size_t len, int noid)
}
static void
-asr_vdebug(const char *fmt, va_list ap)
-{
- if (asr_debug)
- vfprintf(stderr, fmt, ap);
-}
-
-void
asr_printf(const char *fmt, ...)
{
va_list ap;
+ if (asr_debug == NULL)
+ return;
+
va_start(ap, fmt);
- asr_vdebug(fmt, ap);
+ vfprintf(asr_debug, fmt, ap);
va_end(ap);
}
diff --git a/lib/libc/asr/asr_private.h b/lib/libc/asr/asr_private.h
index 7562ca5b190..1342d19e841 100644
--- a/lib/libc/asr/asr_private.h
+++ b/lib/libc/asr/asr_private.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: asr_private.h,v 1.6 2012/09/06 13:57:51 eric Exp $ */
+/* $OpenBSD: asr_private.h,v 1.7 2012/09/09 09:42:06 eric Exp $ */
/*
* Copyright (c) 2012 Eric Faurot <eric@openbsd.org>
*
@@ -329,7 +329,16 @@ struct async *gethostbyaddr_async_ctx(const void *, socklen_t, int,
#ifdef DEBUG
-extern int asr_debug;
+extern FILE * asr_debug;
+
+#define DPRINT(...) do { if(asr_debug) { \
+ fprintf(asr_debug, __VA_ARGS__); \
+ } } while (0)
+#define DPRINT_PACKET(n, p, s) do { if(asr_debug) { \
+ fprintf(asr_debug, "----- %s -----\n", n); \
+ asr_dump_packet(asr_debug, (p), (s), 0); \
+ fprintf(asr_debug, "--------------\n"); \
+ } } while (0)
/* asr_debug.h */
const char *asr_querystr(int);
@@ -337,12 +346,14 @@ const char *asr_transitionstr(int);
void asr_dump(struct asr *);
void asr_dump_async(struct async *);
void asr_dump_packet(FILE *, const void *, size_t, int);
-void asr_printf(const char *fmt, ...);
void async_set_state(struct async *, int);
char *asr_print_addr(const struct sockaddr *, char *, size_t);
#else /* DEBUG */
+#define DPRINT(...)
+#define DPRINT_PACKET(...)
+
#define async_set_state(a, s) do { (a)->as_state = (s); } while (0)
#endif /* DEBUG */
diff --git a/lib/libc/asr/res_search_async.c b/lib/libc/asr/res_search_async.c
index 99e315313e8..5ec59e48ecd 100644
--- a/lib/libc/asr/res_search_async.c
+++ b/lib/libc/asr/res_search_async.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: res_search_async.c,v 1.1 2012/04/14 09:24:18 eric Exp $ */
+/* $OpenBSD: res_search_async.c,v 1.2 2012/09/09 09:42:06 eric Exp $ */
/*
* Copyright (c) 2012 Eric Faurot <eric@openbsd.org>
*
@@ -48,9 +48,9 @@ res_search_async(const char *name, int class, int type, unsigned char *ans,
{
struct asr_ctx *ac;
struct async *as;
-#ifdef DEBUG
- asr_printf("asr: res_search_async(\"%s\", %i, %i)\n", name, class, type);
-#endif
+
+ DPRINT("asr: res_search_async(\"%s\", %i, %i)\n", name, class, type);
+
ac = asr_use_resolver(asr);
as = res_search_async_ctx(name, class, type, ans, anslen, ac);
asr_ctx_unref(ac);
@@ -64,10 +64,7 @@ res_search_async_ctx(const char *name, int class, int type, unsigned char *ans,
{
struct async *as;
-#ifdef DEBUG
- asr_printf("asr: res_search_async_ctx(\"%s\", %i, %i)\n",
- name, class, type);
-#endif
+ DPRINT("asr: res_search_async_ctx(\"%s\", %i, %i)\n", name, class, type);
if ((as = async_new(ac, ASR_SEARCH)) == NULL)
goto err; /* errno set */
diff --git a/lib/libc/asr/res_send_async.c b/lib/libc/asr/res_send_async.c
index cab78a3dc3d..20cc6ff695d 100644
--- a/lib/libc/asr/res_send_async.c
+++ b/lib/libc/asr/res_send_async.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: res_send_async.c,v 1.2 2012/07/07 20:41:52 eric Exp $ */
+/* $OpenBSD: res_send_async.c,v 1.3 2012/09/09 09:42:06 eric Exp $ */
/*
* Copyright (c) 2012 Eric Faurot <eric@openbsd.org>
*
@@ -58,12 +58,8 @@ res_send_async(const unsigned char *buf, int buflen, unsigned char *ans,
struct header h;
struct query q;
-#ifdef DEBUG
- if (asr_debug) {
- asr_printf("asr: res_send_async()\n");
- asr_dump_packet(stderr, buf, buflen, 0);
- }
-#endif
+ DPRINT_PACKET("asr: res_send_async()", buf, buflen);
+
ac = asr_use_resolver(asr);
if ((as = async_new(ac, ASR_SEND)) == NULL) {
asr_ctx_unref(ac);
@@ -122,9 +118,9 @@ res_query_async(const char *name, int class, int type, unsigned char *ans,
{
struct asr_ctx *ac;
struct async *as;
-#ifdef DEBUG
- asr_printf("asr: res_query_async(\"%s\", %i, %i)\n", name, class, type);
-#endif
+
+ DPRINT("asr: res_query_async(\"%s\", %i, %i)\n", name, class, type);
+
ac = asr_use_resolver(asr);
as = res_query_async_ctx(name, class, type, ans, anslen, ac);
asr_ctx_unref(ac);
@@ -138,10 +134,8 @@ res_query_async_ctx(const char *name, int class, int type, unsigned char *ans,
{
struct async *as;
-#ifdef DEBUG
- asr_printf("asr: res_query_async_ctx(\"%s\", %i, %i)\n", name, class,
- type);
-#endif
+ DPRINT("asr: res_query_async_ctx(\"%s\", %i, %i)\n", name, class, type);
+
if ((as = async_new(a_ctx, ASR_SEND)) == NULL)
return (NULL); /* errno set */
as->as_run = res_send_async_run;
@@ -378,25 +372,19 @@ setup_query(struct async *as, const char *name, const char *dom,
if (as->as.dns.flags & ASYNC_EXTOBUF) {
errno = EINVAL;
-#ifdef DEBUG
- asr_printf("attempting to write in user packet");
-#endif
+ DPRINT("attempting to write in user packet");
return (-1);
}
if (asr_make_fqdn(name, dom, fqdn, sizeof(fqdn)) > sizeof(fqdn)) {
errno = EINVAL;
-#ifdef DEBUG
- asr_printf("asr_make_fqdn: name too long\n");
-#endif
+ DPRINT("asr_make_fqdn: name too long\n");
return (-1);
}
if (dname_from_fqdn(fqdn, dname, sizeof(dname)) == -1) {
errno = EINVAL;
-#ifdef DEBUG
- asr_printf("dname_from_fqdn: invalid\n");
-#endif
+ DPRINT("dname_from_fqdn: invalid\n");
return (-1);
}
@@ -418,9 +406,7 @@ setup_query(struct async *as, const char *name, const char *dom,
pack_header(&p, &h);
pack_query(&p, type, class, dname);
if (p.err) {
-#ifdef DEBUG
- asr_printf("error packing query");
-#endif
+ DPRINT("error packing query");
errno = EINVAL;
return (-1);
}
@@ -433,20 +419,12 @@ setup_query(struct async *as, const char *name, const char *dom,
free(as->as.dns.dname);
as->as.dns.dname = strdup(dname);
if (as->as.dns.dname == NULL) {
-#ifdef DEBUG
- asr_printf("strdup");
-#endif
+ DPRINT("strdup");
return (-1); /* errno set */
}
as->as.dns.obuflen = p.offset;
-#ifdef DEBUG
- if (asr_debug) {
- asr_printf("------- asr_setup_query(): packet -------\n");
- asr_dump_packet(stderr, as->as.dns.obuf, as->as.dns.obuflen, 0);
- asr_printf("-----------------------------------------\n");
- }
-#endif
+ DPRINT_PACKET("asr_setup_query", as->as.dns.obuf, as->as.dns.obuflen);
return (0);
}
@@ -463,11 +441,11 @@ udp_send(struct async *as)
int save_errno;
#ifdef DEBUG
char buf[256];
-
- if (asr_debug)
- asr_printf("asr: [%p] connecting to %s UDP\n", as,
- asr_print_addr(AS_NS_SA(as), buf, sizeof buf));
#endif
+
+ DPRINT("asr: [%p] connecting to %s UDP\n", as,
+ asr_print_addr(AS_NS_SA(as), buf, sizeof buf));
+
as->as_fd = sockaddr_connect(AS_NS_SA(as), SOCK_DGRAM);
if (as->as_fd == -1)
return (-1); /* errno set */
@@ -518,13 +496,7 @@ udp_recv(struct async *as)
as->as.dns.ibuflen = n;
-#ifdef DEBUG
- if (asr_debug) {
- asr_printf("------- asr_udp_recv() packet -------\n");
- asr_dump_packet(stderr, as->as.dns.ibuf, as->as.dns.ibuflen, 0);
- asr_printf("-------------------------------------\n");
- }
-#endif
+ DPRINT_PACKET("asr_udp_recv()", as->as.dns.ibuf, as->as.dns.ibuflen);
if (validate_packet(as) == -1)
return (-1); /* errno set */
@@ -552,11 +524,8 @@ tcp_write(struct async *as)
/* First try to connect if not already */
if (as->as_fd == -1) {
-#ifdef DEBUG
- if (asr_debug)
- asr_printf("asr: [%p] connecting to %s TCP\n", as,
- asr_print_addr(AS_NS_SA(as), buf, sizeof buf));
-#endif
+ DPRINT("asr: [%p] connecting to %s TCP\n", as,
+ asr_print_addr(AS_NS_SA(as), buf, sizeof buf));
as->as_fd = sockaddr_connect(AS_NS_SA(as), SOCK_STREAM);
if (as->as_fd == -1)
return (-1); /* errno set */
@@ -675,13 +644,8 @@ tcp_read(struct async *as)
if (as->as.dns.ibuflen != as->as.dns.datalen)
return (1);
-#ifdef DEBUG
- if (asr_debug) {
- asr_printf("------- asr_tcp_read() packet -------\n");
- asr_dump_packet(stderr, as->as.dns.ibuf, as->as.dns.ibuflen, 0);
- asr_printf("-------------------------------------\n");
- }
-#endif
+ DPRINT_PACKET("asr_tcp_read()", as->as.dns.ibuf, as->as.dns.ibuflen);
+
if (validate_packet(as) == -1)
goto close; /* errno set */
@@ -751,9 +715,7 @@ validate_packet(struct async *as)
goto inval;
if (h.id != as->as.dns.reqid) {
-#ifdef DEBUG
- asr_printf("incorrect reqid\n");
-#endif
+ DPRINT("incorrect reqid\n");
goto inval;
}
if (h.qdcount != 1)
@@ -778,10 +740,8 @@ validate_packet(struct async *as)
if (q.q_type != as->as.dns.type ||
q.q_class != as->as.dns.class ||
strcasecmp(q.q_dname, as->as.dns.dname)) {
-#ifdef DEBUG
- asr_printf("incorrect type/class/dname '%s' != '%s'\n",
+ DPRINT("incorrect type/class/dname '%s' != '%s'\n",
q.q_dname, as->as.dns.dname);
-#endif
goto inval;
}