From: Victor Julien Date: Fri, 21 Apr 2023 08:59:19 +0000 (+0200) Subject: mpm/hs: fix scan-build warning X-Git-Tag: suricata-7.0.0-rc2~368 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ec84ba1a3c981108af4613fa16d5f13cc19e1f1d;p=thirdparty%2Fsuricata.git mpm/hs: fix scan-build warning util-mpm-hs.c:340:20: warning: Potential leak of memory pointed to by 'p' [unix.Malloc] p->sids[0] = sid; ~~~~~~~~~~~^~~~~ 1 warning generated. Incorrect error handling could lead to a memory leak. --- diff --git a/src/util-mpm-hs.c b/src/util-mpm-hs.c index 65fda758e0..a6fb82372c 100644 --- a/src/util-mpm-hs.c +++ b/src/util-mpm-hs.c @@ -231,7 +231,7 @@ static inline int SCHSInitHashAdd(SCHSCtx *ctx, SCHSPattern *p) uint32_t hash = SCHSInitHash(p); if (ctx->init_hash == NULL) { - return 0; + return -1; } if (ctx->init_hash[hash] == NULL) { @@ -309,7 +309,8 @@ static int SCHSAddPattern(MpmCtx *mpm_ctx, uint8_t *pat, uint16_t patlen, memcpy(p->original_pat, pat, patlen); /* put in the pattern hash */ - SCHSInitHashAdd(ctx, p); + if (SCHSInitHashAdd(ctx, p) != 0) + goto error; mpm_ctx->pattern_cnt++;