Add two new instructions for forwarding calls

This commit adds `sendforward` and `invokesuperforward` for forwarding
parameters to calls

Co-authored-by: Matt Valentine-House <matt@eightbitraptor.com>
This commit is contained in:
Aaron Patterson 2024-06-03 14:20:04 -07:00 committed by Aaron Patterson
parent a25dd5b12c
commit cc97a27008
7 changed files with 301 additions and 206 deletions

View File

@ -1465,7 +1465,16 @@ new_insn_send(rb_iseq_t *iseq, int line_no, int node_id, ID id, VALUE argc, cons
if (blockiseq) { if (blockiseq) {
RB_OBJ_WRITTEN(iseq, Qundef, blockiseq); RB_OBJ_WRITTEN(iseq, Qundef, blockiseq);
} }
INSN *insn = new_insn_core(iseq, line_no, node_id, BIN(send), 2, operands);
INSN *insn;
if (vm_ci_flag((struct rb_callinfo *)ci) & VM_CALL_FORWARDING) {
insn = new_insn_core(iseq, line_no, node_id, BIN(sendforward), 2, operands);
}
else {
insn = new_insn_core(iseq, line_no, node_id, BIN(send), 2, operands);
}
RB_OBJ_WRITTEN(iseq, Qundef, ci); RB_OBJ_WRITTEN(iseq, Qundef, ci);
RB_GC_GUARD(ci); RB_GC_GUARD(ci);
return insn; return insn;
@ -8009,7 +8018,7 @@ compile_iter(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *const node, in
INSN *iobj; INSN *iobj;
LINK_ELEMENT *last_elem = LAST_ELEMENT(ret); LINK_ELEMENT *last_elem = LAST_ELEMENT(ret);
iobj = IS_INSN(last_elem) ? (INSN*) last_elem : (INSN*) get_prev_insn((INSN*) last_elem); iobj = IS_INSN(last_elem) ? (INSN*) last_elem : (INSN*) get_prev_insn((INSN*) last_elem);
while (INSN_OF(iobj) != BIN(send) && INSN_OF(iobj) != BIN(invokesuper)) { while (!IS_INSN_ID(iobj, send) && !IS_INSN_ID(iobj, invokesuper) && !IS_INSN_ID(iobj, sendforward) && !IS_INSN_ID(iobj, invokesuperforward)) {
iobj = (INSN*) get_prev_insn(iobj); iobj = (INSN*) get_prev_insn(iobj);
} }
ELEM_INSERT_NEXT(&iobj->link, (LINK_ELEMENT*) retry_end_l); ELEM_INSERT_NEXT(&iobj->link, (LINK_ELEMENT*) retry_end_l);
@ -9607,9 +9616,15 @@ compile_super(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *const node, i
if (type == NODE_ZSUPER) flag |= VM_CALL_ZSUPER; if (type == NODE_ZSUPER) flag |= VM_CALL_ZSUPER;
ADD_INSN(ret, node, putself); ADD_INSN(ret, node, putself);
ADD_SEQ(ret, args); ADD_SEQ(ret, args);
ADD_INSN2(ret, node, invokesuper,
new_callinfo(iseq, 0, argc, flag, keywords, parent_block != NULL), const struct rb_callinfo * ci = new_callinfo(iseq, 0, argc, flag, keywords, parent_block != NULL);
parent_block);
if (vm_ci_flag(ci) & VM_CALL_FORWARDING) {
ADD_INSN2(ret, node, invokesuperforward, ci, parent_block);
}
else {
ADD_INSN2(ret, node, invokesuper, ci, parent_block);
}
if (popped) { if (popped) {
ADD_INSN(ret, node, pop); ADD_INSN(ret, node, pop);

View File

@ -866,22 +866,39 @@ send
(VALUE val) (VALUE val)
// attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci); // attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci);
// attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci); // attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci);
{
VALUE bh = vm_caller_setup_arg_block(ec, GET_CFP(), cd->ci, blockiseq, false);
val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_method);
JIT_EXEC(ec, val);
if (UNDEF_P(val)) {
RESTORE_REGS();
NEXT_INSN();
}
}
/* invoke forward method. */
DEFINE_INSN
sendforward
(CALL_DATA cd, ISEQ blockiseq)
(...)
(VALUE val)
// attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci);
// attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci);
{ {
struct rb_forwarding_call_data adjusted_cd; struct rb_forwarding_call_data adjusted_cd;
struct rb_callinfo adjusted_ci; struct rb_callinfo adjusted_ci;
CALL_DATA _cd = cd; CALL_DATA _cd = cd;
VALUE bh = vm_caller_setup_args(GET_EC(), GET_CFP(), &cd, blockiseq, 0, &adjusted_cd, &adjusted_ci); VALUE bh = vm_caller_setup_fwd_args(GET_EC(), GET_CFP(), &cd, blockiseq, 0, &adjusted_cd, &adjusted_ci);
val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_method); val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_method);
JIT_EXEC(ec, val); JIT_EXEC(ec, val);
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {
if (_cd->cc != cd->cc && vm_cc_markable(cd->cc)) { if (_cd->cc != cd->cc && vm_cc_markable(cd->cc)) {
RB_OBJ_WRITE(GET_ISEQ(), &_cd->cc, cd->cc); RB_OBJ_WRITE(GET_ISEQ(), &_cd->cc, cd->cc);
} }
}
if (UNDEF_P(val)) { if (UNDEF_P(val)) {
RESTORE_REGS(); RESTORE_REGS();
@ -1005,21 +1022,38 @@ invokesuper
(VALUE val) (VALUE val)
// attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci); // attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci);
// attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci); // attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci);
{
VALUE bh = vm_caller_setup_arg_block(ec, GET_CFP(), cd->ci, blockiseq, true);
val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_super);
JIT_EXEC(ec, val);
if (UNDEF_P(val)) {
RESTORE_REGS();
NEXT_INSN();
}
}
/* super(args) # args.size => num */
DEFINE_INSN
invokesuperforward
(CALL_DATA cd, ISEQ blockiseq)
(...)
(VALUE val)
// attr rb_snum_t sp_inc = sp_inc_of_sendish(cd->ci);
// attr rb_snum_t comptime_sp_inc = sp_inc_of_sendish(ci);
{ {
CALL_DATA _cd = cd; CALL_DATA _cd = cd;
struct rb_forwarding_call_data adjusted_cd; struct rb_forwarding_call_data adjusted_cd;
struct rb_callinfo adjusted_ci; struct rb_callinfo adjusted_ci;
VALUE bh = vm_caller_setup_args(GET_EC(), GET_CFP(), &cd, blockiseq, 1, &adjusted_cd, &adjusted_ci); VALUE bh = vm_caller_setup_fwd_args(GET_EC(), GET_CFP(), &cd, blockiseq, 1, &adjusted_cd, &adjusted_ci);
val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_super); val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_super);
JIT_EXEC(ec, val); JIT_EXEC(ec, val);
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {
if (_cd->cc != cd->cc && vm_cc_markable(cd->cc)) { if (_cd->cc != cd->cc && vm_cc_markable(cd->cc)) {
RB_OBJ_WRITE(GET_ISEQ(), &_cd->cc, cd->cc); RB_OBJ_WRITE(GET_ISEQ(), &_cd->cc, cd->cc);
} }
}
if (UNDEF_P(val)) { if (UNDEF_P(val)) {
RESTORE_REGS(); RESTORE_REGS();

View File

@ -2990,7 +2990,7 @@ pm_compile_retry_end_label(rb_iseq_t *iseq, LINK_ANCHOR *const ret, LABEL *retry
INSN *iobj; INSN *iobj;
LINK_ELEMENT *last_elem = LAST_ELEMENT(ret); LINK_ELEMENT *last_elem = LAST_ELEMENT(ret);
iobj = IS_INSN(last_elem) ? (INSN*) last_elem : (INSN*) get_prev_insn((INSN*) last_elem); iobj = IS_INSN(last_elem) ? (INSN*) last_elem : (INSN*) get_prev_insn((INSN*) last_elem);
while (INSN_OF(iobj) != BIN(send) && INSN_OF(iobj) != BIN(invokesuper)) { while (!IS_INSN_ID(iobj, send) && !IS_INSN_ID(iobj, invokesuper) && !IS_INSN_ID(iobj, sendforward) && !IS_INSN_ID(iobj, invokesuperforward)) {
iobj = (INSN*) get_prev_insn(iobj); iobj = (INSN*) get_prev_insn(iobj);
} }
ELEM_INSERT_NEXT(&iobj->link, (LINK_ELEMENT*) retry_end_l); ELEM_INSERT_NEXT(&iobj->link, (LINK_ELEMENT*) retry_end_l);
@ -6707,7 +6707,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
flag |= VM_CALL_FORWARDING; flag |= VM_CALL_FORWARDING;
pm_local_index_t mult_local = pm_lookup_local_index(iseq, scope_node, PM_CONSTANT_DOT3, 0); pm_local_index_t mult_local = pm_lookup_local_index(iseq, scope_node, PM_CONSTANT_DOT3, 0);
PUSH_GETLOCAL(ret, location, mult_local.index, mult_local.level); PUSH_GETLOCAL(ret, location, mult_local.index, mult_local.level);
PUSH_INSN2(ret, location, invokesuper, new_callinfo(iseq, 0, 0, flag, NULL, block != NULL), block); PUSH_INSN2(ret, location, invokesuperforward, new_callinfo(iseq, 0, 0, flag, NULL, block != NULL), block);
if (popped) PUSH_INSN(ret, location, pop); if (popped) PUSH_INSN(ret, location, pop);
return; return;
} }
@ -9277,8 +9277,14 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
} }
PUSH_SEQ(ret, args); PUSH_SEQ(ret, args);
if (ISEQ_BODY(ISEQ_BODY(iseq)->local_iseq)->param.flags.forwardable) {
flags |= VM_CALL_FORWARDING;
PUSH_INSN2(ret, location, invokesuperforward, new_callinfo(iseq, 0, argc, flags, keywords, current_block != NULL), current_block);
}
else {
PUSH_INSN2(ret, location, invokesuper, new_callinfo(iseq, 0, argc, flags, keywords, current_block != NULL), current_block); PUSH_INSN2(ret, location, invokesuper, new_callinfo(iseq, 0, argc, flags, keywords, current_block != NULL), current_block);
pm_compile_retry_end_label(iseq, ret, retry_end_l); pm_compile_retry_end_label(iseq, ret, retry_end_l);
}
if (popped) PUSH_INSN(ret, location, pop); if (popped) PUSH_INSN(ret, location, pop);
ISEQ_COMPILE_DATA(iseq)->current_block = previous_block; ISEQ_COMPILE_DATA(iseq)->current_block = previous_block;

View File

@ -1061,14 +1061,13 @@ vm_caller_setup_arg_block(const rb_execution_context_t *ec, rb_control_frame_t *
static void vm_adjust_stack_forwarding(const struct rb_execution_context_struct *ec, struct rb_control_frame_struct *cfp, CALL_INFO callers_info, VALUE splat); static void vm_adjust_stack_forwarding(const struct rb_execution_context_struct *ec, struct rb_control_frame_struct *cfp, CALL_INFO callers_info, VALUE splat);
static VALUE static VALUE
vm_caller_setup_args(const rb_execution_context_t *ec, rb_control_frame_t *reg_cfp, vm_caller_setup_fwd_args(const rb_execution_context_t *ec, rb_control_frame_t *reg_cfp,
CALL_DATA *cd, const rb_iseq_t *blockiseq, const int is_super, CALL_DATA *cd, const rb_iseq_t *blockiseq, const int is_super,
struct rb_forwarding_call_data *adjusted_cd, struct rb_callinfo *adjusted_ci) struct rb_forwarding_call_data *adjusted_cd, struct rb_callinfo *adjusted_ci)
{ {
CALL_INFO site_ci = (*cd)->ci; CALL_INFO site_ci = (*cd)->ci;
VALUE bh = Qundef; VALUE bh = Qundef;
if (vm_ci_flag(site_ci) & VM_CALL_FORWARDING) {
RUBY_ASSERT(ISEQ_BODY(ISEQ_BODY(GET_ISEQ())->local_iseq)->param.flags.forwardable); RUBY_ASSERT(ISEQ_BODY(ISEQ_BODY(GET_ISEQ())->local_iseq)->param.flags.forwardable);
CALL_INFO caller_ci = (CALL_INFO)TOPN(0); CALL_INFO caller_ci = (CALL_INFO)TOPN(0);
@ -1103,10 +1102,13 @@ vm_caller_setup_args(const rb_execution_context_t *ec, rb_control_frame_t *reg_c
adjusted_cd->caller_ci = caller_ci; adjusted_cd->caller_ci = caller_ci;
*cd = &adjusted_cd->cd; *cd = &adjusted_cd->cd;
}
else {
bh = vm_caller_setup_arg_block(ec, GET_CFP(), site_ci, blockiseq, is_super);
}
return bh; return bh;
} }
static VALUE
vm_caller_setup_args(const rb_execution_context_t *ec, rb_control_frame_t *reg_cfp,
CALL_DATA *cd, const rb_iseq_t *blockiseq, const int is_super)
{
return vm_caller_setup_arg_block(ec, GET_CFP(), (*cd)->ci, blockiseq, is_super);
}

View File

@ -5929,7 +5929,15 @@ rb_vm_send(rb_execution_context_t *ec, rb_control_frame_t *reg_cfp, CALL_DATA cd
struct rb_callinfo adjusted_ci; struct rb_callinfo adjusted_ci;
CALL_DATA _cd = cd; CALL_DATA _cd = cd;
VALUE bh = vm_caller_setup_args(ec, GET_CFP(), &cd, blockiseq, false, &adjusted_cd, &adjusted_ci); VALUE bh;
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {
bh = vm_caller_setup_fwd_args(GET_EC(), GET_CFP(), &cd, blockiseq, false, &adjusted_cd, &adjusted_ci);
}
else {
bh = vm_caller_setup_args(ec, GET_CFP(), &cd, blockiseq, false);
}
VALUE val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_method); VALUE val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_method);
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) { if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {
@ -5960,7 +5968,15 @@ rb_vm_invokesuper(rb_execution_context_t *ec, rb_control_frame_t *reg_cfp, CALL_
struct rb_callinfo adjusted_ci; struct rb_callinfo adjusted_ci;
CALL_DATA _cd = cd; CALL_DATA _cd = cd;
VALUE bh = vm_caller_setup_args(ec, GET_CFP(), &cd, blockiseq, true, &adjusted_cd, &adjusted_ci); VALUE bh;
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {
bh = vm_caller_setup_fwd_args(ec, GET_CFP(), &cd, blockiseq, true, &adjusted_cd, &adjusted_ci);
}
else {
bh = vm_caller_setup_args(ec, GET_CFP(), &cd, blockiseq, true);
}
VALUE val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_super); VALUE val = vm_sendish(ec, GET_CFP(), cd, bh, mexp_search_super);
if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) { if (vm_ci_flag(_cd->ci) & VM_CALL_FORWARDING) {

View File

@ -9070,6 +9070,14 @@ fn gen_send(
}) })
} }
fn gen_sendforward(
jit: &mut JITState,
asm: &mut Assembler,
ocb: &mut OutlinedCb,
) -> Option<CodegenStatus> {
return gen_send(jit, asm, ocb);
}
fn gen_invokeblock( fn gen_invokeblock(
jit: &mut JITState, jit: &mut JITState,
asm: &mut Assembler, asm: &mut Assembler,
@ -9253,6 +9261,14 @@ fn gen_invokesuper(
}) })
} }
fn gen_invokesuperforward(
jit: &mut JITState,
asm: &mut Assembler,
ocb: &mut OutlinedCb,
) -> Option<CodegenStatus> {
return gen_invokesuper(jit, asm, ocb);
}
fn gen_invokesuper_specialized( fn gen_invokesuper_specialized(
jit: &mut JITState, jit: &mut JITState,
asm: &mut Assembler, asm: &mut Assembler,
@ -10232,8 +10248,10 @@ fn get_gen_fn(opcode: VALUE) -> Option<InsnGenFn> {
YARVINSN_getblockparam => Some(gen_getblockparam), YARVINSN_getblockparam => Some(gen_getblockparam),
YARVINSN_opt_send_without_block => Some(gen_opt_send_without_block), YARVINSN_opt_send_without_block => Some(gen_opt_send_without_block),
YARVINSN_send => Some(gen_send), YARVINSN_send => Some(gen_send),
YARVINSN_sendforward => Some(gen_sendforward),
YARVINSN_invokeblock => Some(gen_invokeblock), YARVINSN_invokeblock => Some(gen_invokeblock),
YARVINSN_invokesuper => Some(gen_invokesuper), YARVINSN_invokesuper => Some(gen_invokesuper),
YARVINSN_invokesuperforward => Some(gen_invokesuperforward),
YARVINSN_leave => Some(gen_leave), YARVINSN_leave => Some(gen_leave),
YARVINSN_getglobal => Some(gen_getglobal), YARVINSN_getglobal => Some(gen_getglobal),

View File

@ -775,162 +775,166 @@ pub const YARVINSN_defineclass: ruby_vminsn_type = 53;
pub const YARVINSN_definemethod: ruby_vminsn_type = 54; pub const YARVINSN_definemethod: ruby_vminsn_type = 54;
pub const YARVINSN_definesmethod: ruby_vminsn_type = 55; pub const YARVINSN_definesmethod: ruby_vminsn_type = 55;
pub const YARVINSN_send: ruby_vminsn_type = 56; pub const YARVINSN_send: ruby_vminsn_type = 56;
pub const YARVINSN_opt_send_without_block: ruby_vminsn_type = 57; pub const YARVINSN_sendforward: ruby_vminsn_type = 57;
pub const YARVINSN_objtostring: ruby_vminsn_type = 58; pub const YARVINSN_opt_send_without_block: ruby_vminsn_type = 58;
pub const YARVINSN_opt_str_freeze: ruby_vminsn_type = 59; pub const YARVINSN_objtostring: ruby_vminsn_type = 59;
pub const YARVINSN_opt_nil_p: ruby_vminsn_type = 60; pub const YARVINSN_opt_str_freeze: ruby_vminsn_type = 60;
pub const YARVINSN_opt_str_uminus: ruby_vminsn_type = 61; pub const YARVINSN_opt_nil_p: ruby_vminsn_type = 61;
pub const YARVINSN_opt_newarray_send: ruby_vminsn_type = 62; pub const YARVINSN_opt_str_uminus: ruby_vminsn_type = 62;
pub const YARVINSN_invokesuper: ruby_vminsn_type = 63; pub const YARVINSN_opt_newarray_send: ruby_vminsn_type = 63;
pub const YARVINSN_invokeblock: ruby_vminsn_type = 64; pub const YARVINSN_invokesuper: ruby_vminsn_type = 64;
pub const YARVINSN_leave: ruby_vminsn_type = 65; pub const YARVINSN_invokesuperforward: ruby_vminsn_type = 65;
pub const YARVINSN_throw: ruby_vminsn_type = 66; pub const YARVINSN_invokeblock: ruby_vminsn_type = 66;
pub const YARVINSN_jump: ruby_vminsn_type = 67; pub const YARVINSN_leave: ruby_vminsn_type = 67;
pub const YARVINSN_branchif: ruby_vminsn_type = 68; pub const YARVINSN_throw: ruby_vminsn_type = 68;
pub const YARVINSN_branchunless: ruby_vminsn_type = 69; pub const YARVINSN_jump: ruby_vminsn_type = 69;
pub const YARVINSN_branchnil: ruby_vminsn_type = 70; pub const YARVINSN_branchif: ruby_vminsn_type = 70;
pub const YARVINSN_once: ruby_vminsn_type = 71; pub const YARVINSN_branchunless: ruby_vminsn_type = 71;
pub const YARVINSN_opt_case_dispatch: ruby_vminsn_type = 72; pub const YARVINSN_branchnil: ruby_vminsn_type = 72;
pub const YARVINSN_opt_plus: ruby_vminsn_type = 73; pub const YARVINSN_once: ruby_vminsn_type = 73;
pub const YARVINSN_opt_minus: ruby_vminsn_type = 74; pub const YARVINSN_opt_case_dispatch: ruby_vminsn_type = 74;
pub const YARVINSN_opt_mult: ruby_vminsn_type = 75; pub const YARVINSN_opt_plus: ruby_vminsn_type = 75;
pub const YARVINSN_opt_div: ruby_vminsn_type = 76; pub const YARVINSN_opt_minus: ruby_vminsn_type = 76;
pub const YARVINSN_opt_mod: ruby_vminsn_type = 77; pub const YARVINSN_opt_mult: ruby_vminsn_type = 77;
pub const YARVINSN_opt_eq: ruby_vminsn_type = 78; pub const YARVINSN_opt_div: ruby_vminsn_type = 78;
pub const YARVINSN_opt_neq: ruby_vminsn_type = 79; pub const YARVINSN_opt_mod: ruby_vminsn_type = 79;
pub const YARVINSN_opt_lt: ruby_vminsn_type = 80; pub const YARVINSN_opt_eq: ruby_vminsn_type = 80;
pub const YARVINSN_opt_le: ruby_vminsn_type = 81; pub const YARVINSN_opt_neq: ruby_vminsn_type = 81;
pub const YARVINSN_opt_gt: ruby_vminsn_type = 82; pub const YARVINSN_opt_lt: ruby_vminsn_type = 82;
pub const YARVINSN_opt_ge: ruby_vminsn_type = 83; pub const YARVINSN_opt_le: ruby_vminsn_type = 83;
pub const YARVINSN_opt_ltlt: ruby_vminsn_type = 84; pub const YARVINSN_opt_gt: ruby_vminsn_type = 84;
pub const YARVINSN_opt_and: ruby_vminsn_type = 85; pub const YARVINSN_opt_ge: ruby_vminsn_type = 85;
pub const YARVINSN_opt_or: ruby_vminsn_type = 86; pub const YARVINSN_opt_ltlt: ruby_vminsn_type = 86;
pub const YARVINSN_opt_aref: ruby_vminsn_type = 87; pub const YARVINSN_opt_and: ruby_vminsn_type = 87;
pub const YARVINSN_opt_aset: ruby_vminsn_type = 88; pub const YARVINSN_opt_or: ruby_vminsn_type = 88;
pub const YARVINSN_opt_aset_with: ruby_vminsn_type = 89; pub const YARVINSN_opt_aref: ruby_vminsn_type = 89;
pub const YARVINSN_opt_aref_with: ruby_vminsn_type = 90; pub const YARVINSN_opt_aset: ruby_vminsn_type = 90;
pub const YARVINSN_opt_length: ruby_vminsn_type = 91; pub const YARVINSN_opt_aset_with: ruby_vminsn_type = 91;
pub const YARVINSN_opt_size: ruby_vminsn_type = 92; pub const YARVINSN_opt_aref_with: ruby_vminsn_type = 92;
pub const YARVINSN_opt_empty_p: ruby_vminsn_type = 93; pub const YARVINSN_opt_length: ruby_vminsn_type = 93;
pub const YARVINSN_opt_succ: ruby_vminsn_type = 94; pub const YARVINSN_opt_size: ruby_vminsn_type = 94;
pub const YARVINSN_opt_not: ruby_vminsn_type = 95; pub const YARVINSN_opt_empty_p: ruby_vminsn_type = 95;
pub const YARVINSN_opt_regexpmatch2: ruby_vminsn_type = 96; pub const YARVINSN_opt_succ: ruby_vminsn_type = 96;
pub const YARVINSN_invokebuiltin: ruby_vminsn_type = 97; pub const YARVINSN_opt_not: ruby_vminsn_type = 97;
pub const YARVINSN_opt_invokebuiltin_delegate: ruby_vminsn_type = 98; pub const YARVINSN_opt_regexpmatch2: ruby_vminsn_type = 98;
pub const YARVINSN_opt_invokebuiltin_delegate_leave: ruby_vminsn_type = 99; pub const YARVINSN_invokebuiltin: ruby_vminsn_type = 99;
pub const YARVINSN_getlocal_WC_0: ruby_vminsn_type = 100; pub const YARVINSN_opt_invokebuiltin_delegate: ruby_vminsn_type = 100;
pub const YARVINSN_getlocal_WC_1: ruby_vminsn_type = 101; pub const YARVINSN_opt_invokebuiltin_delegate_leave: ruby_vminsn_type = 101;
pub const YARVINSN_setlocal_WC_0: ruby_vminsn_type = 102; pub const YARVINSN_getlocal_WC_0: ruby_vminsn_type = 102;
pub const YARVINSN_setlocal_WC_1: ruby_vminsn_type = 103; pub const YARVINSN_getlocal_WC_1: ruby_vminsn_type = 103;
pub const YARVINSN_putobject_INT2FIX_0_: ruby_vminsn_type = 104; pub const YARVINSN_setlocal_WC_0: ruby_vminsn_type = 104;
pub const YARVINSN_putobject_INT2FIX_1_: ruby_vminsn_type = 105; pub const YARVINSN_setlocal_WC_1: ruby_vminsn_type = 105;
pub const YARVINSN_trace_nop: ruby_vminsn_type = 106; pub const YARVINSN_putobject_INT2FIX_0_: ruby_vminsn_type = 106;
pub const YARVINSN_trace_getlocal: ruby_vminsn_type = 107; pub const YARVINSN_putobject_INT2FIX_1_: ruby_vminsn_type = 107;
pub const YARVINSN_trace_setlocal: ruby_vminsn_type = 108; pub const YARVINSN_trace_nop: ruby_vminsn_type = 108;
pub const YARVINSN_trace_getblockparam: ruby_vminsn_type = 109; pub const YARVINSN_trace_getlocal: ruby_vminsn_type = 109;
pub const YARVINSN_trace_setblockparam: ruby_vminsn_type = 110; pub const YARVINSN_trace_setlocal: ruby_vminsn_type = 110;
pub const YARVINSN_trace_getblockparamproxy: ruby_vminsn_type = 111; pub const YARVINSN_trace_getblockparam: ruby_vminsn_type = 111;
pub const YARVINSN_trace_getspecial: ruby_vminsn_type = 112; pub const YARVINSN_trace_setblockparam: ruby_vminsn_type = 112;
pub const YARVINSN_trace_setspecial: ruby_vminsn_type = 113; pub const YARVINSN_trace_getblockparamproxy: ruby_vminsn_type = 113;
pub const YARVINSN_trace_getinstancevariable: ruby_vminsn_type = 114; pub const YARVINSN_trace_getspecial: ruby_vminsn_type = 114;
pub const YARVINSN_trace_setinstancevariable: ruby_vminsn_type = 115; pub const YARVINSN_trace_setspecial: ruby_vminsn_type = 115;
pub const YARVINSN_trace_getclassvariable: ruby_vminsn_type = 116; pub const YARVINSN_trace_getinstancevariable: ruby_vminsn_type = 116;
pub const YARVINSN_trace_setclassvariable: ruby_vminsn_type = 117; pub const YARVINSN_trace_setinstancevariable: ruby_vminsn_type = 117;
pub const YARVINSN_trace_opt_getconstant_path: ruby_vminsn_type = 118; pub const YARVINSN_trace_getclassvariable: ruby_vminsn_type = 118;
pub const YARVINSN_trace_getconstant: ruby_vminsn_type = 119; pub const YARVINSN_trace_setclassvariable: ruby_vminsn_type = 119;
pub const YARVINSN_trace_setconstant: ruby_vminsn_type = 120; pub const YARVINSN_trace_opt_getconstant_path: ruby_vminsn_type = 120;
pub const YARVINSN_trace_getglobal: ruby_vminsn_type = 121; pub const YARVINSN_trace_getconstant: ruby_vminsn_type = 121;
pub const YARVINSN_trace_setglobal: ruby_vminsn_type = 122; pub const YARVINSN_trace_setconstant: ruby_vminsn_type = 122;
pub const YARVINSN_trace_putnil: ruby_vminsn_type = 123; pub const YARVINSN_trace_getglobal: ruby_vminsn_type = 123;
pub const YARVINSN_trace_putself: ruby_vminsn_type = 124; pub const YARVINSN_trace_setglobal: ruby_vminsn_type = 124;
pub const YARVINSN_trace_putobject: ruby_vminsn_type = 125; pub const YARVINSN_trace_putnil: ruby_vminsn_type = 125;
pub const YARVINSN_trace_putspecialobject: ruby_vminsn_type = 126; pub const YARVINSN_trace_putself: ruby_vminsn_type = 126;
pub const YARVINSN_trace_putstring: ruby_vminsn_type = 127; pub const YARVINSN_trace_putobject: ruby_vminsn_type = 127;
pub const YARVINSN_trace_putchilledstring: ruby_vminsn_type = 128; pub const YARVINSN_trace_putspecialobject: ruby_vminsn_type = 128;
pub const YARVINSN_trace_concatstrings: ruby_vminsn_type = 129; pub const YARVINSN_trace_putstring: ruby_vminsn_type = 129;
pub const YARVINSN_trace_anytostring: ruby_vminsn_type = 130; pub const YARVINSN_trace_putchilledstring: ruby_vminsn_type = 130;
pub const YARVINSN_trace_toregexp: ruby_vminsn_type = 131; pub const YARVINSN_trace_concatstrings: ruby_vminsn_type = 131;
pub const YARVINSN_trace_intern: ruby_vminsn_type = 132; pub const YARVINSN_trace_anytostring: ruby_vminsn_type = 132;
pub const YARVINSN_trace_newarray: ruby_vminsn_type = 133; pub const YARVINSN_trace_toregexp: ruby_vminsn_type = 133;
pub const YARVINSN_trace_newarraykwsplat: ruby_vminsn_type = 134; pub const YARVINSN_trace_intern: ruby_vminsn_type = 134;
pub const YARVINSN_trace_pushtoarraykwsplat: ruby_vminsn_type = 135; pub const YARVINSN_trace_newarray: ruby_vminsn_type = 135;
pub const YARVINSN_trace_duparray: ruby_vminsn_type = 136; pub const YARVINSN_trace_newarraykwsplat: ruby_vminsn_type = 136;
pub const YARVINSN_trace_duphash: ruby_vminsn_type = 137; pub const YARVINSN_trace_pushtoarraykwsplat: ruby_vminsn_type = 137;
pub const YARVINSN_trace_expandarray: ruby_vminsn_type = 138; pub const YARVINSN_trace_duparray: ruby_vminsn_type = 138;
pub const YARVINSN_trace_concatarray: ruby_vminsn_type = 139; pub const YARVINSN_trace_duphash: ruby_vminsn_type = 139;
pub const YARVINSN_trace_concattoarray: ruby_vminsn_type = 140; pub const YARVINSN_trace_expandarray: ruby_vminsn_type = 140;
pub const YARVINSN_trace_pushtoarray: ruby_vminsn_type = 141; pub const YARVINSN_trace_concatarray: ruby_vminsn_type = 141;
pub const YARVINSN_trace_splatarray: ruby_vminsn_type = 142; pub const YARVINSN_trace_concattoarray: ruby_vminsn_type = 142;
pub const YARVINSN_trace_splatkw: ruby_vminsn_type = 143; pub const YARVINSN_trace_pushtoarray: ruby_vminsn_type = 143;
pub const YARVINSN_trace_newhash: ruby_vminsn_type = 144; pub const YARVINSN_trace_splatarray: ruby_vminsn_type = 144;
pub const YARVINSN_trace_newrange: ruby_vminsn_type = 145; pub const YARVINSN_trace_splatkw: ruby_vminsn_type = 145;
pub const YARVINSN_trace_pop: ruby_vminsn_type = 146; pub const YARVINSN_trace_newhash: ruby_vminsn_type = 146;
pub const YARVINSN_trace_dup: ruby_vminsn_type = 147; pub const YARVINSN_trace_newrange: ruby_vminsn_type = 147;
pub const YARVINSN_trace_dupn: ruby_vminsn_type = 148; pub const YARVINSN_trace_pop: ruby_vminsn_type = 148;
pub const YARVINSN_trace_swap: ruby_vminsn_type = 149; pub const YARVINSN_trace_dup: ruby_vminsn_type = 149;
pub const YARVINSN_trace_opt_reverse: ruby_vminsn_type = 150; pub const YARVINSN_trace_dupn: ruby_vminsn_type = 150;
pub const YARVINSN_trace_topn: ruby_vminsn_type = 151; pub const YARVINSN_trace_swap: ruby_vminsn_type = 151;
pub const YARVINSN_trace_setn: ruby_vminsn_type = 152; pub const YARVINSN_trace_opt_reverse: ruby_vminsn_type = 152;
pub const YARVINSN_trace_adjuststack: ruby_vminsn_type = 153; pub const YARVINSN_trace_topn: ruby_vminsn_type = 153;
pub const YARVINSN_trace_defined: ruby_vminsn_type = 154; pub const YARVINSN_trace_setn: ruby_vminsn_type = 154;
pub const YARVINSN_trace_definedivar: ruby_vminsn_type = 155; pub const YARVINSN_trace_adjuststack: ruby_vminsn_type = 155;
pub const YARVINSN_trace_checkmatch: ruby_vminsn_type = 156; pub const YARVINSN_trace_defined: ruby_vminsn_type = 156;
pub const YARVINSN_trace_checkkeyword: ruby_vminsn_type = 157; pub const YARVINSN_trace_definedivar: ruby_vminsn_type = 157;
pub const YARVINSN_trace_checktype: ruby_vminsn_type = 158; pub const YARVINSN_trace_checkmatch: ruby_vminsn_type = 158;
pub const YARVINSN_trace_defineclass: ruby_vminsn_type = 159; pub const YARVINSN_trace_checkkeyword: ruby_vminsn_type = 159;
pub const YARVINSN_trace_definemethod: ruby_vminsn_type = 160; pub const YARVINSN_trace_checktype: ruby_vminsn_type = 160;
pub const YARVINSN_trace_definesmethod: ruby_vminsn_type = 161; pub const YARVINSN_trace_defineclass: ruby_vminsn_type = 161;
pub const YARVINSN_trace_send: ruby_vminsn_type = 162; pub const YARVINSN_trace_definemethod: ruby_vminsn_type = 162;
pub const YARVINSN_trace_opt_send_without_block: ruby_vminsn_type = 163; pub const YARVINSN_trace_definesmethod: ruby_vminsn_type = 163;
pub const YARVINSN_trace_objtostring: ruby_vminsn_type = 164; pub const YARVINSN_trace_send: ruby_vminsn_type = 164;
pub const YARVINSN_trace_opt_str_freeze: ruby_vminsn_type = 165; pub const YARVINSN_trace_sendforward: ruby_vminsn_type = 165;
pub const YARVINSN_trace_opt_nil_p: ruby_vminsn_type = 166; pub const YARVINSN_trace_opt_send_without_block: ruby_vminsn_type = 166;
pub const YARVINSN_trace_opt_str_uminus: ruby_vminsn_type = 167; pub const YARVINSN_trace_objtostring: ruby_vminsn_type = 167;
pub const YARVINSN_trace_opt_newarray_send: ruby_vminsn_type = 168; pub const YARVINSN_trace_opt_str_freeze: ruby_vminsn_type = 168;
pub const YARVINSN_trace_invokesuper: ruby_vminsn_type = 169; pub const YARVINSN_trace_opt_nil_p: ruby_vminsn_type = 169;
pub const YARVINSN_trace_invokeblock: ruby_vminsn_type = 170; pub const YARVINSN_trace_opt_str_uminus: ruby_vminsn_type = 170;
pub const YARVINSN_trace_leave: ruby_vminsn_type = 171; pub const YARVINSN_trace_opt_newarray_send: ruby_vminsn_type = 171;
pub const YARVINSN_trace_throw: ruby_vminsn_type = 172; pub const YARVINSN_trace_invokesuper: ruby_vminsn_type = 172;
pub const YARVINSN_trace_jump: ruby_vminsn_type = 173; pub const YARVINSN_trace_invokesuperforward: ruby_vminsn_type = 173;
pub const YARVINSN_trace_branchif: ruby_vminsn_type = 174; pub const YARVINSN_trace_invokeblock: ruby_vminsn_type = 174;
pub const YARVINSN_trace_branchunless: ruby_vminsn_type = 175; pub const YARVINSN_trace_leave: ruby_vminsn_type = 175;
pub const YARVINSN_trace_branchnil: ruby_vminsn_type = 176; pub const YARVINSN_trace_throw: ruby_vminsn_type = 176;
pub const YARVINSN_trace_once: ruby_vminsn_type = 177; pub const YARVINSN_trace_jump: ruby_vminsn_type = 177;
pub const YARVINSN_trace_opt_case_dispatch: ruby_vminsn_type = 178; pub const YARVINSN_trace_branchif: ruby_vminsn_type = 178;
pub const YARVINSN_trace_opt_plus: ruby_vminsn_type = 179; pub const YARVINSN_trace_branchunless: ruby_vminsn_type = 179;
pub const YARVINSN_trace_opt_minus: ruby_vminsn_type = 180; pub const YARVINSN_trace_branchnil: ruby_vminsn_type = 180;
pub const YARVINSN_trace_opt_mult: ruby_vminsn_type = 181; pub const YARVINSN_trace_once: ruby_vminsn_type = 181;
pub const YARVINSN_trace_opt_div: ruby_vminsn_type = 182; pub const YARVINSN_trace_opt_case_dispatch: ruby_vminsn_type = 182;
pub const YARVINSN_trace_opt_mod: ruby_vminsn_type = 183; pub const YARVINSN_trace_opt_plus: ruby_vminsn_type = 183;
pub const YARVINSN_trace_opt_eq: ruby_vminsn_type = 184; pub const YARVINSN_trace_opt_minus: ruby_vminsn_type = 184;
pub const YARVINSN_trace_opt_neq: ruby_vminsn_type = 185; pub const YARVINSN_trace_opt_mult: ruby_vminsn_type = 185;
pub const YARVINSN_trace_opt_lt: ruby_vminsn_type = 186; pub const YARVINSN_trace_opt_div: ruby_vminsn_type = 186;
pub const YARVINSN_trace_opt_le: ruby_vminsn_type = 187; pub const YARVINSN_trace_opt_mod: ruby_vminsn_type = 187;
pub const YARVINSN_trace_opt_gt: ruby_vminsn_type = 188; pub const YARVINSN_trace_opt_eq: ruby_vminsn_type = 188;
pub const YARVINSN_trace_opt_ge: ruby_vminsn_type = 189; pub const YARVINSN_trace_opt_neq: ruby_vminsn_type = 189;
pub const YARVINSN_trace_opt_ltlt: ruby_vminsn_type = 190; pub const YARVINSN_trace_opt_lt: ruby_vminsn_type = 190;
pub const YARVINSN_trace_opt_and: ruby_vminsn_type = 191; pub const YARVINSN_trace_opt_le: ruby_vminsn_type = 191;
pub const YARVINSN_trace_opt_or: ruby_vminsn_type = 192; pub const YARVINSN_trace_opt_gt: ruby_vminsn_type = 192;
pub const YARVINSN_trace_opt_aref: ruby_vminsn_type = 193; pub const YARVINSN_trace_opt_ge: ruby_vminsn_type = 193;
pub const YARVINSN_trace_opt_aset: ruby_vminsn_type = 194; pub const YARVINSN_trace_opt_ltlt: ruby_vminsn_type = 194;
pub const YARVINSN_trace_opt_aset_with: ruby_vminsn_type = 195; pub const YARVINSN_trace_opt_and: ruby_vminsn_type = 195;
pub const YARVINSN_trace_opt_aref_with: ruby_vminsn_type = 196; pub const YARVINSN_trace_opt_or: ruby_vminsn_type = 196;
pub const YARVINSN_trace_opt_length: ruby_vminsn_type = 197; pub const YARVINSN_trace_opt_aref: ruby_vminsn_type = 197;
pub const YARVINSN_trace_opt_size: ruby_vminsn_type = 198; pub const YARVINSN_trace_opt_aset: ruby_vminsn_type = 198;
pub const YARVINSN_trace_opt_empty_p: ruby_vminsn_type = 199; pub const YARVINSN_trace_opt_aset_with: ruby_vminsn_type = 199;
pub const YARVINSN_trace_opt_succ: ruby_vminsn_type = 200; pub const YARVINSN_trace_opt_aref_with: ruby_vminsn_type = 200;
pub const YARVINSN_trace_opt_not: ruby_vminsn_type = 201; pub const YARVINSN_trace_opt_length: ruby_vminsn_type = 201;
pub const YARVINSN_trace_opt_regexpmatch2: ruby_vminsn_type = 202; pub const YARVINSN_trace_opt_size: ruby_vminsn_type = 202;
pub const YARVINSN_trace_invokebuiltin: ruby_vminsn_type = 203; pub const YARVINSN_trace_opt_empty_p: ruby_vminsn_type = 203;
pub const YARVINSN_trace_opt_invokebuiltin_delegate: ruby_vminsn_type = 204; pub const YARVINSN_trace_opt_succ: ruby_vminsn_type = 204;
pub const YARVINSN_trace_opt_invokebuiltin_delegate_leave: ruby_vminsn_type = 205; pub const YARVINSN_trace_opt_not: ruby_vminsn_type = 205;
pub const YARVINSN_trace_getlocal_WC_0: ruby_vminsn_type = 206; pub const YARVINSN_trace_opt_regexpmatch2: ruby_vminsn_type = 206;
pub const YARVINSN_trace_getlocal_WC_1: ruby_vminsn_type = 207; pub const YARVINSN_trace_invokebuiltin: ruby_vminsn_type = 207;
pub const YARVINSN_trace_setlocal_WC_0: ruby_vminsn_type = 208; pub const YARVINSN_trace_opt_invokebuiltin_delegate: ruby_vminsn_type = 208;
pub const YARVINSN_trace_setlocal_WC_1: ruby_vminsn_type = 209; pub const YARVINSN_trace_opt_invokebuiltin_delegate_leave: ruby_vminsn_type = 209;
pub const YARVINSN_trace_putobject_INT2FIX_0_: ruby_vminsn_type = 210; pub const YARVINSN_trace_getlocal_WC_0: ruby_vminsn_type = 210;
pub const YARVINSN_trace_putobject_INT2FIX_1_: ruby_vminsn_type = 211; pub const YARVINSN_trace_getlocal_WC_1: ruby_vminsn_type = 211;
pub const VM_INSTRUCTION_SIZE: ruby_vminsn_type = 212; pub const YARVINSN_trace_setlocal_WC_0: ruby_vminsn_type = 212;
pub const YARVINSN_trace_setlocal_WC_1: ruby_vminsn_type = 213;
pub const YARVINSN_trace_putobject_INT2FIX_0_: ruby_vminsn_type = 214;
pub const YARVINSN_trace_putobject_INT2FIX_1_: ruby_vminsn_type = 215;
pub const VM_INSTRUCTION_SIZE: ruby_vminsn_type = 216;
pub type ruby_vminsn_type = u32; pub type ruby_vminsn_type = u32;
pub type rb_iseq_callback = ::std::option::Option< pub type rb_iseq_callback = ::std::option::Option<
unsafe extern "C" fn(arg1: *const rb_iseq_t, arg2: *mut ::std::os::raw::c_void), unsafe extern "C" fn(arg1: *const rb_iseq_t, arg2: *mut ::std::os::raw::c_void),