tcg-sparc: Use ADDXC in setcond_i64
authorRichard Henderson <rth@twiddle.net>
Wed, 6 Aug 2014 19:11:25 +0000 (12:11 -0700)
committerRichard Henderson <rth@redhat.com>
Mon, 29 Sep 2014 18:55:27 +0000 (14:55 -0400)
Similar to the ADDC tricks we use in setcond_i32.

Signed-off-by: Richard Henderson <rth@twiddle.net>
tcg/sparc/tcg-target.c

index 3b232d63331fac8ad8ecb68925f7d493bb0e3057..d0bd08cb85401514110609aebcd7f2f81f8a33ab 100644 (file)
@@ -716,6 +716,23 @@ static void tcg_out_setcond_i32(TCGContext *s, TCGCond cond, TCGReg ret,
 static void tcg_out_setcond_i64(TCGContext *s, TCGCond cond, TCGReg ret,
                                 TCGReg c1, int32_t c2, int c2const)
 {
+    if (use_vis3_instructions) {
+        switch (cond) {
+        case TCG_COND_NE:
+            if (c2 != 0) {
+                break;
+            }
+            c2 = c1, c2const = 0, c1 = TCG_REG_G0;
+            /* FALLTHRU */
+        case TCG_COND_LTU:
+            tcg_out_cmp(s, c1, c2, c2const);
+            tcg_out_arith(s, ret, TCG_REG_G0, TCG_REG_G0, ARITH_ADDXC);
+            return;
+        default:
+            break;
+        }
+    }
+
     /* For 64-bit signed comparisons vs zero, we can avoid the compare
        if the input does not overlap the output.  */
     if (c2 == 0 && !is_unsigned_cond(cond) && c1 != ret) {