aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBryon Gloden, CISSPĀ® <cissp@bryongloden.com>2016-08-02 17:19:19 -0400
committerGitHub <noreply@github.com>2016-08-02 17:19:19 -0400
commita7abc8348801f8bc2f802447c109083b9e199806 (patch)
tree87a6d2d19e8c7080144950629d60d64e9fb5f085
parent0ef106e8a3a39c3dbd8e2cc5f24fff7e0e23ac40 (diff)
downloadrspamd-a7abc8348801f8bc2f802447c109083b9e199806.tar.gz
rspamd-a7abc8348801f8bc2f802447c109083b9e199806.zip
Update acism_create.c
Passing one pointer into realloc() and assigning the result directly into that same pointer variable can cause a memory leak if the reallocation fails, because the original allocation will still exist. The correct way to do this is to use a temporary pointer variable. Credit: http://stackoverflow.com/a/11548901 Found by https://github.com/bryongloden/cppcheck
-rw-r--r--contrib/aho-corasick/acism_create.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/contrib/aho-corasick/acism_create.c b/contrib/aho-corasick/acism_create.c
index b1d9b51e3..a6d007fd7 100644
--- a/contrib/aho-corasick/acism_create.c
+++ b/contrib/aho-corasick/acism_create.c
@@ -323,9 +323,15 @@ interleave(TNODE *troot, int nnodes, int nsyms, TNODE **v1, TNODE **v2)
if (last_trans < last) {
last_trans = last;
if (last + nsyms >= usev_size) {
- usev = realloc(usev, usev_size << 1);
- memset(usev + usev_size, 0, usev_size);
- usev_size <<= 1;
+ char *tmp = realloc(usev, usev_size << 1);
+ if (tmp != NULL) {
+ usev = tmp;
+ memset(usev + usev_size, 0, usev_size);
+ usev_size <<= 1;
+ } else {
+ free(usev);
+ /* And handle error */
+ }
}
}
}