summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--yjit/src/codegen.rs10
1 files changed, 5 insertions, 5 deletions
diff --git a/yjit/src/codegen.rs b/yjit/src/codegen.rs
index 58bc036756..87bb43caa2 100644
--- a/yjit/src/codegen.rs
+++ b/yjit/src/codegen.rs
@@ -3054,11 +3054,11 @@ fn gen_opt_succ(
gen_opt_send_without_block(jit, ctx, asm, ocb)
}
-/*
+
fn gen_opt_str_freeze(
jit: &mut JITState,
ctx: &mut Context,
- cb: &mut CodeBlock,
+ asm: &mut Assembler,
ocb: &mut OutlinedCb,
) -> CodegenStatus {
if !assume_bop_not_redefined(jit, ocb, STRING_REDEFINED_OP_FLAG, BOP_FREEZE) {
@@ -3066,15 +3066,15 @@ fn gen_opt_str_freeze(
}
let str = jit_get_arg(jit, 0);
- jit_mov_gc_ptr(jit, cb, REG0, str);
// Push the return value onto the stack
let stack_ret = ctx.stack_push(Type::CString);
- mov(cb, stack_ret, REG0);
+ asm.mov(stack_ret, str.into());
KeepCompiling
}
+/*
fn gen_opt_str_uminus(
jit: &mut JITState,
ctx: &mut Context,
@@ -5964,7 +5964,7 @@ fn get_gen_fn(opcode: VALUE) -> Option<InsnGenFn> {
YARVINSN_opt_gt => Some(gen_opt_gt),
YARVINSN_opt_ge => Some(gen_opt_ge),
YARVINSN_opt_mod => Some(gen_opt_mod),
- //YARVINSN_opt_str_freeze => Some(gen_opt_str_freeze),
+ YARVINSN_opt_str_freeze => Some(gen_opt_str_freeze),
//YARVINSN_opt_str_uminus => Some(gen_opt_str_uminus),
YARVINSN_splatarray => Some(gen_splatarray),
YARVINSN_newrange => Some(gen_newrange),