datadog-ruby_core_source 3.4.0 → 3.4.1

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 (108) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.datadog.md +4 -0
  3. data/README.md +8 -5
  4. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ccan/build_assert/build_assert.h +40 -0
  5. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ccan/check_type/check_type.h +63 -0
  6. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ccan/container_of/container_of.h +142 -0
  7. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ccan/list/list.h +791 -0
  8. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ccan/str/str.h +17 -0
  9. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/id.h +352 -0
  10. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/id_table.h +39 -0
  11. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/array.h +152 -0
  12. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/basic_operators.h +65 -0
  13. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/bignum.h +244 -0
  14. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/bits.h +650 -0
  15. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/class.h +283 -0
  16. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/cmdlineopt.h +61 -0
  17. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/compar.h +29 -0
  18. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/compile.h +34 -0
  19. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/compilers.h +107 -0
  20. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/complex.h +29 -0
  21. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/cont.h +35 -0
  22. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/dir.h +16 -0
  23. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/enc.h +19 -0
  24. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/encoding.h +38 -0
  25. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/enum.h +18 -0
  26. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/enumerator.h +21 -0
  27. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/error.h +244 -0
  28. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/eval.h +33 -0
  29. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/file.h +38 -0
  30. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/fixnum.h +185 -0
  31. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/gc.h +333 -0
  32. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/hash.h +193 -0
  33. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/imemo.h +257 -0
  34. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/inits.h +47 -0
  35. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/io.h +143 -0
  36. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/load.h +18 -0
  37. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/loadpath.h +16 -0
  38. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/math.h +23 -0
  39. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/missing.h +19 -0
  40. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/numeric.h +274 -0
  41. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/object.h +63 -0
  42. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/parse.h +131 -0
  43. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/proc.h +30 -0
  44. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/process.h +124 -0
  45. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/ractor.h +10 -0
  46. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/random.h +17 -0
  47. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/range.h +40 -0
  48. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/rational.h +71 -0
  49. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/re.h +28 -0
  50. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/ruby_parser.h +102 -0
  51. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/sanitizers.h +330 -0
  52. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/serial.h +23 -0
  53. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/signal.h +24 -0
  54. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/st.h +11 -0
  55. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/static_assert.h +16 -0
  56. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/string.h +199 -0
  57. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/struct.h +119 -0
  58. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/symbol.h +47 -0
  59. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/thread.h +108 -0
  60. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/time.h +37 -0
  61. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/transcode.h +23 -0
  62. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/util.h +27 -0
  63. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/variable.h +70 -0
  64. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/vm.h +137 -0
  65. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal/warnings.h +16 -0
  66. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/internal.h +108 -0
  67. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/iseq.h +351 -0
  68. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/method.h +258 -0
  69. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/node.h +122 -0
  70. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/parser_st.h +162 -0
  71. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/parser_value.h +106 -0
  72. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/ast.h +7964 -0
  73. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/defines.h +260 -0
  74. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/diagnostic.h +451 -0
  75. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/encoding.h +283 -0
  76. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/extension.h +19 -0
  77. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/node.h +129 -0
  78. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/options.h +442 -0
  79. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/pack.h +163 -0
  80. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/parser.h +933 -0
  81. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/prettyprint.h +34 -0
  82. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/prism.h +383 -0
  83. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/regexp.h +43 -0
  84. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/static_literals.h +121 -0
  85. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_buffer.h +228 -0
  86. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_char.h +204 -0
  87. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_constant_pool.h +218 -0
  88. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_integer.h +126 -0
  89. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_list.h +97 -0
  90. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_memchr.h +29 -0
  91. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_newline_list.h +113 -0
  92. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_string.h +190 -0
  93. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_strncasecmp.h +32 -0
  94. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/util/pm_strpbrk.h +46 -0
  95. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism/version.h +29 -0
  96. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/prism_compile.h +105 -0
  97. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ractor_core.h +382 -0
  98. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ruby_assert.h +14 -0
  99. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/ruby_atomic.h +23 -0
  100. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/rubyparser.h +1380 -0
  101. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/shape.h +234 -0
  102. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/thread_none.h +21 -0
  103. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/thread_pthread.h +167 -0
  104. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/vm_core.h +2235 -0
  105. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/vm_debug.h +124 -0
  106. data/lib/datadog/ruby_core_source/ruby-3.5.0-preview1/vm_opts.h +67 -0
  107. data/lib/datadog/ruby_core_source/version.rb +1 -1
  108. metadata +105 -2
