debase-ruby_core_source 0.10.5 → 0.10.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (57) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +5 -0
  3. data/lib/debase/ruby_core_source.rb +1 -1
  4. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/addr2line.h +21 -0
  5. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ccan/build_assert/build_assert.h +40 -0
  6. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ccan/check_type/check_type.h +63 -0
  7. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ccan/container_of/container_of.h +142 -0
  8. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ccan/list/list.h +788 -0
  9. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ccan/str/str.h +16 -0
  10. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/constant.h +51 -0
  11. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/debug_counter.h +283 -0
  12. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/dln.h +51 -0
  13. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/encindex.h +69 -0
  14. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/eval_intern.h +333 -0
  15. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/gc.h +116 -0
  16. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/hrtime.h +168 -0
  17. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/id.h +252 -0
  18. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/id_table.h +31 -0
  19. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/insns.inc +249 -0
  20. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/insns_info.inc +9374 -0
  21. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/internal.h +2470 -0
  22. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/iseq.h +304 -0
  23. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/known_errors.inc +791 -0
  24. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/method.h +229 -0
  25. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/mjit.h +148 -0
  26. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/mjit_compile.inc +4226 -0
  27. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/node.h +449 -0
  28. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/node_name.inc +200 -0
  29. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/opt_sc.inc +109 -0
  30. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/optinsn.inc +128 -0
  31. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/optunifs.inc +43 -0
  32. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/parse.h +207 -0
  33. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/probes_helper.h +42 -0
  34. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/regenc.h +254 -0
  35. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/regint.h +938 -0
  36. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/regparse.h +370 -0
  37. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/revision.h +1 -0
  38. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ruby_assert.h +60 -0
  39. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/ruby_atomic.h +244 -0
  40. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/siphash.h +48 -0
  41. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/symbol.h +112 -0
  42. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/thread_pthread.h +75 -0
  43. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/thread_win32.h +36 -0
  44. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/timev.h +53 -0
  45. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/transcode_data.h +139 -0
  46. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/transient_heap.h +60 -0
  47. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/version.h +73 -0
  48. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm.inc +4504 -0
  49. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_call_iseq_optimized.inc +213 -0
  50. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_core.h +1910 -0
  51. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_debug.h +37 -0
  52. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_exec.h +202 -0
  53. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_insnhelper.h +316 -0
  54. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vm_opts.h +70 -0
  55. data/lib/debase/ruby_core_source/ruby-2.6.5-p114/vmtc.inc +243 -0
  56. data/lib/debase/ruby_core_source/version.rb +1 -1
  57. metadata +55 -3
