diff options
author | Jan Hubicka <jh@suse.cz> | 2006-10-15 21:46:26 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2006-10-15 19:46:26 +0000 |
commit | ba19ceaeeda23eb90bf8a277eeb9bcdbb78413fa (patch) | |
tree | 1902397fabe9819b2a235506aa5e63af0363f012 /gcc/cgraphunit.c | |
parent | 564738dfd1e2f0d3182d811d7abafd9391208ed8 (diff) | |
download | gcc-ba19ceaeeda23eb90bf8a277eeb9bcdbb78413fa.zip gcc-ba19ceaeeda23eb90bf8a277eeb9bcdbb78413fa.tar.gz gcc-ba19ceaeeda23eb90bf8a277eeb9bcdbb78413fa.tar.bz2 |
re PR middle-end/29241 ([non unit-at-a-time] ICE with always inline)
PR middle-end/29241
* cgraphunit.c (cgraph_preserve_function_body_p): Preserve functions
declared always_inline even when not inlining.
* gcc.c-torture/compile/pr29241.c: New testcase.
From-SVN: r117753
Diffstat (limited to 'gcc/cgraphunit.c')
-rw-r--r-- | gcc/cgraphunit.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index fbe70dd..309fb73 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -1494,7 +1494,9 @@ cgraph_preserve_function_body_p (tree decl) { struct cgraph_node *node; if (!cgraph_global_info_ready) - return (DECL_INLINE (decl) && !flag_really_no_inline); + return (flag_really_no_inline + ? lang_hooks.tree_inlining.disregard_inline_limits (decl) + : DECL_INLINE (decl)); /* Look if there is any clone around. */ for (node = cgraph_node (decl); node; node = node->next_clone) if (node->global.inlined_to) |