[PATCH] common: Fix memory leak and incorrect comparison
Maks Mishin
maks.mishinfz at gmail.com
Thu Feb 6 14:48:09 CET 2025
Changing the order of actions: the input argument is checked before
memory is allocated.
The input argument `n` is of type `size_t` and cannot take
negative values, so the comparison has been fixed.
Signed-off-by: Maks Mishin <maks.mishinFZ at gmail.com>
---
common/dlmalloc.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/common/dlmalloc.c b/common/dlmalloc.c
index cc4d3a0a02..2f4cabda4a 100644
--- a/common/dlmalloc.c
+++ b/common/dlmalloc.c
@@ -2093,6 +2093,8 @@ Void_t* cALLOc_impl(n, elem_size) size_t n; size_t elem_size;
mchunkptr p;
INTERNAL_SIZE_T csz;
+ if ((long)n <= 0) return NULL;
+
INTERNAL_SIZE_T sz = n * elem_size;
/* check if expand_top called, in which case don't need to clear */
@@ -2104,8 +2106,6 @@ Void_t* cALLOc_impl(n, elem_size) size_t n; size_t elem_size;
#endif
Void_t* mem = mALLOc_impl (sz);
- if ((long)n < 0) return NULL;
-
if (mem == NULL)
return NULL;
else
--
2.34.1
More information about the U-Boot
mailing list