mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 16:23:55 -06:00
tcg/mips: Support negsetcond
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
84f57d50ac
commit
ce27066de1
2 changed files with 27 additions and 2 deletions
|
@ -41,7 +41,7 @@ extern bool use_mips32r2_instructions;
|
||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
#define TCG_TARGET_HAS_bswap16_i32 1
|
#define TCG_TARGET_HAS_bswap16_i32 1
|
||||||
#define TCG_TARGET_HAS_bswap32_i32 1
|
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||||
#define TCG_TARGET_HAS_negsetcond_i32 0
|
#define TCG_TARGET_HAS_negsetcond_i32 1
|
||||||
|
|
||||||
#if TCG_TARGET_REG_BITS == 64
|
#if TCG_TARGET_REG_BITS == 64
|
||||||
#define TCG_TARGET_HAS_add2_i32 0
|
#define TCG_TARGET_HAS_add2_i32 0
|
||||||
|
@ -51,7 +51,7 @@ extern bool use_mips32r2_instructions;
|
||||||
#define TCG_TARGET_HAS_sub2_i64 0
|
#define TCG_TARGET_HAS_sub2_i64 0
|
||||||
#define TCG_TARGET_HAS_ext32s_i64 1
|
#define TCG_TARGET_HAS_ext32s_i64 1
|
||||||
#define TCG_TARGET_HAS_ext32u_i64 1
|
#define TCG_TARGET_HAS_ext32u_i64 1
|
||||||
#define TCG_TARGET_HAS_negsetcond_i64 0
|
#define TCG_TARGET_HAS_negsetcond_i64 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* optional instructions detected at runtime */
|
/* optional instructions detected at runtime */
|
||||||
|
|
|
@ -959,6 +959,25 @@ static void tcg_out_setcond(TCGContext *s, TCGCond cond, TCGReg ret,
|
||||||
tcg_out_setcond_end(s, ret, tmpflags);
|
tcg_out_setcond_end(s, ret, tmpflags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void tcg_out_negsetcond(TCGContext *s, TCGCond cond, TCGReg ret,
|
||||||
|
TCGReg arg1, TCGReg arg2)
|
||||||
|
{
|
||||||
|
int tmpflags = tcg_out_setcond_int(s, cond, ret, arg1, arg2);
|
||||||
|
TCGReg tmp = tmpflags & ~SETCOND_FLAGS;
|
||||||
|
|
||||||
|
/* If intermediate result is zero/non-zero: test != 0. */
|
||||||
|
if (tmpflags & SETCOND_NEZ) {
|
||||||
|
tcg_out_opc_reg(s, OPC_SLTU, ret, TCG_REG_ZERO, tmp);
|
||||||
|
tmp = ret;
|
||||||
|
}
|
||||||
|
/* Produce the 0/-1 result. */
|
||||||
|
if (tmpflags & SETCOND_INV) {
|
||||||
|
tcg_out_opc_imm(s, OPC_ADDIU, ret, tmp, -1);
|
||||||
|
} else {
|
||||||
|
tcg_out_opc_reg(s, OPC_SUBU, ret, TCG_REG_ZERO, tmp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void tcg_out_brcond(TCGContext *s, TCGCond cond, TCGReg arg1,
|
static void tcg_out_brcond(TCGContext *s, TCGCond cond, TCGReg arg1,
|
||||||
TCGReg arg2, TCGLabel *l)
|
TCGReg arg2, TCGLabel *l)
|
||||||
{
|
{
|
||||||
|
@ -2270,6 +2289,10 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
||||||
case INDEX_op_setcond_i64:
|
case INDEX_op_setcond_i64:
|
||||||
tcg_out_setcond(s, args[3], a0, a1, a2);
|
tcg_out_setcond(s, args[3], a0, a1, a2);
|
||||||
break;
|
break;
|
||||||
|
case INDEX_op_negsetcond_i32:
|
||||||
|
case INDEX_op_negsetcond_i64:
|
||||||
|
tcg_out_negsetcond(s, args[3], a0, a1, a2);
|
||||||
|
break;
|
||||||
case INDEX_op_setcond2_i32:
|
case INDEX_op_setcond2_i32:
|
||||||
tcg_out_setcond2(s, args[5], a0, a1, a2, args[3], args[4]);
|
tcg_out_setcond2(s, args[5], a0, a1, a2, args[3], args[4]);
|
||||||
break;
|
break;
|
||||||
|
@ -2364,6 +2387,8 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
||||||
|
|
||||||
case INDEX_op_setcond_i32:
|
case INDEX_op_setcond_i32:
|
||||||
case INDEX_op_setcond_i64:
|
case INDEX_op_setcond_i64:
|
||||||
|
case INDEX_op_negsetcond_i32:
|
||||||
|
case INDEX_op_negsetcond_i64:
|
||||||
return C_O1_I2(r, rz, rz);
|
return C_O1_I2(r, rz, rz);
|
||||||
|
|
||||||
case INDEX_op_deposit_i32:
|
case INDEX_op_deposit_i32:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue