aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Krebbel <Andreas.Krebbel@de.ibm.com>2014-03-27 15:38:29 +0000
committerAndreas Krebbel <krebbel@gcc.gnu.org>2014-03-27 15:38:29 +0000
commit6e77facf95d5a2f42afc26d505a5771f5d2a7e7d (patch)
tree2ca0ac0e4dada8c049c2be1623704d083ff78ff6
parentba1925c3688053d6279e6c12d1689ebb13fb5128 (diff)
downloadgcc-6e77facf95d5a2f42afc26d505a5771f5d2a7e7d.zip
gcc-6e77facf95d5a2f42afc26d505a5771f5d2a7e7d.tar.gz
gcc-6e77facf95d5a2f42afc26d505a5771f5d2a7e7d.tar.bz2
s390.c (s390_can_use_return_insn): Check for call-saved FPRs on 31 bit.
2014-03-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> * config/s390/s390.c (s390_can_use_return_insn): Check for call-saved FPRs on 31 bit. 2014-03-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> * gcc.target/s390/20140327-1.c: New testcase. From-SVN: r208867
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/config/s390/s390.c7
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/s390/20140327-1.c10
4 files changed, 26 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index fb61812..674f3a44 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2014-03-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
+
+ * config/s390/s390.c (s390_can_use_return_insn): Check for
+ call-saved FPRs on 31 bit.
+
2014-03-27 Jakub Jelinek <jakub@redhat.com>
PR middle-end/60682
diff --git a/gcc/config/s390/s390.c b/gcc/config/s390/s390.c
index 7a79286..bdb577c 100644
--- a/gcc/config/s390/s390.c
+++ b/gcc/config/s390/s390.c
@@ -9225,6 +9225,13 @@ s390_can_use_return_insn (void)
if (cfun_gpr_save_slot (i))
return false;
+ /* For 31 bit this is not covered by the frame_size check below
+ since f4, f6 are saved in the register save area without needing
+ additional stack space. */
+ if (!TARGET_64BIT
+ && (cfun_fpr_save_p (FPR4_REGNUM) || cfun_fpr_save_p (FPR6_REGNUM)))
+ return false;
+
if (cfun->machine->base_reg
&& !call_really_used_regs[REGNO (cfun->machine->base_reg)])
return false;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index c2a13d9..bcdaa3d 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2014-03-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
+
+ * gcc.target/s390/20140327-1.c: New testcase.
+
2014-03-27 Jakub Jelinek <jakub@redhat.com>
PR middle-end/60682
diff --git a/gcc/testsuite/gcc.target/s390/20140327-1.c b/gcc/testsuite/gcc.target/s390/20140327-1.c
new file mode 100644
index 0000000..f71c38f
--- /dev/null
+++ b/gcc/testsuite/gcc.target/s390/20140327-1.c
@@ -0,0 +1,10 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -m31 -mzarch" } */
+
+void
+foo ()
+{
+ asm ("" ::: "%f4");
+}
+
+/* { dg-final { scan-assembler "ld" } } */