mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
_mjit_compile_send.erb: do not inline tailcall ISeq
because it's not supported by this file. Also, shared `def_iseq_ptr` instead of copying the main definition of it. vm_core.h: moved `def_iseq_ptr` to this place. added `inline` to avoid compiler warnings since it's not used in some files including vm_core.h. vm_insnhelper.c: moved `def_iseq_ptr` to vm_core.h. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@65440 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
fae6c6bfd8
commit
51a0f04e6b
3 changed files with 11 additions and 10 deletions
|
@ -23,7 +23,8 @@
|
||||||
argc += ((ci->flag & VM_CALL_ARGS_BLOCKARG) ? 1 : 0);
|
argc += ((ci->flag & VM_CALL_ARGS_BLOCKARG) ? 1 : 0);
|
||||||
% end
|
% end
|
||||||
|
|
||||||
if (cc_copy->me->def->type == VM_METHOD_TYPE_ISEQ && inlinable_iseq_p(ci, cc_copy, iseq = rb_iseq_check(cc_copy->me->def->body.iseq.iseqptr))) { /* CC_SET_FASTPATH in vm_callee_setup_arg */
|
if (!(ci->flag & VM_CALL_TAILCALL) && /* inlining non-tailcall path */
|
||||||
|
cc_copy->me->def->type == VM_METHOD_TYPE_ISEQ && inlinable_iseq_p(ci, cc_copy, iseq = def_iseq_ptr(cc_copy->me->def)) /* CC_SET_FASTPATH in vm_callee_setup_arg */) {
|
||||||
int param_size = iseq->body->param.size; /* TODO: check calling->argc for argument_arity_error */
|
int param_size = iseq->body->param.size; /* TODO: check calling->argc for argument_arity_error */
|
||||||
|
|
||||||
fprintf(f, "{\n");
|
fprintf(f, "{\n");
|
||||||
|
|
|
@ -507,6 +507,15 @@ rb_iseq_check(const rb_iseq_t *iseq)
|
||||||
return iseq;
|
return iseq;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline const rb_iseq_t *
|
||||||
|
def_iseq_ptr(rb_method_definition_t *def)
|
||||||
|
{
|
||||||
|
#if VM_CHECK_MODE > 0
|
||||||
|
if (def->type != VM_METHOD_TYPE_ISEQ) rb_bug("def_iseq_ptr: not iseq (%d)", def->type);
|
||||||
|
#endif
|
||||||
|
return rb_iseq_check(def->body.iseq.iseqptr);
|
||||||
|
}
|
||||||
|
|
||||||
enum ruby_special_exceptions {
|
enum ruby_special_exceptions {
|
||||||
ruby_error_reenter,
|
ruby_error_reenter,
|
||||||
ruby_error_nomemory,
|
ruby_error_nomemory,
|
||||||
|
|
|
@ -1590,15 +1590,6 @@ static inline VALUE vm_call_method(rb_execution_context_t *ec, rb_control_frame_
|
||||||
|
|
||||||
static vm_call_handler vm_call_iseq_setup_func(const struct rb_call_info *ci, const int param_size, const int local_size);
|
static vm_call_handler vm_call_iseq_setup_func(const struct rb_call_info *ci, const int param_size, const int local_size);
|
||||||
|
|
||||||
static const rb_iseq_t *
|
|
||||||
def_iseq_ptr(rb_method_definition_t *def)
|
|
||||||
{
|
|
||||||
#if VM_CHECK_MODE > 0
|
|
||||||
if (def->type != VM_METHOD_TYPE_ISEQ) rb_bug("def_iseq_ptr: not iseq (%d)", def->type);
|
|
||||||
#endif
|
|
||||||
return rb_iseq_check(def->body.iseq.iseqptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
vm_call_iseq_setup_tailcall_0start(rb_execution_context_t *ec, rb_control_frame_t *cfp, struct rb_calling_info *calling, const struct rb_call_info *ci, struct rb_call_cache *cc)
|
vm_call_iseq_setup_tailcall_0start(rb_execution_context_t *ec, rb_control_frame_t *cfp, struct rb_calling_info *calling, const struct rb_call_info *ci, struct rb_call_cache *cc)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue