aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver/spf.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-12-06 13:10:43 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-12-06 13:10:43 +0000
commitc25ecd901b07ba752e61bcf8c4d52d0d708ec413 (patch)
tree2506f6d531f404a661eb6bbb232ba33f9e411ca7 /src/libserver/spf.c
parenta7e98226be0a25c1342720e97b7c6841c2e14eb5 (diff)
downloadrspamd-c25ecd901b07ba752e61bcf8c4d52d0d708ec413.tar.gz
rspamd-c25ecd901b07ba752e61bcf8c4d52d0d708ec413.zip
[Minor] Add debugging for spf references to find refcount leak
Diffstat (limited to 'src/libserver/spf.c')
-rw-r--r--src/libserver/spf.c30
1 files changed, 22 insertions, 8 deletions
diff --git a/src/libserver/spf.c b/src/libserver/spf.c
index ec8decb50..d21789c01 100644
--- a/src/libserver/spf.c
+++ b/src/libserver/spf.c
@@ -111,6 +111,10 @@ struct rspamd_spf_library_ctx *spf_lib_ctx = NULL;
rspamd_spf_log_id, "spf", rec->task->task_pool->tag.uid, \
G_STRFUNC, \
__VA_ARGS__)
+#define msg_debug_spf_flatten(...) rspamd_conditional_debug_fast_num_id (NULL, NULL, \
+ rspamd_spf_log_id, "spf", (flat)->digest, \
+ G_STRFUNC, \
+ __VA_ARGS__)
INIT_LOG_MODULE(spf)
@@ -157,6 +161,14 @@ RSPAMD_DESTRUCTOR(rspamd_spf_lib_ctx_dtor) {
spf_lib_ctx = NULL;
}
+static void
+spf_record_cached_unref_dtor (gpointer p)
+{
+ struct spf_resolved *flat = (struct spf_resolved *)p;
+
+ _spf_record_unref (flat, "LRU cache");
+}
+
void
spf_library_config (const ucl_object_t *obj)
{
@@ -208,7 +220,7 @@ spf_library_config (const ucl_object_t *obj)
spf_lib_ctx->spf_hash = rspamd_lru_hash_new (
ival,
NULL,
- (GDestroyNotify) spf_record_unref);
+ spf_record_cached_unref_dtor);
}
}
else {
@@ -216,7 +228,7 @@ spf_library_config (const ucl_object_t *obj)
spf_lib_ctx->spf_hash = rspamd_lru_hash_new (
2048,
NULL,
- (GDestroyNotify) spf_record_unref);
+ spf_record_cached_unref_dtor);
}
}
@@ -608,7 +620,7 @@ rspamd_spf_maybe_return (struct spf_record *rec)
}
rec->callback (flat, rec->task, rec->cbdata);
- REF_RELEASE (flat);
+ spf_record_unref (flat);
rec->done = TRUE;
}
}
@@ -2471,16 +2483,18 @@ rspamd_spf_resolve (struct rspamd_task *task, spf_cb_t callback,
}
struct spf_resolved *
-spf_record_ref (struct spf_resolved *rec)
+_spf_record_ref (struct spf_resolved *flat, const gchar *loc)
{
- REF_RETAIN (rec);
- return rec;
+ msg_debug_spf_flatten ("record ref %s; refcount=%d++", loc, flat->ref.refcount);
+ REF_RETAIN (flat);
+ return flat;
}
void
-spf_record_unref (struct spf_resolved *rec)
+_spf_record_unref (struct spf_resolved *flat, const gchar *loc)
{
- REF_RELEASE (rec);
+ msg_debug_spf_flatten ("record unref %s; refcount=%d--", loc, flat->ref.refcount);
+ REF_RELEASE (flat);
}
gchar *