summaryrefslogtreecommitdiff
path: root/sbin/unwind
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/unwind')
-rw-r--r--sbin/unwind/resolver.c64
1 files changed, 60 insertions, 4 deletions
diff --git a/sbin/unwind/resolver.c b/sbin/unwind/resolver.c
index 20bae1a1676..bec89fe1c58 100644
--- a/sbin/unwind/resolver.c
+++ b/sbin/unwind/resolver.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: resolver.c,v 1.89 2019/12/02 08:56:03 otto Exp $ */
+/* $OpenBSD: resolver.c,v 1.90 2019/12/02 14:40:53 florian Exp $ */
/*
* Copyright (c) 2018 Florian Obser <florian@openbsd.org>
@@ -43,14 +43,19 @@
#include <unistd.h>
#include "libunbound/config.h"
+#include "libunbound/libunbound/context.h"
#include "libunbound/libunbound/libworker.h"
#include "libunbound/libunbound/unbound.h"
#include "libunbound/libunbound/unbound-event.h"
+#include "libunbound/services/cache/rrset.h"
#include "libunbound/sldns/sbuffer.h"
#include "libunbound/sldns/rrdef.h"
#include "libunbound/sldns/pkthdr.h"
#include "libunbound/sldns/wire2str.h"
+#include "libunbound/util/config_file.h"
+#include "libunbound/util/module.h"
#include "libunbound/util/regional.h"
+#include "libunbound/util/storage/slabhash.h"
#include <openssl/crypto.h>
@@ -149,6 +154,7 @@ void new_asr_forwarders(void);
void new_static_forwarders(int);
void new_static_dot_forwarders(void);
struct uw_resolver *create_resolver(enum uw_resolver_type, int);
+void set_unified_cache(struct uw_resolver *);
void free_resolver(struct uw_resolver *);
void set_forwarders(struct uw_resolver *,
struct uw_forwarder_head *, int);
@@ -199,6 +205,10 @@ struct event_base *ev_base;
RB_GENERATE(force_tree, force_tree_entry, entry, force_tree_cmp)
+struct alloc_cache unified_cache_alloc;
+struct slabhash *unified_msg_cache;
+struct rrset_cache *unified_rrset_cache;
+
static const char * const as112_zones[] = {
/* RFC1918 */
"10.in-addr.arpa. transparent",
@@ -317,9 +327,10 @@ resolver_sig_handler(int sig, short event, void *arg)
void
resolver(int debug, int verbose)
{
- struct event ev_sigint, ev_sigterm;
- struct passwd *pw;
- struct timeval tv = {DECAY_PERIOD, 0};
+ struct config_file *ub_cfg;
+ struct event ev_sigint, ev_sigterm;
+ struct passwd *pw;
+ struct timeval tv = {DECAY_PERIOD, 0};
resolver_conf = config_new_empty();
@@ -373,6 +384,29 @@ resolver(int debug, int verbose)
clock_gettime(CLOCK_MONOTONIC, &last_network_change);
+ if ((ub_cfg = config_create_forlib()) == NULL)
+ fatal(NULL);
+
+ alloc_init(&unified_cache_alloc, NULL, 0);
+
+ /*
+ * context_finalize() ensures that the cache is sized according to
+ * the context's config. If we want to change the cache size we
+ * need to reflect it in the config as well otherwise these cache
+ * objects get deleted and re-created.
+ */
+ if ((unified_msg_cache = slabhash_create(ub_cfg->msg_cache_slabs,
+ HASH_DEFAULT_STARTARRAY, ub_cfg->msg_cache_size, msgreply_sizefunc,
+ query_info_compare, query_entry_delete, reply_info_delete, NULL))
+ == NULL)
+ fatal(NULL);
+
+ if ((unified_rrset_cache = rrset_cache_adjust(NULL, ub_cfg,
+ &unified_cache_alloc)) == NULL)
+ fatal(NULL);
+
+ config_delete(ub_cfg);
+
new_recursor();
TAILQ_INIT(&autoconf_forwarder_list);
@@ -1030,6 +1064,7 @@ new_recursor(void)
return;
resolvers[UW_RES_RECURSOR] = create_resolver(UW_RES_RECURSOR, 0);
+ set_unified_cache(resolvers[UW_RES_RECURSOR]);
check_resolver(resolvers[UW_RES_RECURSOR]);
}
@@ -1048,6 +1083,7 @@ new_forwarders(int oppdot)
log_debug("%s: create_resolver", __func__);
resolvers[UW_RES_DHCP] = create_resolver(UW_RES_DHCP, oppdot);
+ set_unified_cache(resolvers[UW_RES_DHCP]);
check_resolver(resolvers[UW_RES_DHCP]);
}
@@ -1081,6 +1117,7 @@ new_static_forwarders(int oppdot)
log_debug("%s: create_resolver", __func__);
resolvers[UW_RES_FORWARDER] = create_resolver(UW_RES_FORWARDER, oppdot);
+ set_unified_cache(resolvers[UW_RES_FORWARDER]);
check_resolver(resolvers[UW_RES_FORWARDER]);
}
@@ -1099,10 +1136,23 @@ new_static_dot_forwarders(void)
log_debug("%s: create_resolver", __func__);
resolvers[UW_RES_DOT] = create_resolver(UW_RES_DOT, 0);
+ set_unified_cache(resolvers[UW_RES_DOT]);
check_resolver(resolvers[UW_RES_DOT]);
}
+void
+set_unified_cache(struct uw_resolver *res)
+{
+ if (res == NULL)
+ return;
+
+ res->ctx->env->msg_cache = unified_msg_cache;
+ res->ctx->env->rrset_cache = unified_rrset_cache;
+
+ context_finalize(res->ctx);
+}
+
static const struct {
const char *name;
const char *value;
@@ -1289,6 +1339,12 @@ free_resolver(struct uw_resolver *res)
res->stop = 1;
else {
evtimer_del(&res->check_ev);
+ if (res->ctx != NULL) {
+ if (res->ctx->env->msg_cache == unified_msg_cache)
+ res->ctx->env->msg_cache = NULL;
+ if (res->ctx->env->rrset_cache == unified_rrset_cache)
+ res->ctx->env->rrset_cache = NULL;
+ }
ub_ctx_delete(res->ctx);
asr_resolver_free(res->asr_ctx);
free(res->why_bogus);