debase-ruby_core_source 3.3.5 → 3.3.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (149) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +2 -1
  3. data/.idea/vcs.xml +28 -0
  4. data/CHANGELOG.md +8 -0
  5. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/addr2line.h +22 -0
  6. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/builtin.h +119 -0
  7. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ccan/build_assert/build_assert.h +40 -0
  8. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ccan/check_type/check_type.h +63 -0
  9. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ccan/container_of/container_of.h +142 -0
  10. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ccan/list/list.h +791 -0
  11. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ccan/str/str.h +17 -0
  12. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/constant.h +53 -0
  13. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/darray.h +209 -0
  14. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/debug_counter.h +423 -0
  15. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/dln.h +32 -0
  16. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/encindex.h +70 -0
  17. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/eval_intern.h +324 -0
  18. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/hrtime.h +237 -0
  19. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/id.h +347 -0
  20. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/id_table.h +39 -0
  21. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/insns.inc +265 -0
  22. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/insns_info.inc +9902 -0
  23. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/array.h +152 -0
  24. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/basic_operators.h +64 -0
  25. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/bignum.h +244 -0
  26. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/bits.h +568 -0
  27. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/class.h +283 -0
  28. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/cmdlineopt.h +65 -0
  29. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/compar.h +29 -0
  30. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/compile.h +34 -0
  31. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/compilers.h +107 -0
  32. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/complex.h +29 -0
  33. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/cont.h +35 -0
  34. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/dir.h +16 -0
  35. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/enc.h +19 -0
  36. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/encoding.h +36 -0
  37. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/enum.h +18 -0
  38. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/enumerator.h +21 -0
  39. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/error.h +218 -0
  40. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/eval.h +33 -0
  41. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/file.h +38 -0
  42. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/fixnum.h +184 -0
  43. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/gc.h +322 -0
  44. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/hash.h +192 -0
  45. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/imemo.h +261 -0
  46. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/inits.h +47 -0
  47. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/io.h +143 -0
  48. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/load.h +18 -0
  49. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/loadpath.h +16 -0
  50. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/math.h +23 -0
  51. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/missing.h +19 -0
  52. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/numeric.h +274 -0
  53. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/object.h +63 -0
  54. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/parse.h +129 -0
  55. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/proc.h +30 -0
  56. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/process.h +124 -0
  57. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/ractor.h +6 -0
  58. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/random.h +17 -0
  59. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/range.h +40 -0
  60. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/rational.h +71 -0
  61. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/re.h +28 -0
  62. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/ruby_parser.h +102 -0
  63. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/sanitizers.h +326 -0
  64. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/serial.h +23 -0
  65. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/signal.h +24 -0
  66. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/st.h +11 -0
  67. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/static_assert.h +16 -0
  68. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/string.h +186 -0
  69. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/struct.h +127 -0
  70. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/symbol.h +45 -0
  71. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/thread.h +85 -0
  72. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/time.h +34 -0
  73. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/transcode.h +23 -0
  74. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/util.h +27 -0
  75. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/variable.h +72 -0
  76. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/vm.h +137 -0
  77. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal/warnings.h +16 -0
  78. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/internal.h +108 -0
  79. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/iseq.h +340 -0
  80. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/known_errors.inc +1419 -0
  81. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/method.h +255 -0
  82. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/node.h +111 -0
  83. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/node_name.inc +224 -0
  84. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/optinsn.inc +128 -0
  85. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/optunifs.inc +43 -0
  86. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/parse.h +244 -0
  87. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/parser_bits.h +564 -0
  88. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/parser_node.h +32 -0
  89. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/parser_st.h +162 -0
  90. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/parser_value.h +106 -0
  91. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/ast.h +7524 -0
  92. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/defines.h +242 -0
  93. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/diagnostic.h +450 -0
  94. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/encoding.h +283 -0
  95. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/extension.h +19 -0
  96. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/node.h +129 -0
  97. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/options.h +396 -0
  98. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/pack.h +163 -0
  99. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/parser.h +933 -0
  100. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/prettyprint.h +34 -0
  101. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/prism.h +336 -0
  102. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/regexp.h +43 -0
  103. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/static_literals.h +121 -0
  104. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_buffer.h +218 -0
  105. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_char.h +204 -0
  106. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_constant_pool.h +218 -0
  107. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_integer.h +126 -0
  108. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_list.h +97 -0
  109. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_memchr.h +29 -0
  110. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_newline_list.h +113 -0
  111. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_string.h +190 -0
  112. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_strncasecmp.h +32 -0
  113. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/util/pm_strpbrk.h +46 -0
  114. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism/version.h +29 -0
  115. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/prism_compile.h +99 -0
  116. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/probes_helper.h +42 -0
  117. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ractor_core.h +382 -0
  118. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/regenc.h +254 -0
  119. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/regint.h +1006 -0
  120. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/regparse.h +371 -0
  121. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/revision.h +5 -0
  122. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/rjit.h +101 -0
  123. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/rjit_c.h +165 -0
  124. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ruby_assert.h +14 -0
  125. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/ruby_atomic.h +23 -0
  126. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/rubyparser.h +1350 -0
  127. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/shape.h +234 -0
  128. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/siphash.h +48 -0
  129. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/symbol.h +123 -0
  130. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/thread_none.h +21 -0
  131. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/thread_pthread.h +168 -0
  132. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/thread_win32.h +58 -0
  133. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/timev.h +58 -0
  134. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/transcode_data.h +138 -0
  135. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/variable.h +39 -0
  136. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/version.h +69 -0
  137. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm.inc +5840 -0
  138. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_call_iseq_optimized.inc +244 -0
  139. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_callinfo.h +627 -0
  140. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_core.h +2222 -0
  141. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_debug.h +124 -0
  142. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_exec.h +199 -0
  143. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_insnhelper.h +277 -0
  144. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_opts.h +67 -0
  145. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vm_sync.h +137 -0
  146. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/vmtc.inc +259 -0
  147. data/lib/debase/ruby_core_source/ruby-3.4.0-preview2/yjit.h +79 -0
  148. data/lib/debase/ruby_core_source/version.rb +1 -1
  149. metadata +150 -6
