11#ifndef USE_DEBUG_COUNTER
12#define USE_DEBUG_COUNTER 0
15#ifdef RB_DEBUG_COUNTER
18RB_DEBUG_COUNTER(mc_inline_hit)
19RB_DEBUG_COUNTER(mc_inline_miss_klass)
20RB_DEBUG_COUNTER(mc_inline_miss_invalidated)
21RB_DEBUG_COUNTER(mc_inline_miss_empty)
22RB_DEBUG_COUNTER(mc_inline_miss_same_cc)
23RB_DEBUG_COUNTER(mc_inline_miss_same_cme)
24RB_DEBUG_COUNTER(mc_inline_miss_same_def)
25RB_DEBUG_COUNTER(mc_inline_miss_diff)
27RB_DEBUG_COUNTER(cvar_write_inline_hit)
28RB_DEBUG_COUNTER(cvar_read_inline_hit)
29RB_DEBUG_COUNTER(cvar_inline_miss)
30RB_DEBUG_COUNTER(cvar_class_invalidate)
31RB_DEBUG_COUNTER(cvar_include_invalidate)
33RB_DEBUG_COUNTER(mc_cme_complement)
34RB_DEBUG_COUNTER(mc_cme_complement_hit)
36RB_DEBUG_COUNTER(mc_search)
37RB_DEBUG_COUNTER(mc_search_notfound)
38RB_DEBUG_COUNTER(mc_search_super)
41RB_DEBUG_COUNTER(ci_packed)
42RB_DEBUG_COUNTER(ci_kw)
43RB_DEBUG_COUNTER(ci_nokw)
44RB_DEBUG_COUNTER(ci_runtime)
47RB_DEBUG_COUNTER(cc_new)
48RB_DEBUG_COUNTER(cc_temp)
49RB_DEBUG_COUNTER(cc_found_in_ccs)
50RB_DEBUG_COUNTER(cc_not_found_in_ccs)
52RB_DEBUG_COUNTER(cc_ent_invalidate)
53RB_DEBUG_COUNTER(cc_cme_invalidate)
55RB_DEBUG_COUNTER(cc_invalidate_leaf)
56RB_DEBUG_COUNTER(cc_invalidate_leaf_ccs)
57RB_DEBUG_COUNTER(cc_invalidate_leaf_callable)
58RB_DEBUG_COUNTER(cc_invalidate_tree)
59RB_DEBUG_COUNTER(cc_invalidate_tree_cme)
60RB_DEBUG_COUNTER(cc_invalidate_tree_callable)
61RB_DEBUG_COUNTER(cc_invalidate_negative)
63RB_DEBUG_COUNTER(ccs_free)
64RB_DEBUG_COUNTER(ccs_maxlen)
65RB_DEBUG_COUNTER(ccs_found)
66RB_DEBUG_COUNTER(ccs_not_found)
69RB_DEBUG_COUNTER(call0_public)
70RB_DEBUG_COUNTER(call0_other)
71RB_DEBUG_COUNTER(gccct_hit)
72RB_DEBUG_COUNTER(gccct_miss)
73RB_DEBUG_COUNTER(gccct_null)
76RB_DEBUG_COUNTER(iseq_num)
77RB_DEBUG_COUNTER(iseq_cd_num)
82RB_DEBUG_COUNTER(ccf_general)
83RB_DEBUG_COUNTER(ccf_iseq_setup)
84RB_DEBUG_COUNTER(ccf_iseq_setup_0start)
85RB_DEBUG_COUNTER(ccf_iseq_setup_tailcall_0start)
86RB_DEBUG_COUNTER(ccf_iseq_fix)
87RB_DEBUG_COUNTER(ccf_iseq_opt)
88RB_DEBUG_COUNTER(ccf_iseq_kw1)
89RB_DEBUG_COUNTER(ccf_iseq_kw2)
90RB_DEBUG_COUNTER(ccf_cfunc)
91RB_DEBUG_COUNTER(ccf_cfunc_with_frame)
92RB_DEBUG_COUNTER(ccf_ivar)
93RB_DEBUG_COUNTER(ccf_attrset)
94RB_DEBUG_COUNTER(ccf_method_missing)
95RB_DEBUG_COUNTER(ccf_zsuper)
96RB_DEBUG_COUNTER(ccf_bmethod)
97RB_DEBUG_COUNTER(ccf_opt_send)
98RB_DEBUG_COUNTER(ccf_opt_call)
99RB_DEBUG_COUNTER(ccf_opt_block_call)
100RB_DEBUG_COUNTER(ccf_opt_struct_aref)
101RB_DEBUG_COUNTER(ccf_opt_struct_aset)
102RB_DEBUG_COUNTER(ccf_super_method)
114RB_DEBUG_COUNTER(frame_push)
115RB_DEBUG_COUNTER(frame_push_method)
116RB_DEBUG_COUNTER(frame_push_block)
117RB_DEBUG_COUNTER(frame_push_class)
118RB_DEBUG_COUNTER(frame_push_top)
119RB_DEBUG_COUNTER(frame_push_cfunc)
120RB_DEBUG_COUNTER(frame_push_ifunc)
121RB_DEBUG_COUNTER(frame_push_eval)
122RB_DEBUG_COUNTER(frame_push_rescue)
123RB_DEBUG_COUNTER(frame_push_dummy)
125RB_DEBUG_COUNTER(frame_R2R)
126RB_DEBUG_COUNTER(frame_R2C)
127RB_DEBUG_COUNTER(frame_C2C)
128RB_DEBUG_COUNTER(frame_C2R)
141RB_DEBUG_COUNTER(ivar_get_ic_hit)
142RB_DEBUG_COUNTER(ivar_get_ic_miss)
143RB_DEBUG_COUNTER(ivar_get_ic_miss_serial)
144RB_DEBUG_COUNTER(ivar_get_ic_miss_unset)
145RB_DEBUG_COUNTER(ivar_get_ic_miss_noobject)
146RB_DEBUG_COUNTER(ivar_set_ic_hit)
147RB_DEBUG_COUNTER(ivar_set_ic_miss)
148RB_DEBUG_COUNTER(ivar_set_ic_miss_serial)
149RB_DEBUG_COUNTER(ivar_set_ic_miss_unset)
150RB_DEBUG_COUNTER(ivar_set_ic_miss_iv_hit)
151RB_DEBUG_COUNTER(ivar_set_ic_miss_noobject)
152RB_DEBUG_COUNTER(ivar_get_base)
153RB_DEBUG_COUNTER(ivar_set_base)
162RB_DEBUG_COUNTER(lvar_get)
163RB_DEBUG_COUNTER(lvar_get_dynamic)
164RB_DEBUG_COUNTER(lvar_set)
165RB_DEBUG_COUNTER(lvar_set_dynamic)
166RB_DEBUG_COUNTER(lvar_set_slowpath)
176RB_DEBUG_COUNTER(gc_count)
177RB_DEBUG_COUNTER(gc_minor_newobj)
178RB_DEBUG_COUNTER(gc_minor_malloc)
179RB_DEBUG_COUNTER(gc_minor_method)
180RB_DEBUG_COUNTER(gc_minor_capi)
181RB_DEBUG_COUNTER(gc_minor_stress)
182RB_DEBUG_COUNTER(gc_major_nofree)
183RB_DEBUG_COUNTER(gc_major_oldgen)
184RB_DEBUG_COUNTER(gc_major_shady)
185RB_DEBUG_COUNTER(gc_major_force)
186RB_DEBUG_COUNTER(gc_major_oldmalloc)
188RB_DEBUG_COUNTER(gc_enter_start)
189RB_DEBUG_COUNTER(gc_enter_mark_continue)
190RB_DEBUG_COUNTER(gc_enter_sweep_continue)
191RB_DEBUG_COUNTER(gc_enter_rest)
192RB_DEBUG_COUNTER(gc_enter_finalizer)
194RB_DEBUG_COUNTER(gc_isptr_trial)
195RB_DEBUG_COUNTER(gc_isptr_range)
196RB_DEBUG_COUNTER(gc_isptr_align)
197RB_DEBUG_COUNTER(gc_isptr_maybe)
237RB_DEBUG_COUNTER(obj_newobj)
238RB_DEBUG_COUNTER(obj_newobj_slowpath)
239RB_DEBUG_COUNTER(obj_newobj_wb_unprotected)
240RB_DEBUG_COUNTER(obj_free)
241RB_DEBUG_COUNTER(obj_promote)
242RB_DEBUG_COUNTER(obj_wb_unprotect)
244RB_DEBUG_COUNTER(obj_obj_embed)
245RB_DEBUG_COUNTER(obj_obj_transient)
246RB_DEBUG_COUNTER(obj_obj_ptr)
248RB_DEBUG_COUNTER(obj_str_ptr)
249RB_DEBUG_COUNTER(obj_str_embed)
250RB_DEBUG_COUNTER(obj_str_shared)
251RB_DEBUG_COUNTER(obj_str_nofree)
252RB_DEBUG_COUNTER(obj_str_fstr)
254RB_DEBUG_COUNTER(obj_ary_embed)
255RB_DEBUG_COUNTER(obj_ary_transient)
256RB_DEBUG_COUNTER(obj_ary_ptr)
257RB_DEBUG_COUNTER(obj_ary_extracapa)
264RB_DEBUG_COUNTER(obj_ary_shared_create)
265RB_DEBUG_COUNTER(obj_ary_shared)
266RB_DEBUG_COUNTER(obj_ary_shared_root_occupied)
268RB_DEBUG_COUNTER(obj_hash_empty)
269RB_DEBUG_COUNTER(obj_hash_1)
270RB_DEBUG_COUNTER(obj_hash_2)
271RB_DEBUG_COUNTER(obj_hash_3)
272RB_DEBUG_COUNTER(obj_hash_4)
273RB_DEBUG_COUNTER(obj_hash_5_8)
274RB_DEBUG_COUNTER(obj_hash_g8)
276RB_DEBUG_COUNTER(obj_hash_null)
277RB_DEBUG_COUNTER(obj_hash_ar)
278RB_DEBUG_COUNTER(obj_hash_st)
279RB_DEBUG_COUNTER(obj_hash_transient)
280RB_DEBUG_COUNTER(obj_hash_force_convert)
282RB_DEBUG_COUNTER(obj_struct_embed)
283RB_DEBUG_COUNTER(obj_struct_transient)
284RB_DEBUG_COUNTER(obj_struct_ptr)
286RB_DEBUG_COUNTER(obj_data_empty)
287RB_DEBUG_COUNTER(obj_data_xfree)
288RB_DEBUG_COUNTER(obj_data_imm_free)
289RB_DEBUG_COUNTER(obj_data_zombie)
291RB_DEBUG_COUNTER(obj_match_under4)
292RB_DEBUG_COUNTER(obj_match_ge4)
293RB_DEBUG_COUNTER(obj_match_ge8)
294RB_DEBUG_COUNTER(obj_match_ptr)
296RB_DEBUG_COUNTER(obj_iclass_ptr)
297RB_DEBUG_COUNTER(obj_class_ptr)
298RB_DEBUG_COUNTER(obj_module_ptr)
300RB_DEBUG_COUNTER(obj_bignum_ptr)
301RB_DEBUG_COUNTER(obj_bignum_embed)
302RB_DEBUG_COUNTER(obj_float)
303RB_DEBUG_COUNTER(obj_complex)
304RB_DEBUG_COUNTER(obj_rational)
306RB_DEBUG_COUNTER(obj_regexp_ptr)
307RB_DEBUG_COUNTER(obj_file_ptr)
308RB_DEBUG_COUNTER(obj_symbol)
310RB_DEBUG_COUNTER(obj_imemo_ment)
311RB_DEBUG_COUNTER(obj_imemo_iseq)
312RB_DEBUG_COUNTER(obj_imemo_env)
313RB_DEBUG_COUNTER(obj_imemo_tmpbuf)
314RB_DEBUG_COUNTER(obj_imemo_ast)
315RB_DEBUG_COUNTER(obj_imemo_cref)
316RB_DEBUG_COUNTER(obj_imemo_svar)
317RB_DEBUG_COUNTER(obj_imemo_throw_data)
318RB_DEBUG_COUNTER(obj_imemo_ifunc)
319RB_DEBUG_COUNTER(obj_imemo_memo)
320RB_DEBUG_COUNTER(obj_imemo_parser_strterm)
321RB_DEBUG_COUNTER(obj_imemo_callinfo)
322RB_DEBUG_COUNTER(obj_imemo_callcache)
323RB_DEBUG_COUNTER(obj_imemo_constcache)
326RB_DEBUG_COUNTER(artable_hint_hit)
327RB_DEBUG_COUNTER(artable_hint_miss)
328RB_DEBUG_COUNTER(artable_hint_notfound)
334RB_DEBUG_COUNTER(heap_xmalloc)
335RB_DEBUG_COUNTER(heap_xrealloc)
336RB_DEBUG_COUNTER(heap_xfree)
339RB_DEBUG_COUNTER(theap_alloc)
340RB_DEBUG_COUNTER(theap_alloc_fail)
341RB_DEBUG_COUNTER(theap_evacuate)
344RB_DEBUG_COUNTER(vm_sync_lock)
345RB_DEBUG_COUNTER(vm_sync_lock_enter)
346RB_DEBUG_COUNTER(vm_sync_lock_enter_nb)
347RB_DEBUG_COUNTER(vm_sync_lock_enter_cr)
348RB_DEBUG_COUNTER(vm_sync_barrier)
351RB_DEBUG_COUNTER(mjit_exec)
352RB_DEBUG_COUNTER(mjit_exec_not_added)
353RB_DEBUG_COUNTER(mjit_exec_not_ready)
354RB_DEBUG_COUNTER(mjit_exec_not_compiled)
355RB_DEBUG_COUNTER(mjit_exec_call_func)
358RB_DEBUG_COUNTER(mjit_add_iseq_to_process)
359RB_DEBUG_COUNTER(mjit_unload_units)
362RB_DEBUG_COUNTER(mjit_frame_VM2VM)
363RB_DEBUG_COUNTER(mjit_frame_VM2JT)
364RB_DEBUG_COUNTER(mjit_frame_JT2JT)
365RB_DEBUG_COUNTER(mjit_frame_JT2VM)
368RB_DEBUG_COUNTER(mjit_cancel)
369RB_DEBUG_COUNTER(mjit_cancel_ivar_inline)
370RB_DEBUG_COUNTER(mjit_cancel_exivar_inline)
371RB_DEBUG_COUNTER(mjit_cancel_send_inline)
372RB_DEBUG_COUNTER(mjit_cancel_opt_insn)
373RB_DEBUG_COUNTER(mjit_cancel_invalidate_all)
374RB_DEBUG_COUNTER(mjit_cancel_leave)
377RB_DEBUG_COUNTER(mjit_length_unit_queue)
378RB_DEBUG_COUNTER(mjit_length_active_units)
379RB_DEBUG_COUNTER(mjit_length_compact_units)
380RB_DEBUG_COUNTER(mjit_length_stale_units)
383RB_DEBUG_COUNTER(mjit_compile_failures)
392#ifndef RUBY_DEBUG_COUNTER_H
393#define RUBY_DEBUG_COUNTER_H 1
395#include "ruby/internal/config.h"
399#if !defined(__GNUC__) && USE_DEBUG_COUNTER
400#error "USE_DEBUG_COUNTER is not supported by other than __GNUC__"
403enum rb_debug_counter_type {
404#define RB_DEBUG_COUNTER(name) RB_DEBUG_COUNTER_##name,
407#undef RB_DEBUG_COUNTER
411extern size_t rb_debug_counter[];
413RUBY_EXTERN void rb_debug_counter_add_atomic(
enum rb_debug_counter_type
type,
int add);
416rb_debug_counter_add(
enum rb_debug_counter_type
type,
int add,
int cond)
419 if (ruby_single_main_ractor != NULL) {
420 rb_debug_counter[(int)
type] += add;
423 rb_debug_counter_add_atomic(
type, add);
430rb_debug_counter_max(
enum rb_debug_counter_type
type,
unsigned int num)
433 if (rb_debug_counter[(
int)
type] < num) {
434 rb_debug_counter[(int)
type] = num;
442VALUE rb_debug_counter_reset(VALUE klass);
443VALUE rb_debug_counter_show(VALUE klass);
445#define RB_DEBUG_COUNTER_INC(type) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, 1)
446#define RB_DEBUG_COUNTER_INC_UNLESS(type, cond) (!rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, !(cond)))
447#define RB_DEBUG_COUNTER_INC_IF(type, cond) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, !!(cond))
448#define RB_DEBUG_COUNTER_ADD(type, num) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, (num), 1)
449#define RB_DEBUG_COUNTER_SETMAX(type, num) rb_debug_counter_max(RB_DEBUG_COUNTER_##type, (unsigned int)(num))
452#define RB_DEBUG_COUNTER_INC(type) ((void)0)
453#define RB_DEBUG_COUNTER_INC_UNLESS(type, cond) (!!(cond))
454#define RB_DEBUG_COUNTER_INC_IF(type, cond) (!!(cond))
455#define RB_DEBUG_COUNTER_ADD(type, num) ((void)0)
456#define RB_DEBUG_COUNTER_SETMAX(type, num) 0
459void rb_debug_counter_show_results(
const char *msg);
461RUBY_SYMBOL_EXPORT_BEGIN
463size_t ruby_debug_counter_get(
const char **names_ptr,
size_t *counters_ptr);
464void ruby_debug_counter_reset(
void);
465void ruby_debug_counter_show_at_exit(
int enable);
467RUBY_SYMBOL_EXPORT_END
#define RUBY_EXTERN
Declaration of externally visible global variables.
VALUE type(ANYARGS)
ANYARGS-ed function type.