blob: 66af6afa2f3418a8a61f898465dad6820ca47090 [file] [log] [blame]
Andrew Geissler6ce62a22020-11-30 19:58:47 -06001From 1c01a5bc9ac7f8aaa484b1a8e0e74aa5f8899d0e Mon Sep 17 00:00:00 2001
2From: Khem Raj <raj.khem@gmail.com>
3Date: Sun, 8 Nov 2020 11:17:59 -0800
4Subject: [PATCH] malloc: Check for excessive values to malloc
5
6with whole program optimizers like lto smalloc()
7is inlined the excessive constant argument is propagated to
8malloc() and ultimately triggers the warning.
9
10malloc.c:15:9: error: argument 1 range [18446744065119617024, 18446744073709551580] exceeds maximum object size 9223372036854775807 [-Werror=alloc-size-larger-than=]
11
12therefore add a check before excessive constant argument before calling
13malloc
14
15Note that this will not happen with normal compile since they happen to
16be in different translation units and compiler can not semantically
17analyze as much
18
19Upstream-Status: Pending
20
21Signed-off-by: Khem Raj <raj.khem@gmail.com>
22---
23 malloc.c | 3 +++
24 1 file changed, 3 insertions(+)
25
26diff --git a/malloc.c b/malloc.c
27index a7fa7c5..520377c 100644
28--- a/malloc.c
29+++ b/malloc.c
30@@ -2,6 +2,7 @@
31 * malloc.c: safe wrappers around malloc, realloc, free, strdup
32 */
33
34+#include <stdint.h>
35 #include <stdlib.h>
36 #include <string.h>
37 #include "puzzles.h"
38@@ -12,6 +13,8 @@
39 */
40 void *smalloc(size_t size) {
41 void *p;
42+ if (size > PTRDIFF_MAX)
43+ fatal("exceeds maximum object size");
44 p = malloc(size);
45 if (!p)
46 fatal("out of memory");
47--
482.29.2
49