@@ -0,0 +1,17 @@
1
+ /* CC0 (Public domain) - see ccan/licenses/CC0 file for details */
2
+ #ifndef CCAN_STR_H
3
+ #define CCAN_STR_H
4
+ /**
5
+ * ccan_stringify - Turn expression into a string literal
6
+ * @expr: any C expression
7
+ *
8
+ * Example:
9
+ * #define PRINT_COND_IF_FALSE(cond) \
10
+ * ((cond) || printf("%s is false!", ccan_stringify(cond)))
11
+ */
12
+ #define stringify(expr) ccan_stringify_1(expr)
13
+ #define ccan_stringify(expr) ccan_stringify_1(expr)
14
+ /* Double-indirection required to stringify expansions */
15
+ #define ccan_stringify_1(expr) #expr
16
+
17
+ #endif /* CCAN_STR_H */
@@ -0,0 +1,53 @@
1
+ #ifndef CONSTANT_H
2
+ #define CONSTANT_H
3
+ /**********************************************************************
4
+
5
+ constant.h -
6
+
7
+ $Author$
8
+ created at: Sun Nov 15 00:09:33 2009
9
+
10
+ Copyright (C) 2009 Yusuke Endoh
11
+
12
+ **********************************************************************/
13
+ #include "ruby/ruby.h"
14
+ #include "id_table.h"
15
+
16
+ typedef enum {
17
+ CONST_DEPRECATED = 0x100,
18
+
19
+ CONST_VISIBILITY_MASK = 0xff,
20
+ CONST_PUBLIC = 0x00,
21
+ CONST_PRIVATE,
22
+ CONST_VISIBILITY_MAX
23
+ } rb_const_flag_t;
24
+
25
+ #define RB_CONST_PRIVATE_P(ce) \
26
+ (((ce)->flag & CONST_VISIBILITY_MASK) == CONST_PRIVATE)
27
+ #define RB_CONST_PUBLIC_P(ce) \
28
+ (((ce)->flag & CONST_VISIBILITY_MASK) == CONST_PUBLIC)
29
+
30
+ #define RB_CONST_DEPRECATED_P(ce) \
31
+ ((ce)->flag & CONST_DEPRECATED)
32
+
33
+ typedef struct rb_const_entry_struct {
34
+ rb_const_flag_t flag;
35
+ int line;
36
+ VALUE value; /* should be mark */
37
+ VALUE file; /* should be mark */
38
+ } rb_const_entry_t;
39
+
40
+ VALUE rb_mod_private_constant(int argc, const VALUE *argv, VALUE obj);
41
+ VALUE rb_mod_public_constant(int argc, const VALUE *argv, VALUE obj);
42
+ VALUE rb_mod_deprecate_constant(int argc, const VALUE *argv, VALUE obj);
43
+ void rb_free_const_table(struct rb_id_table *tbl);
44
+ VALUE rb_const_source_location(VALUE, ID);
45
+
46
+ int rb_autoloading_value(VALUE mod, ID id, VALUE *value, rb_const_flag_t *flag);
47
+ rb_const_entry_t *rb_const_lookup(VALUE klass, ID id);
48
+ VALUE rb_public_const_get_at(VALUE klass, ID id);
49
+ VALUE rb_public_const_get_from(VALUE klass, ID id);
50
+ int rb_public_const_defined_from(VALUE klass, ID id);
51
+ VALUE rb_const_source_location_at(VALUE, ID);
52
+
53
+ #endif /* CONSTANT_H */
@@ -0,0 +1,209 @@
1
+ #ifndef RUBY_DARRAY_H
2
+ #define RUBY_DARRAY_H
3
+
4
+ #include <stdint.h>
5
+ #include <stddef.h>
6
+ #include <stdlib.h>
7
+
8
+ #include "internal/bits.h"
9
+
10
+ // Type for a dynamic array. Use to declare a dynamic array.
11
+ // It is a pointer so it fits in st_table nicely. Designed
12
+ // to be fairly type-safe.
13
+ //
14
+ // NULL is a valid empty dynamic array.
15
+ //
16
+ // Example:
17
+ // rb_darray(char) char_array = NULL;
18
+ // rb_darray_append(&char_array, 'e');
19
+ // printf("pushed %c\n", *rb_darray_ref(char_array, 0));
20
+ // rb_darray_free(char_array);
21
+ //
22
+ #define rb_darray(T) struct { rb_darray_meta_t meta; T data[]; } *
23
+
24
+ // Copy an element out of the array. Warning: not bounds checked.
25
+ //
26
+ // T rb_darray_get(rb_darray(T) ary, size_t idx);
27
+ //
28
+ #define rb_darray_get(ary, idx) ((ary)->data[(idx)])
29
+
30
+ // Assign to an element. Warning: not bounds checked.
31
+ //
32
+ // void rb_darray_set(rb_darray(T) ary, size_t idx, T element);
33
+ //
34
+ #define rb_darray_set(ary, idx, element) ((ary)->data[(idx)] = (element))
35
+
36
+ // Get a pointer to an element. Warning: not bounds checked.
37
+ //
38
+ // T *rb_darray_ref(rb_darray(T) ary, size_t idx);
39
+ //
40
+ #define rb_darray_ref(ary, idx) (&((ary)->data[(idx)]))
41
+
42
+ /* Copy a new element into the array. ptr_to_ary is evaluated multiple times.
43
+ *
44
+ * void rb_darray_append(rb_darray(T) *ptr_to_ary, T element);
45
+ */
46
+ #define rb_darray_append(ptr_to_ary, element) do { \
47
+ rb_darray_ensure_space((ptr_to_ary), \
48
+ sizeof(**(ptr_to_ary)), \
49
+ sizeof((*(ptr_to_ary))->data[0])); \
50
+ rb_darray_set(*(ptr_to_ary), \
51
+ (*(ptr_to_ary))->meta.size, \
52
+ (element)); \
53
+ (*(ptr_to_ary))->meta.size++; \
54
+ } while (0)
55
+
56
+ #define rb_darray_insert(ptr_to_ary, idx, element) do { \
57
+ rb_darray_ensure_space((ptr_to_ary), \
58
+ sizeof(**(ptr_to_ary)), \
59
+ sizeof((*(ptr_to_ary))->data[0])); \
60
+ MEMMOVE( \
61
+ rb_darray_ref(*(ptr_to_ary), idx + 1), \
62
+ rb_darray_ref(*(ptr_to_ary), idx), \
63
+ sizeof((*(ptr_to_ary))->data[0]), \
64
+ rb_darray_size(*(ptr_to_ary)) - idx); \
65
+ rb_darray_set(*(ptr_to_ary), idx, element); \
66
+ (*(ptr_to_ary))->meta.size++; \
67
+ } while (0)
68
+
69
+ // Iterate over items of the array in a for loop
70
+ //
71
+ #define rb_darray_foreach(ary, idx_name, elem_ptr_var) \
72
+ for (size_t idx_name = 0; idx_name < rb_darray_size(ary) && ((elem_ptr_var) = rb_darray_ref(ary, idx_name)); ++idx_name)
73
+
74
+ // Iterate over valid indices in the array in a for loop
75
+ //
76
+ #define rb_darray_for(ary, idx_name) \
77
+ for (size_t idx_name = 0; idx_name < rb_darray_size(ary); ++idx_name)
78
+
79
+ /* Make a dynamic array of a certain size. All bytes backing the elements are set to zero.
80
+ * Return 1 on success and 0 on failure.
81
+ *
82
+ * Note that NULL is a valid empty dynamic array.
83
+ *
84
+ * void rb_darray_make(rb_darray(T) *ptr_to_ary, size_t size);
85
+ */
86
+ #define rb_darray_make(ptr_to_ary, size) \
87
+ rb_darray_make_impl((ptr_to_ary), size, sizeof(**(ptr_to_ary)), sizeof((*(ptr_to_ary))->data[0]))
88
+
89
+ /* Resize the darray to a new capacity. The new capacity must be greater than
90
+ * or equal to the size of the darray.
91
+ *
92
+ * void rb_darray_resize_capa(rb_darray(T) *ptr_to_ary, size_t capa);
93
+ */
94
+ #define rb_darray_resize_capa(ptr_to_ary, capa) \
95
+ rb_darray_resize_capa_impl((ptr_to_ary), capa, sizeof(**(ptr_to_ary)), sizeof((*(ptr_to_ary))->data[0]))
96
+
97
+ #define rb_darray_data_ptr(ary) ((ary)->data)
98
+
99
+ typedef struct rb_darray_meta {
100
+ size_t size;
101
+ size_t capa;
102
+ } rb_darray_meta_t;
103
+
104
+ /* Set the size of the array to zero without freeing the backing memory.
105
+ * Allows reusing the same array. */
106
+ static inline void
107
+ rb_darray_clear(void *ary)
108
+ {
109
+ rb_darray_meta_t *meta = ary;
110
+ if (meta) {
111
+ meta->size = 0;
112
+ }
113
+ }
114
+
115
+ // Get the size of the dynamic array.
116
+ //
117
+ static inline size_t
118
+ rb_darray_size(const void *ary)
119
+ {
120
+ const rb_darray_meta_t *meta = ary;
121
+ return meta ? meta->size : 0;
122
+ }
123
+
124
+
125
+ static inline void
126
+ rb_darray_pop(void *ary, size_t count)
127
+ {
128
+ rb_darray_meta_t *meta = ary;
129
+ meta->size -= count;
130
+ }
131
+
132
+ // Get the capacity of the dynamic array.
133
+ //
134
+ static inline size_t
135
+ rb_darray_capa(const void *ary)
136
+ {
137
+ const rb_darray_meta_t *meta = ary;
138
+ return meta ? meta->capa : 0;
139
+ }
140
+
141
+ /* Free the dynamic array. */
142
+ static inline void
143
+ rb_darray_free(void *ary)
144
+ {
145
+ xfree(ary);
146
+ }
147
+
148
+ /* Internal function. Resizes the capacity of a darray. The new capacity must
149
+ * be greater than or equal to the size of the darray. */
150
+ static inline void
151
+ rb_darray_resize_capa_impl(void *ptr_to_ary, size_t new_capa, size_t header_size, size_t element_size)
152
+ {
153
+ rb_darray_meta_t **ptr_to_ptr_to_meta = ptr_to_ary;
154
+ rb_darray_meta_t *meta = *ptr_to_ptr_to_meta;
155
+
156
+ rb_darray_meta_t *new_ary = xrealloc(meta, new_capa * element_size + header_size);
157
+
158
+ if (meta == NULL) {
159
+ /* First allocation. Initialize size. On subsequence allocations
160
+ * realloc takes care of carrying over the size. */
161
+ new_ary->size = 0;
162
+ }
163
+
164
+ RUBY_ASSERT(new_ary->size <= new_capa);
165
+
166
+ new_ary->capa = new_capa;
167
+
168
+ // We don't have access to the type of the dynamic array in function context.
169
+ // Write out result with memcpy to avoid strict aliasing issue.
170
+ memcpy(ptr_to_ary, &new_ary, sizeof(new_ary));
171
+ }
172
+
173
+ // Internal function
174
+ // Ensure there is space for one more element.
175
+ // Note: header_size can be bigger than sizeof(rb_darray_meta_t) when T is __int128_t, for example.
176
+ static inline void
177
+ rb_darray_ensure_space(void *ptr_to_ary, size_t header_size, size_t element_size)
178
+ {
179
+ rb_darray_meta_t **ptr_to_ptr_to_meta = ptr_to_ary;
180
+ rb_darray_meta_t *meta = *ptr_to_ptr_to_meta;
181
+ size_t current_capa = rb_darray_capa(meta);
182
+ if (rb_darray_size(meta) < current_capa) return;
183
+
184
+ // Double the capacity
185
+ size_t new_capa = current_capa == 0 ? 1 : current_capa * 2;
186
+
187
+ rb_darray_resize_capa_impl(ptr_to_ary, new_capa, header_size, element_size);
188
+ }
189
+
190
+ static inline void
191
+ rb_darray_make_impl(void *ptr_to_ary, size_t array_size, size_t header_size, size_t element_size)
192
+ {
193
+ rb_darray_meta_t **ptr_to_ptr_to_meta = ptr_to_ary;
194
+ if (array_size == 0) {
195
+ *ptr_to_ptr_to_meta = NULL;
196
+ return;
197
+ }
198
+
199
+ rb_darray_meta_t *meta = xcalloc(array_size * element_size + header_size, 1);
200
+
201
+ meta->size = array_size;
202
+ meta->capa = array_size;
203
+
204
+ // We don't have access to the type of the dynamic array in function context.
205
+ // Write out result with memcpy to avoid strict aliasing issue.
206
+ memcpy(ptr_to_ary, &meta, sizeof(meta));
207
+ }
208
+
209
+ #endif /* RUBY_DARRAY_H */
@@ -0,0 +1,423 @@
1
+ /**********************************************************************
2
+
3
+ debug_counter.h -
4
+
5
+ created at: Tue Feb 21 16:51:18 2017
6
+
7
+ Copyright (C) 2017 Koichi Sasada
8
+
9
+ **********************************************************************/
10
+
11
+ #ifndef USE_DEBUG_COUNTER
12
+ #define USE_DEBUG_COUNTER 0
13
+ #endif
14
+
15
+ #ifdef RB_DEBUG_COUNTER
16
+
17
+ // method cache (IMC: inline method cache)
18
+ RB_DEBUG_COUNTER(mc_inline_hit) // IMC hit
19
+ RB_DEBUG_COUNTER(mc_inline_miss_klass) // IMC miss by different class
20
+ RB_DEBUG_COUNTER(mc_inline_miss_invalidated) // IMC miss by invalidated ME
21
+ RB_DEBUG_COUNTER(mc_inline_miss_empty) // IMC miss because prev is empty slot
22
+ RB_DEBUG_COUNTER(mc_inline_miss_same_cc) // IMC miss, but same CC
23
+ RB_DEBUG_COUNTER(mc_inline_miss_same_cme) // IMC miss, but same CME
24
+ RB_DEBUG_COUNTER(mc_inline_miss_same_def) // IMC miss, but same definition
25
+ RB_DEBUG_COUNTER(mc_inline_miss_diff) // IMC miss, different methods
26
+
27
+ RB_DEBUG_COUNTER(cvar_write_inline_hit) // cvar cache hit on write
28
+ RB_DEBUG_COUNTER(cvar_read_inline_hit) // cvar cache hit on read
29
+ RB_DEBUG_COUNTER(cvar_inline_miss) // miss inline cache
30
+ RB_DEBUG_COUNTER(cvar_class_invalidate) // invalidate cvar cache when define a cvar that's defined on a subclass
31
+ RB_DEBUG_COUNTER(cvar_include_invalidate) // invalidate cvar cache on module include or prepend
32
+
33
+ RB_DEBUG_COUNTER(mc_cme_complement) // number of acquiring complement CME
34
+ RB_DEBUG_COUNTER(mc_cme_complement_hit) // number of cache hit for complemented CME
35
+
36
+ RB_DEBUG_COUNTER(mc_search) // count for method lookup in class tree
37
+ RB_DEBUG_COUNTER(mc_search_notfound) // method lookup, but not found
38
+ RB_DEBUG_COUNTER(mc_search_super) // total traversed classes
39
+
40
+ // callinfo
41
+ RB_DEBUG_COUNTER(ci_packed) // number of packed CI
42
+ RB_DEBUG_COUNTER(ci_kw) // non-packed CI w/ keywords
43
+ RB_DEBUG_COUNTER(ci_nokw) // non-packed CI w/o keywords
44
+ RB_DEBUG_COUNTER(ci_runtime) // creating temporary CI
45
+
46
+ // callcache
47
+ RB_DEBUG_COUNTER(cc_new) // number of CC
48
+ RB_DEBUG_COUNTER(cc_temp) // dummy CC (stack-allocated)
49
+ RB_DEBUG_COUNTER(cc_found_in_ccs) // count for CC lookup success in CCS
50
+ RB_DEBUG_COUNTER(cc_not_found_in_ccs) // count for CC lookup success in CCS
51
+
52
+ RB_DEBUG_COUNTER(cc_ent_invalidate) // count for invalidating cc (cc->klass = 0)
53
+ RB_DEBUG_COUNTER(cc_cme_invalidate) // count for invalidating CME
54
+
55
+ RB_DEBUG_COUNTER(cc_invalidate_leaf) // count for invalidating klass if klass has no-subclasses
56
+ RB_DEBUG_COUNTER(cc_invalidate_leaf_ccs) // corresponding CCS
57
+ RB_DEBUG_COUNTER(cc_invalidate_leaf_callable) // complimented cache (no-subclasses)
58
+ RB_DEBUG_COUNTER(cc_invalidate_tree) // count for invalidating klass if klass has subclasses
59
+ RB_DEBUG_COUNTER(cc_invalidate_tree_cme) // cme if cme is found in this class or superclasses
60
+ RB_DEBUG_COUNTER(cc_invalidate_tree_callable) // complimented cache (subclasses)
61
+ RB_DEBUG_COUNTER(cc_invalidate_negative) // count for invalidating negative cache
62
+
63
+ RB_DEBUG_COUNTER(ccs_free) // count for free'ing ccs
64
+ RB_DEBUG_COUNTER(ccs_maxlen) // maximum length of ccs
65
+ RB_DEBUG_COUNTER(ccs_found) // count for finding corresponding ccs on method lookup
66
+ RB_DEBUG_COUNTER(ccs_not_found) // count for not found corresponding ccs on method lookup
67
+
68
+ // vm_eval.c
69
+ RB_DEBUG_COUNTER(call0_public)
70
+ RB_DEBUG_COUNTER(call0_other)
71
+ RB_DEBUG_COUNTER(gccct_hit)
72
+ RB_DEBUG_COUNTER(gccct_miss)
73
+ RB_DEBUG_COUNTER(gccct_null)
74
+
75
+ // iseq
76
+ RB_DEBUG_COUNTER(iseq_num) // number of total created iseq
77
+ RB_DEBUG_COUNTER(iseq_cd_num) // number of total created cd (call_data)
78
+
79
+ /*
80
+ * call cache fastpath usage
81
+ */
82
+ RB_DEBUG_COUNTER(ccf_general)
83
+ RB_DEBUG_COUNTER(ccf_iseq_setup)
84
+ RB_DEBUG_COUNTER(ccf_iseq_setup_0start)
85
+ RB_DEBUG_COUNTER(ccf_iseq_setup_tailcall_0start)
86
+ RB_DEBUG_COUNTER(ccf_iseq_fix) /* several functions created with tool/mk_call_iseq_optimized.rb */
87
+ RB_DEBUG_COUNTER(ccf_iseq_opt) /* has_opt == TRUE (has optional parameters), but other flags are FALSE */
88
+ RB_DEBUG_COUNTER(ccf_iseq_kw1) /* vm_call_iseq_setup_kwparm_kwarg() */
89
+ RB_DEBUG_COUNTER(ccf_iseq_kw2) /* vm_call_iseq_setup_kwparm_nokwarg() */
90
+ RB_DEBUG_COUNTER(ccf_cfunc)
91
+ RB_DEBUG_COUNTER(ccf_cfunc_with_frame)
92
+ RB_DEBUG_COUNTER(ccf_ivar) /* attr_reader */
93
+ RB_DEBUG_COUNTER(ccf_attrset) /* attr_writer */
94
+ RB_DEBUG_COUNTER(ccf_method_missing)
95
+ RB_DEBUG_COUNTER(ccf_zsuper)
96
+ RB_DEBUG_COUNTER(ccf_bmethod)
97
+ RB_DEBUG_COUNTER(ccf_opt_send)
98
+ RB_DEBUG_COUNTER(ccf_opt_call)
99
+ RB_DEBUG_COUNTER(ccf_opt_block_call)
100
+ RB_DEBUG_COUNTER(ccf_opt_struct_aref)
101
+ RB_DEBUG_COUNTER(ccf_opt_struct_aset)
102
+ RB_DEBUG_COUNTER(ccf_super_method)
103
+ RB_DEBUG_COUNTER(ccf_cfunc_other)
104
+ RB_DEBUG_COUNTER(ccf_cfunc_only_splat)
105
+ RB_DEBUG_COUNTER(ccf_cfunc_only_splat_kw)
106
+ RB_DEBUG_COUNTER(ccf_iseq_bmethod)
107
+ RB_DEBUG_COUNTER(ccf_noniseq_bmethod)
108
+ RB_DEBUG_COUNTER(ccf_opt_send_complex)
109
+ RB_DEBUG_COUNTER(ccf_opt_send_simple)
110
+
111
+ /*
112
+ * control frame push counts.
113
+ *
114
+ * * frame_push: frame push counts.
115
+ * * frame_push_*: frame push counts per each type.
116
+ * * frame_R2R: Ruby frame to Ruby frame
117
+ * * frame_R2C: Ruby frame to C frame
118
+ * * frame_C2C: C frame to C frame
119
+ * * frame_C2R: C frame to Ruby frame
120
+ */
121
+ RB_DEBUG_COUNTER(frame_push)
122
+ RB_DEBUG_COUNTER(frame_push_method)
123
+ RB_DEBUG_COUNTER(frame_push_block)
124
+ RB_DEBUG_COUNTER(frame_push_class)
125
+ RB_DEBUG_COUNTER(frame_push_top)
126
+ RB_DEBUG_COUNTER(frame_push_cfunc)
127
+ RB_DEBUG_COUNTER(frame_push_ifunc)
128
+ RB_DEBUG_COUNTER(frame_push_eval)
129
+ RB_DEBUG_COUNTER(frame_push_rescue)
130
+ RB_DEBUG_COUNTER(frame_push_dummy)
131
+
132
+ RB_DEBUG_COUNTER(frame_R2R)
133
+ RB_DEBUG_COUNTER(frame_R2C)
134
+ RB_DEBUG_COUNTER(frame_C2C)
135
+ RB_DEBUG_COUNTER(frame_C2R)
136
+
137
+ /* instance variable counts */
138
+ RB_DEBUG_COUNTER(ivar_get_obj_hit) // Only T_OBJECT hits
139
+ RB_DEBUG_COUNTER(ivar_get_obj_miss) // Only T_OBJECT misses
140
+ RB_DEBUG_COUNTER(ivar_get_ic_hit) // All hits
141
+ RB_DEBUG_COUNTER(ivar_get_ic_miss) // All misses
142
+ RB_DEBUG_COUNTER(ivar_set_ic_hit) // All hits
143
+ RB_DEBUG_COUNTER(ivar_set_obj_hit) // Only T_OBJECT hits
144
+ RB_DEBUG_COUNTER(ivar_set_obj_miss) // Only T_OBJECT misses
145
+ RB_DEBUG_COUNTER(ivar_set_ic_miss) // All misses
146
+ RB_DEBUG_COUNTER(ivar_set_ic_miss_noobject) // Miss because non T_OBJECT
147
+ RB_DEBUG_COUNTER(ivar_get_base) // Calls to `rb_ivar_get` (very slow path)
148
+ RB_DEBUG_COUNTER(ivar_set_base) // Calls to `ivar_set` (very slow path)
149
+ RB_DEBUG_COUNTER(ivar_get_ic_miss_set) // Misses on IV reads where the cache was wrong
150
+ RB_DEBUG_COUNTER(ivar_get_cc_miss_set) // Misses on attr_reader where the cache was wrong
151
+ RB_DEBUG_COUNTER(ivar_get_ic_miss_unset) // Misses on IV read where the cache wasn't set
152
+ RB_DEBUG_COUNTER(ivar_get_cc_miss_unset) // Misses on attr_reader where the cache wasn't set
153
+
154
+ /* local variable counts
155
+ *
156
+ * * lvar_get: total lvar get counts (VM insn)
157
+ * * lvar_get_dynamic: lvar get counts if accessing upper env (VM insn)
158
+ * * lvar_set*: same as "get"
159
+ * * lvar_set_slowpath: counts using vm_env_write_slowpath()
160
+ */
161
+ RB_DEBUG_COUNTER(lvar_get)
162
+ RB_DEBUG_COUNTER(lvar_get_dynamic)
163
+ RB_DEBUG_COUNTER(lvar_set)
164
+ RB_DEBUG_COUNTER(lvar_set_dynamic)
165
+ RB_DEBUG_COUNTER(lvar_set_slowpath)
166
+
167
+ /* GC counts:
168
+ *
169
+ * * count: simple count
170
+ * * _minor: minor gc
171
+ * * _major: major gc
172
+ * * other suffix is corresponding to last_gc_info or
173
+ * gc_profile_record_flag in gc.c.
174
+ */
175
+ RB_DEBUG_COUNTER(gc_count)
176
+ RB_DEBUG_COUNTER(gc_minor_newobj)
177
+ RB_DEBUG_COUNTER(gc_minor_malloc)
178
+ RB_DEBUG_COUNTER(gc_minor_method)
179
+ RB_DEBUG_COUNTER(gc_minor_capi)
180
+ RB_DEBUG_COUNTER(gc_minor_stress)
181
+ RB_DEBUG_COUNTER(gc_major_nofree)
182
+ RB_DEBUG_COUNTER(gc_major_oldgen)
183
+ RB_DEBUG_COUNTER(gc_major_shady)
184
+ RB_DEBUG_COUNTER(gc_major_force)
185
+ RB_DEBUG_COUNTER(gc_major_oldmalloc)
186
+
187
+ RB_DEBUG_COUNTER(gc_enter_start)
188
+ RB_DEBUG_COUNTER(gc_enter_continue)
189
+ RB_DEBUG_COUNTER(gc_enter_rest)
190
+ RB_DEBUG_COUNTER(gc_enter_finalizer)
191
+
192
+ RB_DEBUG_COUNTER(gc_isptr_trial)
193
+ RB_DEBUG_COUNTER(gc_isptr_range)
194
+ RB_DEBUG_COUNTER(gc_isptr_align)
195
+ RB_DEBUG_COUNTER(gc_isptr_maybe)
196
+
197
+ /* object allocation counts:
198
+ *
199
+ * * obj_newobj: newobj counts
200
+ * * obj_newobj_slowpath: newobj with slowpath counts
201
+ * * obj_newobj_wb_unprotected: newobj for wb_unprotected.
202
+ * * obj_free: obj_free() counts
203
+ * * obj_promote: promoted counts (oldgen)
204
+ * * obj_wb_unprotect: wb unprotect counts
205
+ *
206
+ * * obj_[type]_[attr]: *free'ed counts* for each type.
207
+ * Note that it is not a allocated counts.
208
+ * * [type]
209
+ * * _obj: T_OBJECT
210
+ * * _str: T_STRING
211
+ * * _ary: T_ARRAY
212
+ * * _xxx: T_XXX (hash, struct, ...)
213
+ *
214
+ * * [attr]
215
+ * * _ptr: R?? is not embed.
216
+ * * _embed: R?? is embed.
217
+ * * type specific attr.
218
+ * * str_shared: str is shared.
219
+ * * str_nofree: nofree
220
+ * * str_fstr: fstr
221
+ * * hash_empty: hash is empty
222
+ * * hash_1_4: has 1 to 4 entries
223
+ * * hash_5_8: has 5 to 8 entries
224
+ * * hash_g8: has n entries (n>8)
225
+ * * match_under4: has under 4 oniguruma regions allocated
226
+ * * match_ge4: has n regions allocated (4<=n<8)
227
+ * * match_ge8: has n regions allocated (8<=n)
228
+ * * data_empty: T_DATA but no memory free.
229
+ * * data_xfree: free'ed by xfree().
230
+ * * data_imm_free: free'ed immediately.
231
+ * * data_zombie: free'ed with zombie.
232
+ * * imemo_*: T_IMEMO with each type.
233
+ */
234
+ RB_DEBUG_COUNTER(obj_newobj)
235
+ RB_DEBUG_COUNTER(obj_newobj_slowpath)
236
+ RB_DEBUG_COUNTER(obj_newobj_wb_unprotected)
237
+ RB_DEBUG_COUNTER(obj_free)
238
+ RB_DEBUG_COUNTER(obj_promote)
239
+ RB_DEBUG_COUNTER(obj_wb_unprotect)
240
+
241
+ RB_DEBUG_COUNTER(obj_obj_embed)
242
+ RB_DEBUG_COUNTER(obj_obj_ptr)
243
+ RB_DEBUG_COUNTER(obj_obj_too_complex)
244
+
245
+ RB_DEBUG_COUNTER(obj_str_ptr)
246
+ RB_DEBUG_COUNTER(obj_str_embed)
247
+ RB_DEBUG_COUNTER(obj_str_shared)
248
+ RB_DEBUG_COUNTER(obj_str_nofree)
249
+ RB_DEBUG_COUNTER(obj_str_fstr)
250
+
251
+ RB_DEBUG_COUNTER(obj_ary_embed)
252
+ RB_DEBUG_COUNTER(obj_ary_ptr)
253
+ RB_DEBUG_COUNTER(obj_ary_extracapa)
254
+ /*
255
+ ary_shared_create: shared ary by Array#dup and so on.
256
+ ary_shared: finished in shard.
257
+ ary_shared_root_occupied: shared_root but has only 1 refcnt.
258
+ The number (ary_shared - ary_shared_root_occupied) is meaningful.
259
+ */
260
+ RB_DEBUG_COUNTER(obj_ary_shared_create)
261
+ RB_DEBUG_COUNTER(obj_ary_shared)
262
+ RB_DEBUG_COUNTER(obj_ary_shared_root_occupied)
263
+
264
+ RB_DEBUG_COUNTER(obj_hash_empty)
265
+ RB_DEBUG_COUNTER(obj_hash_1)
266
+ RB_DEBUG_COUNTER(obj_hash_2)
267
+ RB_DEBUG_COUNTER(obj_hash_3)
268
+ RB_DEBUG_COUNTER(obj_hash_4)
269
+ RB_DEBUG_COUNTER(obj_hash_5_8)
270
+ RB_DEBUG_COUNTER(obj_hash_g8)
271
+
272
+ RB_DEBUG_COUNTER(obj_hash_null)
273
+ RB_DEBUG_COUNTER(obj_hash_ar)
274
+ RB_DEBUG_COUNTER(obj_hash_st)
275
+ RB_DEBUG_COUNTER(obj_hash_force_convert)
276
+
277
+ RB_DEBUG_COUNTER(obj_struct_embed)
278
+ RB_DEBUG_COUNTER(obj_struct_ptr)
279
+
280
+ RB_DEBUG_COUNTER(obj_data_empty)
281
+ RB_DEBUG_COUNTER(obj_data_xfree)
282
+ RB_DEBUG_COUNTER(obj_data_imm_free)
283
+ RB_DEBUG_COUNTER(obj_data_zombie)
284
+
285
+ RB_DEBUG_COUNTER(obj_match_under4)
286
+ RB_DEBUG_COUNTER(obj_match_ge4)
287
+ RB_DEBUG_COUNTER(obj_match_ge8)
288
+ RB_DEBUG_COUNTER(obj_match_ptr)
289
+
290
+ RB_DEBUG_COUNTER(obj_iclass_ptr)
291
+ RB_DEBUG_COUNTER(obj_class_ptr)
292
+ RB_DEBUG_COUNTER(obj_module_ptr)
293
+
294
+ RB_DEBUG_COUNTER(obj_bignum_ptr)
295
+ RB_DEBUG_COUNTER(obj_bignum_embed)
296
+ RB_DEBUG_COUNTER(obj_float)
297
+ RB_DEBUG_COUNTER(obj_complex)
298
+ RB_DEBUG_COUNTER(obj_rational)
299
+
300
+ RB_DEBUG_COUNTER(obj_regexp_ptr)
301
+ RB_DEBUG_COUNTER(obj_file_ptr)
302
+ RB_DEBUG_COUNTER(obj_symbol)
303
+
304
+ RB_DEBUG_COUNTER(obj_imemo_ment)
305
+ RB_DEBUG_COUNTER(obj_imemo_iseq)
306
+ RB_DEBUG_COUNTER(obj_imemo_env)
307
+ RB_DEBUG_COUNTER(obj_imemo_tmpbuf)
308
+ RB_DEBUG_COUNTER(obj_imemo_ast)
309
+ RB_DEBUG_COUNTER(obj_imemo_cref)
310
+ RB_DEBUG_COUNTER(obj_imemo_svar)
311
+ RB_DEBUG_COUNTER(obj_imemo_throw_data)
312
+ RB_DEBUG_COUNTER(obj_imemo_ifunc)
313
+ RB_DEBUG_COUNTER(obj_imemo_memo)
314
+ RB_DEBUG_COUNTER(obj_imemo_parser_strterm)
315
+ RB_DEBUG_COUNTER(obj_imemo_callinfo)
316
+ RB_DEBUG_COUNTER(obj_imemo_callcache)
317
+ RB_DEBUG_COUNTER(obj_imemo_constcache)
318
+
319
+ /* ar_table */
320
+ RB_DEBUG_COUNTER(artable_hint_hit)
321
+ RB_DEBUG_COUNTER(artable_hint_miss)
322
+ RB_DEBUG_COUNTER(artable_hint_notfound)
323
+
324
+ /* heap function counts
325
+ *
326
+ * * heap_xmalloc/realloc/xfree: call counts
327
+ */
328
+ RB_DEBUG_COUNTER(heap_xmalloc)
329
+ RB_DEBUG_COUNTER(heap_xrealloc)
330
+ RB_DEBUG_COUNTER(heap_xfree)
331
+
332
+ // VM sync
333
+ RB_DEBUG_COUNTER(vm_sync_lock)
334
+ RB_DEBUG_COUNTER(vm_sync_lock_enter)
335
+ RB_DEBUG_COUNTER(vm_sync_lock_enter_nb)
336
+ RB_DEBUG_COUNTER(vm_sync_lock_enter_cr)
337
+ RB_DEBUG_COUNTER(vm_sync_barrier)
338
+
339
+ /* load (not implemented yet) */
340
+ /*
341
+ RB_DEBUG_COUNTER(load_files)
342
+ RB_DEBUG_COUNTER(load_path_is_not_realpath)
343
+ */
344
+ #endif
345
+
346
+ #ifndef RUBY_DEBUG_COUNTER_H
347
+ #define RUBY_DEBUG_COUNTER_H 1
348
+
349
+ #include "ruby/internal/config.h"
350
+ #include <stddef.h> /* for size_t */
351
+ #include "ruby/ruby.h" /* for VALUE */
352
+
353
+ #if !defined(__GNUC__) && USE_DEBUG_COUNTER
354
+ #error "USE_DEBUG_COUNTER is not supported by other than __GNUC__"
355
+ #endif
356
+
357
+ enum rb_debug_counter_type {
358
+ #define RB_DEBUG_COUNTER(name) RB_DEBUG_COUNTER_##name,
359
+ #include "debug_counter.h"
360
+ RB_DEBUG_COUNTER_MAX
361
+ #undef RB_DEBUG_COUNTER
362
+ };
363
+
364
+ #if USE_DEBUG_COUNTER
365
+ extern size_t rb_debug_counter[];
366
+ RUBY_EXTERN struct rb_ractor_struct *ruby_single_main_ractor;
367
+ RUBY_EXTERN void rb_debug_counter_add_atomic(enum rb_debug_counter_type type, int add);
368
+
369
+ inline static int
370
+ rb_debug_counter_add(enum rb_debug_counter_type type, int add, int cond)
371
+ {
372
+ if (cond) {
373
+ if (ruby_single_main_ractor != NULL) {
374
+ rb_debug_counter[(int)type] += add;
375
+ }
376
+ else {
377
+ rb_debug_counter_add_atomic(type, add);
378
+ }
379
+ }
380
+ return cond;
381
+ }
382
+
383
+ inline static int
384
+ rb_debug_counter_max(enum rb_debug_counter_type type, unsigned int num)
385
+ {
386
+ // TODO: sync
387
+ if (rb_debug_counter[(int)type] < num) {
388
+ rb_debug_counter[(int)type] = num;
389
+ return 1;
390
+ }
391
+ else {
392
+ return 0;
393
+ }
394
+ }
395
+
396
+ VALUE rb_debug_counter_reset(VALUE klass);
397
+ VALUE rb_debug_counter_show(VALUE klass);
398
+
399
+ #define RB_DEBUG_COUNTER_INC(type) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, 1)
400
+ #define RB_DEBUG_COUNTER_INC_UNLESS(type, cond) (!rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, !(cond)))
401
+ #define RB_DEBUG_COUNTER_INC_IF(type, cond) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, 1, !!(cond))
402
+ #define RB_DEBUG_COUNTER_ADD(type, num) rb_debug_counter_add(RB_DEBUG_COUNTER_##type, (num), 1)
403
+ #define RB_DEBUG_COUNTER_SETMAX(type, num) rb_debug_counter_max(RB_DEBUG_COUNTER_##type, (unsigned int)(num))
404
+
405
+ #else
406
+ #define RB_DEBUG_COUNTER_INC(type) ((void)0)
407
+ #define RB_DEBUG_COUNTER_INC_UNLESS(type, cond) (!!(cond))
408
+ #define RB_DEBUG_COUNTER_INC_IF(type, cond) (!!(cond))
409
+ #define RB_DEBUG_COUNTER_ADD(type, num) ((void)0)
410
+ #define RB_DEBUG_COUNTER_SETMAX(type, num) 0
411
+ #endif
412
+
413
+ void rb_debug_counter_show_results(const char *msg);
414
+
415
+ RUBY_SYMBOL_EXPORT_BEGIN
416
+
417
+ size_t ruby_debug_counter_get(const char **names_ptr, size_t *counters_ptr);
418
+ void ruby_debug_counter_reset(void);
419
+ void ruby_debug_counter_show_at_exit(int enable);
420
+
421
+ RUBY_SYMBOL_EXPORT_END
422
+
423
+ #endif /* RUBY_DEBUG_COUNTER_H */