@@ -0,0 +1,333 @@
1
+ #ifndef RUBY_EVAL_INTERN_H
2
+ #define RUBY_EVAL_INTERN_H
3
+
4
+ #include "ruby/ruby.h"
5
+ #include "vm_core.h"
6
+
7
+ static inline void
8
+ vm_passed_block_handler_set(rb_execution_context_t *ec, VALUE block_handler)
9
+ {
10
+ vm_block_handler_verify(block_handler);
11
+ ec->passed_block_handler = block_handler;
12
+ }
13
+
14
+ static inline void
15
+ pass_passed_block_handler(rb_execution_context_t *ec)
16
+ {
17
+ VALUE block_handler = rb_vm_frame_block_handler(ec->cfp);
18
+ vm_passed_block_handler_set(ec, block_handler);
19
+ VM_ENV_FLAGS_SET(ec->cfp->ep, VM_FRAME_FLAG_PASSED);
20
+ }
21
+
22
+ #define PASS_PASSED_BLOCK_HANDLER_EC(ec) pass_passed_block_handler(ec)
23
+ #define PASS_PASSED_BLOCK_HANDLER() pass_passed_block_handler(GET_EC())
24
+
25
+ #ifdef HAVE_STDLIB_H
26
+ #include <stdlib.h>
27
+ #endif
28
+ #ifndef EXIT_SUCCESS
29
+ #define EXIT_SUCCESS 0
30
+ #endif
31
+ #ifndef EXIT_FAILURE
32
+ #define EXIT_FAILURE 1
33
+ #endif
34
+
35
+ #include <stdio.h>
36
+ #include <setjmp.h>
37
+
38
+ #ifdef __APPLE__
39
+ # ifdef HAVE_CRT_EXTERNS_H
40
+ # include <crt_externs.h>
41
+ # else
42
+ # include "missing/crt_externs.h"
43
+ # endif
44
+ #endif
45
+
46
+ #ifndef HAVE_STRING_H
47
+ char *strrchr(const char *, const char);
48
+ #endif
49
+
50
+ #ifdef HAVE_UNISTD_H
51
+ #include <unistd.h>
52
+ #endif
53
+
54
+ #ifdef HAVE_NET_SOCKET_H
55
+ #include <net/socket.h>
56
+ #endif
57
+
58
+ #define ruby_setjmp(env) RUBY_SETJMP(env)
59
+ #define ruby_longjmp(env,val) RUBY_LONGJMP((env),(val))
60
+ #ifdef __CYGWIN__
61
+ # ifndef _setjmp
62
+ int _setjmp(jmp_buf);
63
+ # endif
64
+ # ifndef _longjmp
65
+ NORETURN(void _longjmp(jmp_buf, int));
66
+ # endif
67
+ #endif
68
+
69
+ #include <sys/types.h>
70
+ #include <signal.h>
71
+ #include <errno.h>
72
+
73
+ #ifdef HAVE_SYS_SELECT_H
74
+ #include <sys/select.h>
75
+ #endif
76
+
77
+ /*
78
+ Solaris sys/select.h switches select to select_large_fdset to support larger
79
+ file descriptors if FD_SETSIZE is larger than 1024 on 32bit environment.
80
+ But Ruby doesn't change FD_SETSIZE because fd_set is allocated dynamically.
81
+ So following definition is required to use select_large_fdset.
82
+ */
83
+ #ifdef HAVE_SELECT_LARGE_FDSET
84
+ #define select(n, r, w, e, t) select_large_fdset((n), (r), (w), (e), (t))
85
+ extern int select_large_fdset(int, fd_set *, fd_set *, fd_set *, struct timeval *);
86
+ #endif
87
+
88
+ #ifdef HAVE_SYS_PARAM_H
89
+ #include <sys/param.h>
90
+ #endif
91
+
92
+ #include <sys/stat.h>
93
+
94
+ #ifdef _MSC_VER
95
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT \
96
+ __try {
97
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT \
98
+ } \
99
+ __except (GetExceptionCode() == EXCEPTION_STACK_OVERFLOW ? \
100
+ (rb_ec_raised_set(GET_EC(), RAISED_STACKOVERFLOW), \
101
+ raise(SIGSEGV), \
102
+ EXCEPTION_EXECUTE_HANDLER) : \
103
+ EXCEPTION_CONTINUE_SEARCH) { \
104
+ /* never reaches here */ \
105
+ }
106
+ #elif defined(__MINGW32__)
107
+ LONG WINAPI rb_w32_stack_overflow_handler(struct _EXCEPTION_POINTERS *);
108
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT \
109
+ do { \
110
+ PVOID _handler = AddVectoredExceptionHandler(1, rb_w32_stack_overflow_handler);
111
+
112
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT \
113
+ RemoveVectoredExceptionHandler(_handler); \
114
+ } while (0);
115
+ #else
116
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT
117
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT
118
+ #endif
119
+
120
+ #define SAVE_ROOT_JMPBUF(th, stmt) do \
121
+ if (ruby_setjmp((th)->root_jmpbuf) == 0) { \
122
+ SAVE_ROOT_JMPBUF_BEFORE_STMT \
123
+ stmt; \
124
+ SAVE_ROOT_JMPBUF_AFTER_STMT \
125
+ } \
126
+ else { \
127
+ rb_fiber_start(); \
128
+ } while (0)
129
+
130
+ #define EC_PUSH_TAG(ec) do { \
131
+ rb_execution_context_t * const _ec = (ec); \
132
+ struct rb_vm_tag _tag; \
133
+ _tag.state = TAG_NONE; \
134
+ _tag.tag = Qundef; \
135
+ _tag.prev = _ec->tag;
136
+
137
+ #define EC_POP_TAG() \
138
+ _ec->tag = _tag.prev; \
139
+ } while (0)
140
+
141
+ #define EC_TMPPOP_TAG() \
142
+ _ec->tag = _tag.prev
143
+
144
+ #define EC_REPUSH_TAG() (void)(_ec->tag = &_tag)
145
+
146
+ #if defined __GNUC__ && __GNUC__ == 4 && (__GNUC_MINOR__ >= 6 && __GNUC_MINOR__ <= 8) || __clang__
147
+ /* This macro prevents GCC 4.6--4.8 from emitting maybe-uninitialized warnings.
148
+ * This macro also prevents Clang from dumping core in EC_EXEC_TAG().
149
+ * (I confirmed Clang 4.0.1 and 5.0.0.)
150
+ */
151
+ # define VAR_FROM_MEMORY(var) __extension__(*(__typeof__(var) volatile *)&(var))
152
+ # define VAR_INITIALIZED(var) ((var) = VAR_FROM_MEMORY(var))
153
+ # define VAR_NOCLOBBERED(var) volatile var
154
+ #else
155
+ # define VAR_FROM_MEMORY(var) (var)
156
+ # define VAR_INITIALIZED(var) ((void)&(var))
157
+ # define VAR_NOCLOBBERED(var) var
158
+ #endif
159
+
160
+ #if defined(USE_UNALIGNED_MEMBER_ACCESS) && USE_UNALIGNED_MEMBER_ACCESS && \
161
+ defined(__clang__)
162
+ # define UNALIGNED_MEMBER_ACCESS(expr) __extension__({ \
163
+ COMPILER_WARNING_PUSH; \
164
+ COMPILER_WARNING_IGNORED(-Waddress-of-packed-member); \
165
+ typeof(expr) unaligned_member_access_result = (expr); \
166
+ COMPILER_WARNING_POP; \
167
+ unaligned_member_access_result; \
168
+ })
169
+ #else
170
+ # define UNALIGNED_MEMBER_ACCESS(expr) expr
171
+ #endif
172
+ #define UNALIGNED_MEMBER_PTR(ptr, mem) UNALIGNED_MEMBER_ACCESS(&(ptr)->mem)
173
+
174
+ #undef RB_OBJ_WRITE
175
+ #define RB_OBJ_WRITE(a, slot, b) UNALIGNED_MEMBER_ACCESS(rb_obj_write((VALUE)(a), (VALUE *)(slot), (VALUE)(b), __FILE__, __LINE__))
176
+
177
+ /* clear ec->tag->state, and return the value */
178
+ static inline int
179
+ rb_ec_tag_state(const rb_execution_context_t *ec)
180
+ {
181
+ enum ruby_tag_type state = ec->tag->state;
182
+ ec->tag->state = TAG_NONE;
183
+ return state;
184
+ }
185
+
186
+ NORETURN(static inline void rb_ec_tag_jump(const rb_execution_context_t *ec, enum ruby_tag_type st));
187
+ static inline void
188
+ rb_ec_tag_jump(const rb_execution_context_t *ec, enum ruby_tag_type st)
189
+ {
190
+ ec->tag->state = st;
191
+ ruby_longjmp(ec->tag->buf, 1);
192
+ }
193
+
194
+ /*
195
+ setjmp() in assignment expression rhs is undefined behavior
196
+ [ISO/IEC 9899:1999] 7.13.1.1
197
+ */
198
+ #define EC_EXEC_TAG() \
199
+ (ruby_setjmp(_tag.buf) ? rb_ec_tag_state(VAR_FROM_MEMORY(_ec)) : (EC_REPUSH_TAG(), 0))
200
+
201
+ #define EC_JUMP_TAG(ec, st) rb_ec_tag_jump(ec, st)
202
+
203
+ #define INTERNAL_EXCEPTION_P(exc) FIXNUM_P(exc)
204
+
205
+ /* CREF operators */
206
+
207
+ #define CREF_FL_PUSHED_BY_EVAL IMEMO_FL_USER1
208
+ #define CREF_FL_OMOD_SHARED IMEMO_FL_USER2
209
+
210
+ static inline VALUE
211
+ CREF_CLASS(const rb_cref_t *cref)
212
+ {
213
+ return cref->klass;
214
+ }
215
+
216
+ static inline rb_cref_t *
217
+ CREF_NEXT(const rb_cref_t *cref)
218
+ {
219
+ return cref->next;
220
+ }
221
+
222
+ static inline const rb_scope_visibility_t *
223
+ CREF_SCOPE_VISI(const rb_cref_t *cref)
224
+ {
225
+ return &cref->scope_visi;
226
+ }
227
+
228
+ static inline VALUE
229
+ CREF_REFINEMENTS(const rb_cref_t *cref)
230
+ {
231
+ return cref->refinements;
232
+ }
233
+
234
+ static inline void
235
+ CREF_REFINEMENTS_SET(rb_cref_t *cref, VALUE refs)
236
+ {
237
+ RB_OBJ_WRITE(cref, &cref->refinements, refs);
238
+ }
239
+
240
+ static inline int
241
+ CREF_PUSHED_BY_EVAL(const rb_cref_t *cref)
242
+ {
243
+ return cref->flags & CREF_FL_PUSHED_BY_EVAL;
244
+ }
245
+
246
+ static inline void
247
+ CREF_PUSHED_BY_EVAL_SET(rb_cref_t *cref)
248
+ {
249
+ cref->flags |= CREF_FL_PUSHED_BY_EVAL;
250
+ }
251
+
252
+ static inline int
253
+ CREF_OMOD_SHARED(const rb_cref_t *cref)
254
+ {
255
+ return cref->flags & CREF_FL_OMOD_SHARED;
256
+ }
257
+
258
+ static inline void
259
+ CREF_OMOD_SHARED_SET(rb_cref_t *cref)
260
+ {
261
+ cref->flags |= CREF_FL_OMOD_SHARED;
262
+ }
263
+
264
+ static inline void
265
+ CREF_OMOD_SHARED_UNSET(rb_cref_t *cref)
266
+ {
267
+ cref->flags &= ~CREF_FL_OMOD_SHARED;
268
+ }
269
+
270
+ void rb_thread_cleanup(void);
271
+ void rb_thread_wait_other_threads(void);
272
+
273
+ enum {
274
+ RAISED_EXCEPTION = 1,
275
+ RAISED_STACKOVERFLOW = 2,
276
+ RAISED_NOMEMORY = 4
277
+ };
278
+ #define rb_ec_raised_set(ec, f) ((ec)->raised_flag |= (f))
279
+ #define rb_ec_raised_reset(ec, f) ((ec)->raised_flag &= ~(f))
280
+ #define rb_ec_raised_p(ec, f) (((ec)->raised_flag & (f)) != 0)
281
+ #define rb_ec_raised_clear(ec) ((ec)->raised_flag = 0)
282
+ int rb_ec_set_raised(rb_execution_context_t *ec);
283
+ int rb_ec_reset_raised(rb_execution_context_t *ec);
284
+ int rb_ec_stack_check(rb_execution_context_t *ec);
285
+
286
+ VALUE rb_f_eval(int argc, const VALUE *argv, VALUE self);
287
+ VALUE rb_make_exception(int argc, const VALUE *argv);
288
+
289
+ NORETURN(void rb_method_name_error(VALUE, VALUE));
290
+
291
+ NORETURN(void rb_fiber_start(void));
292
+
293
+ NORETURN(void rb_print_undef(VALUE, ID, rb_method_visibility_t));
294
+ NORETURN(void rb_print_undef_str(VALUE, VALUE));
295
+ NORETURN(void rb_print_inaccessible(VALUE, ID, rb_method_visibility_t));
296
+ NORETURN(void rb_vm_localjump_error(const char *,VALUE, int));
297
+ #if 0
298
+ NORETURN(void rb_vm_jump_tag_but_local_jump(int));
299
+ #endif
300
+
301
+ VALUE rb_vm_make_jump_tag_but_local_jump(int state, VALUE val);
302
+ rb_cref_t *rb_vm_cref(void);
303
+ rb_cref_t *rb_vm_cref_replace_with_duplicated_cref(void);
304
+ VALUE rb_vm_call_cfunc(VALUE recv, VALUE (*func)(VALUE), VALUE arg, VALUE block_handler, VALUE filename);
305
+ void rb_vm_set_progname(VALUE filename);
306
+ void rb_thread_terminate_all(void);
307
+ VALUE rb_vm_cbase(void);
308
+
309
+ /* vm_backtrace.c */
310
+ VALUE rb_ec_backtrace_object(const rb_execution_context_t *ec);
311
+ VALUE rb_ec_backtrace_str_ary(const rb_execution_context_t *ec, long lev, long n);
312
+
313
+ #ifndef CharNext /* defined as CharNext[AW] on Windows. */
314
+ # ifdef HAVE_MBLEN
315
+ # define CharNext(p) ((p) + mblen((p), RUBY_MBCHAR_MAXSIZE))
316
+ # else
317
+ # define CharNext(p) ((p) + 1)
318
+ # endif
319
+ #endif
320
+
321
+ #if defined DOSISH || defined __CYGWIN__
322
+ static inline void
323
+ translit_char(char *p, int from, int to)
324
+ {
325
+ while (*p) {
326
+ if ((unsigned char)*p == from)
327
+ *p = to;
328
+ p = CharNext(p);
329
+ }
330
+ }
331
+ #endif
332
+
333
+ #endif /* RUBY_EVAL_INTERN_H */
@@ -0,0 +1,116 @@
1
+
2
+ #ifndef RUBY_GC_H
3
+ #define RUBY_GC_H 1
4
+
5
+ #if defined(__x86_64__) && !defined(_ILP32) && defined(__GNUC__)
6
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movq\t%%rsp, %0" : "=r" (*(p)))
7
+ #elif defined(__i386) && defined(__GNUC__)
8
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movl\t%%esp, %0" : "=r" (*(p)))
9
+ #else
10
+ NOINLINE(void rb_gc_set_stack_end(VALUE **stack_end_p));
11
+ #define SET_MACHINE_STACK_END(p) rb_gc_set_stack_end(p)
12
+ #define USE_CONSERVATIVE_STACK_END
13
+ #endif
14
+
15
+ /* for GC debug */
16
+
17
+ #ifndef RUBY_MARK_FREE_DEBUG
18
+ #define RUBY_MARK_FREE_DEBUG 0
19
+ #endif
20
+
21
+ #if RUBY_MARK_FREE_DEBUG
22
+ extern int ruby_gc_debug_indent;
23
+
24
+ static inline void
25
+ rb_gc_debug_indent(void)
26
+ {
27
+ printf("%*s", ruby_gc_debug_indent, "");
28
+ }
29
+
30
+ static inline void
31
+ rb_gc_debug_body(const char *mode, const char *msg, int st, void *ptr)
32
+ {
33
+ if (st == 0) {
34
+ ruby_gc_debug_indent--;
35
+ }
36
+ rb_gc_debug_indent();
37
+ printf("%s: %s %s (%p)\n", mode, st ? "->" : "<-", msg, ptr);
38
+
39
+ if (st) {
40
+ ruby_gc_debug_indent++;
41
+ }
42
+
43
+ fflush(stdout);
44
+ }
45
+
46
+ #define RUBY_MARK_ENTER(msg) rb_gc_debug_body("mark", (msg), 1, ptr)
47
+ #define RUBY_MARK_LEAVE(msg) rb_gc_debug_body("mark", (msg), 0, ptr)
48
+ #define RUBY_FREE_ENTER(msg) rb_gc_debug_body("free", (msg), 1, ptr)
49
+ #define RUBY_FREE_LEAVE(msg) rb_gc_debug_body("free", (msg), 0, ptr)
50
+ #define RUBY_GC_INFO rb_gc_debug_indent(); printf
51
+
52
+ #else
53
+ #define RUBY_MARK_ENTER(msg)
54
+ #define RUBY_MARK_LEAVE(msg)
55
+ #define RUBY_FREE_ENTER(msg)
56
+ #define RUBY_FREE_LEAVE(msg)
57
+ #define RUBY_GC_INFO if(0)printf
58
+ #endif
59
+
60
+ #define RUBY_MARK_UNLESS_NULL(ptr) do { \
61
+ VALUE markobj = (ptr); \
62
+ if (RTEST(markobj)) {rb_gc_mark(markobj);} \
63
+ } while (0)
64
+ #define RUBY_FREE_UNLESS_NULL(ptr) if(ptr){ruby_xfree(ptr);(ptr)=NULL;}
65
+
66
+ #if STACK_GROW_DIRECTION > 0
67
+ # define STACK_UPPER(x, a, b) (a)
68
+ #elif STACK_GROW_DIRECTION < 0
69
+ # define STACK_UPPER(x, a, b) (b)
70
+ #else
71
+ RUBY_EXTERN int ruby_stack_grow_direction;
72
+ int ruby_get_stack_grow_direction(volatile VALUE *addr);
73
+ # define stack_growup_p(x) ( \
74
+ (ruby_stack_grow_direction ? \
75
+ ruby_stack_grow_direction : \
76
+ ruby_get_stack_grow_direction(x)) > 0)
77
+ # define STACK_UPPER(x, a, b) (stack_growup_p(x) ? (a) : (b))
78
+ #endif
79
+
80
+ #if STACK_GROW_DIRECTION
81
+ #define STACK_GROW_DIR_DETECTION
82
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(0, (a), (b))
83
+ #else
84
+ #define STACK_GROW_DIR_DETECTION VALUE stack_grow_dir_detection
85
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(&stack_grow_dir_detection, (a), (b))
86
+ #endif
87
+ #define IS_STACK_DIR_UPPER() STACK_DIR_UPPER(1,0)
88
+
89
+ const char *rb_obj_info(VALUE obj);
90
+ const char *rb_raw_obj_info(char *buff, const int buff_size, VALUE obj);
91
+ void rb_obj_info_dump(VALUE obj);
92
+
93
+ struct rb_thread_struct;
94
+
95
+ RUBY_SYMBOL_EXPORT_BEGIN
96
+
97
+ /* exports for objspace module */
98
+ size_t rb_objspace_data_type_memsize(VALUE obj);
99
+ void rb_objspace_reachable_objects_from(VALUE obj, void (func)(VALUE, void *), void *data);
100
+ void rb_objspace_reachable_objects_from_root(void (func)(const char *category, VALUE, void *), void *data);
101
+ int rb_objspace_markable_object_p(VALUE obj);
102
+ int rb_objspace_internal_object_p(VALUE obj);
103
+ int rb_objspace_marked_object_p(VALUE obj);
104
+ int rb_objspace_garbage_object_p(VALUE obj);
105
+
106
+ void rb_objspace_each_objects(
107
+ int (*callback)(void *start, void *end, size_t stride, void *data),
108
+ void *data);
109
+
110
+ void rb_objspace_each_objects_without_setup(
111
+ int (*callback)(void *, void *, size_t, void *),
112
+ void *data);
113
+
114
+ RUBY_SYMBOL_EXPORT_END
115
+
116
+ #endif /* RUBY_GC_H */
@@ -0,0 +1,168 @@
1
+ #ifndef RB_HRTIME_H
2
+ #define RB_HRTIME_H
3
+ #include "ruby/ruby.h"
4
+ #include <time.h>
5
+ #if defined(HAVE_SYS_TIME_H)
6
+ # include <sys/time.h>
7
+ #endif
8
+
9
+ /*
10
+ * Hi-res monotonic clock. It is currently nsec resolution, which has over
11
+ * 500 years of range (with an unsigned 64-bit integer). Developers
12
+ * targeting small systems may try 32-bit and low-resolution (milliseconds).
13
+ *
14
+ * TBD: Is nsec even necessary? usec resolution seems enough for userspace
15
+ * and it'll be suitable for use with devices lasting over 500,000 years
16
+ * (maybe some devices designed for long-term space travel)
17
+ *
18
+ * Current API:
19
+ *
20
+ * * rb_hrtime_now - current clock value (monotonic if available)
21
+ * * rb_hrtime_mul - multiply with overflow check
22
+ * * rb_hrtime_add - add with overflow check
23
+ * * rb_timeval2hrtime - convert from timeval
24
+ * * rb_timespec2hrtime - convert from timespec
25
+ * * rb_msec2hrtime - convert from millisecond
26
+ * * rb_sec2hrtime - convert from time_t (seconds)
27
+ * * rb_hrtime2timeval - convert to timeval
28
+ * * rb_hrtime2timespec - convert to timespec
29
+ *
30
+ * Note: no conversion to milliseconds is provided here because different
31
+ * functions have different limits (e.g. epoll_wait vs w32_wait_events).
32
+ * So we provide RB_HRTIME_PER_MSEC and similar macros for implementing
33
+ * this for each use case.
34
+ */
35
+ #define RB_HRTIME_PER_USEC ((rb_hrtime_t)1000)
36
+ #define RB_HRTIME_PER_MSEC (RB_HRTIME_PER_USEC * (rb_hrtime_t)1000)
37
+ #define RB_HRTIME_PER_SEC (RB_HRTIME_PER_MSEC * (rb_hrtime_t)1000)
38
+ #define RB_HRTIME_MAX UINT64_MAX
39
+
40
+ /*
41
+ * Lets try to support time travelers. Lets assume anybody with a time machine
42
+ * also has access to a modern gcc or clang with 128-bit int support
43
+ */
44
+ #ifdef MY_RUBY_BUILD_MAY_TIME_TRAVEL
45
+ typedef int128_t rb_hrtime_t;
46
+ #else
47
+ typedef uint64_t rb_hrtime_t;
48
+ #endif
49
+
50
+ /* thread.c */
51
+ /* returns the value of the monotonic clock (if available) */
52
+ rb_hrtime_t rb_hrtime_now(void);
53
+
54
+ /*
55
+ * multiply @a and @b with overflow check and return the
56
+ * (clamped to RB_HRTIME_MAX) result.
57
+ */
58
+ static inline rb_hrtime_t
59
+ rb_hrtime_mul(rb_hrtime_t a, rb_hrtime_t b)
60
+ {
61
+ rb_hrtime_t c;
62
+
63
+ #ifdef HAVE_BUILTIN___BUILTIN_MUL_OVERFLOW
64
+ if (__builtin_mul_overflow(a, b, &c))
65
+ return RB_HRTIME_MAX;
66
+ #else
67
+ if (b != 0 && a > RB_HRTIME_MAX / b) /* overflow */
68
+ return RB_HRTIME_MAX;
69
+ c = a * b;
70
+ #endif
71
+ return c;
72
+ }
73
+
74
+ /*
75
+ * add @a and @b with overflow check and return the
76
+ * (clamped to RB_HRTIME_MAX) result.
77
+ */
78
+ static inline rb_hrtime_t
79
+ rb_hrtime_add(rb_hrtime_t a, rb_hrtime_t b)
80
+ {
81
+ rb_hrtime_t c;
82
+
83
+ #ifdef HAVE_BUILTIN___BUILTIN_ADD_OVERFLOW
84
+ if (__builtin_add_overflow(a, b, &c))
85
+ return RB_HRTIME_MAX;
86
+ #else
87
+ c = a + b;
88
+ if (c < a) /* overflow */
89
+ return RB_HRTIME_MAX;
90
+ #endif
91
+ return c;
92
+ }
93
+
94
+ /*
95
+ * convert a timeval struct to rb_hrtime_t, clamping at RB_HRTIME_MAX
96
+ */
97
+ static inline rb_hrtime_t
98
+ rb_timeval2hrtime(const struct timeval *tv)
99
+ {
100
+ rb_hrtime_t s = rb_hrtime_mul((rb_hrtime_t)tv->tv_sec, RB_HRTIME_PER_SEC);
101
+ rb_hrtime_t u = rb_hrtime_mul((rb_hrtime_t)tv->tv_usec, RB_HRTIME_PER_USEC);
102
+
103
+ return rb_hrtime_add(s, u);
104
+ }
105
+
106
+ /*
107
+ * convert a timespec struct to rb_hrtime_t, clamping at RB_HRTIME_MAX
108
+ */
109
+ static inline rb_hrtime_t
110
+ rb_timespec2hrtime(const struct timespec *ts)
111
+ {
112
+ rb_hrtime_t s = rb_hrtime_mul((rb_hrtime_t)ts->tv_sec, RB_HRTIME_PER_SEC);
113
+
114
+ return rb_hrtime_add(s, (rb_hrtime_t)ts->tv_nsec);
115
+ }
116
+
117
+ /*
118
+ * convert a millisecond value to rb_hrtime_t, clamping at RB_HRTIME_MAX
119
+ */
120
+ static inline rb_hrtime_t
121
+ rb_msec2hrtime(unsigned long msec)
122
+ {
123
+ return rb_hrtime_mul((rb_hrtime_t)msec, RB_HRTIME_PER_MSEC);
124
+ }
125
+
126
+ /*
127
+ * convert a time_t value to rb_hrtime_t, clamping at RB_HRTIME_MAX
128
+ * Negative values will be clamped at 0.
129
+ */
130
+ static inline rb_hrtime_t
131
+ rb_sec2hrtime(time_t sec)
132
+ {
133
+ if (sec <= 0) return 0;
134
+
135
+ return rb_hrtime_mul((rb_hrtime_t)sec, RB_HRTIME_PER_SEC);
136
+ }
137
+
138
+ /*
139
+ * convert a rb_hrtime_t value to a timespec, suitable for calling
140
+ * functions like ppoll(2) or kevent(2)
141
+ */
142
+ static inline struct timespec *
143
+ rb_hrtime2timespec(struct timespec *ts, const rb_hrtime_t *hrt)
144
+ {
145
+ if (hrt) {
146
+ ts->tv_sec = (time_t)(*hrt / RB_HRTIME_PER_SEC);
147
+ ts->tv_nsec = (int32_t)(*hrt % RB_HRTIME_PER_SEC);
148
+ return ts;
149
+ }
150
+ return 0;
151
+ }
152
+
153
+ /*
154
+ * convert a rb_hrtime_t value to a timeval, suitable for calling
155
+ * functions like select(2)
156
+ */
157
+ static inline struct timeval *
158
+ rb_hrtime2timeval(struct timeval *tv, const rb_hrtime_t *hrt)
159
+ {
160
+ if (hrt) {
161
+ tv->tv_sec = (time_t)(*hrt / RB_HRTIME_PER_SEC);
162
+ tv->tv_usec = (int32_t)((*hrt % RB_HRTIME_PER_SEC)/RB_HRTIME_PER_USEC);
163
+
164
+ return tv;
165
+ }
166
+ return 0;
167
+ }
168
+ #endif /* RB_HRTIME_H */