From: Greta Yorsh Date: Fri, 15 Feb 2013 13:27:11 +0000 (+0000) Subject: interrupt-1.c: Fix for thumb mode. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=45e4e1e9585a9a0437c7b7eeaad552b77f9d29b3;p=gcc.git interrupt-1.c: Fix for thumb mode. 2012-02-15 Greta Yorsh * gcc.target/arm/interrupt-1.c: Fix for thumb mode. * gcc.target/arm/interrupt-2.c: Likewise. From-SVN: r196076 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5d1726f0e89..cbee8ae7e79 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2012-02-15 Greta Yorsh + + * gcc.target/arm/interrupt-1.c: Fix for thumb mode. + * gcc.target/arm/interrupt-2.c: Likewise. + 2013-02-15 Tobias Burnus PR fortran/56318 diff --git a/gcc/testsuite/gcc.target/arm/interrupt-1.c b/gcc/testsuite/gcc.target/arm/interrupt-1.c index 18379de33d0..a38424228cf 100644 --- a/gcc/testsuite/gcc.target/arm/interrupt-1.c +++ b/gcc/testsuite/gcc.target/arm/interrupt-1.c @@ -1,10 +1,10 @@ /* Verify that prologue and epilogue are correct for functions with __attribute__ ((interrupt)). */ /* { dg-do compile } */ -/* { dg-options "-O0" } */ +/* { dg-require-effective-target arm_nothumb } */ +/* { dg-options "-O0 -marm" } */ -/* This test is not valid when -mthumb. We just cheat. */ -#ifndef __thumb__ +/* This test is not valid when -mthumb. */ extern void bar (int); extern void foo (void) __attribute__ ((interrupt("IRQ"))); @@ -12,12 +12,6 @@ void foo () { bar (0); } -#else -void foo () -{ - asm ("stmfd\tsp!, {r0, r1, r2, r3, r4, fp, ip, lr}"); - asm ("ldmfd\tsp!, {r0, r1, r2, r3, r4, fp, ip, pc}^"); -} -#endif + /* { dg-final { scan-assembler "stmfd\tsp!, {r0, r1, r2, r3, r4, fp, ip, lr}" } } */ /* { dg-final { scan-assembler "ldmfd\tsp!, {r0, r1, r2, r3, r4, fp, ip, pc}\\^" } } */ diff --git a/gcc/testsuite/gcc.target/arm/interrupt-2.c b/gcc/testsuite/gcc.target/arm/interrupt-2.c index b979bf17e8a..61d31305367 100644 --- a/gcc/testsuite/gcc.target/arm/interrupt-2.c +++ b/gcc/testsuite/gcc.target/arm/interrupt-2.c @@ -1,26 +1,19 @@ /* Verify that prologue and epilogue are correct for functions with __attribute__ ((interrupt)). */ /* { dg-do compile } */ -/* { dg-options "-O1" } */ +/* { dg-require-effective-target arm_nothumb } */ +/* { dg-options "-O1 -marm" } */ -/* This test is not valid when -mthum. We just cheat. */ -#ifndef __thumb__ +/* This test is not valid when -mthumb. */ extern void bar (int); extern void test (void) __attribute__((__interrupt__)); int foo; void test() { - funcptrs(foo); + bar (foo); foo = 0; } -#else -void test () -{ - asm ("stmfd\tsp!, {r0, r1, r2, r3, r4, r5, ip, lr}"); - asm ("ldmfd\tsp!, {r0, r1, r2, r3, r4, r5, ip, pc}^"); -} -#endif /* { dg-final { scan-assembler "stmfd\tsp!, {r0, r1, r2, r3, r4, r5, ip, lr}" } } */ /* { dg-final { scan-assembler "ldmfd\tsp!, {r0, r1, r2, r3, r4, r5, ip, pc}\\^" } } */