42 lines
1.5 KiB
Diff
42 lines
1.5 KiB
Diff
From eebd284f830ba900b7eeb0a48a476d47780450e4 Mon Sep 17 00:00:00 2001
|
|
From: Richard Weinberger <richard@nod.at>
|
|
Date: Fri, 2 Aug 2024 12:08:44 +0200
|
|
Subject: [PATCH] dlmalloc: Fix integer overflow in request2size()
|
|
|
|
req is of type size_t, casting it to long opens the door
|
|
for an integer overflow.
|
|
Values between LONG_MAX - (SIZE_SZ + MALLOC_ALIGN_MASK) - 1 and LONG_MAX
|
|
cause and overflow such that request2size() returns MINSIZE.
|
|
|
|
Fix by removing the cast.
|
|
The origin of the cast is unclear, it's in u-boot and ppcboot since ever
|
|
and predates the CVS history.
|
|
Doug Lea's original dlmalloc implementation also doesn't have it.
|
|
|
|
Signed-off-by: Richard Weinberger <richard@nod.at>
|
|
Reviewed-by: Simon Glass <sjg@chromium.org>
|
|
(cherry picked from 8642b2178d2c4002c99a0b69a845a48f2ae2706f)
|
|
Signed-off-by: Andrea della Porta <andrea.porta@suse.com>
|
|
---
|
|
common/dlmalloc.c | 4 ++--
|
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/common/dlmalloc.c b/common/dlmalloc.c
|
|
index ce4e56da..62935009 100644
|
|
--- a/common/dlmalloc.c
|
|
+++ b/common/dlmalloc.c
|
|
@@ -379,8 +379,8 @@ nextchunk-> +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
/* pad request bytes into a usable size */
|
|
|
|
#define request2size(req) \
|
|
- (((long)((req) + (SIZE_SZ + MALLOC_ALIGN_MASK)) < \
|
|
- (long)(MINSIZE + MALLOC_ALIGN_MASK)) ? MINSIZE : \
|
|
+ ((((req) + (SIZE_SZ + MALLOC_ALIGN_MASK)) < \
|
|
+ (MINSIZE + MALLOC_ALIGN_MASK)) ? MINSIZE : \
|
|
(((req) + (SIZE_SZ + MALLOC_ALIGN_MASK)) & ~(MALLOC_ALIGN_MASK)))
|
|
|
|
/* Check if m has acceptable alignment */
|
|
--
|
|
2.35.3
|
|
|