diff options
author | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2017-12-14 17:13:03 +0000 |
---|---|---|
committer | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2017-12-14 17:13:03 +0000 |
commit | db27256ba7e76c7793585dcd1dea1b0613779e57 (patch) | |
tree | 7fc95bfc6d53bef0dd47c3785657c8096a0bcb78 | |
parent | 9ca42b6474e1f5b4caeaa58e36aaf993951660af (diff) | |
download | gcc-db27256ba7e76c7793585dcd1dea1b0613779e57.tar.gz |
* gcc-interface/trans.c (Call_to_gnu): Set DECL_DISREGARD_INLINE_LIMITS
to 0 on the callee if the call is recursive.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@255648 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ada/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/ada/gcc-interface/trans.c | 14 |
2 files changed, 15 insertions, 4 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index c87f4a22692..350ac1f8d25 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,5 +1,10 @@ 2017-12-14 Eric Botcazou <ebotcazou@adacore.com> + * gcc-interface/trans.c (Call_to_gnu): Set DECL_DISREGARD_INLINE_LIMITS + to 0 on the callee if the call is recursive. + +2017-12-14 Eric Botcazou <ebotcazou@adacore.com> + * gcc-interface/decl.c (gnat_to_gnu_field): Do not set the alignment of the enclosing record type if it is not already set. diff --git a/gcc/ada/gcc-interface/trans.c b/gcc/ada/gcc-interface/trans.c index cae156fa8c6..55638a10c23 100644 --- a/gcc/ada/gcc-interface/trans.c +++ b/gcc/ada/gcc-interface/trans.c @@ -4306,10 +4306,16 @@ Call_to_gnu (Node_Id gnat_node, tree *gnu_result_type_p, tree gnu_target, return call_expr; } - /* For a call to a nested function, check the inlining status. */ - if (TREE_CODE (gnu_subprog) == FUNCTION_DECL - && decl_function_context (gnu_subprog)) - check_inlining_for_nested_subprog (gnu_subprog); + if (TREE_CODE (gnu_subprog) == FUNCTION_DECL) + { + /* For a call to a nested function, check the inlining status. */ + if (decl_function_context (gnu_subprog)) + check_inlining_for_nested_subprog (gnu_subprog); + + /* For a recursive call, avoid explosion due to recursive inlining. */ + if (gnu_subprog == current_function_decl) + DECL_DISREGARD_INLINE_LIMITS (gnu_subprog) = 0; + } /* The only way we can be making a call via an access type is if Name is an explicit dereference. In that case, get the list of formal args from the |