diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-02-27 12:37:02 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-02-27 12:37:02 +0000 |
commit | 3bfbd8fd104995e351c00635dff492b1a9a0e97e (patch) | |
tree | 593010e7091746b0e589ba8eae5c87e5b6926720 /src | |
parent | fd449b38e77db529a69dd44ccfd7e90dcbbd7717 (diff) | |
download | rspamd-3bfbd8fd104995e351c00635dff492b1a9a0e97e.tar.gz rspamd-3bfbd8fd104995e351c00635dff492b1a9a0e97e.zip |
[CritFix] Fix critical memory issues with radix maps
Diffstat (limited to 'src')
-rw-r--r-- | src/libutil/map.c | 6 | ||||
-rw-r--r-- | src/libutil/radix.c | 22 |
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 ++; |