From e0404769facf1a009b94a53c076adb02bfda48ad Mon Sep 17 00:00:00 2001 From: Aurelien Jarno Date: Mon, 1 Mar 2010 22:33:49 +0100 Subject: [PATCH] tcg/arm: implement setcond2 Signed-off-by: Aurelien Jarno Signed-off-by: Andrzej Zaborowski --- tcg/arm/tcg-target.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/tcg/arm/tcg-target.c b/tcg/arm/tcg-target.c index 9a76ecb84..d743dbcb7 100644 --- a/tcg/arm/tcg-target.c +++ b/tcg/arm/tcg-target.c @@ -1539,6 +1539,16 @@ static inline void tcg_out_op(TCGContext *s, int opc, tcg_out_dat_imm(s, tcg_cond_to_arm_cond[tcg_invert_cond(args[3])], ARITH_MOV, args[0], 0, 0); break; + case INDEX_op_setcond2_i32: + /* See brcond2_i32 comment */ + tcg_out_dat_reg(s, COND_AL, ARITH_CMP, 0, + args[2], args[4], SHIFT_IMM_LSL(0)); + tcg_out_dat_reg(s, COND_EQ, ARITH_CMP, 0, + args[1], args[3], SHIFT_IMM_LSL(0)); + tcg_out_dat_imm(s, tcg_cond_to_arm_cond[args[5]], + ARITH_MOV, args[0], 0, 1); + tcg_out_dat_imm(s, tcg_cond_to_arm_cond[tcg_invert_cond(args[5])], + ARITH_MOV, args[0], 0, 0); case INDEX_op_qemu_ld8u: tcg_out_qemu_ld(s, COND_AL, args, 0); @@ -1643,6 +1653,7 @@ static const TCGTargetOpDef arm_op_defs[] = { { INDEX_op_add2_i32, { "r", "r", "r", "r", "r", "r" } }, { INDEX_op_sub2_i32, { "r", "r", "r", "r", "r", "r" } }, { INDEX_op_brcond2_i32, { "r", "r", "r", "r" } }, + { INDEX_op_setcond2_i32, { "r", "r", "r", "r", "r" } }, { INDEX_op_qemu_ld8u, { "r", "x", "X" } }, { INDEX_op_qemu_ld8s, { "r", "x", "X" } }, -- 2.39.5