On 2024-11-05 08:51, Paul Eggert wrote:
I suppose this stuff should be documented better in Gnulib.
I gave that a shot by installing the attached further patch.
From af7386f12fcef998d3f8a38538675d62e71add4f Mon Sep 17 00:00:00 2001
From: Paul Eggert <egg...@cs.ucla.edu>
Date: Tue, 5 Nov 2024 15:57:20 -0800
Subject: [PATCH] doc: improve documentation for malloc, realloc etc
---
doc/posix-functions/calloc.texi | 12 ++++++--
doc/posix-functions/malloc.texi | 12 ++++++--
doc/posix-functions/realloc.texi | 41 +++++++++++++++++++--------
doc/posix-functions/reallocarray.texi | 11 +++++++
doc/posix-functions/strdup.texi | 12 ++++++--
5 files changed, 67 insertions(+), 21 deletions(-)
diff --git a/doc/posix-functions/calloc.texi b/doc/posix-functions/calloc.texi
index ecd8b227c0..37e6e008b5 100644
--- a/doc/posix-functions/calloc.texi
+++ b/doc/posix-functions/calloc.texi
@@ -10,9 +10,15 @@ Gnulib module: calloc-posix
Portability problems fixed by Gnulib:
@itemize
@item
-Upon failure, the function does not set @code{errno} to @code{ENOMEM} on
-some platforms:
-mingw, MSVC 14, Solaris 11.4.
+On some platforms, when the function fails it does not set @code{errno}:
+mingw, MSVC 14.
+
+@item
+On some platforms, when the function fails it might set @code{errno}
+to @code{EAGAIN} instead of to @code{ENOMEM}. Although POSIX allows
+@code{EAGAIN}, the @code{calloc-posix} module insists on @code{ENOMEM}
+which also conforms to POSIX and is GNU-compatible:
+Solaris 11.4.
@item
On some platforms, @code{calloc (n, s)} can succeed even if
diff --git a/doc/posix-functions/malloc.texi b/doc/posix-functions/malloc.texi
index 6a6f3c1059..0b552bdf67 100644
--- a/doc/posix-functions/malloc.texi
+++ b/doc/posix-functions/malloc.texi
@@ -10,9 +10,15 @@ Gnulib module: malloc-posix
Portability problems fixed by Gnulib:
@itemize
@item
-Upon failure, the function does not set @code{errno} to @code{ENOMEM} on
-some platforms:
-mingw, MSVC 14, Solaris 11.4.
+On some platforms, when the function fails it does not set @code{errno}:
+mingw, MSVC 14.
+
+@item
+On some platforms, when the function fails it might set @code{errno}
+to @code{EAGAIN} instead of to @code{ENOMEM}. Although POSIX allows
+@code{EAGAIN}, the @code{malloc-posix} module insists on @code{ENOMEM}
+which also conforms to POSIX and is GNU-compatible:
+Solaris 11.4.
@item
On some platforms, @code{malloc (n)} can succeed even if @code{n}
diff --git a/doc/posix-functions/realloc.texi b/doc/posix-functions/realloc.texi
index 0c7ab115d3..b08f76c5f1 100644
--- a/doc/posix-functions/realloc.texi
+++ b/doc/posix-functions/realloc.texi
@@ -11,24 +11,33 @@ Portability problems fixed by Gnulib:
@itemize
@item
-Upon failure, the function does not set @code{errno} to @code{ENOMEM} on
-some platforms:
-mingw, MSVC 14, Solaris 11.4.
+On some platforms, when the function fails it does not set @code{errno}:
+mingw, MSVC 14.
+
+@item
+On some platforms, when the function fails it might set @code{errno}
+to @code{EAGAIN} instead of to @code{ENOMEM}. Although POSIX allows
+@code{EAGAIN}, the @code{realloc-posix} module insists on @code{ENOMEM}
+which also conforms to POSIX and is GNU-compatible:
+Solaris 11.4.
@item
On some platforms, @code{realloc (p, n)} can succeed even if @code{n}
exceeds @code{PTRDIFF_MAX}. Although this behavior is arguably
-allowed by POSIX it can lead to behavior not defined by POSIX later,
+allowed by POSIX it is not compatible with GNU and
+can lead to behavior not defined by POSIX later,
so @code{realloc-posix} does not allow going over the limit.
@item
-It is not portable to call @code{realloc} with a size of 0. With a
-null pointer argument, this is the same ambiguity as @code{malloc (0)}
+It is not portable to call @code{realloc} with a size of 0.
+
+With a null pointer argument, this is the same ambiguity as @code{malloc (0)}
as to whether a successful call returns a null pointer or a pointer to a
-new zero-sized memory region. The @code{realloc-posix} module
-implements the latter behavior.
+new zero-sized memory region. Although both behaviors conform to POSIX,
+@code{realloc-posix} insists on the latter behavior, which is
+compatible with GNU.
-Behavior is a real mess for @code{realloc (p, 0)} with non-null @code{p}.
+With non-null @code{p}, behavior is a real mess for @code{realloc (p, 0)}.
C23 says behavior is undefined.
C89 through C17 say a successful call returns either a null pointer
or a pointer to a new zero-sized memory region.
@@ -51,7 +60,7 @@ glibc 2.33--2.40 by default, Android.
Free @code{p}, possibly set @code{errno}, and return a null pointer:
glibc 1--2.1 if specially built with @code{REALLOC_ZERO_BYTES_FREES=1},
glibc 2.1.1--2.32 by default,
-mingw, MSVC.
+mingw, MSVC 14.
@item
Free @code{p}, set @code{errno} to @code{EINVAL}, and return a null pointer:
@@ -66,9 +75,9 @@ musl libc, macOS, FreeBSD, NetBSD, OpenBSD, Solaris, Cygwin.
@noindent
Behaviors (3) and (4) conform to POSIX; behaviors (1) and (2) do not.
-The @code{realloc-posix} module implements behavior (4) as it is more
+The @code{realloc-posix} module insists on behavior (4) as it is more
popular than (3) and is more useful in practice. Behavior (4) is the
-only one of the four in which returning a a null pointer means failure,
+only one of the four in which returning a null pointer means failure,
which is what non-expert programmers typically expect.
A program not suspecting these variations in semantics will either:
@@ -84,6 +93,14 @@ Falsely respond to memory exhaustion (if it wisely checks for @code{realloc}
failure), or have double-free bugs (if it unwisely does not check),
when it assumes behavior (4) but the system implements (1), (2) or (3).
@end itemize
+
+@item
+When @code{realloc (p, 0)} sets errno to @code{EINVAL} and returns null,
+a POSIX.1-2024 application cannot tell whether the call has succeeded
+and freed @code{p}, or has failed without freeing @code{p}.
+This is only a theoretical problem, though, as the only practical
+implementation with this behavior is AIX without @code{_LINUX_SOURCE_COMPAT},
+which behaves this way only when the call succeeds.
@end itemize
Portability problems not fixed by Gnulib:
diff --git a/doc/posix-functions/reallocarray.texi b/doc/posix-functions/reallocarray.texi
index aa43596b60..318f7854cc 100644
--- a/doc/posix-functions/reallocarray.texi
+++ b/doc/posix-functions/reallocarray.texi
@@ -26,6 +26,13 @@ Portability problems fixed by Gnulib:
This function is missing on many platforms:
glibc 2.25, macOS 14, FreeBSD 10, NetBSD 7, OpenBSD 5.5, Minix 3.3.0, AIX 7.2, HP-UX 11, Solaris 11.4, Cygwin 1.7.x, mingw, MSVC 14, Android 9.0.
+@item
+On some platforms, when the function fails it might set @code{errno}
+to @code{EAGAIN} instead of to @code{ENOMEM}. Although POSIX allows
+@code{EAGAIN}, the @code{reallocarray} module insists on @code{ENOMEM}
+which also conforms to POSIX and is GNU-compatible:
+Solaris 11.4.
+
@item
On some platforms, @code{reallocarray (p, n, s)} can succeed even if
multiplying @code{n} by @code{s} would exceed @code{PTRDIFF_MAX},
@@ -41,4 +48,8 @@ that @code{realloc} does. @xref{realloc}.
Portability problems not fixed by Gnulib:
@itemize
+@item
+When not growing an already-allocated region,
+@code{reallocarray}, like @code{realloc}, can fail and return a null pointer:
+glibc 2.40 and probably other platforms.
@end itemize
diff --git a/doc/posix-functions/strdup.texi b/doc/posix-functions/strdup.texi
index 89bc78ee03..82fc1e517f 100644
--- a/doc/posix-functions/strdup.texi
+++ b/doc/posix-functions/strdup.texi
@@ -17,9 +17,15 @@ This function has no prototype in @code{<string.h>} on some old platforms.
Portability problems fixed by Gnulib module @code{strdup-posix}:
@itemize
@item
-Upon failure, the function does not set @code{errno} to @code{ENOMEM} on
-some platforms:
-mingw, MSVC 14, Solaris 11.4.
+On some platforms, when the function fails it does not set @code{errno}:
+mingw, MSVC 14.
+
+@item
+On some platforms, when the function fails it might set @code{errno}
+to @code{EAGAIN} instead of to @code{ENOMEM}. Although POSIX allows
+@code{EAGAIN}, the @code{strdup-posix} module insists on @code{ENOMEM}
+which also conforms to POSIX and is GNU-compatible:
+Solaris 11.4.
@end itemize
Portability problems not fixed by Gnulib:
--
2.43.0