diff --git a/src/mono/browser/runtime/jiterpreter-trace-generator.ts b/src/mono/browser/runtime/jiterpreter-trace-generator.ts index 25b701752e238f..eb62b4cc9bae4f 100644 --- a/src/mono/browser/runtime/jiterpreter-trace-generator.ts +++ b/src/mono/browser/runtime/jiterpreter-trace-generator.ts @@ -2745,8 +2745,7 @@ function append_call_handler_store_ret_ip ( builder: WasmBuilder, ip: MintOpcodePtr, frame: NativePointer, opcode: MintOpcode ) { - const shortOffset = (opcode === MintOpcode.MINT_CALL_HANDLER_S), - retIp = shortOffset ? ip + (3 * 2) : ip + (4 * 2), + const retIp = ip + (4 * 2), clauseIndex = getU16(retIp - 2), clauseDataOffset = get_imethod_clause_data_offset(frame, clauseIndex); @@ -2773,9 +2772,6 @@ function getBranchDisplacement ( case MintOpArgType.MintOpBranch: result = getI32_unaligned(payloadAddress); break; - case MintOpArgType.MintOpShortBranch: - result = getI16(payloadAddress); - break; case MintOpArgType.MintOpShortAndBranch: result = getI32_unaligned(payloadAddress + 2); break; diff --git a/src/mono/mono/mini/interp/interp.c b/src/mono/mono/mini/interp/interp.c index c1ff0db5b3e0dc..cb951d6206a6ca 100644 --- a/src/mono/mono/mini/interp/interp.c +++ b/src/mono/mono/mini/interp/interp.c @@ -4474,12 +4474,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause #define BACK_BRANCH_PROFILE(offset) #endif - MINT_IN_CASE(MINT_BR_S) { - short br_offset = (short) *(ip + 1); - BACK_BRANCH_PROFILE (br_offset); - ip += br_offset; - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BR) { gint32 br_offset = (gint32) READ32(ip + 1); BACK_BRANCH_PROFILE (br_offset); @@ -4487,14 +4481,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause MINT_IN_BREAK; } -#define ZEROP_S(datatype, op) \ - if (LOCAL_VAR (ip [1], datatype) op 0) { \ - gint16 br_offset = (gint16) ip [2]; \ - BACK_BRANCH_PROFILE (br_offset); \ - ip += br_offset; \ - } else \ - ip += 3; - #define ZEROP(datatype, op) \ if (LOCAL_VAR (ip [1], datatype) op 0) { \ gint32 br_offset = (gint32)READ32(ip + 2); \ @@ -4503,39 +4489,18 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause } else \ ip += 4; - MINT_IN_CASE(MINT_BRFALSE_I4_S) - ZEROP_S(gint32, ==); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BRFALSE_I8_S) - ZEROP_S(gint64, ==); - MINT_IN_BREAK; MINT_IN_CASE(MINT_BRFALSE_I4) ZEROP(gint32, ==); MINT_IN_BREAK; MINT_IN_CASE(MINT_BRFALSE_I8) ZEROP(gint64, ==); MINT_IN_BREAK; - MINT_IN_CASE(MINT_BRTRUE_I4_S) - ZEROP_S(gint32, !=); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BRTRUE_I8_S) - ZEROP_S(gint64, !=); - MINT_IN_BREAK; MINT_IN_CASE(MINT_BRTRUE_I4) ZEROP(gint32, !=); MINT_IN_BREAK; MINT_IN_CASE(MINT_BRTRUE_I8) ZEROP(gint64, !=); MINT_IN_BREAK; -#define CONDBR_S(cond) \ - if (cond) { \ - gint16 br_offset = (gint16) ip [3]; \ - BACK_BRANCH_PROFILE (br_offset); \ - ip += br_offset; \ - } else \ - ip += 4; -#define BRELOP_S(datatype, op) \ - CONDBR_S(LOCAL_VAR (ip [1], datatype) op LOCAL_VAR (ip [2], datatype)) #define CONDBR(cond) \ if (cond) { \ @@ -4548,24 +4513,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause #define BRELOP(datatype, op) \ CONDBR(LOCAL_VAR (ip [1], datatype) op LOCAL_VAR (ip [2], datatype)) - MINT_IN_CASE(MINT_BEQ_I4_S) - BRELOP_S(gint32, ==) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BEQ_I8_S) - BRELOP_S(gint64, ==) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BEQ_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(!isunordered (f1, f2) && f1 == f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BEQ_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(!mono_isunordered (d1, d2) && d1 == d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BEQ_I4) BRELOP(gint32, ==) MINT_IN_BREAK; @@ -4584,24 +4531,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(!mono_isunordered (d1, d2) && d1 == d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BGE_I4_S) - BRELOP_S(gint32, >=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGE_I8_S) - BRELOP_S(gint64, >=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGE_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(!isunordered (f1, f2) && f1 >= f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BGE_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(!mono_isunordered (d1, d2) && d1 >= d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BGE_I4) BRELOP(gint32, >=) MINT_IN_BREAK; @@ -4620,24 +4549,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(!mono_isunordered (d1, d2) && d1 >= d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BGT_I4_S) - BRELOP_S(gint32, >) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGT_I8_S) - BRELOP_S(gint64, >) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGT_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(!isunordered (f1, f2) && f1 > f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BGT_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(!mono_isunordered (d1, d2) && d1 > d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BGT_I4) BRELOP(gint32, >) MINT_IN_BREAK; @@ -4656,24 +4567,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(!mono_isunordered (d1, d2) && d1 > d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BLT_I4_S) - BRELOP_S(gint32, <) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLT_I8_S) - BRELOP_S(gint64, <) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLT_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(!isunordered (f1, f2) && f1 < f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BLT_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(!mono_isunordered (d1, d2) && d1 < d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BLT_I4) BRELOP(gint32, <) MINT_IN_BREAK; @@ -4692,24 +4585,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(!mono_isunordered (d1, d2) && d1 < d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BLE_I4_S) - BRELOP_S(gint32, <=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLE_I8_S) - BRELOP_S(gint64, <=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLE_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(!isunordered (f1, f2) && f1 <= f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BLE_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(!mono_isunordered (d1, d2) && d1 <= d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BLE_I4) BRELOP(gint32, <=) MINT_IN_BREAK; @@ -4728,24 +4603,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(!mono_isunordered (d1, d2) && d1 <= d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BNE_UN_I4_S) - BRELOP_S(gint32, !=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BNE_UN_I8_S) - BRELOP_S(gint64, !=) - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BNE_UN_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(isunordered (f1, f2) || f1 != f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BNE_UN_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(mono_isunordered (d1, d2) || d1 != d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BNE_UN_I4) BRELOP(gint32, !=) MINT_IN_BREAK; @@ -4765,14 +4622,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause MINT_IN_BREAK; } -#define BRELOP_S_CAST(datatype, op) \ - if (LOCAL_VAR (ip [1], datatype) op LOCAL_VAR (ip [2], datatype)) { \ - gint16 br_offset = (gint16) ip [3]; \ - BACK_BRANCH_PROFILE (br_offset); \ - ip += br_offset; \ - } else \ - ip += 4; - #define BRELOP_CAST(datatype, op) \ if (LOCAL_VAR (ip [1], datatype) op LOCAL_VAR (ip [2], datatype)) { \ gint32 br_offset = (gint32)READ32(ip + 3); \ @@ -4781,24 +4630,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause } else \ ip += 5; - MINT_IN_CASE(MINT_BGE_UN_I4_S) - BRELOP_S_CAST(guint32, >=); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGE_UN_I8_S) - BRELOP_S_CAST(guint64, >=); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGE_UN_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(isunordered (f1, f2) || f1 >= f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BGE_UN_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(mono_isunordered (d1, d2) || d1 >= d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BGE_UN_I4) BRELOP_CAST(guint32, >=); MINT_IN_BREAK; @@ -4817,24 +4648,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(mono_isunordered (d1, d2) || d1 >= d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BGT_UN_I4_S) - BRELOP_S_CAST(guint32, >); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGT_UN_I8_S) - BRELOP_S_CAST(guint64, >); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BGT_UN_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(isunordered (f1, f2) || f1 > f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BGT_UN_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(mono_isunordered (d1, d2) || d1 > d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BGT_UN_I4) BRELOP_CAST(guint32, >); MINT_IN_BREAK; @@ -4853,24 +4666,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(mono_isunordered (d1, d2) || d1 > d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BLE_UN_I4_S) - BRELOP_S_CAST(guint32, <=); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLE_UN_I8_S) - BRELOP_S_CAST(guint64, <=); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLE_UN_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(isunordered (f1, f2) || f1 <= f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BLE_UN_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(mono_isunordered (d1, d2) || d1 <= d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BLE_UN_I4) BRELOP_CAST(guint32, <=); MINT_IN_BREAK; @@ -4889,24 +4684,6 @@ mono_interp_exec_method (InterpFrame *frame, ThreadContext *context, FrameClause CONDBR(mono_isunordered (d1, d2) || d1 <= d2) MINT_IN_BREAK; } - MINT_IN_CASE(MINT_BLT_UN_I4_S) - BRELOP_S_CAST(guint32, <); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLT_UN_I8_S) - BRELOP_S_CAST(guint64, <); - MINT_IN_BREAK; - MINT_IN_CASE(MINT_BLT_UN_R4_S) { - float f1 = LOCAL_VAR (ip [1], float); - float f2 = LOCAL_VAR (ip [2], float); - CONDBR_S(isunordered (f1, f2) || f1 < f2) - MINT_IN_BREAK; - } - MINT_IN_CASE(MINT_BLT_UN_R8_S) { - double d1 = LOCAL_VAR (ip [1], double); - double d2 = LOCAL_VAR (ip [2], double); - CONDBR_S(mono_isunordered (d1, d2) || d1 < d2) - MINT_IN_BREAK; - } MINT_IN_CASE(MINT_BLT_UN_I4) BRELOP_CAST(guint32, <); MINT_IN_BREAK; @@ -7128,31 +6905,25 @@ MINT_IN_CASE(MINT_BRTRUE_I8_SP) ZEROP_SP(gint64, !=); MINT_IN_BREAK; ip = ret_ip; MINT_IN_BREAK; } - MINT_IN_CASE(MINT_CALL_HANDLER) - MINT_IN_CASE(MINT_CALL_HANDLER_S) { - gboolean short_offset = *ip == MINT_CALL_HANDLER_S; - const guint16 *ret_ip = short_offset ? (ip + 3) : (ip + 4); + MINT_IN_CASE(MINT_CALL_HANDLER) { + const guint16 *ret_ip = ip + 4; guint16 clause_index = *(ret_ip - 1); *(const guint16**)(locals + frame->imethod->clause_data_offsets [clause_index]) = ret_ip; // jump to clause - ip += short_offset ? (gint16)*(ip + 1) : (gint32)READ32 (ip + 1); + ip += (gint32)READ32 (ip + 1); MINT_IN_BREAK; } - MINT_IN_CASE(MINT_LEAVE_CHECK) - MINT_IN_CASE(MINT_LEAVE_S_CHECK) { - int leave_opcode = *ip; - + MINT_IN_CASE(MINT_LEAVE_CHECK) { if (frame->imethod->method->wrapper_type != MONO_WRAPPER_RUNTIME_INVOKE) { MonoException *abort_exc = mono_interp_leave (frame); if (abort_exc) THROW_EX (abort_exc, ip); } - gboolean const short_offset = leave_opcode == MINT_LEAVE_S_CHECK; - ip += short_offset ? (gint16)*(ip + 1) : (gint32)READ32 (ip + 1); + ip += (gint32)READ32 (ip + 1); MINT_IN_BREAK; } MINT_IN_CASE(MINT_ICALL) { diff --git a/src/mono/mono/mini/interp/mintops.def b/src/mono/mono/mini/interp/mintops.def index 9150da9fb75030..eca8c5727665f7 100644 --- a/src/mono/mono/mini/interp/mintops.def +++ b/src/mono/mono/mini/interp/mintops.def @@ -179,11 +179,8 @@ OPDEF(MINT_STIND_OFFSET_IMM_I4, "stind_off_imm.i4", 4, 0, 2, MintOpShortInt) OPDEF(MINT_STIND_OFFSET_IMM_I8, "stind_off_imm.i8", 4, 0, 2, MintOpShortInt) OPDEF(MINT_BR, "br", 3, 0, 0, MintOpBranch) -OPDEF(MINT_BR_S, "br.s", 2, 0, 0, MintOpShortBranch) OPDEF(MINT_LEAVE_CHECK, "leave.check", 3, 0, 0, MintOpBranch) -OPDEF(MINT_LEAVE_S_CHECK, "leave.s.check", 2, 0, 0, MintOpShortBranch) OPDEF(MINT_CALL_HANDLER, "call_handler", 4, 0, 0, MintOpBranch) -OPDEF(MINT_CALL_HANDLER_S, "call_handler.s", 3, 0, 0, MintOpShortBranch) OPDEF(MINT_THROW, "throw", 2, 0, 1, MintOpNoArgs) OPDEF(MINT_RETHROW, "rethrow", 2, 0, 0, MintOpUShortInt) @@ -197,11 +194,6 @@ OPDEF(MINT_BRFALSE_I8, "brfalse.i8", 4, 0, 1, MintOpBranch) OPDEF(MINT_BRTRUE_I4, "brtrue.i4", 4, 0, 1, MintOpBranch) OPDEF(MINT_BRTRUE_I8, "brtrue.i8", 4, 0, 1, MintOpBranch) -OPDEF(MINT_BRFALSE_I4_S, "brfalse.i4.s", 3, 0, 1, MintOpShortBranch) -OPDEF(MINT_BRFALSE_I8_S, "brfalse.i8.s", 3, 0, 1, MintOpShortBranch) -OPDEF(MINT_BRTRUE_I4_S, "brtrue.i4.s", 3, 0, 1, MintOpShortBranch) -OPDEF(MINT_BRTRUE_I8_S, "brtrue.i8.s", 3, 0, 1, MintOpShortBranch) - OPDEF(MINT_BEQ_I4, "beq.i4", 5, 0, 2, MintOpBranch) OPDEF(MINT_BEQ_I8, "beq.i8", 5, 0, 2, MintOpBranch) OPDEF(MINT_BEQ_R4, "beq.r4", 5, 0, 2, MintOpBranch) @@ -244,48 +236,6 @@ OPDEF(MINT_BLT_UN_I8, "blt.un.i8", 5, 0, 2, MintOpBranch) OPDEF(MINT_BLT_UN_R4, "blt.un.r4", 5, 0, 2, MintOpBranch) OPDEF(MINT_BLT_UN_R8, "blt.un.r8", 5, 0, 2, MintOpBranch) -OPDEF(MINT_BEQ_I4_S, "beq.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BEQ_I8_S, "beq.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BEQ_R4_S, "beq.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BEQ_R8_S, "beq.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_I4_S, "bge.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_I8_S, "bge.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_R4_S, "bge.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_R8_S, "bge.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_I4_S, "bgt.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_I8_S, "bgt.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_R4_S, "bgt.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_R8_S, "bgt.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_I4_S, "blt.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_I8_S, "blt.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_R4_S, "blt.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_R8_S, "blt.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_I4_S, "ble.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_I8_S, "ble.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_R4_S, "ble.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_R8_S, "ble.r8.s", 4, 0, 2, MintOpShortBranch) - -OPDEF(MINT_BNE_UN_I4_S, "bne.un.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BNE_UN_I8_S, "bne.un.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BNE_UN_R4_S, "bne.un.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BNE_UN_R8_S, "bne.un.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_UN_I4_S, "bge.un.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_UN_I8_S, "bge.un.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_UN_R4_S, "bge.un.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGE_UN_R8_S, "bge.un.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_UN_I4_S, "bgt.un.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_UN_I8_S, "bgt.un.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_UN_R4_S, "bgt.un.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BGT_UN_R8_S, "bgt.un.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_UN_I4_S, "ble.un.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_UN_I8_S, "ble.un.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_UN_R4_S, "ble.un.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLE_UN_R8_S, "ble.un.r8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_UN_I4_S, "blt.un.i4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_UN_I8_S, "blt.un.i8.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_UN_R4_S, "blt.un.r4.s", 4, 0, 2, MintOpShortBranch) -OPDEF(MINT_BLT_UN_R8_S, "blt.un.r8.s", 4, 0, 2, MintOpShortBranch) - OPDEF(MINT_BRFALSE_I4_SP, "brfalse.i4.sp", 4, 0, 1, MintOpBranch) OPDEF(MINT_BRFALSE_I8_SP, "brfalse.i8.sp", 4, 0, 1, MintOpBranch) OPDEF(MINT_BRTRUE_I4_SP, "brtrue.i4.sp", 4, 0, 1, MintOpBranch) diff --git a/src/mono/mono/mini/interp/mintops.h b/src/mono/mono/mini/interp/mintops.h index a998abf61d67cb..e289e60197cd6a 100644 --- a/src/mono/mono/mini/interp/mintops.h +++ b/src/mono/mono/mini/interp/mintops.h @@ -19,7 +19,6 @@ typedef enum MintOpFloat, MintOpDouble, MintOpBranch, - MintOpShortBranch, MintOpSwitch, MintOpMethodToken, MintOpFieldToken, @@ -212,10 +211,10 @@ typedef enum { #define MINT_IS_NOP(op) ((op) == MINT_NOP || (op) == MINT_DEF || (op) == MINT_DEF_ARG || (op) == MINT_DUMMY_USE || (op) == MINT_IL_SEQ_POINT) #define MINT_IS_EMIT_NOP(op) ((op) == MINT_NOP || (op) == MINT_DEF || (op) == MINT_DEF_ARG || (op) == MINT_DEF_TIER_VAR || (op) == MINT_DUMMY_USE) #define MINT_IS_MOV(op) ((op) >= MINT_MOV_I4_I1 && (op) <= MINT_MOV_VT) -#define MINT_IS_UNCONDITIONAL_BRANCH(op) ((op) >= MINT_BR && (op) <= MINT_CALL_HANDLER_S) -#define MINT_IS_CONDITIONAL_BRANCH(op) ((op) >= MINT_BRFALSE_I4 && (op) <= MINT_BLT_UN_R8_S) -#define MINT_IS_UNOP_CONDITIONAL_BRANCH(op) ((op) >= MINT_BRFALSE_I4 && (op) <= MINT_BRTRUE_I8_S) -#define MINT_IS_BINOP_CONDITIONAL_BRANCH(op) ((op) >= MINT_BEQ_I4 && (op) <= MINT_BLT_UN_R8_S) +#define MINT_IS_UNCONDITIONAL_BRANCH(op) ((op) >= MINT_BR && (op) <= MINT_CALL_HANDLER) +#define MINT_IS_CONDITIONAL_BRANCH(op) ((op) >= MINT_BRFALSE_I4 && (op) <= MINT_BLT_UN_R8) +#define MINT_IS_UNOP_CONDITIONAL_BRANCH(op) ((op) >= MINT_BRFALSE_I4 && (op) <= MINT_BRTRUE_I8) +#define MINT_IS_BINOP_CONDITIONAL_BRANCH(op) ((op) >= MINT_BEQ_I4 && (op) <= MINT_BLT_UN_R8) #define MINT_IS_COMPARE(op) ((op) >= MINT_CEQ_I4 && (op) <= MINT_CLT_UN_R8) #define MINT_IS_SUPER_BRANCH(op) ((op) >= MINT_BRFALSE_I4_SP && (op) <= MINT_BLT_UN_I8_IMM_SP) #define MINT_IS_CALL(op) ((op) >= MINT_CALL && (op) <= MINT_JIT_CALL) diff --git a/src/mono/mono/mini/interp/transform.c b/src/mono/mono/mini/interp/transform.c index 20c9f3211a0afa..61488f1767c136 100644 --- a/src/mono/mono/mini/interp/transform.c +++ b/src/mono/mono/mini/interp/transform.c @@ -1424,15 +1424,6 @@ interp_dump_ins_data (InterpInst *ins, gint32 ins_offset, const guint16 *data, i g_string_append_printf (str, " %g", * (double *)&tmp); break; } - case MintOpShortBranch: - if (ins) { - /* the target IL is already embedded in the instruction */ - g_string_append_printf (str, " BB%d", ins->info.target_bb->index); - } else { - target = ins_offset + *(gint16*)data; - g_string_append_printf (str, " IR_%04x", target); - } - break; case MintOpBranch: if (ins) { g_string_append_printf (str, " BB%d", ins->info.target_bb->index); @@ -8661,10 +8652,6 @@ handle_relocations (TransformData *td) int offset = reloc->target_bb->native_offset - reloc->offset; switch (reloc->type) { - case RELOC_SHORT_BRANCH: - g_assert (td->new_code [reloc->offset + reloc->skip + 1] == 0xdead); - td->new_code [reloc->offset + reloc->skip + 1] = GINT_TO_UINT16 (offset); - break; case RELOC_LONG_BRANCH: { guint16 *v = (guint16 *)&offset; g_assert (td->new_code [reloc->offset + reloc->skip + 1] == 0xdead); @@ -8790,42 +8777,6 @@ interp_compute_native_offset_estimates (TransformData *td) return noe; } -gboolean -interp_is_short_offset (int src_offset, int dest_offset) -{ - int diff = dest_offset - src_offset; - if (diff >= G_MININT16 && diff <= G_MAXINT16) - return TRUE; - return FALSE; -} - -static int -get_short_brop (int opcode) -{ - if (MINT_IS_UNCONDITIONAL_BRANCH (opcode)) { - if (opcode == MINT_BR) - return MINT_BR_S; - else if (opcode == MINT_LEAVE_CHECK) - return MINT_LEAVE_S_CHECK; - else if (opcode == MINT_CALL_HANDLER) - return MINT_CALL_HANDLER_S; - else - return opcode; - } - - if (opcode >= MINT_BRFALSE_I4 && opcode <= MINT_BRTRUE_I8) - return opcode + MINT_BRFALSE_I4_S - MINT_BRFALSE_I4; - - if (opcode >= MINT_BEQ_I4 && opcode <= MINT_BLT_UN_R8) - return opcode + MINT_BEQ_I4_S - MINT_BEQ_I4; - - if (MINT_IS_SUPER_BRANCH (opcode)) - g_assert_not_reached (); - - // Already short branch - return opcode; -} - static void interp_mark_ref_slots_for_vt (TransformData *td, int base_offset, MonoClass *klass) { @@ -8981,37 +8932,20 @@ emit_compacted_instruction (TransformData *td, guint16* start_ip, InterpInst *in if (ins->info.target_bb->native_offset >= 0) { int offset = ins->info.target_bb->native_offset - br_offset; - // Backwards branch. We can already patch it. Branch super ins are always long offset - if (!MINT_IS_SUPER_BRANCH (opcode) && - interp_is_short_offset (br_offset, ins->info.target_bb->native_offset)) { - // Replace the long opcode we added at the start - *start_ip = GINT_TO_OPCODE (get_short_brop (opcode)); - *ip++ = GINT_TO_UINT16 (ins->info.target_bb->native_offset - br_offset); - } else { - WRITE32 (ip, &offset); - } + WRITE32 (ip, &offset); } else if (opcode == MINT_BR && ins->info.target_bb == td->cbb->next_bb) { // Ignore branch to the next basic block. Revert the added MINT_BR. ip--; } else { - // If the estimate offset is short, then surely the real offset is short - // otherwise we conservatively have to use long branch opcodes - int cur_estimation_error = td->cbb->native_offset_estimate - td->cbb->native_offset; - int target_bb_estimated_offset = ins->info.target_bb->native_offset_estimate - cur_estimation_error; - gboolean is_short = !MINT_IS_SUPER_BRANCH (opcode) && interp_is_short_offset (br_offset, target_bb_estimated_offset); - if (is_short) - *start_ip = GINT_TO_OPCODE (get_short_brop (opcode)); - // We don't know the in_offset of the target, add a reloc Reloc *reloc = (Reloc*)mono_mempool_alloc0 (td->mempool, sizeof (Reloc)); - reloc->type = is_short ? RELOC_SHORT_BRANCH : RELOC_LONG_BRANCH; + reloc->type = RELOC_LONG_BRANCH; reloc->skip = mono_interp_op_sregs [opcode] + has_imm; reloc->offset = br_offset; reloc->target_bb = ins->info.target_bb; g_ptr_array_add (td->relocs, reloc); *ip++ = 0xdead; - if (!is_short) - *ip++ = 0xbeef; + *ip++ = 0xbeef; } if (opcode == MINT_CALL_HANDLER) *ip++ = ins->data [2]; diff --git a/src/mono/mono/mini/interp/transform.h b/src/mono/mono/mini/interp/transform.h index e3d63dcc9aab5f..9432eebf396143 100644 --- a/src/mono/mono/mini/interp/transform.h +++ b/src/mono/mono/mini/interp/transform.h @@ -182,7 +182,6 @@ struct _InterpCallInfo { }; typedef enum { - RELOC_SHORT_BRANCH, RELOC_LONG_BRANCH, RELOC_SWITCH } RelocType;