* gcc.dg/i386-asm-4.c: New test.
authorJakub Jelinek <jakub@redhat.com>
Fri, 14 Jan 2005 10:45:54 +0000 (11:45 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 14 Jan 2005 10:45:54 +0000 (11:45 +0100)
From-SVN: r93638

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/i386-asm-4.c [new file with mode: 0644]

index 62cda60e35a75bcb7fa6f924c71bedc843caf099..6d606915063708ededa7df75b635f6ea23fa0d68 100644 (file)
@@ -1,3 +1,7 @@
+2005-01-14  Jakub Jelinek  <jakub@redhat.com>
+
+       * gcc.dg/i386-asm-4.c: New test.
+
 2005-01-14  Eric Botcazou  <ebotcazou@libertysurf.fr>
 
        * gcc.dg/nested-func-2.c: New test.
diff --git a/gcc/testsuite/gcc.dg/i386-asm-4.c b/gcc/testsuite/gcc.dg/i386-asm-4.c
new file mode 100644 (file)
index 0000000..c132438
--- /dev/null
@@ -0,0 +1,39 @@
+/* Test if functions marked __attribute__((used)), but with address never
+   taken in C code, don't use alternate calling convention for local
+   functions on IA-32.  */
+/* { dg-do run { target i?86-*-* x86_64-*-* } } */
+/* { dg-options "-O2" } */
+
+extern void abort (void);
+
+static int foo (int, int, int, int) __asm ("foo");
+static __attribute__((noinline, used)) int
+foo (int i, int j, int k, int l)
+{
+  return i + j + k + l;
+}
+
+void
+bar (void)
+{
+  if (foo (1, 2, 3, 4) != 10)
+    abort ();
+}
+
+int (*fn) (int, int, int, int);
+
+void
+baz (void)
+{
+  __asm ("movl $foo, %k0" : "=r" (fn));
+  if (fn (2, 3, 4, 5) != 14)
+    abort ();
+}
+
+int
+main (void)
+{
+  bar ();
+  baz ();
+  return 0;
+}