re PR target/47197 (ICE in gimplify_expr, at gimplify.c:7153 on AltiVec code (vec_dst))
authorBill Schmidt <wschmidt@linux.vnet.ibm.com>
Tue, 24 Apr 2012 15:51:58 +0000 (15:51 +0000)
committerWilliam Schmidt <wschmidt@gcc.gnu.org>
Tue, 24 Apr 2012 15:51:58 +0000 (15:51 +0000)
gcc:

2012-04-24  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>

PR target/47197
* config/rs6000/rs6000-c.c (fully_fold_convert): New function.
(altivec_build_resolved_builtin): Call fully_fold_convert.

gcc/testsuite:

2012-04-24  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>

PR target/47197
* gcc.target/powerpc/pr47197.c: New test.

From-SVN: r186771

gcc/ChangeLog
gcc/config/rs6000/rs6000-c.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/powerpc/pr47197.c [new file with mode: 0644]

index 9d55ef06477fd91e1a2ead12dc75bff02f7c26b1..5eb9411fc1376579f742858884b074750deacf91 100644 (file)
@@ -1,3 +1,9 @@
+2012-04-24  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
+
+       PR target/47197
+       * config/rs6000/rs6000-c.c (fully_fold_convert): New function.
+       (altivec_build_resolved_builtin): Call fully_fold_convert.
+
 2012-04-24  Georg-Johann Lay  <avr@gjlay.de>
 
        PR target/53065
index 76a21463ec3183607cdb5ccc0c81f584f10049ae..0717b91b2bc2d1782d47fa4ac6b524d7f812098a 100644 (file)
@@ -3421,6 +3421,22 @@ rs6000_builtin_type_compatible (tree t, int id)
 }
 
 
+/* In addition to calling fold_convert for EXPR of type TYPE, also
+   call c_fully_fold to remove any C_MAYBE_CONST_EXPRs that could be
+   hiding there (PR47197).  */
+
+static tree
+fully_fold_convert (tree type, tree expr)
+{
+  tree result = fold_convert (type, expr);
+  bool maybe_const = true;
+
+  if (!c_dialect_cxx ())
+    result = c_fully_fold (result, false, &maybe_const);
+
+  return result;
+}
+
 /* Build a tree for a function call to an Altivec non-overloaded builtin.
    The overloaded builtin that matched the types and args is described
    by DESC.  The N arguments are given in ARGS, respectively.  
@@ -3470,18 +3486,18 @@ altivec_build_resolved_builtin (tree *args, int n,
       break;
     case 1:
       call = build_call_expr (impl_fndecl, 1,
-                             fold_convert (arg_type[0], args[0]));
+                             fully_fold_convert (arg_type[0], args[0]));
       break;
     case 2:
       call = build_call_expr (impl_fndecl, 2,
-                             fold_convert (arg_type[0], args[0]),
-                             fold_convert (arg_type[1], args[1]));
+                             fully_fold_convert (arg_type[0], args[0]),
+                             fully_fold_convert (arg_type[1], args[1]));
       break;
     case 3:
       call = build_call_expr (impl_fndecl, 3,
-                             fold_convert (arg_type[0], args[0]),
-                             fold_convert (arg_type[1], args[1]),
-                             fold_convert (arg_type[2], args[2]));
+                             fully_fold_convert (arg_type[0], args[0]),
+                             fully_fold_convert (arg_type[1], args[1]),
+                             fully_fold_convert (arg_type[2], args[2]));
       break;
     default:
       gcc_unreachable ();
index 646a150f134e9530e5bd83fcbc05aaf4b0548d8a..0a4d974ef08ec59cf05bfce50c08b2291faa0d36 100644 (file)
@@ -1,3 +1,8 @@
+2012-04-24  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
+
+       PR target/47197
+       * gcc.target/powerpc/pr47197.c: New test.
+       
 2012-04-24  Richard Guenther  <rguenther@suse.de>
 
        PR tree-optimization/53085
diff --git a/gcc/testsuite/gcc.target/powerpc/pr47197.c b/gcc/testsuite/gcc.target/powerpc/pr47197.c
new file mode 100644 (file)
index 0000000..729dcfb
--- /dev/null
@@ -0,0 +1,12 @@
+/* { dg-do compile } */
+/* { dg-options "-maltivec" } */
+
+/* Compile-only test to ensure that expressions can be passed to
+   Altivec builtins without error.  */
+
+#include <altivec.h>
+
+void func(unsigned char *buf, unsigned len)
+{
+        vec_dst(buf, (len >= 256 ? 0 : len) | 512, 2);
+}