From: Aurelien Jarno Date: Mon, 1 Mar 2010 21:33:49 +0000 (+0100) Subject: tcg/arm: implement setcond2 X-Git-Tag: v0.13.0-rc0~1227 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=e0404769facf1a009b94a53c076adb02bfda48ad;p=thirdparty%2Fqemu.git tcg/arm: implement setcond2 Signed-off-by: Aurelien Jarno Signed-off-by: Andrzej Zaborowski --- diff --git a/tcg/arm/tcg-target.c b/tcg/arm/tcg-target.c index 9a76ecb8458..d743dbcb725 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" } },