aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libutil/mem_pool.c33
1 files changed, 32 insertions, 1 deletions
diff --git a/src/libutil/mem_pool.c b/src/libutil/mem_pool.c
index ddaa5cc85..a40578e83 100644
--- a/src/libutil/mem_pool.c
+++ b/src/libutil/mem_pool.c
@@ -57,6 +57,9 @@ pthread_mutex_t stat_mtx = PTHREAD_MUTEX_INITIALIZER;
/* Internal statistic */
static rspamd_mempool_stat_t *mem_pool_stat = NULL;
+/* Environment variable */
+static gboolean env_checked = FALSE;
+static gboolean always_malloc = FALSE;
/**
* Function that return free space in pool page
@@ -207,6 +210,17 @@ rspamd_mempool_new (gsize size)
memset (map, 0, sizeof (rspamd_mempool_stat_t));
}
+ if (!env_checked) {
+ /* Check G_SLICE=always-malloc to allow memory pool debug */
+ const char *g_slice;
+
+ g_slice = getenv ("G_SLICE");
+ if (g_slice != NULL && g_ascii_strcasecmp (g_slice, "always-malloc") == 0) {
+ always_malloc = TRUE;
+ }
+ env_checked = TRUE;
+ }
+
new = g_slice_alloc (sizeof (rspamd_mempool_t));
if (new == NULL) {
msg_err ("cannot allocate %z bytes, aborting",
@@ -238,6 +252,15 @@ memory_pool_alloc_common (rspamd_mempool_t * pool, gsize size, gboolean is_tmp)
if (pool) {
POOL_MTX_LOCK ();
+ if (always_malloc) {
+ void *ptr;
+
+ ptr = g_malloc (size);
+ POOL_MTX_UNLOCK ();
+ rspamd_mempool_add_destructor (pool, g_free, ptr);
+
+ return ptr;
+ }
#ifdef MEMORY_GREEDY
if (is_tmp) {
cur = pool->first_pool_tmp;
@@ -564,7 +587,15 @@ rspamd_mempool_add_destructor_full (rspamd_mempool_t * pool,
{
struct _pool_destructors *cur;
- cur = rspamd_mempool_alloc (pool, sizeof (struct _pool_destructors));
+ if (always_malloc) {
+ /* Ugly workaround */
+ always_malloc = FALSE;
+ cur = rspamd_mempool_alloc (pool, sizeof (struct _pool_destructors));
+ always_malloc = TRUE;
+ }
+ else {
+ cur = rspamd_mempool_alloc (pool, sizeof (struct _pool_destructors));
+ }
if (cur) {
POOL_MTX_LOCK ();
cur->func = func;