summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorJo-Philipp Wich <jo@mein.io>2024-12-31 02:00:45 +0100
committerGitHub <noreply@github.com>2024-12-31 02:00:45 +0100
commit6443e754f60a025f43cb7e60913110a5a187bdca (patch)
tree5dad149d67742b0e4cde0767c46ec1a903c5aa4c
parentef7033878f878c9a4c51ab73353db7b93a4f99e3 (diff)
parent0f69da9c3777c5e94e9ca2ab207c16914b28f99b (diff)
Merge pull request #260 from jow-/struct-memory-fixes
struct: fix memory leak in buffer.pull()
-rw-r--r--lib/struct.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/struct.c b/lib/struct.c
index 7c039f2..7393347 100644
--- a/lib/struct.c
+++ b/lib/struct.c
@@ -2514,7 +2514,10 @@ grow_buffer(uc_vm_t *vm, void **buf, size_t *bufsz, size_t length)
return false;
}
- memset(tmp + overhead + old_size - 1, 0, new_size - old_size + 1);
+ if (*buf)
+ memset(tmp + overhead + old_size - 1, 0, new_size - old_size + 1);
+ else
+ memset(tmp, 0, new_size + overhead);
*buf = tmp;
*bufsz = new_size;
@@ -3655,7 +3658,7 @@ uc_fmtbuf_pull(uc_vm_t *vm, size_t nargs)
buffer->position = 0;
buffer->length = 0;
- return ucv_get(&us->header);
+ return &us->header;
}