bug-gnulib
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH] read-file: reduce max size from SIZE_MAX to PTRDIFF_MAX


From: Pádraig Brady
Subject: [PATCH] read-file: reduce max size from SIZE_MAX to PTRDIFF_MAX
Date: Sun, 2 Feb 2020 16:13:21 +0000

On x86_64 with glibc-2.30, gcc 9.2 is giving:
  error: argument 2 value '18446744073709551615'
  exceeds maximum object size 9223372036854775807
  [-Werror=alloc-size-larger-than=]
The details of this restriction are discussed at:
https://stackoverflow.com/q/42574890/4421
* lib/read-file.c: s/SIZE_MAX/PTRDIFF_MAX/
---
 ChangeLog       | 11 +++++++++++
 lib/read-file.c | 10 +++++-----
 2 files changed, 16 insertions(+), 5 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index 1e5f94d3c..86f8626d6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2020-02-02  Pádraig Brady  <address@hidden>
+
+       read-file: reduce max size from SIZE_MAX to PTRDIFF_MAX
+       On x86_64 with glibc-2.30, gcc 9.2 is giving:
+         error: argument 2 value '18446744073709551615'
+         exceeds maximum object size 9223372036854775807
+         [-Werror=alloc-size-larger-than=]
+       The details of this restriction are discussed at:
+       https://stackoverflow.com/q/42574890/4421
+       * lib/read-file.c: s/SIZE_MAX/PTRDIFF_MAX/
+
 2020-02-02  Pádraig Brady  <address@hidden>
 
        sysctl.h: avoid including on glibc
diff --git a/lib/read-file.c b/lib/read-file.c
index 50bb00f0c..c6f230178 100644
--- a/lib/read-file.c
+++ b/lib/read-file.c
@@ -25,7 +25,7 @@
 /* Get ftello.  */
 #include <stdio.h>
 
-/* Get SIZE_MAX.  */
+/* Get PTRDIFF_MAX.  */
 #include <stdint.h>
 
 /* Get malloc, realloc, free. */
@@ -59,7 +59,7 @@ fread_file (FILE *stream, size_t *length)
             off_t alloc_off = st.st_size - pos;
 
             /* '1' below, accounts for the trailing NUL.  */
-            if (SIZE_MAX - 1 < alloc_off)
+            if (PTRDIFF_MAX - 1 < alloc_off)
               {
                 errno = ENOMEM;
                 return NULL;
@@ -107,16 +107,16 @@ fread_file (FILE *stream, size_t *length)
         {
           char *new_buf;
 
-          if (alloc == SIZE_MAX)
+          if (alloc == PTRDIFF_MAX)
             {
               save_errno = ENOMEM;
               break;
             }
 
-          if (alloc < SIZE_MAX - alloc / 2)
+          if (alloc < PTRDIFF_MAX - alloc / 2)
             alloc = alloc + alloc / 2;
           else
-            alloc = SIZE_MAX;
+            alloc = PTRDIFF_MAX;
 
           if (!(new_buf = realloc (buf, alloc)))
             {
-- 
2.24.1




reply via email to

[Prev in Thread] Current Thread [Next in Thread]