diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-09-12 21:19:51 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-09-12 21:19:51 +0000 |
commit | 26f19261581bf915b6e41e850643c76b033aaa9d (patch) | |
tree | 828e93cbb23579f8ca8fc10515dcc6799ef95972 | |
parent | 379c7561c3953896b89e7d09175dfebbfb1e57a6 (diff) | |
download | gcc-26f19261581bf915b6e41e850643c76b033aaa9d.tar.gz |
PR target/32338
* config/ia64/ia64.c (ia64_expand_epilogue): Emit blockage
before sp restoration even when total_size is 0, but
frame_pointer_needed.
* gcc.dg/pr32338-1.c: New test.
* gcc.dg/pr32338-2.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@128446 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/config/ia64/ia64.c | 4 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/pr32338-1.c | 47 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/pr32338-2.c | 47 |
5 files changed, 110 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index af05fca5d5e..d16c38c8c15 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2007-09-12 Jakub Jelinek <jakub@redhat.com> + + PR target/32338 + * config/ia64/ia64.c (ia64_expand_epilogue): Emit blockage + before sp restoration even when total_size is 0, but + frame_pointer_needed. + 2007-09-12 Bob Wilson <bob.wilson@acm.org> * config/xtensa/xtensa.c (machine_function): Add vararg_a7_copy. diff --git a/gcc/config/ia64/ia64.c b/gcc/config/ia64/ia64.c index 46f75c5a205..6a6a9e62f0c 100644 --- a/gcc/config/ia64/ia64.c +++ b/gcc/config/ia64/ia64.c @@ -3437,7 +3437,9 @@ ia64_expand_epilogue (int sibcall_p) finish_spill_pointers (); - if (current_frame_info.total_size || cfun->machine->ia64_eh_epilogue_sp) + if (current_frame_info.total_size + || cfun->machine->ia64_eh_epilogue_sp + || frame_pointer_needed) { /* ??? At this point we must generate a magic insn that appears to modify the spill iterators, the stack pointer, and the frame diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 433471cd1d3..977c2a50eed 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2007-09-12 Jakub Jelinek <jakub@redhat.com> + + PR target/32338 + * gcc.dg/pr32338-1.c: New test. + * gcc.dg/pr32338-2.c: New test. + 2007-09-12 Bob Wilson <bob.wilson@acm.org> * lib/target-supports.exp (check_effective_target_sync_int_long): diff --git a/gcc/testsuite/gcc.dg/pr32338-1.c b/gcc/testsuite/gcc.dg/pr32338-1.c new file mode 100644 index 00000000000..6a79a8c2281 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr32338-1.c @@ -0,0 +1,47 @@ +/* PR target/32338 */ +/* { dg-do link } */ +/* { dg-options "-O2 -fno-omit-frame-pointer" } */ + +struct S +{ +}; + +int +__attribute__((noinline)) +foo (struct S *d) +{ + return 2; +} + +int +__attribute__((noinline)) +bar (struct S *d) +{ + return 4; +} + +int +__attribute__((noinline)) +fnl (char const *q) +{ + return __builtin_strlen (q); +} + +int +__attribute__((noinline)) +baz (struct S *d, char const *q) +{ + unsigned int len; + len = fnl (q); + if (len > 512) + return bar (d); + return foo (d); +} + +int +main (int argc, char *argv[]) +{ + if (argc > 30) + return baz ((void *) 0, "abcde"); + return 0; +} diff --git a/gcc/testsuite/gcc.dg/pr32338-2.c b/gcc/testsuite/gcc.dg/pr32338-2.c new file mode 100644 index 00000000000..81daddf6a67 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr32338-2.c @@ -0,0 +1,47 @@ +/* PR target/32338 */ +/* { dg-do link } */ +/* { dg-options "-O2 -fno-omit-frame-pointer" } */ + +struct S +{ +}; + +int +__attribute__((noinline)) +foo (void) +{ + return 2; +} + +int +__attribute__((noinline)) +bar (void) +{ + return 4; +} + +int +__attribute__((noinline)) +fnl (void) +{ + return 6; +} + +int +__attribute__((noinline)) +baz (void) +{ + unsigned int len; + len = fnl (); + if (len > 512) + return bar (); + return foo (); +} + +int +main (int argc, char *argv[]) +{ + if (argc > 30) + return baz (); + return 0; +} |