summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-02-27 12:37:02 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-02-27 12:37:02 +0000
commit3bfbd8fd104995e351c00635dff492b1a9a0e97e (patch)
tree593010e7091746b0e589ba8eae5c87e5b6926720 /src
parentfd449b38e77db529a69dd44ccfd7e90dcbbd7717 (diff)
downloadrspamd-3bfbd8fd104995e351c00635dff492b1a9a0e97e.tar.gz
rspamd-3bfbd8fd104995e351c00635dff492b1a9a0e97e.zip
[CritFix] Fix critical memory issues with radix maps
Diffstat (limited to 'src')
-rw-r--r--src/libutil/map.c6
-rw-r--r--src/libutil/radix.c22
2 files changed, 24 insertions, 4 deletions
diff --git a/src/libutil/map.c b/src/libutil/map.c
index da99e384c..11ef2c441 100644
--- a/src/libutil/map.c
+++ b/src/libutil/map.c
@@ -2069,8 +2069,12 @@ static void
radix_tree_insert_helper (gpointer st, gconstpointer key, gconstpointer value)
{
radix_compressed_t *tree = (radix_compressed_t *)st;
+ rspamd_mempool_t *pool;
+ gpointer nvalue;
- rspamd_radix_add_iplist ((gchar *)key, ",", tree, value, FALSE);
+ pool = radix_get_pool (tree);
+ nvalue = rspamd_mempool_strdup (pool, value);
+ rspamd_radix_add_iplist (key, ",", tree, nvalue, FALSE);
}
static void
diff --git a/src/libutil/radix.c b/src/libutil/radix.c
index 8b1ca01c9..b44391bfc 100644
--- a/src/libutil/radix.c
+++ b/src/libutil/radix.c
@@ -163,6 +163,7 @@ rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
struct in_addr ina;
struct in6_addr ina6;
guint k = G_MAXINT;
+ gpointer key;
gint af;
gint res = 0, r;
struct addrinfo hints, *ai_res, *cur_ai;
@@ -246,8 +247,12 @@ rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
k = 32;
}
+ key = rspamd_mempool_alloc (tree->pool,
+ sizeof (sin->sin_addr));
+ memcpy (key, &sin->sin_addr,
+ sizeof (sin->sin_addr));
radix_insert_compressed (tree,
- (guint8 *)&sin->sin_addr,
+ key,
sizeof (sin->sin_addr),
32 - k, (uintptr_t)value);
res ++;
@@ -260,8 +265,13 @@ rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
k = 128;
}
+
+ key = rspamd_mempool_alloc (tree->pool,
+ sizeof (sin6->sin6_addr));
+ memcpy (key, &sin6->sin6_addr,
+ sizeof (sin6->sin6_addr));
radix_insert_compressed (tree,
- (guint8 *)&sin6->sin6_addr,
+ key,
sizeof (sin6->sin6_addr),
128 - k, (uintptr_t)value);
res ++;
@@ -292,7 +302,10 @@ rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
k = 32;
}
- radix_insert_compressed (tree, (guint8 *)&ina, sizeof (ina),
+
+ key = rspamd_mempool_alloc (tree->pool, sizeof (ina));
+ memcpy (key, &ina, sizeof (ina));
+ radix_insert_compressed (tree, key, sizeof (ina),
32 - k, (uintptr_t)value);
res ++;
}
@@ -300,6 +313,9 @@ rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
if (k > 128) {
k = 128;
}
+
+ key = rspamd_mempool_alloc (tree->pool, sizeof (ina6));
+ memcpy (key, &ina6, sizeof (ina6));
radix_insert_compressed (tree, (guint8 *)&ina6, sizeof (ina6),
128 - k, (uintptr_t)value);
res ++;