mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
vm_core.h: vm_thread_with_frame
* vm_core.h (vm_thread_with_frame): skip function call in GET_THREAD which is empty unless OPT_CALL_CFUNC_WITHOUT_FRAME is enabled. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52040 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
8b4cf7b708
commit
37ab3ed99d
1 changed files with 7 additions and 5 deletions
12
vm_core.h
12
vm_core.h
|
@ -1061,18 +1061,20 @@ extern rb_event_flag_t ruby_vm_event_flags;
|
|||
#define OPT_CALL_CFUNC_WITHOUT_FRAME 0
|
||||
#endif
|
||||
|
||||
static inline rb_thread_t *
|
||||
GET_THREAD(void)
|
||||
{
|
||||
rb_thread_t *th = ruby_current_thread;
|
||||
#define GET_THREAD() vm_thread_with_frame(ruby_current_thread)
|
||||
#if OPT_CALL_CFUNC_WITHOUT_FRAME
|
||||
static inline rb_thread_t *
|
||||
vm_thread_with_frame(rb_thread_t *th)
|
||||
{
|
||||
if (UNLIKELY(th->passed_ci != 0)) {
|
||||
void rb_vm_call_cfunc_push_frame(rb_thread_t *th);
|
||||
rb_vm_call_cfunc_push_frame(th);
|
||||
}
|
||||
#endif
|
||||
return th;
|
||||
}
|
||||
#else
|
||||
#define vm_thread_with_frame(th) (th)
|
||||
#endif
|
||||
|
||||
#define rb_thread_set_current_raw(th) (void)(ruby_current_thread = (th))
|
||||
#define rb_thread_set_current(th) do { \
|
||||
|
|
Loading…
Add table
Reference in a new issue