summaryrefslogtreecommitdiffstats
path: root/testsuites
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2021-04-20 19:30:35 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2021-04-20 20:33:03 +0200
commit51defd927427b5b74c3a0c0f0b5c161929547cfc (patch)
tree7b7dc7a66a95427b3e420f45bd9f1a27ecc4dcf1 /testsuites
parentmalloc: Hide RTEMS_Malloc_Sbrk_amount (diff)
downloadrtems-51defd927427b5b74c3a0c0f0b5c161929547cfc.tar.bz2
Fix calloc() behaviour in case of overflow
The multiplication to calculate the length of the memory area to allocate may overflow. Return NULL in case of an overflow. Close #4389.
Diffstat (limited to 'testsuites')
-rw-r--r--testsuites/libtests/malloctest/init.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/testsuites/libtests/malloctest/init.c b/testsuites/libtests/malloctest/init.c
index 1d91385683..4d0f421c02 100644
--- a/testsuites/libtests/malloctest/init.c
+++ b/testsuites/libtests/malloctest/init.c
@@ -1190,6 +1190,14 @@ static void test_rtems_calloc(void)
rtems_test_assert(p == NULL);
rtems_test_assert(errno == 0);
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Walloc-size-larger-than=N"
+ errno = 0;
+ p = rtems_calloc(SIZE_MAX, SIZE_MAX);
+ rtems_test_assert(p == NULL);
+ rtems_test_assert(errno == 0);
+#pragma GCC diagnostic pop
+
i = rtems_calloc(1, sizeof(*i));
rtems_test_assert(i != NULL);
rtems_test_assert(*i == 0);
@@ -1313,22 +1321,17 @@ rtems_task Init(
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Walloc-size-larger-than=N"
p1 = calloc( 1, SIZE_MAX );
+ rtems_test_assert( p1 == NULL );
+
+ p1 = calloc( SIZE_MAX, SIZE_MAX );
+ rtems_test_assert( p1 == NULL );
#pragma GCC diagnostic pop
- if (p1) {
- printf("ERROR on attempt to calloc SIZE_MAX block expected failure.");
- free( p1 );
- }
/*
* Verify error case where malloc of size 0.
*/
p1 = malloc( 0 );
- if (p1) {
- printf("ERROR on attempt to malloc size 0 block expected failure.");
- free( p1 );
- }
-
-
+ rtems_test_assert( p1 == NULL );
test_heap_initialize();
test_heap_block_allocate();