aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUros Bizjak <ubizjak@gmail.com>2006-12-08 19:20:25 +0100
committerUros Bizjak <uros@gcc.gnu.org>2006-12-08 19:20:25 +0100
commit4280a3e362da8fbf6236b723f544ea598a00c9be (patch)
treed5926ab1190fe1d080932c18c3f0cf070e65bdb5
parent4efc447f98b3fb3ab60b79784e8f7ab88a8c7dc9 (diff)
downloadgcc-4280a3e362da8fbf6236b723f544ea598a00c9be.zip
gcc-4280a3e362da8fbf6236b723f544ea598a00c9be.tar.gz
gcc-4280a3e362da8fbf6236b723f544ea598a00c9be.tar.bz2
re PR target/30120 (silent miscompilation of argument passing)
PR target/30120 * reg-stack.c (convert_regs_entry): Mark current argument passing registers as live. * config/i386/i386.h (X87_REGPARM_MAX): Set to 0 to disable passing of float arguments in x87 registers. testsuite/ChangeLog: * gcc.target/i386/x87regparm-1.c: XFAIL. * gcc.target/i386/x87regparm-2.c: XFAIL. * gcc.target/i386/x87regparm-3.c: XFAIL. * gcc.target/i386/x87regparm-4.c: XFAIL. From-SVN: r119663
-rw-r--r--gcc/ChangeLog9
-rw-r--r--gcc/config/i386/i386.h4
-rw-r--r--gcc/reg-stack.c3
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.target/i386/x87regparm-1.c2
-rw-r--r--gcc/testsuite/gcc.target/i386/x87regparm-2.c2
-rw-r--r--gcc/testsuite/gcc.target/i386/x87regparm-3.c2
-rw-r--r--gcc/testsuite/gcc.target/i386/x87regparm-4.c2
8 files changed, 25 insertions, 6 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index bb90505..287d0de 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,12 @@
+2006-12-08 Uros Bizjak <ubizjak@gmail.com>
+
+ PR target/30120
+ * reg-stack.c (convert_regs_entry): Mark current argument passing
+ registers as live.
+
+ * config/i386/i386.h (X87_REGPARM_MAX): Set to 0 to disable passing
+ of float arguments in x87 registers.
+
2006-12-08 John David Anglin <dave.anglin.@nrc-cnrc.gc.ca>
* pa.h (LEGITIMATE_CONSTANT_P): Simplify.
diff --git a/gcc/config/i386/i386.h b/gcc/config/i386/i386.h
index dc15a2b..e05bf66 100644
--- a/gcc/config/i386/i386.h
+++ b/gcc/config/i386/i386.h
@@ -1778,7 +1778,9 @@ do { \
#define REGPARM_MAX (TARGET_64BIT ? 6 : 3)
-#define X87_REGPARM_MAX 3
+/* ??? Currently disabled, as reg-stack.c does not know how to
+ rearrange input registers if some arguments are left unused. */
+#define X87_REGPARM_MAX 0
#define SSE_REGPARM_MAX (TARGET_64BIT ? 8 : (TARGET_SSE ? 3 : 0))
diff --git a/gcc/reg-stack.c b/gcc/reg-stack.c
index 57924ce..327cee5 100644
--- a/gcc/reg-stack.c
+++ b/gcc/reg-stack.c
@@ -2595,7 +2595,8 @@ convert_regs_entry (void)
int reg, top = -1;
for (reg = LAST_STACK_REG; reg >= FIRST_STACK_REG; --reg)
- if (TEST_HARD_REG_BIT (bi->stack_in.reg_set, reg))
+ if (TEST_HARD_REG_BIT (bi->stack_in.reg_set, reg)
+ || TEST_HARD_REG_BIT (incoming_regs, reg))
{
rtx init;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index fe8632a..a054286 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2006-12-08 Uros Bizjak <ubizjak@gmail.com>
+
+ * gcc.target/i386/x87regparm-1.c: XFAIL.
+ * gcc.target/i386/x87regparm-2.c: XFAIL.
+ * gcc.target/i386/x87regparm-3.c: XFAIL.
+ * gcc.target/i386/x87regparm-4.c: XFAIL.
+
2006-12-08 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
* lib/target-supports.exp
diff --git a/gcc/testsuite/gcc.target/i386/x87regparm-1.c b/gcc/testsuite/gcc.target/i386/x87regparm-1.c
index fa93401..a1e6660 100644
--- a/gcc/testsuite/gcc.target/i386/x87regparm-1.c
+++ b/gcc/testsuite/gcc.target/i386/x87regparm-1.c
@@ -19,4 +19,4 @@ void test()
/* Check that no memory is used to pass arguments. */
-/* { dg-final { scan-assembler-not "\\(%esp\\)" } } */
+/* { dg-final { scan-assembler-not "\\(%esp\\)" { xfail *-*-* } } } */
diff --git a/gcc/testsuite/gcc.target/i386/x87regparm-2.c b/gcc/testsuite/gcc.target/i386/x87regparm-2.c
index b28dbc1..47508f8 100644
--- a/gcc/testsuite/gcc.target/i386/x87regparm-2.c
+++ b/gcc/testsuite/gcc.target/i386/x87regparm-2.c
@@ -19,4 +19,4 @@ void test()
/* Check that no memory is used to pass arguments. */
-/* { dg-final { scan-assembler-not "\\(%esp\\)" } } */
+/* { dg-final { scan-assembler-not "\\(%esp\\)" { xfail *-*-* } } } */
diff --git a/gcc/testsuite/gcc.target/i386/x87regparm-3.c b/gcc/testsuite/gcc.target/i386/x87regparm-3.c
index b90ff85..8e3ff70 100644
--- a/gcc/testsuite/gcc.target/i386/x87regparm-3.c
+++ b/gcc/testsuite/gcc.target/i386/x87regparm-3.c
@@ -19,4 +19,4 @@ void test()
/* Check that float and double arguments are passed through memory. */
-/* { dg-final { scan-assembler-times "\\(%esp\\)" 4 } } */
+/* { dg-final { scan-assembler-times "\\(%esp\\)" 4 { xfail *-*-* } } } */
diff --git a/gcc/testsuite/gcc.target/i386/x87regparm-4.c b/gcc/testsuite/gcc.target/i386/x87regparm-4.c
index 78a6cdd..95fe2a5 100644
--- a/gcc/testsuite/gcc.target/i386/x87regparm-4.c
+++ b/gcc/testsuite/gcc.target/i386/x87regparm-4.c
@@ -19,4 +19,4 @@ void test()
/* Check that no memory is used to pass arguments. */
-/* { dg-final { scan-assembler-not "\\(%esp\\)" } } */
+/* { dg-final { scan-assembler-not "\\(%esp\\)" { xfail *-*-* } } } */