aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobin Dapp <rdapp@linux.ibm.com>2019-07-08 14:42:49 +0000
committerRobin Dapp <rdapp@gcc.gnu.org>2019-07-08 14:42:49 +0000
commit5fad9d33e1dacbd754473e441f5e305ba7d3ef6c (patch)
tree9cefdcb9fd52e27cabd6c42c0b688464f71fbac0
parente2839e47894f0b4917ddbd59013071e98f525336 (diff)
downloadgcc-5fad9d33e1dacbd754473e441f5e305ba7d3ef6c.zip
gcc-5fad9d33e1dacbd754473e441f5e305ba7d3ef6c.tar.gz
gcc-5fad9d33e1dacbd754473e441f5e305ba7d3ef6c.tar.bz2
S/390: Define shift_truncation_mask.
Define s390_shift_truncation_mask to allow the optabs optimization sh = (64 - sh) -> sh = -sh for a rotation operation. gcc/ChangeLog: 2019-07-08 Robin Dapp <rdapp@linux.ibm.com> * config/s390/s390.c (s390_shift_truncation_mask): Define. (TARGET_SHIFT_TRUNCATION_MASK): Define. gcc/testsuite/ChangeLog: 2019-07-08 Robin Dapp <rdapp@linux.ibm.com> * gcc.target/s390/rotate-truncation-mask.c: New test. From-SVN: r273237
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/config/s390/s390.c8
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/s390/rotate-truncation-mask.c11
4 files changed, 28 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c4f0503..b47aead 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,10 @@
2019-07-08 Robin Dapp <rdapp@linux.ibm.com>
+ * config/s390/s390.c (s390_shift_truncation_mask): Define.
+ (TARGET_SHIFT_TRUNCATION_MASK): Define.
+
+2019-07-08 Robin Dapp <rdapp@linux.ibm.com>
+
* config/s390/constraints.md: Add new jsc constraint.
* config/s390/predicates.md: New predicates.
* config/s390/s390-protos.h (s390_valid_shift_count): New function.
diff --git a/gcc/config/s390/s390.c b/gcc/config/s390/s390.c
index 324d9d2..75b0b5b 100644
--- a/gcc/config/s390/s390.c
+++ b/gcc/config/s390/s390.c
@@ -16412,7 +16412,13 @@ s390_sched_dependencies_evaluation (rtx_insn *head, rtx_insn *tail)
add_dependence (r11_restore, r15_restore, REG_DEP_ANTI);
}
+/* Implement TARGET_SHIFT_TRUNCATION_MASK for integer shifts. */
+static unsigned HOST_WIDE_INT
+s390_shift_truncation_mask (machine_mode mode)
+{
+ return mode == DImode || mode == SImode ? 63 : 0;
+}
/* Initialize GCC target structure. */
@@ -16709,6 +16715,8 @@ s390_sched_dependencies_evaluation (rtx_insn *head, rtx_insn *tail)
#define TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK \
s390_sched_dependencies_evaluation
+#undef TARGET_SHIFT_TRUNCATION_MASK
+#define TARGET_SHIFT_TRUNCATION_MASK s390_shift_truncation_mask
/* Use only short displacement, since long displacement is not available for
the floating point instructions. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b1c6ea2..a7a67fb9 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,9 @@
2019-07-08 Robin Dapp <rdapp@linux.ibm.com>
+ * gcc.target/s390/rotate-truncation-mask.c: New test.
+
+2019-07-08 Robin Dapp <rdapp@linux.ibm.com>
+
* gcc.target/s390/combine-rotate-modulo.c: New test.
* gcc.target/s390/combine-shift-rotate-add-mod.c: New test.
* gcc.target/s390/vector/combine-shift-vec.c: New test.
diff --git a/gcc/testsuite/gcc.target/s390/rotate-truncation-mask.c b/gcc/testsuite/gcc.target/s390/rotate-truncation-mask.c
new file mode 100644
index 0000000..1cdd209
--- /dev/null
+++ b/gcc/testsuite/gcc.target/s390/rotate-truncation-mask.c
@@ -0,0 +1,11 @@
+/* Check that we do not use (64 - sh) for rotating. */
+
+/* { dg-options "-O1 -m64" } */
+
+/* { dg-final { scan-assembler "lcr\t%r.+,%r.+" } } */
+/* { dg-final { scan-assembler-not "lhi\t%r.+,64" } } */
+/* { dg-final { scan-assembler-not "sr\t%r.+,%r.+" } } */
+unsigned long rotr (unsigned long in, unsigned long sh)
+{
+ return (in >> sh) | (in << (64 - sh));
+}