]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
alloc-util: reintroduce malloc_usable_size() into greedy_realloc()
authorLennart Poettering <lennart@poettering.net>
Tue, 30 Apr 2019 08:13:57 +0000 (10:13 +0200)
committerLennart Poettering <lennart@poettering.net>
Thu, 2 May 2019 12:53:40 +0000 (14:53 +0200)
This is another attempt at d4b604baeadbb2498e4f2c3e260260eed210f5d6 and #12438

Instead of blindly using the extra allocated space, let's do so only
after telling libc about it, via a second realloc(). The second
realloc() should be quick, since it never has to copy memory around.

src/basic/alloc-util.c

index f4bd33f4e014246a9c9e68f8f75e0023541a967d..a16db6824fe84f2299e290f0b8d961aee165d234 100644 (file)
@@ -1,5 +1,6 @@
 /* SPDX-License-Identifier: LGPL-2.1+ */
 
+#include <malloc.h>
 #include <stdint.h>
 #include <string.h>
 
@@ -63,6 +64,29 @@ void* greedy_realloc(void **p, size_t *allocated, size_t need, size_t size) {
         if (!q)
                 return NULL;
 
+        if (size > 0) {
+                size_t bn;
+
+                /* Adjust for the 64 byte minimum */
+                newalloc = a / size;
+
+                bn = malloc_usable_size(q) / size;
+                if (bn > newalloc) {
+                        void *qq;
+
+                        /* The actual size allocated is larger than what we asked for. Let's call realloc() again to
+                         * take possession of the extra space. This should be cheap, since libc doesn't have to move
+                         * the memory for this. */
+
+                        qq = realloc(q, bn * size);
+                        if (_likely_(qq)) {
+                                *p = qq;
+                                *allocated = bn;
+                                return qq;
+                        }
+                }
+        }
+
         *p = q;
         *allocated = newalloc;
         return q;