diff options
| -rw-r--r-- | gcc/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/calls.c | 9 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/eh2.C | 18 |
4 files changed, 32 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2c42e845680..35ae9ddc335 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-10-27 Jakub Jelinek <jakub@redhat.com> + + * calls.c (expand_call): If sibcall_failure is set during pass 1, + clear tail_call_insns as well. + 2000-10-27 Nick Clifton <nickc@redhat.com> * config/arm/arm-protos.h (arm_function_ok_for_sibcall): Add diff --git a/gcc/calls.c b/gcc/calls.c index e90be2ea81f..da850ccada4 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -3363,10 +3363,6 @@ expand_call (exp, target, ignore) { tail_call_insns = insns; - /* If something prevents making this a sibling call, - zero out the sequence. */ - if (sibcall_failure) - tail_call_insns = NULL_RTX; /* Restore the pending stack adjustment now that we have finished generating the sibling call sequence. */ @@ -3385,6 +3381,11 @@ expand_call (exp, target, ignore) } else normal_call_insns = insns; + + /* If something prevents making this a sibling call, + zero out the sequence. */ + if (sibcall_failure) + tail_call_insns = NULL_RTX; } /* The function optimize_sibling_and_tail_recursive_calls doesn't diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1a4bc84404f..84b84c801a5 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-10-27 Jakub Jelinek <jakub@redhat.com> + + * g++.old-deja/g++.other/eh2.C: New test. + 2000-10-27 Bernd Schmidt <bernds@cygnus.co.uk> * gcc.c-torture/execute/20001027-1.c: New test. diff --git a/gcc/testsuite/g++.old-deja/g++.other/eh2.C b/gcc/testsuite/g++.old-deja/g++.other/eh2.C new file mode 100644 index 00000000000..514d645359c --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/eh2.C @@ -0,0 +1,18 @@ +// Build don't link: +// Origin: Jakub Jelinek <jakub@redhat.com> +// Special g++ Options: -O2 + +class a { +public: + double b; + int c; + ~a() { } +}; + +int bar(a x); +a foo(double x); + +int baz(double x, int y) +{ + return bar(foo(x)); +} |

