summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIvan Maidanski <ivmai@mail.ru>2023-03-19 22:56:42 +0300
committerIvan Maidanski <ivmai@mail.ru>2023-04-28 22:14:40 +0300
commit8f6e7a6f378530defa747718e08a722a4baf17c8 (patch)
tree03bc9e7d96236ea7b6f254a04bb4885bdb45ea90
parent7a7f709527250a6eea9fd3004fc315907c66d525 (diff)
downloadbdwgc-8f6e7a6f378530defa747718e08a722a4baf17c8.tar.gz
Fix of GC_bytes_allocd increment in GC_generic_malloc_inner
EXTRA_BYTES should be always counted when updating GC_bytes_allocd. * malloc.c (GC_generic_malloc_inner): Define lb_adjusted local variable and set it to ADD_SLOP(lb); increment GC_bytes_allocd by lb_adjusted instead of lb (in case of a non-small object). * malloc.c [DBG_HDRS_ALL || GC_GCJ_SUPPORT || !GC_NO_FINALIZATION] (GC_generic_malloc_inner_ignore_off_page): Change type of lb_adjusted local variable from word to size_t.
-rw-r--r--malloc.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/malloc.c b/malloc.c
index aa0331cb..74104508 100644
--- a/malloc.c
+++ b/malloc.c
@@ -139,9 +139,11 @@ GC_INNER void * GC_generic_malloc_inner(size_t lb, int k)
obj_link(op) = 0;
GC_bytes_allocd += GRANULES_TO_BYTES(lg);
} else {
- op = (ptr_t)GC_alloc_large_and_clear(ADD_SLOP(lb), k, 0);
+ size_t lb_adjusted = ADD_SLOP(lb);
+
+ op = (ptr_t)GC_alloc_large_and_clear(lb_adjusted, k, 0 /* flags */);
if (op != NULL)
- GC_bytes_allocd += lb;
+ GC_bytes_allocd += lb_adjusted;
}
return op;
@@ -153,7 +155,7 @@ GC_INNER void * GC_generic_malloc_inner(size_t lb, int k)
/* guarantees that pointers past the first page are not relevant. */
GC_INNER void * GC_generic_malloc_inner_ignore_off_page(size_t lb, int k)
{
- word lb_adjusted;
+ size_t lb_adjusted;
void * op;
if (lb <= HBLKSIZE)