diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-08-21 15:54:35 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-08-21 15:54:35 +0100 |
commit | 184d5044cd76ed3b5ec0651d859ade495088b5d1 (patch) | |
tree | 692d00236d7797f32562746e42063dbd60769602 /src/libserver/dns.c | |
parent | a6d3bbb1a744673cf898284f345935467a7179bb (diff) | |
download | rspamd-184d5044cd76ed3b5ec0651d859ade495088b5d1.tar.gz rspamd-184d5044cd76ed3b5ec0651d859ade495088b5d1.zip |
Allow to use resolver without the pool.
Diffstat (limited to 'src/libserver/dns.c')
-rw-r--r-- | src/libserver/dns.c | 35 |
1 files changed, 26 insertions, 9 deletions
diff --git a/src/libserver/dns.c b/src/libserver/dns.c index dae19e849..aa4877783 100644 --- a/src/libserver/dns.c +++ b/src/libserver/dns.c @@ -41,15 +41,19 @@ struct rspamd_dns_request_ud { struct rspamd_async_session *session; dns_callback_type cb; gpointer ud; + rspamd_mempool_t *pool; struct rdns_request *req; }; static void rspamd_dns_fin_cb (gpointer arg) { - struct rdns_request *req = arg; + struct rspamd_dns_request_ud *reqdata = (struct rspamd_dns_request_ud *)arg; - rdns_request_release (req); + rdns_request_release (reqdata->req); + if (reqdata->pool == NULL) { + g_slice_free1 (sizeof (struct rspamd_dns_request_ud), reqdata); + } } static void @@ -67,6 +71,9 @@ rspamd_dns_callback (struct rdns_reply *reply, gpointer ud) if (reqdata->session) { remove_normal_event (reqdata->session, rspamd_dns_fin_cb, reqdata->req); } + if (reqdata->pool == NULL) { + g_slice_free1 (sizeof (struct rspamd_dns_request_ud), reqdata); + } } gboolean @@ -79,10 +86,16 @@ make_dns_request (struct rspamd_dns_resolver *resolver, const char *name) { struct rdns_request *req; - struct rspamd_dns_request_ud *reqdata; + struct rspamd_dns_request_ud *reqdata = NULL; - reqdata = - rspamd_mempool_alloc (pool, sizeof (struct rspamd_dns_request_ud)); + if (pool != NULL) { + reqdata = + rspamd_mempool_alloc (pool, sizeof (struct rspamd_dns_request_ud)); + } + else { + reqdata = g_slice_alloc (sizeof (struct rspamd_dns_request_ud)); + } + reqdata->pool = pool; reqdata->session = session; reqdata->cb = cb; reqdata->ud = ud; @@ -90,18 +103,22 @@ make_dns_request (struct rspamd_dns_resolver *resolver, req = rdns_make_request_full (resolver->r, rspamd_dns_callback, reqdata, resolver->request_timeout, resolver->max_retransmits, 1, name, type); + reqdata->req = req; if (session) { if (req != NULL) { register_async_event (session, (event_finalizer_t)rspamd_dns_fin_cb, - req, + reqdata, g_quark_from_static_string ("dns resolver")); - reqdata->req = req; } - else { - return FALSE; + } + + if (req == NULL) { + if (pool == NULL) { + g_slice_free1 (sizeof (struct rspamd_dns_request_ud), reqdata); } + return FALSE; } return TRUE; |