/* Test of realloc function. Copyright (C) 2010-2025 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include /* Specification. */ #include #include #include #include "macros.h" /* Work around clang bug . */ void *(*volatile my_realloc) (void *, size_t) = realloc; #undef realloc #define realloc my_realloc int main (int argc, _GL_UNUSED char **argv) { void *p; /* Check that realloc (NULL, 0) is not a NULL pointer. */ p = realloc (NULL, 0); ASSERT (p != NULL); #ifdef NOT_YET free (p); /* Check that realloc (p, 0) for non-NULL p is not a NULL pointer. */ p = malloc (200); p = realloc (p, 0); ASSERT (p != NULL); free (p); /* Check that realloc (p, 0) for non-NULL p is not a NULL pointer. */ p = malloc (2 * 1024 * 1024); p = realloc (p, 0); ASSERT (p != NULL); #endif /* Check that realloc (p, n) fails when p is non-null and n exceeds PTRDIFF_MAX. */ if (PTRDIFF_MAX < SIZE_MAX) { size_t one = argc != 12345; void *r = realloc (p, PTRDIFF_MAX + one); ASSERT (r == NULL); /* Avoid a test failure due to glibc bug . */ if (!getenv ("MALLOC_CHECK_")) ASSERT (errno == ENOMEM); } /* Check that realloc sets errno when it fails. Do this only in 64-bit processes, because there are many bi-arch systems nowadays where a 32-bit process can actually allocate 2 GiB of RAM. */ if (sizeof (size_t) >= 8) { void *r; errno = 0; r = realloc (p, SIZE_MAX / 10); ASSERT (r == NULL); ASSERT (errno == ENOMEM); errno = 0; r = realloc (p, SIZE_MAX / 3); ASSERT (r == NULL); ASSERT (errno == ENOMEM); } free (p); return test_exit_status; }