aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/combine.c4
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/mips/truncate-3.c11
4 files changed, 21 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 59a4f35..2a28379 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2009-06-22 Adam Nemet <anemet@caviumnetworks.com>
+
+ * combine.c (combine_simplify_rtx): Remove TRULY_NOOP_TRUNCATION
+ check when calling force_to_mode on TRUNCATE's operand.
+
2009-06-22 Ian Lance Taylor <iant@google.com>
* config/rs6000/rs6000.opt: Move msched-epilog before
diff --git a/gcc/combine.c b/gcc/combine.c
index b7c4f1c..abe43b9 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -4889,9 +4889,7 @@ combine_simplify_rtx (rtx x, enum machine_mode op0_mode, int in_dest)
if (GET_MODE_CLASS (mode) == MODE_PARTIAL_INT)
break;
- if (GET_MODE_BITSIZE (mode) <= HOST_BITS_PER_WIDE_INT
- && TRULY_NOOP_TRUNCATION (GET_MODE_BITSIZE (mode),
- GET_MODE_BITSIZE (GET_MODE (XEXP (x, 0)))))
+ if (GET_MODE_BITSIZE (mode) <= HOST_BITS_PER_WIDE_INT)
SUBST (XEXP (x, 0),
force_to_mode (XEXP (x, 0), GET_MODE (XEXP (x, 0)),
GET_MODE_MASK (mode), 0));
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 59918e1..7dbb38f 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2009-06-22 Adam Nemet <anemet@caviumnetworks.com>
+
+ * gcc.target/mips/truncate-3.c: New test.
+
2009-06-22 Janus Weil <janus@gcc.gnu.org>
PR fortran/37254
diff --git a/gcc/testsuite/gcc.target/mips/truncate-3.c b/gcc/testsuite/gcc.target/mips/truncate-3.c
new file mode 100644
index 0000000..90f2c77
--- /dev/null
+++ b/gcc/testsuite/gcc.target/mips/truncate-3.c
@@ -0,0 +1,11 @@
+/* Remove redundant operations in truncate's operand. */
+/* { dg-options "-O -mgp64" } */
+/* { dg-final { scan-assembler-not "\tandi?\t" } } */
+
+f (long long d)
+{
+ long long c = d & 0xffffffffff;
+ int i = (int) c;
+ g (i);
+}
+