OSDN Git Service

Correct expand_vec_perm_blend in i386.c for V8HImode merge.
authorhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 26 Feb 2010 13:18:17 +0000 (13:18 +0000)
committerhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 26 Feb 2010 13:18:17 +0000 (13:18 +0000)
gcc/

2010-02-26  Uros Bizjak  <ubizjak@gmail.com>

PR target/43175
* config/i386/i386.c (expand_vec_perm_blend): Use correct
operands in V8HImode subregs.  Fix operand order in VEC_MERGE
rtx.

gcc/testsuite/

2010-02-26  H.J. Lu  <hongjiu.lu@intel.com>

PR target/43175
* gcc.target/i386/vperm-v4si-2-sse4.c: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@157087 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/vperm-v4si-2-sse4.c [new file with mode: 0644]

index 6374791..5c889ad 100644 (file)
@@ -1,3 +1,10 @@
+2010-02-26  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/43175
+       * config/i386/i386.c (expand_vec_perm_blend): Use correct
+       operands in V8HImode subregs.  Fix operand order in VEC_MERGE
+       rtx.
+
 2010-02-26  Jan Kratochvil  <jan.kratochvil@redhat.com>
 
        * doc/invoke.texi (-fvar-tracking-assignments): Fix typo.
index bb03cba..3a3b2ac 100644 (file)
@@ -29144,8 +29144,8 @@ expand_vec_perm_blend (struct expand_vec_perm_d *d)
     do_subreg:
       vmode = V8HImode;
       target = gen_lowpart (vmode, target);
-      op0 = gen_lowpart (vmode, target);
-      op1 = gen_lowpart (vmode, target);
+      op0 = gen_lowpart (vmode, op0);
+      op1 = gen_lowpart (vmode, op1);
       break;
 
     default:
@@ -29153,7 +29153,7 @@ expand_vec_perm_blend (struct expand_vec_perm_d *d)
     }
 
   /* This matches five different patterns with the different modes.  */
-  x = gen_rtx_VEC_MERGE (vmode, op0, op1, GEN_INT (mask));
+  x = gen_rtx_VEC_MERGE (vmode, op1, op0, GEN_INT (mask));
   x = gen_rtx_SET (VOIDmode, target, x);
   emit_insn (x);
 
index f738c32..8c78047 100644 (file)
@@ -1,3 +1,8 @@
+2010-02-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/43175
+       * gcc.target/i386/vperm-v4si-2-sse4.c: New.
+
 2010-02-25  Eric Botcazou  <ebotcazou@adacore.com>
 
        * g++.dg/abi/packed1.C: Expect warning on the SPARC.
diff --git a/gcc/testsuite/gcc.target/i386/vperm-v4si-2-sse4.c b/gcc/testsuite/gcc.target/i386/vperm-v4si-2-sse4.c
new file mode 100644 (file)
index 0000000..1f35b82
--- /dev/null
@@ -0,0 +1,4 @@
+/* { dg-do run } */
+/* { dg-require-effective-target sse4 } */
+/* { dg-options "-O -msse4" } */
+#include "vperm-v4si-2.c"