diff options
-rw-r--r-- | target-tilegx/translate.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/target-tilegx/translate.c b/target-tilegx/translate.c index f15d0d0ac6..31b6a6cc06 100644 --- a/target-tilegx/translate.c +++ b/target-tilegx/translate.c @@ -503,9 +503,16 @@ static TileExcp gen_rrr_opcode(DisasContext *dc, unsigned opext, break; case OE_RRR(CMOVEQZ, 0, X0): case OE_RRR(CMOVEQZ, 4, Y0): + tcg_gen_movcond_tl(TCG_COND_EQ, tdest, tsrca, load_zero(dc), + tsrcb, load_gr(dc, dest)); + mnemonic = "cmoveqz"; + break; case OE_RRR(CMOVNEZ, 0, X0): case OE_RRR(CMOVNEZ, 4, Y0): - return TILEGX_EXCP_OPCODE_UNIMPLEMENTED; + tcg_gen_movcond_tl(TCG_COND_NE, tdest, tsrca, load_zero(dc), + tsrcb, load_gr(dc, dest)); + mnemonic = "cmovnez"; + break; case OE_RRR(CMPEQ, 0, X0): case OE_RRR(CMPEQ, 0, X1): case OE_RRR(CMPEQ, 3, Y0): |