i386.c (ix86_function_arg_regno_p): Never return true for 64-bit mode only SSE regist...
authorJakub Jelinek <jakub@redhat.com>
Mon, 21 Jan 2002 15:53:31 +0000 (16:53 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Mon, 21 Jan 2002 15:53:31 +0000 (16:53 +0100)
* config/i386/i386.c (ix86_function_arg_regno_p): Never return
true for 64-bit mode only SSE registers in 32-bit mode.

* gcc.dg/20020218-1.c: New test.

From-SVN: r49046

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/20020218-1.c [new file with mode: 0644]

index b83e503df73167f259868784b4abda0074e67239..be36d3197d794612036fc1d487e139a77dfc8ca9 100644 (file)
@@ -1,3 +1,8 @@
+2002-01-21  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/i386/i386.c (ix86_function_arg_regno_p): Never return
+       true for 64-bit mode only SSE registers in 32-bit mode.
+
 2002-01-21  Kazu Hirata  <kazu@hxi.com>
 
        * unwind-dw2.c: Fix formatting.
index a51990b38864c9a99378c89afd4a64016a4ad5f2..7eedba3ac7042097801f4d998d1bca771180e4b1 100644 (file)
@@ -1483,7 +1483,8 @@ ix86_function_arg_regno_p (regno)
 {
   int i;
   if (!TARGET_64BIT)
-    return regno < REGPARM_MAX || (TARGET_SSE && SSE_REGNO_P (regno));
+    return (regno < REGPARM_MAX
+           || (TARGET_SSE && SSE_REGNO_P (regno) && !fixed_regs[regno]));
   if (SSE_REGNO_P (regno) && TARGET_SSE)
     return true;
   /* RAX is used as hidden argument to va_arg functions.  */
index 9fd7c578d72f589c588e9a26cbed5ccca2adcbad..d806caf6677da35785b691098a1e7acd5562a08f 100644 (file)
@@ -1,3 +1,7 @@
+2002-01-21  Jakub Jelinek  <jakub@redhat.com>
+
+       * gcc.dg/20020218-1.c: New test.
+
 2002-01-21  David.Billinghurst <David.Billinghurst@riotinto.com>
 
        * lib/prune.exp (prune_gcc_output): Prune "At global scope"
diff --git a/gcc/testsuite/gcc.dg/20020218-1.c b/gcc/testsuite/gcc.dg/20020218-1.c
new file mode 100644 (file)
index 0000000..2887328
--- /dev/null
@@ -0,0 +1,34 @@
+/* Verify that X86-64 only SSE registers aren't restored on IA-32.  */
+/* { dg-do compile { target i?86-*-* } } */
+/* { dg-options "-O2 -msse" } */
+/* { dg-final { scan-assembler-not "xmm8" } } */
+
+extern void abort (void);
+extern void exit (int);
+
+void *bar (void *p, void *q)
+{
+  if (p != (void *) 26 || q != (void *) 35)
+    abort ();
+  return (void *) 76;
+}
+
+void *foo (void **args)
+{
+  void *argcookie = &args[1];
+
+  __builtin_return (__builtin_apply (args[0], &argcookie,
+                                    2 * sizeof (void *)));
+}
+
+int main (void)
+{
+  void *args[3];
+
+  args[0] = (void *) bar;
+  args[1] = (void *) 26;
+  args[2] = (void *) 35;
+  if (foo (args) != (void *) 76)
+    abort ();
+  exit (0);
+}