@@ -0,0 +1,333 @@
1
+ #ifndef INTERNAL_GC_H /*-*-C-*-vi:se ft=c:*/
2
+ #define INTERNAL_GC_H
3
+ /**
4
+ * @author Ruby developers <ruby-core@ruby-lang.org>
5
+ * @copyright This file is a part of the programming language Ruby.
6
+ * Permission is hereby granted, to either redistribute and/or
7
+ * modify this file, provided that the conditions mentioned in the
8
+ * file COPYING are met. Consult the file for details.
9
+ * @brief Internal header for GC.
10
+ */
11
+ #include "ruby/internal/config.h"
12
+
13
+ #include <stddef.h> /* for size_t */
14
+
15
+ #include "internal/compilers.h" /* for __has_attribute */
16
+ #include "ruby/ruby.h" /* for rb_event_flag_t */
17
+ #include "vm_core.h" /* for GET_EC() */
18
+
19
+ #ifndef USE_MODULAR_GC
20
+ # define USE_MODULAR_GC 0
21
+ #endif
22
+
23
+ #if defined(__x86_64__) && !defined(_ILP32) && defined(__GNUC__)
24
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movq\t%%rsp, %0" : "=r" (*(p)))
25
+ #elif defined(__i386) && defined(__GNUC__)
26
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movl\t%%esp, %0" : "=r" (*(p)))
27
+ #elif (defined(__powerpc__) || defined(__powerpc64__)) && defined(__GNUC__) && !defined(_AIX) && !defined(__APPLE__) // Not Apple is NEEDED to unbreak ppc64 build on Darwin. Don't ask.
28
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("mr\t%0, %%r1" : "=r" (*(p)))
29
+ #elif (defined(__powerpc__) || defined(__powerpc64__)) && defined(__GNUC__) && defined(_AIX)
30
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("mr %0,1" : "=r" (*(p)))
31
+ #elif defined(__POWERPC__) && defined(__APPLE__) // Darwin ppc and ppc64
32
+ #define SET_MACHINE_STACK_END(p) __asm__ volatile("mr %0, r1" : "=r" (*(p)))
33
+ #elif defined(__aarch64__) && defined(__GNUC__)
34
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("mov\t%0, sp" : "=r" (*(p)))
35
+ #else
36
+ NOINLINE(void rb_gc_set_stack_end(VALUE **stack_end_p));
37
+ #define SET_MACHINE_STACK_END(p) rb_gc_set_stack_end(p)
38
+ #define USE_CONSERVATIVE_STACK_END
39
+ #endif
40
+
41
+ /* for GC debug */
42
+
43
+ #ifndef RUBY_MARK_FREE_DEBUG
44
+ #define RUBY_MARK_FREE_DEBUG 0
45
+ #endif
46
+
47
+ #if RUBY_MARK_FREE_DEBUG
48
+ extern int ruby_gc_debug_indent;
49
+
50
+ static inline void
51
+ rb_gc_debug_indent(void)
52
+ {
53
+ ruby_debug_printf("%*s", ruby_gc_debug_indent, "");
54
+ }
55
+
56
+ static inline void
57
+ rb_gc_debug_body(const char *mode, const char *msg, int st, void *ptr)
58
+ {
59
+ if (st == 0) {
60
+ ruby_gc_debug_indent--;
61
+ }
62
+ rb_gc_debug_indent();
63
+ ruby_debug_printf("%s: %s %s (%p)\n", mode, st ? "->" : "<-", msg, ptr);
64
+
65
+ if (st) {
66
+ ruby_gc_debug_indent++;
67
+ }
68
+
69
+ fflush(stdout);
70
+ }
71
+
72
+ #define RUBY_MARK_ENTER(msg) rb_gc_debug_body("mark", (msg), 1, ptr)
73
+ #define RUBY_MARK_LEAVE(msg) rb_gc_debug_body("mark", (msg), 0, ptr)
74
+ #define RUBY_FREE_ENTER(msg) rb_gc_debug_body("free", (msg), 1, ptr)
75
+ #define RUBY_FREE_LEAVE(msg) rb_gc_debug_body("free", (msg), 0, ptr)
76
+ #define RUBY_GC_INFO rb_gc_debug_indent(), ruby_debug_printf
77
+
78
+ #else
79
+ #define RUBY_MARK_ENTER(msg)
80
+ #define RUBY_MARK_LEAVE(msg)
81
+ #define RUBY_FREE_ENTER(msg)
82
+ #define RUBY_FREE_LEAVE(msg)
83
+ #define RUBY_GC_INFO if(0)printf
84
+ #endif
85
+
86
+ #define RUBY_FREE_UNLESS_NULL(ptr) if(ptr){ruby_xfree(ptr);(ptr)=NULL;}
87
+
88
+ #if STACK_GROW_DIRECTION > 0
89
+ # define STACK_UPPER(x, a, b) (a)
90
+ #elif STACK_GROW_DIRECTION < 0
91
+ # define STACK_UPPER(x, a, b) (b)
92
+ #else
93
+ RUBY_EXTERN int ruby_stack_grow_direction;
94
+ int ruby_get_stack_grow_direction(volatile VALUE *addr);
95
+ # define stack_growup_p(x) ( \
96
+ (ruby_stack_grow_direction ? \
97
+ ruby_stack_grow_direction : \
98
+ ruby_get_stack_grow_direction(x)) > 0)
99
+ # define STACK_UPPER(x, a, b) (stack_growup_p(x) ? (a) : (b))
100
+ #endif
101
+
102
+ /*
103
+ STACK_GROW_DIR_DETECTION is used with STACK_DIR_UPPER.
104
+
105
+ On most normal systems, stacks grow from high address to lower address. In
106
+ this case, STACK_DIR_UPPER(a, b) will return (b), but on exotic systems where
107
+ the stack grows UP (from low address to high address), it will return (a).
108
+ */
109
+
110
+ #if STACK_GROW_DIRECTION
111
+ #define STACK_GROW_DIR_DETECTION
112
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(0, (a), (b))
113
+ #else
114
+ #define STACK_GROW_DIR_DETECTION VALUE stack_grow_dir_detection
115
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(&stack_grow_dir_detection, (a), (b))
116
+ #endif
117
+ #define IS_STACK_DIR_UPPER() STACK_DIR_UPPER(1,0)
118
+
119
+ const char *rb_obj_info(VALUE obj);
120
+ const char *rb_raw_obj_info(char *const buff, const size_t buff_size, VALUE obj);
121
+
122
+ struct rb_execution_context_struct; /* in vm_core.h */
123
+ struct rb_objspace; /* in vm_core.h */
124
+
125
+ #define NEWOBJ_OF(var, T, c, f, s, ec) \
126
+ T *(var) = (T *)(((f) & FL_WB_PROTECTED) ? \
127
+ rb_wb_protected_newobj_of((ec ? ec : GET_EC()), (c), (f) & ~FL_WB_PROTECTED, s) : \
128
+ rb_wb_unprotected_newobj_of((c), (f), s))
129
+
130
+ #ifndef RB_GC_OBJECT_METADATA_ENTRY_DEFINED
131
+ # define RB_GC_OBJECT_METADATA_ENTRY_DEFINED
132
+ struct rb_gc_object_metadata_entry {
133
+ ID name;
134
+ VALUE val;
135
+ };
136
+ #endif
137
+
138
+ #ifndef USE_UNALIGNED_MEMBER_ACCESS
139
+ # define UNALIGNED_MEMBER_ACCESS(expr) (expr)
140
+ #elif ! USE_UNALIGNED_MEMBER_ACCESS
141
+ # define UNALIGNED_MEMBER_ACCESS(expr) (expr)
142
+ #elif ! (__has_warning("-Waddress-of-packed-member") || GCC_VERSION_SINCE(9, 0, 0))
143
+ # define UNALIGNED_MEMBER_ACCESS(expr) (expr)
144
+ #else
145
+ # include "internal/warnings.h"
146
+ # define UNALIGNED_MEMBER_ACCESS(expr) __extension__({ \
147
+ COMPILER_WARNING_PUSH; \
148
+ COMPILER_WARNING_IGNORED(-Waddress-of-packed-member); \
149
+ __typeof__(expr) unaligned_member_access_result = (expr); \
150
+ COMPILER_WARNING_POP; \
151
+ unaligned_member_access_result; \
152
+ })
153
+
154
+ # define UNALIGNED_MEMBER_PTR(ptr, mem) __extension__({ \
155
+ COMPILER_WARNING_PUSH; \
156
+ COMPILER_WARNING_IGNORED(-Waddress-of-packed-member); \
157
+ const volatile void *unaligned_member_ptr_result = &(ptr)->mem; \
158
+ COMPILER_WARNING_POP; \
159
+ (__typeof__((ptr)->mem) *)unaligned_member_ptr_result; \
160
+ })
161
+ #endif
162
+
163
+ #ifndef UNALIGNED_MEMBER_PTR
164
+ # define UNALIGNED_MEMBER_PTR(ptr, mem) UNALIGNED_MEMBER_ACCESS(&(ptr)->mem)
165
+ #endif
166
+
167
+ #define RB_OBJ_WRITE_UNALIGNED(old, slot, young) do { \
168
+ VALUE *_slot = UNALIGNED_MEMBER_ACCESS(slot); \
169
+ RB_OBJ_WRITE(old, _slot, young); \
170
+ } while (0)
171
+
172
+ /* Used in places that could malloc during, which can cause the GC to run. We
173
+ * need to temporarily disable the GC to allow the malloc to happen.
174
+ * Allocating memory during GC is a bad idea, so use this only when absolutely
175
+ * necessary. */
176
+ #define DURING_GC_COULD_MALLOC_REGION_START() \
177
+ assert(rb_during_gc()); \
178
+ VALUE _already_disabled = rb_gc_disable_no_rest()
179
+
180
+ #define DURING_GC_COULD_MALLOC_REGION_END() \
181
+ if (_already_disabled == Qfalse) rb_gc_enable()
182
+
183
+ /* gc.c */
184
+ RUBY_ATTR_MALLOC void *ruby_mimmalloc(size_t size);
185
+ RUBY_ATTR_MALLOC void *ruby_mimcalloc(size_t num, size_t size);
186
+ void ruby_mimfree(void *ptr);
187
+ void rb_gc_prepare_heap(void);
188
+ void rb_objspace_set_event_hook(const rb_event_flag_t event);
189
+ VALUE rb_objspace_gc_enable(void *objspace);
190
+ VALUE rb_objspace_gc_disable(void *objspace);
191
+ void ruby_gc_set_params(void);
192
+ void rb_gc_copy_attributes(VALUE dest, VALUE obj);
193
+ size_t rb_size_mul_or_raise(size_t, size_t, VALUE); /* used in compile.c */
194
+ size_t rb_size_mul_add_or_raise(size_t, size_t, size_t, VALUE); /* used in iseq.h */
195
+ size_t rb_malloc_grow_capa(size_t current_capacity, size_t type_size);
196
+ RUBY_ATTR_MALLOC void *rb_xmalloc_mul_add(size_t, size_t, size_t);
197
+ RUBY_ATTR_MALLOC void *rb_xcalloc_mul_add(size_t, size_t, size_t);
198
+ void *rb_xrealloc_mul_add(const void *, size_t, size_t, size_t);
199
+ RUBY_ATTR_MALLOC void *rb_xmalloc_mul_add_mul(size_t, size_t, size_t, size_t);
200
+ RUBY_ATTR_MALLOC void *rb_xcalloc_mul_add_mul(size_t, size_t, size_t, size_t);
201
+ static inline void *ruby_sized_xrealloc_inlined(void *ptr, size_t new_size, size_t old_size) RUBY_ATTR_RETURNS_NONNULL RUBY_ATTR_ALLOC_SIZE((2));
202
+ static inline void *ruby_sized_xrealloc2_inlined(void *ptr, size_t new_count, size_t elemsiz, size_t old_count) RUBY_ATTR_RETURNS_NONNULL RUBY_ATTR_ALLOC_SIZE((2, 3));
203
+ static inline void ruby_sized_xfree_inlined(void *ptr, size_t size);
204
+
205
+ void *rb_gc_ractor_cache_alloc(rb_ractor_t *ractor);
206
+ void rb_gc_ractor_cache_free(void *cache);
207
+
208
+ bool rb_gc_size_allocatable_p(size_t size);
209
+ size_t *rb_gc_heap_sizes(void);
210
+ size_t rb_gc_heap_id_for_size(size_t size);
211
+
212
+ void rb_gc_mark_and_move(VALUE *ptr);
213
+
214
+ void rb_gc_mark_weak(VALUE *ptr);
215
+ void rb_gc_remove_weak(VALUE parent_obj, VALUE *ptr);
216
+
217
+ void rb_gc_ref_update_table_values_only(st_table *tbl);
218
+
219
+ void rb_gc_initial_stress_set(VALUE flag);
220
+
221
+ void rb_gc_before_fork(void);
222
+ void rb_gc_after_fork(rb_pid_t pid);
223
+
224
+ #define rb_gc_mark_and_move_ptr(ptr) do { \
225
+ VALUE _obj = (VALUE)*(ptr); \
226
+ rb_gc_mark_and_move(&_obj); \
227
+ if (_obj != (VALUE)*(ptr)) *(ptr) = (void *)_obj; \
228
+ } while (0)
229
+
230
+ RUBY_SYMBOL_EXPORT_BEGIN
231
+ /* exports for objspace module */
232
+ void rb_objspace_reachable_objects_from(VALUE obj, void (func)(VALUE, void *), void *data);
233
+ void rb_objspace_reachable_objects_from_root(void (func)(const char *category, VALUE, void *), void *data);
234
+ int rb_objspace_internal_object_p(VALUE obj);
235
+ int rb_objspace_garbage_object_p(VALUE obj);
236
+ bool rb_gc_pointer_to_heap_p(VALUE obj);
237
+
238
+ void rb_objspace_each_objects(
239
+ int (*callback)(void *start, void *end, size_t stride, void *data),
240
+ void *data);
241
+
242
+ size_t rb_gc_obj_slot_size(VALUE obj);
243
+
244
+ VALUE rb_gc_disable_no_rest(void);
245
+
246
+ #define RB_GC_MAX_NAME_LEN 20
247
+
248
+ /* gc.c (export) */
249
+ const char *rb_objspace_data_type_name(VALUE obj);
250
+ VALUE rb_wb_protected_newobj_of(struct rb_execution_context_struct *, VALUE, VALUE, size_t);
251
+ VALUE rb_wb_unprotected_newobj_of(VALUE, VALUE, size_t);
252
+ size_t rb_obj_memsize_of(VALUE);
253
+ struct rb_gc_object_metadata_entry *rb_gc_object_metadata(VALUE obj);
254
+ void rb_gc_mark_values(long n, const VALUE *values);
255
+ void rb_gc_mark_vm_stack_values(long n, const VALUE *values);
256
+ void rb_gc_update_values(long n, VALUE *values);
257
+ void *ruby_sized_xrealloc(void *ptr, size_t new_size, size_t old_size) RUBY_ATTR_RETURNS_NONNULL RUBY_ATTR_ALLOC_SIZE((2));
258
+ void *ruby_sized_xrealloc2(void *ptr, size_t new_count, size_t element_size, size_t old_count) RUBY_ATTR_RETURNS_NONNULL RUBY_ATTR_ALLOC_SIZE((2, 3));
259
+ void ruby_sized_xfree(void *x, size_t size);
260
+
261
+ const char *rb_gc_active_gc_name(void);
262
+ int rb_gc_modular_gc_loaded_p(void);
263
+
264
+ RUBY_SYMBOL_EXPORT_END
265
+
266
+ int rb_ec_stack_check(struct rb_execution_context_struct *ec);
267
+ void rb_gc_writebarrier_remember(VALUE obj);
268
+ const char *rb_obj_info(VALUE obj);
269
+ void ruby_annotate_mmap(const void *addr, unsigned long size, const char *name);
270
+
271
+ #if defined(HAVE_MALLOC_USABLE_SIZE) || defined(HAVE_MALLOC_SIZE) || defined(_WIN32)
272
+
273
+ static inline void *
274
+ ruby_sized_xrealloc_inlined(void *ptr, size_t new_size, size_t old_size)
275
+ {
276
+ return ruby_xrealloc(ptr, new_size);
277
+ }
278
+
279
+ static inline void *
280
+ ruby_sized_xrealloc2_inlined(void *ptr, size_t new_count, size_t elemsiz, size_t old_count)
281
+ {
282
+ return ruby_xrealloc2(ptr, new_count, elemsiz);
283
+ }
284
+
285
+ static inline void
286
+ ruby_sized_xfree_inlined(void *ptr, size_t size)
287
+ {
288
+ ruby_xfree(ptr);
289
+ }
290
+
291
+ # define SIZED_REALLOC_N(x, y, z, w) REALLOC_N(x, y, z)
292
+
293
+ static inline void *
294
+ ruby_sized_realloc_n(void *ptr, size_t new_count, size_t element_size, size_t old_count)
295
+ {
296
+ return ruby_xrealloc2(ptr, new_count, element_size);
297
+ }
298
+
299
+ #else
300
+
301
+ static inline void *
302
+ ruby_sized_xrealloc_inlined(void *ptr, size_t new_size, size_t old_size)
303
+ {
304
+ return ruby_sized_xrealloc(ptr, new_size, old_size);
305
+ }
306
+
307
+ static inline void *
308
+ ruby_sized_xrealloc2_inlined(void *ptr, size_t new_count, size_t elemsiz, size_t old_count)
309
+ {
310
+ return ruby_sized_xrealloc2(ptr, new_count, elemsiz, old_count);
311
+ }
312
+
313
+ static inline void
314
+ ruby_sized_xfree_inlined(void *ptr, size_t size)
315
+ {
316
+ ruby_sized_xfree(ptr, size);
317
+ }
318
+
319
+ # define SIZED_REALLOC_N(v, T, m, n) \
320
+ ((v) = (T *)ruby_sized_xrealloc2((void *)(v), (m), sizeof(T), (n)))
321
+
322
+ static inline void *
323
+ ruby_sized_realloc_n(void *ptr, size_t new_count, size_t element_size, size_t old_count)
324
+ {
325
+ return ruby_sized_xrealloc2(ptr, new_count, element_size, old_count);
326
+ }
327
+
328
+ #endif /* HAVE_MALLOC_USABLE_SIZE */
329
+
330
+ #define ruby_sized_xrealloc ruby_sized_xrealloc_inlined
331
+ #define ruby_sized_xrealloc2 ruby_sized_xrealloc2_inlined
332
+ #define ruby_sized_xfree ruby_sized_xfree_inlined
333
+ #endif /* INTERNAL_GC_H */
@@ -0,0 +1,193 @@
1
+ #ifndef INTERNAL_HASH_H /*-*-C-*-vi:se ft=c:*/
2
+ #define INTERNAL_HASH_H
3
+ /**
4
+ * @author Ruby developers <ruby-core@ruby-lang.org>
5
+ * @copyright This file is a part of the programming language Ruby.
6
+ * Permission is hereby granted, to either redistribute and/or
7
+ * modify this file, provided that the conditions mentioned in the
8
+ * file COPYING are met. Consult the file for details.
9
+ * @brief Internal header for Hash.
10
+ */
11
+ #include "ruby/internal/config.h"
12
+ #include <stddef.h> /* for size_t */
13
+ #include "ruby/internal/stdbool.h" /* for bool */
14
+ #include "ruby/ruby.h" /* for struct RBasic */
15
+ #include "ruby/st.h" /* for struct st_table */
16
+
17
+ #define RHASH_AR_TABLE_MAX_SIZE SIZEOF_VALUE
18
+
19
+ struct ar_table_struct;
20
+ typedef unsigned char ar_hint_t;
21
+
22
+ enum ruby_rhash_flags {
23
+ RHASH_PASS_AS_KEYWORDS = FL_USER1, /* FL 1 */
24
+ RHASH_PROC_DEFAULT = FL_USER2, /* FL 2 */
25
+ RHASH_ST_TABLE_FLAG = FL_USER3, /* FL 3 */
26
+ RHASH_AR_TABLE_SIZE_MASK = (FL_USER4|FL_USER5|FL_USER6|FL_USER7), /* FL 4..7 */
27
+ RHASH_AR_TABLE_SIZE_SHIFT = (FL_USHIFT+4),
28
+ RHASH_AR_TABLE_BOUND_MASK = (FL_USER8|FL_USER9|FL_USER10|FL_USER11), /* FL 8..11 */
29
+ RHASH_AR_TABLE_BOUND_SHIFT = (FL_USHIFT+8),
30
+
31
+ // we can not put it in "enum" because it can exceed "int" range.
32
+ #define RHASH_LEV_MASK (FL_USER13 | FL_USER14 | FL_USER15 | /* FL 13..19 */ \
33
+ FL_USER16 | FL_USER17 | FL_USER18 | FL_USER19)
34
+
35
+ RHASH_LEV_SHIFT = (FL_USHIFT + 13),
36
+ RHASH_LEV_MAX = 127, /* 7 bits */
37
+ };
38
+
39
+ typedef struct ar_table_pair_struct {
40
+ VALUE key;
41
+ VALUE val;
42
+ } ar_table_pair;
43
+
44
+ typedef struct ar_table_struct {
45
+ union {
46
+ ar_hint_t ary[RHASH_AR_TABLE_MAX_SIZE];
47
+ VALUE word;
48
+ } ar_hint;
49
+ /* 64bit CPU: 8B * 2 * 8 = 128B */
50
+ ar_table_pair pairs[RHASH_AR_TABLE_MAX_SIZE];
51
+ } ar_table;
52
+
53
+ struct RHash {
54
+ struct RBasic basic;
55
+ const VALUE ifnone;
56
+ };
57
+
58
+ #define RHASH(obj) ((struct RHash *)(obj))
59
+
60
+ #ifdef RHASH_IFNONE
61
+ # undef RHASH_IFNONE
62
+ #endif
63
+
64
+ #ifdef RHASH_SIZE
65
+ # undef RHASH_SIZE
66
+ #endif
67
+
68
+ #ifdef RHASH_EMPTY_P
69
+ # undef RHASH_EMPTY_P
70
+ #endif
71
+
72
+ /* hash.c */
73
+ void rb_hash_st_table_set(VALUE hash, st_table *st);
74
+ VALUE rb_hash_default_value(VALUE hash, VALUE key);
75
+ VALUE rb_hash_set_default_proc(VALUE hash, VALUE proc);
76
+ long rb_dbl_long_hash(double d);
77
+ st_table *rb_init_identtable(void);
78
+ st_index_t rb_any_hash(VALUE a);
79
+ int rb_any_cmp(VALUE a, VALUE b);
80
+ VALUE rb_to_hash_type(VALUE obj);
81
+ VALUE rb_hash_key_str(VALUE);
82
+ VALUE rb_hash_values(VALUE hash);
83
+ VALUE rb_hash_rehash(VALUE hash);
84
+ int rb_hash_add_new_element(VALUE hash, VALUE key, VALUE val);
85
+ VALUE rb_hash_set_pair(VALUE hash, VALUE pair);
86
+ int rb_hash_stlike_delete(VALUE hash, st_data_t *pkey, st_data_t *pval);
87
+ int rb_hash_stlike_foreach_with_replace(VALUE hash, st_foreach_check_callback_func *func, st_update_callback_func *replace, st_data_t arg);
88
+ int rb_hash_stlike_update(VALUE hash, st_data_t key, st_update_callback_func *func, st_data_t arg);
89
+ bool rb_hash_default_unredefined(VALUE hash);
90
+ VALUE rb_ident_hash_new_with_size(st_index_t size);
91
+ void rb_hash_free(VALUE hash);
92
+ RUBY_EXTERN VALUE rb_cHash_empty_frozen;
93
+
94
+ static inline unsigned RHASH_AR_TABLE_SIZE_RAW(VALUE h);
95
+ static inline VALUE RHASH_IFNONE(VALUE h);
96
+ static inline size_t RHASH_SIZE(VALUE h);
97
+ static inline bool RHASH_EMPTY_P(VALUE h);
98
+ static inline bool RHASH_AR_TABLE_P(VALUE h);
99
+ static inline bool RHASH_ST_TABLE_P(VALUE h);
100
+ static inline struct ar_table_struct *RHASH_AR_TABLE(VALUE h);
101
+ static inline st_table *RHASH_ST_TABLE(VALUE h);
102
+ static inline size_t RHASH_ST_SIZE(VALUE h);
103
+ static inline void RHASH_ST_CLEAR(VALUE h);
104
+
105
+ RUBY_SYMBOL_EXPORT_BEGIN
106
+ /* hash.c (export) */
107
+ VALUE rb_hash_delete_entry(VALUE hash, VALUE key);
108
+ VALUE rb_ident_hash_new(void);
109
+ int rb_hash_stlike_foreach(VALUE hash, st_foreach_callback_func *func, st_data_t arg);
110
+ RUBY_SYMBOL_EXPORT_END
111
+
112
+ VALUE rb_hash_new_with_size(st_index_t size);
113
+ VALUE rb_hash_resurrect(VALUE hash);
114
+ int rb_hash_stlike_lookup(VALUE hash, st_data_t key, st_data_t *pval);
115
+ VALUE rb_hash_keys(VALUE hash);
116
+ VALUE rb_hash_has_key(VALUE hash, VALUE key);
117
+ VALUE rb_hash_compare_by_id_p(VALUE hash);
118
+
119
+ st_table *rb_hash_tbl_raw(VALUE hash, const char *file, int line);
120
+ #define RHASH_TBL_RAW(h) rb_hash_tbl_raw(h, __FILE__, __LINE__)
121
+
122
+ VALUE rb_hash_compare_by_id(VALUE hash);
123
+
124
+ static inline bool
125
+ RHASH_AR_TABLE_P(VALUE h)
126
+ {
127
+ return ! FL_TEST_RAW(h, RHASH_ST_TABLE_FLAG);
128
+ }
129
+
130
+ RBIMPL_ATTR_RETURNS_NONNULL()
131
+ static inline struct ar_table_struct *
132
+ RHASH_AR_TABLE(VALUE h)
133
+ {
134
+ return (struct ar_table_struct *)((uintptr_t)h + sizeof(struct RHash));
135
+ }
136
+
137
+ RBIMPL_ATTR_RETURNS_NONNULL()
138
+ static inline st_table *
139
+ RHASH_ST_TABLE(VALUE h)
140
+ {
141
+ return (st_table *)((uintptr_t)h + sizeof(struct RHash));
142
+ }
143
+
144
+ static inline VALUE
145
+ RHASH_IFNONE(VALUE h)
146
+ {
147
+ return RHASH(h)->ifnone;
148
+ }
149
+
150
+ static inline size_t
151
+ RHASH_SIZE(VALUE h)
152
+ {
153
+ if (RHASH_AR_TABLE_P(h)) {
154
+ return RHASH_AR_TABLE_SIZE_RAW(h);
155
+ }
156
+ else {
157
+ return RHASH_ST_SIZE(h);
158
+ }
159
+ }
160
+
161
+ static inline bool
162
+ RHASH_EMPTY_P(VALUE h)
163
+ {
164
+ return RHASH_SIZE(h) == 0;
165
+ }
166
+
167
+ static inline bool
168
+ RHASH_ST_TABLE_P(VALUE h)
169
+ {
170
+ return ! RHASH_AR_TABLE_P(h);
171
+ }
172
+
173
+ static inline size_t
174
+ RHASH_ST_SIZE(VALUE h)
175
+ {
176
+ return RHASH_ST_TABLE(h)->num_entries;
177
+ }
178
+
179
+ static inline void
180
+ RHASH_ST_CLEAR(VALUE h)
181
+ {
182
+ memset(RHASH_ST_TABLE(h), 0, sizeof(st_table));
183
+ }
184
+
185
+ static inline unsigned
186
+ RHASH_AR_TABLE_SIZE_RAW(VALUE h)
187
+ {
188
+ VALUE ret = FL_TEST_RAW(h, RHASH_AR_TABLE_SIZE_MASK);
189
+ ret >>= RHASH_AR_TABLE_SIZE_SHIFT;
190
+ return (unsigned)ret;
191
+ }
192
+
193
+ #endif /* INTERNAL_HASH_H */