re PR middle-end/52750 (32xsigned char __builtin_shuffle)
authorJakub Jelinek <jakub@redhat.com>
Wed, 28 Mar 2012 14:40:57 +0000 (16:40 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 28 Mar 2012 14:40:57 +0000 (16:40 +0200)
PR middle-end/52750
* tree-vect-generic.c (vector_element): Perform multiplication
for pos in bitsizetype type instead of idx type.

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

From-SVN: r185914

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/compile/pr52750.c [new file with mode: 0644]
gcc/tree-vect-generic.c

index 3509bda22595133523742ccceff7da95a8ffe9c9..a33cac30620764a343d5a06db3ba086f35b9ccbb 100644 (file)
@@ -1,3 +1,9 @@
+2012-03-28  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/52750
+       * tree-vect-generic.c (vector_element): Perform multiplication
+       for pos in bitsizetype type instead of idx type.
+
 2012-03-28  Richard Guenther  <rguenther@suse.de>
 
        * loop-init.c (loop_optimizer_init): If loops are preserved
index d4d2bc170e88eb1cad5563645bbf5fa41c954d00..d3344759cda9f7ed27b1fe72b48664acb980b84f 100644 (file)
@@ -1,3 +1,8 @@
+2012-03-28  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/52750
+       * gcc.c-torture/compile/pr52750.c: New test.
+
 2012-03-28  Georg-Johann Lay  <avr@gjlay.de>
 
        PR target/52692
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr52750.c b/gcc/testsuite/gcc.c-torture/compile/pr52750.c
new file mode 100644 (file)
index 0000000..36391ba
--- /dev/null
@@ -0,0 +1,11 @@
+/* PR middle-end/52750 */
+
+typedef signed char V __attribute__((vector_size (32)));
+
+void
+foo (V *x)
+{
+  V m = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
+         16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31};
+  *x = __builtin_shuffle (*x, m);
+}
index 203f62caec7c2e4939ae01ec3d394169cfb98be7..e0146c210797a04f3f7a7c5f6d208e19edf798be 100644 (file)
@@ -567,8 +567,9 @@ vector_element (gimple_stmt_iterator *gsi, tree vect, tree idx, tree *ptmpvec)
       else
         {
          tree size = TYPE_SIZE (vect_elt_type);
-          tree pos = fold_build2 (MULT_EXPR, TREE_TYPE (idx), idx, size);
-          return fold_build3 (BIT_FIELD_REF, vect_elt_type, vect, size, pos);
+         tree pos = fold_build2 (MULT_EXPR, bitsizetype, bitsize_int (index),
+                                 size);
+         return fold_build3 (BIT_FIELD_REF, vect_elt_type, vect, size, pos);
         }
     }