diff options
author | Ivan Maidanski <ivmai@mail.ru> | 2023-03-19 22:56:42 +0300 |
---|---|---|
committer | Ivan Maidanski <ivmai@mail.ru> | 2023-04-28 22:14:40 +0300 |
commit | 8f6e7a6f378530defa747718e08a722a4baf17c8 (patch) | |
tree | 03bc9e7d96236ea7b6f254a04bb4885bdb45ea90 | |
parent | 7a7f709527250a6eea9fd3004fc315907c66d525 (diff) | |
download | bdwgc-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.c | 8 |
1 files changed, 5 insertions, 3 deletions
@@ -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) |