]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gcc/testsuite/
authorshinwell <shinwell@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 19 Mar 2007 21:00:14 +0000 (21:00 +0000)
committershinwell <shinwell@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 19 Mar 2007 21:00:14 +0000 (21:00 +0000)
* gcc.target/arm/register-variables.c: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@123071 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/arm/register-variables.c [new file with mode: 0644]

index 72474a89ce2b3ae4ba744f11c37e3b8f3e5da8cf..2ac81780bf87443863df6c62eed81ca697fe82d0 100644 (file)
@@ -1,3 +1,7 @@
+2007-03-19  Mark Shinwell  <shinwell@codesourcery.com>
+
+       * gcc.target/arm/register-variables.c: New.
+
 2007-03-19  Jeff Law  <law@redhat.com>
 
        * PR tree-optimization/30984
diff --git a/gcc/testsuite/gcc.target/arm/register-variables.c b/gcc/testsuite/gcc.target/arm/register-variables.c
new file mode 100644 (file)
index 0000000..8c874b2
--- /dev/null
@@ -0,0 +1,21 @@
+/* { dg-do run } */
+/* { dg-options "-O" } */
+
+#include <stdlib.h>
+
+void __attribute__((noinline)) 
+bar(int a, int b)
+{
+  if (a != 43 || b != 42)
+    abort();
+}
+
+int main(void)
+{
+    register int r0 asm("r0") = 42;
+    register int r1 asm("r1") = 43;
+    asm volatile("": "+r" (r0), "+r" (r1));
+    bar(r1, r0);
+    return 0;
+}
+