[AArch64] PR target/69161: Don't use special predicate for CCmode comparisons in...
authorKyrylo Tkachov <kyrylo.tkachov@arm.com>
Wed, 17 Feb 2016 13:42:35 +0000 (13:42 +0000)
committerKyrylo Tkachov <ktkachov@gcc.gnu.org>
Wed, 17 Feb 2016 13:42:35 +0000 (13:42 +0000)
PR target/69161
* config/aarch64/predicates.md (aarch64_comparison_operator_mode):
New predicate.
(aarch64_comparison_operator): Break overly long line into two.
(aarch64_comparison_operation): Likewise.
* config/aarch64/aarch64.md (cstorecc4): Use
aarch64_comparison_operator_mode instead of
aarch64_comparison_operator.
(cstore<mode>4): Likewise.
(aarch64_cstore<mode>): Likewise.
(*cstoresi_insn_uxtw): Likewise.
(cstore<mode>_neg): Likewise.
(*cstoresi_neg_uxtw): Likewise.

* gcc.c-torture/compile/pr69161.c: New test.

From-SVN: r233496

gcc/ChangeLog
gcc/config/aarch64/aarch64.md
gcc/config/aarch64/predicates.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/compile/pr69161.c [new file with mode: 0644]

index 5f4bd78..6d2a4bd 100644 (file)
@@ -1,6 +1,22 @@
 2016-02-17  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
 
        PR target/69161
+       * config/aarch64/predicates.md (aarch64_comparison_operator_mode):
+       New predicate.
+       (aarch64_comparison_operator): Break overly long line into two.
+       (aarch64_comparison_operation): Likewise.
+       * config/aarch64/aarch64.md (cstorecc4): Use
+       aarch64_comparison_operator_mode instead of
+       aarch64_comparison_operator.
+       (cstore<mode>4): Likewise.
+       (aarch64_cstore<mode>): Likewise.
+       (*cstoresi_insn_uxtw): Likewise.
+       (cstore<mode>_neg): Likewise.
+       (*cstoresi_neg_uxtw): Likewise.
+
+2016-02-17  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       PR target/69161
        * config/arm/predicates.md (arm_comparison_operator_mode):
        New predicate.
        * config/arm/arm.md (*mov_scc): Use arm_comparison_operator_mode
index 77bd191..68676c9 100644 (file)
 
 (define_expand "cstorecc4"
   [(set (match_operand:SI 0 "register_operand")
-       (match_operator 1 "aarch64_comparison_operator"
+       (match_operator 1 "aarch64_comparison_operator_mode"
        [(match_operand 2 "cc_register")
          (match_operand 3 "const0_operand")]))]
   ""
 
 (define_expand "cstore<mode>4"
   [(set (match_operand:SI 0 "register_operand" "")
-       (match_operator:SI 1 "aarch64_comparison_operator"
+       (match_operator:SI 1 "aarch64_comparison_operator_mode"
         [(match_operand:GPF 2 "register_operand" "")
          (match_operand:GPF 3 "aarch64_fp_compare_operand" "")]))]
   ""
 
 (define_insn "aarch64_cstore<mode>"
   [(set (match_operand:ALLI 0 "register_operand" "=r")
-       (match_operator:ALLI 1 "aarch64_comparison_operator"
+       (match_operator:ALLI 1 "aarch64_comparison_operator_mode"
         [(match_operand 2 "cc_register" "") (const_int 0)]))]
   ""
   "cset\\t%<w>0, %m1"
 (define_insn "*cstoresi_insn_uxtw"
   [(set (match_operand:DI 0 "register_operand" "=r")
        (zero_extend:DI
-        (match_operator:SI 1 "aarch64_comparison_operator"
+        (match_operator:SI 1 "aarch64_comparison_operator_mode"
          [(match_operand 2 "cc_register" "") (const_int 0)])))]
   ""
   "cset\\t%w0, %m1"
 
 (define_insn "cstore<mode>_neg"
   [(set (match_operand:ALLI 0 "register_operand" "=r")
-       (neg:ALLI (match_operator:ALLI 1 "aarch64_comparison_operator"
+       (neg:ALLI (match_operator:ALLI 1 "aarch64_comparison_operator_mode"
                  [(match_operand 2 "cc_register" "") (const_int 0)])))]
   ""
   "csetm\\t%<w>0, %m1"
 (define_insn "*cstoresi_neg_uxtw"
   [(set (match_operand:DI 0 "register_operand" "=r")
        (zero_extend:DI
-        (neg:SI (match_operator:SI 1 "aarch64_comparison_operator"
+        (neg:SI (match_operator:SI 1 "aarch64_comparison_operator_mode"
                  [(match_operand 2 "cc_register" "") (const_int 0)]))))]
   ""
   "csetm\\t%w0, %m1"
index e80e406..1186827 100644 (file)
 
 ;; True for integer comparisons and for FP comparisons other than LTGT or UNEQ.
 (define_special_predicate "aarch64_comparison_operator"
-  (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,ordered,unlt,unle,unge,ungt"))
+  (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
+              ordered,unlt,unle,unge,ungt"))
+
+;; Same as aarch64_comparison_operator but don't ignore the mode.
+;; RTL SET operations require their operands source and destination have
+;; the same modes, so we can't ignore the modes there.  See PR target/69161.
+(define_predicate "aarch64_comparison_operator_mode"
+  (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
+              ordered,unlt,unle,unge,ungt"))
 
 (define_special_predicate "aarch64_comparison_operation"
-  (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,ordered,unlt,unle,unge,ungt")
+  (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
+              ordered,unlt,unle,unge,ungt")
 {
   if (XEXP (op, 1) != const0_rtx)
     return false;
index ffe84ee..660d471 100644 (file)
@@ -1,3 +1,8 @@
+2016-02-17  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       PR target/69161
+       * gcc.c-torture/compile/pr69161.c: New test.
+
 2016-02-17  David Sherwood  <david.sherwood@arm.com>
 
        PR target/69532
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr69161.c b/gcc/testsuite/gcc.c-torture/compile/pr69161.c
new file mode 100644 (file)
index 0000000..fdbb63f
--- /dev/null
@@ -0,0 +1,19 @@
+/* PR target/69161.  */
+
+char a;
+int b, c, d, e;
+
+void
+foo (void)
+{
+  int f;
+  for (f = 0; f <= 4; f++)
+    {
+      for (d = 0; d < 20; d++)
+       {
+         __INTPTR_TYPE__ g = (__INTPTR_TYPE__) & c;
+         b &= (0 != g) > e;
+       }
+      e &= a;
+    }
+}