about summary refs log tree commit diff
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2022-10-01 18:27:02 +0200
committerGitHub <noreply@github.com>2022-10-01 18:27:02 +0200
commit3e0fe8646549998f7421f2c1b278d09923bd08ce (patch)
tree9e3d2ca930b62e9c243727b1b0c92a96e3d88501
parent586aec711679e1cdaac17cc9749746055fdb55f8 (diff)
parent0eeddda2c84b13158bfda1505e5ff2467dec08f0 (diff)
downloadafl++-3e0fe8646549998f7421f2c1b278d09923bd08ce.tar.gz
Merge pull request #1539 from devnexen/reallocarr
libdislocator adding netbsd's reallocarr
-rw-r--r--utils/libdislocator/libdislocator.so.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/utils/libdislocator/libdislocator.so.c b/utils/libdislocator/libdislocator.so.c
index a6d8ecfd..638735ef 100644
--- a/utils/libdislocator/libdislocator.so.c
+++ b/utils/libdislocator/libdislocator.so.c
@@ -510,6 +510,24 @@ __attribute__((alloc_size(2, 3))) void *reallocarray(void *ptr, size_t elem_len,
 
 }
 
+int reallocarr(void *ptr, size_t elem_len, size_t elem_cnt) {
+
+  void *ret = NULL;
+  const size_t elem_tot = elem_len * elem_cnt;
+
+  if (elem_tot == 0) {
+
+    void **h = &ptr;
+    *h = ret;
+    return 0;
+
+  }
+
+  ret = reallocarray(ptr, elem_len, elem_cnt);
+  return ret ? 0 : -1;
+
+}
+
 #if defined(__APPLE__)
 size_t malloc_size(const void *ptr) {