match.pd ((convert (op:s (convert@2 @0) (convert?@3 @1)))): Add support for constant...
authorBin Cheng <bin.cheng@arm.com>
Thu, 27 Oct 2016 14:59:04 +0000 (14:59 +0000)
committerBin Cheng <amker@gcc.gnu.org>
Thu, 27 Oct 2016 14:59:04 +0000 (14:59 +0000)
* match.pd ((convert (op:s (convert@2 @0) (convert?@3 @1)))): Add
support for constant operand for OP.

gcc/testsuite
* gcc.dg/fold-narrowbopcst-1.c: New test.

From-SVN: r241624

gcc/ChangeLog
gcc/match.pd
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/fold-narrowbopcst-1.c [new file with mode: 0644]

index 9eea9a3b7a3113faa0bca8cfc88e19f9a715369b..73d3004b7cdd394aed50a40c8f03efa91c5bf411 100644 (file)
@@ -1,3 +1,8 @@
+2016-10-27  Bin Cheng  <bin.cheng@arm.com>
+
+       * match.pd ((convert (op:s (convert@2 @0) (convert?@3 @1)))): Add
+       support for constant operand for OP.
+
 2016-10-27  Jakub Jelinek  <jakub@redhat.com>
 
        * dwarf2out.c (gen_member_die): Only reparent_child instead of
index 73bee34dcc5a82152952a02f1fc5afa9efac71ff..48f73514a3fa6bfef3e4af0b8cbdce6eed46470f 100644 (file)
@@ -3277,7 +3277,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
    operation and convert the result to the desired type.  */
 (for op (plus minus)
   (simplify
-    (convert (op:s (convert@2 @0) (convert@3 @1)))
+    (convert (op:s (convert@2 @0) (convert?@3 @1)))
     (if (INTEGRAL_TYPE_P (type)
         /* We check for type compatibility between @0 and @1 below,
            so there's no need to check that @1/@3 are integral types.  */
@@ -3293,12 +3293,16 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
         && TYPE_PRECISION (type) == GET_MODE_PRECISION (TYPE_MODE (type))
         /* The inner conversion must be a widening conversion.  */
         && TYPE_PRECISION (TREE_TYPE (@2)) > TYPE_PRECISION (TREE_TYPE (@0))
-        && types_match (@0, @1)
-        && types_match (@0, type))
+        && types_match (@0, type)
+        && (types_match (@0, @1)
+            /* Or the second operand is const integer or converted const
+               integer from valueize.  */
+            || TREE_CODE (@1) == INTEGER_CST))
       (if (TYPE_OVERFLOW_WRAPS (TREE_TYPE (@0)))
-       (convert (op @0 @1))
+       (op @0 (convert @1))
        (with { tree utype = unsigned_type_for (TREE_TYPE (@0)); }
-        (convert (op (convert:utype @0) (convert:utype @1))))))))
+        (convert (op (convert:utype @0)
+                     (convert:utype @1))))))))
 
 /* This is another case of narrowing, specifically when there's an outer
    BIT_AND_EXPR which masks off bits outside the type of the innermost
index 22a9ce83ac39f979826146b4b1e6935e1302daf0..72f669cfcf74d3975442d40a50fc95b32def95cb 100644 (file)
@@ -1,3 +1,7 @@
+2016-10-27  Bin Cheng  <bin.cheng@arm.com>
+
+       * gcc.dg/fold-narrowbopcst-1.c: New test.
+
 2016-10-27  Fritz Reese <fritzoreese@gmail.com>
 
        * gfortran.dg/dec_io_5.f90: Don't use "test.txt", and use
diff --git a/gcc/testsuite/gcc.dg/fold-narrowbopcst-1.c b/gcc/testsuite/gcc.dg/fold-narrowbopcst-1.c
new file mode 100644 (file)
index 0000000..8a33677
--- /dev/null
@@ -0,0 +1,14 @@
+/* { dg-do compile } */
+/* { dg-options "-O1 -fdump-tree-optimized" } */
+
+int foo1 (unsigned char a[], unsigned int x)
+{
+  unsigned int i;
+  for (i = 0; i < 1000; i++)
+    {
+      x = a[i];
+      a[i] = (unsigned char)(x >= 100 ? x - 100 : 0);
+    }
+  return x;
+}
+/* { dg-final { scan-tree-dump " = _.* \\+ 156" "optimized" } } */