diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2014-09-06 10:57:43 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2014-09-06 10:57:43 -0700 |
commit | 049d706978ccff755ac717456772d4d6a6c0b77f (patch) | |
tree | fea200043bb2d6254e066693e7fa6805076cbbae /gc.c | |
parent | 373fc643da68c080dd83c0cc7cf28a93bad5d7ea (diff) | |
download | txr-049d706978ccff755ac717456772d4d6a6c0b77f.tar.gz txr-049d706978ccff755ac717456772d4d6a6c0b77f.tar.bz2 txr-049d706978ccff755ac717456772d4d6a6c0b77f.zip |
Make the garbage collector aware of malloced bytes, to
prevent skyrocketing memory use when the program manipulates
heap objects that have large amounts of malloc memory
attached, like very large bignums.
* gc.c (MALLOC_DELTA_THRESH): New preprocessor symbol.
(prev_malloc_bytes): New static variable.
(make_obj): when the value of malloc_bytes jumps by MALLOC_DELTA_THRESH
or more since the last gc, trigger gc.
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 13 |
1 files changed, 10 insertions, 3 deletions
@@ -49,6 +49,7 @@ #define MUTOBJ_VEC_SIZE (HEAP_SIZE / 4) #define FULL_GC_INTERVAL 40 #define FRESHOBJ_VEC_SIZE (8 * HEAP_SIZE) +#define MALLOC_DELTA_THRESH (64L * 1024 * 1024) typedef struct heap { struct heap *next; @@ -76,6 +77,7 @@ static heap_t *heap_list; static val heap_min_bound, heap_max_bound; alloc_bytes_t gc_bytes; +static alloc_bytes_t prev_malloc_bytes; int gc_enabled = 1; @@ -153,17 +155,22 @@ static void more(void) val make_obj(void) { int tries; - + alloc_bytes_t malloc_delta = malloc_bytes - prev_malloc_bytes; assert (!async_sig_enabled); #if CONFIG_GEN_GC - if (opt_gc_debug || freshobj_idx >= FRESHOBJ_VEC_SIZE) { + if (opt_gc_debug || freshobj_idx >= FRESHOBJ_VEC_SIZE || + malloc_delta >= MALLOC_DELTA_THRESH) + { gc(); assert (freshobj_idx < FRESHOBJ_VEC_SIZE); + prev_malloc_bytes = malloc_bytes; } #else - if (opt_gc_debug) + if (opt_gc_debug || malloc_delta >= MALLOC_DELTA_THRESH) { gc(); + prev_malloc_bytes = malloc_bytes; + } #endif for (tries = 0; tries < 3; tries++) { |