aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJeff Law <law@redhat.com>2017-04-18 22:52:54 -0600
committerJeff Law <law@gcc.gnu.org>2017-04-18 22:52:54 -0600
commitd904a98328774c6df5d0aa6e2940b749dc36b12c (patch)
treee4d111ca9e9114d438f2ce2b87bce5d33ad3a700 /gcc
parent90e87d4f1a7b2d91dae78385485ccb74d19d08e2 (diff)
downloadgcc-d904a98328774c6df5d0aa6e2940b749dc36b12c.zip
gcc-d904a98328774c6df5d0aa6e2940b749dc36b12c.tar.gz
gcc-d904a98328774c6df5d0aa6e2940b749dc36b12c.tar.bz2
re PR target/74563 (Classic MIPS16 (non-MIPS16e) function return broken)
PR target/74563 * mips.md ({return,simple_return}_internal): Do not overwrite operands[0]. PR target/74563 * gcc.target/mips/pr74563: New test. From-SVN: r246987
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/config/mips/mips.md1
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.target/mips/pr74563.c14
4 files changed, 25 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index ea44ddb..7aa8c03 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2017-04-18 Jeff Law <law@redhat.com>
+
+ PR target/74563
+ * mips.md ({return,simple_return}_internal): Do not overwrite
+ operands[0].
+
2017-04-18 Jakub Jelinek <jakub@redhat.com>
PR tree-optimization/80443
diff --git a/gcc/config/mips/mips.md b/gcc/config/mips/mips.md
index 7acf00d..28e0a44 100644
--- a/gcc/config/mips/mips.md
+++ b/gcc/config/mips/mips.md
@@ -6585,7 +6585,6 @@
(use (match_operand 0 "pmode_register_operand" ""))]
""
{
- operands[0] = gen_rtx_REG (Pmode, RETURN_ADDR_REGNUM);
return mips_output_jump (operands, 0, -1, false);
}
[(set_attr "type" "jump")
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 11410bb..c21e373 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-04-18 Jeff Law <law@redhat.com>
+
+ PR target/74563
+ * gcc.target/mips/pr74563: New test.
+
2017-04-18 Jakub Jelinek <jakub@redhat.com>
PR tree-optimization/80443
diff --git a/gcc/testsuite/gcc.target/mips/pr74563.c b/gcc/testsuite/gcc.target/mips/pr74563.c
new file mode 100644
index 0000000..09545fc
--- /dev/null
+++ b/gcc/testsuite/gcc.target/mips/pr74563.c
@@ -0,0 +1,14 @@
+/* { dg-do compile } */
+/* { dg-options "-mips3 -mips16 -msoft-float" } */
+
+void f2(void);
+
+void f1(void)
+{
+ f2();
+}
+
+/* { dg-final { scan-assembler-not "\tjr\t\\\$31" } } */
+/* { dg-final { scan-assembler "\tjr\t\\\$7" } } */
+
+