From f8dbff557af75c0347f271cf5a1a557eea9f9eed Mon Sep 17 00:00:00 2001 From: ko1 Date: Wed, 24 Oct 2018 22:17:03 +0000 Subject: add new debug_counters for GC. * debug_counter.h: add new debug counters to count GC. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@65359 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- gc.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'gc.c') diff --git a/gc.c b/gc.c index f6f5617dd8..d5588bc19c 100644 --- a/gc.c +++ b/gc.c @@ -6536,6 +6536,23 @@ gc_start(rb_objspace_t *objspace, int reason) reason, do_full_mark, !is_incremental_marking(objspace), objspace->flags.immediate_sweep); +#if USE_DEBUG_COUNTER + RB_DEBUG_COUNTER_INC(gc_count); + if (reason & GPR_FLAG_MAJOR_MASK) { + (void)RB_DEBUG_COUNTER_INC_IF(gc_major_nofree, reason & GPR_FLAG_MAJOR_BY_NOFREE); + (void)RB_DEBUG_COUNTER_INC_IF(gc_major_oldgen, reason & GPR_FLAG_MAJOR_BY_OLDGEN); + (void)RB_DEBUG_COUNTER_INC_IF(gc_major_shady, reason & GPR_FLAG_MAJOR_BY_SHADY); + (void)RB_DEBUG_COUNTER_INC_IF(gc_major_force, reason & GPR_FLAG_MAJOR_BY_FORCE); + } + else { + (void)RB_DEBUG_COUNTER_INC_IF(gc_minor_newobj, reason & GPR_FLAG_NEWOBJ); + (void)RB_DEBUG_COUNTER_INC_IF(gc_minor_malloc, reason & GPR_FLAG_MALLOC); + (void)RB_DEBUG_COUNTER_INC_IF(gc_minor_method, reason & GPR_FLAG_METHOD); + (void)RB_DEBUG_COUNTER_INC_IF(gc_minor_capi, reason & GPR_FLAG_CAPI); + (void)RB_DEBUG_COUNTER_INC_IF(gc_minor_stress, reason & GPR_FLAG_NEWOBJ); + } +#endif + objspace->profile.count++; objspace->profile.latest_gc_info = reason; objspace->profile.total_allocated_objects_at_gc_start = objspace->total_allocated_objects; -- cgit v1.2.3