diff options
author | Jan Hubicka <jh@suse.cz> | 2013-09-17 19:45:00 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2013-09-17 17:45:00 +0000 |
commit | b631d45ac3d9d53a648885ac6b88210da192ab37 (patch) | |
tree | ad0eee441d92de888ca7a13df2182efb4f34930e /gcc/ipa-inline.c | |
parent | 8d34e421a5668e25a992bd0b349cb81e91ee3e49 (diff) | |
download | gcc-b631d45ac3d9d53a648885ac6b88210da192ab37.tar.gz |
re PR ipa/58332 (error: inlined_to pointer is set but no predecessors found)
PR middle-end/58332
* gcc.c-torture/compile/pr58332.c: New testcase.
* cif-code.def (FUNCTION_NOT_OPTIMIZED): New CIF code.
* ipa-inline.c (can_inline_edge_p): Do not downgrade
FUNCTION_NOT_OPTIMIZED.
* ipa-inline-analysis.c (compute_inline_parameters): Function
not optimized is not inlinable unless it is alwaysinline.
(inline_analyze_function): Force calls in not optimized
function not inlinable.
From-SVN: r202661
Diffstat (limited to 'gcc/ipa-inline.c')
-rw-r--r-- | gcc/ipa-inline.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/ipa-inline.c b/gcc/ipa-inline.c index 266c0486728..3672e57e471 100644 --- a/gcc/ipa-inline.c +++ b/gcc/ipa-inline.c @@ -275,7 +275,8 @@ can_inline_edge_p (struct cgraph_edge *e, bool report, } else if (e->call_stmt_cannot_inline_p) { - e->inline_failed = CIF_MISMATCHED_ARGUMENTS; + if (e->inline_failed != CIF_FUNCTION_NOT_OPTIMIZED) + e->inline_failed = CIF_MISMATCHED_ARGUMENTS; inlinable = false; } /* Don't inline if the functions have different EH personalities. */ |