]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: htm.md (ttest): Use correct shift value to get CR0.
authorPeter Bergner <bergner@vnet.ibm.com>
Thu, 22 May 2014 16:07:07 +0000 (11:07 -0500)
committerPeter Bergner <bergner@gcc.gnu.org>
Thu, 22 May 2014 16:07:07 +0000 (11:07 -0500)
Backport from mainline
2014-05-22  Peter Bergner  <bergner@vnet.ibm.com>

gcc/
* config/rs6000/htm.md (ttest): Use correct shift value to get CR0.

gcc/testsuite/
* gcc.target/powerpc/htm-ttest.c: New test.

From-SVN: r210818

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

index 97346e852c060367cfa57e56c54bc61e63f37452..667a495b12f28026cd36529d313d6e2905f10afd 100644 (file)
@@ -1,3 +1,10 @@
+2014-05-22  Peter Bergner  <bergner@vnet.ibm.com>
+
+       Backport from mainline
+       2014-05-22  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * config/rs6000/htm.md (ttest): Use correct shift value to get CR0.
+
 2014-05-22  Richard Earnshaw  <rearnsha@arm.com>
 
        PR target/61208
index e8ec91aef71d50c4e01a15f4963747f0fd32fbcb..1a1e4351e5c577af205cf24e5e238411ddbbf903 100644 (file)
                             (const_int 0)]
                            UNSPECV_HTM_TABORTWCI))
    (set (subreg:CC (match_dup 2) 0) (match_dup 1))
-   (set (match_dup 3) (lshiftrt:SI (match_dup 2) (const_int 24)))
+   (set (match_dup 3) (lshiftrt:SI (match_dup 2) (const_int 28)))
    (parallel [(set (match_operand:SI 0 "int_reg_operand" "")
                   (and:SI (match_dup 3) (const_int 15)))
               (clobber (scratch:CC))])]
index 28598e5da21af566dbefeb87e532416d29030ca9..1d4513fc7b540cc85a2dc737f341b8b2f6da1e34 100644 (file)
@@ -1,3 +1,10 @@
+2014-05-22  Peter Bergner  <bergner@vnet.ibm.com>
+
+       Backport from mainline
+       2014-05-22  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * gcc.target/powerpc/htm-ttest.c: New test.
+
 2014-05-22  Release Manager
 
        * GCC 4.8.3 released.
diff --git a/gcc/testsuite/gcc.target/powerpc/htm-ttest.c b/gcc/testsuite/gcc.target/powerpc/htm-ttest.c
new file mode 100644 (file)
index 0000000..29cbd5b
--- /dev/null
@@ -0,0 +1,14 @@
+/* { dg-do compile { target { powerpc*-*-* } } } */
+/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
+/* { dg-require-effective-target powerpc_htm_ok } */
+/* { dg-options "-O2 -mhtm" } */
+
+/* { dg-final { scan-assembler "rlwinm r?\[0-9\]+,r?\[0-9\]+,3,30,31" { target { ilp32 } } } } */
+/* { dg-final { scan-assembler "rldicl r?\[0-9\]+,r?\[0-9\]+,35,62" { target { lp64 } } } } */
+
+#include <htmintrin.h>
+long
+ttest (void)
+{
+  return _HTM_STATE(__builtin_ttest());
+}