summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2017-12-14 17:13:03 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2017-12-14 17:13:03 +0000
commitdb27256ba7e76c7793585dcd1dea1b0613779e57 (patch)
tree7fc95bfc6d53bef0dd47c3785657c8096a0bcb78
parent9ca42b6474e1f5b4caeaa58e36aaf993951660af (diff)
downloadgcc-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/ChangeLog5
-rw-r--r--gcc/ada/gcc-interface/trans.c14
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