diff options
author | Greta Yorsh <greta.yorsh@arm.com> | 2013-02-15 13:27:11 +0000 |
---|---|---|
committer | Greta Yorsh <gretay@gcc.gnu.org> | 2013-02-15 13:27:11 +0000 |
commit | 45e4e1e9585a9a0437c7b7eeaad552b77f9d29b3 (patch) | |
tree | 787836adf4bdb9b60225c76988e3579b2156776d /gcc | |
parent | 711db0a61dbaabd31de82202297478c632840f95 (diff) | |
download | gcc-45e4e1e9585a9a0437c7b7eeaad552b77f9d29b3.zip gcc-45e4e1e9585a9a0437c7b7eeaad552b77f9d29b3.tar.gz gcc-45e4e1e9585a9a0437c7b7eeaad552b77f9d29b3.tar.bz2 |
interrupt-1.c: Fix for thumb mode.
2012-02-15 Greta Yorsh <Greta.Yorsh@arm.com>
* gcc.target/arm/interrupt-1.c: Fix for thumb mode.
* gcc.target/arm/interrupt-2.c: Likewise.
From-SVN: r196076
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/arm/interrupt-1.c | 14 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/arm/interrupt-2.c | 15 |
3 files changed, 13 insertions, 21 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5d1726f..cbee8ae 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2012-02-15 Greta Yorsh <Greta.Yorsh@arm.com> + + * gcc.target/arm/interrupt-1.c: Fix for thumb mode. + * gcc.target/arm/interrupt-2.c: Likewise. + 2013-02-15 Tobias Burnus <burnus@net-b.de> PR fortran/56318 diff --git a/gcc/testsuite/gcc.target/arm/interrupt-1.c b/gcc/testsuite/gcc.target/arm/interrupt-1.c index 18379de..a384242 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 b979bf1..61d3130 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}\\^" } } */ |