diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-12-06 13:10:43 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-12-06 13:10:43 +0000 |
commit | c25ecd901b07ba752e61bcf8c4d52d0d708ec413 (patch) | |
tree | 2506f6d531f404a661eb6bbb232ba33f9e411ca7 /src/libserver/spf.c | |
parent | a7e98226be0a25c1342720e97b7c6841c2e14eb5 (diff) | |
download | rspamd-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.c | 30 |
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 * |