]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: vsx.md (vsx_set_<mode>): Reorder operands.
authorPeter Bergner <bergner@vnet.ibm.com>
Fri, 2 Mar 2012 22:12:52 +0000 (16:12 -0600)
committerPeter Bergner <bergner@gcc.gnu.org>
Fri, 2 Mar 2012 22:12:52 +0000 (16:12 -0600)
Backport from mainline
2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
gcc/
* config/rs6000/vsx.md (vsx_set_<mode>): Reorder operands.

gcc/testsuite/
* gcc.target/powerpc/pr52457.c: New test.

From-SVN: r184834

gcc/ChangeLog
gcc/config/rs6000/vsx.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/powerpc/pr52457.c [new file with mode: 0644]

index 22a1359dd964bb2a2324af6200a698b08487709e..9648450c7186e353457bb86e3e4d4254ec5d2fce 100644 (file)
@@ -1,3 +1,10 @@
+2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
+
+       Backport from mainline
+       2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * config/rs6000/vsx.md (vsx_set_<mode>): Reorder operands.
+
 2012-03-02  Bill Schmidt <wschmidt@linux.vnet.ibm.com>
            Ira Rosen <irar@il.ibm.com>
 
index b45f51020f199ec4e6269e968d5efbc6ff3d39c9..05c794e1dfa3290f6081feb04ebff17c68632e25 100644 (file)
   "VECTOR_MEM_VSX_P (<MODE>mode)"
 {
   if (INTVAL (operands[3]) == 0)
-    return \"xxpermdi %x0,%x1,%x2,1\";
+    return \"xxpermdi %x0,%x2,%x1,1\";
   else if (INTVAL (operands[3]) == 1)
-    return \"xxpermdi %x0,%x2,%x1,0\";
+    return \"xxpermdi %x0,%x1,%x2,0\";
   else
     gcc_unreachable ();
 }
index db7cd8b39410a1259c8574bd767bfeea840fee5c..567a8deaa4514c69ead2e7d717eec49396ef4c14 100644 (file)
@@ -1,3 +1,10 @@
+2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
+
+       Backport from mainline
+       2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * gcc.target/powerpc/pr52457.c: New test.
+
 2012-03-01  Release Manager
 
        * GCC 4.6.3 released.
diff --git a/gcc/testsuite/gcc.target/powerpc/pr52457.c b/gcc/testsuite/gcc.target/powerpc/pr52457.c
new file mode 100644 (file)
index 0000000..4470e55
--- /dev/null
@@ -0,0 +1,34 @@
+/* { dg-do run { target { powerpc*-*-linux* } } } */
+/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
+/* { dg-skip-if "" { powerpc*-*-*spe* } { "*" } { "" } } */
+/* { dg-require-effective-target vsx_hw } */
+/* { dg-options "-O1 -mcpu=power7" } */
+
+extern void abort (void);
+
+typedef long long T;
+typedef T vl_t __attribute__((vector_size(2 * sizeof (T))));
+
+vl_t
+buggy_func (T x)
+{
+  vl_t w;
+  T *p = (T *)&w;
+  p[0] = p[1] = x;
+  return w;
+}
+
+int
+main(void)
+{
+  vl_t rval;
+  T *pl;
+
+  pl = (T *) &rval;
+  rval = buggy_func (2);
+
+  if (pl[0] != 2 || pl[1] != 2)
+    abort ();
+
+  return 0;
+}