aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJan Hubicka <hubicka@ucw.cz>2015-03-02 21:31:21 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2015-03-02 20:31:21 +0000
commit1af8bfe51613a7ba044d1e7cc8d3e244c6daf8bc (patch)
treeee0a53af265611768823eb755d621853a9759d70 /gcc
parentb91b562cf2764dc10ba00a9473287728a59c4443 (diff)
downloadgcc-1af8bfe51613a7ba044d1e7cc8d3e244c6daf8bc.zip
gcc-1af8bfe51613a7ba044d1e7cc8d3e244c6daf8bc.tar.gz
gcc-1af8bfe51613a7ba044d1e7cc8d3e244c6daf8bc.tar.bz2
re PR lto/65130 (ICE with LTO on valid code on x86_64-linux-gnu)
PR ipa/65130 * ipa-inline.c (check_callers): Looks for recursion. (inline_to_all_callers): Give up on uninlinable or recursive edges. * ipa-inline-analysis.c (inline_summary_t::duplicate): Do not update summary of inline clones. (do_estimate_growth_1): Fix recursion check. * gcc.dg/lto/pr65130_0.c: New testcase. * gcc.dg/lto/pr65130_1.c: New testcase. From-SVN: r221124
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog9
-rw-r--r--gcc/ipa-inline-analysis.c12
-rw-r--r--gcc/ipa-inline.c11
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gcc.dg/lto/pr65130_0.c19
-rw-r--r--gcc/testsuite/gcc.dg/lto/pr65130_1.c17
6 files changed, 69 insertions, 5 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f84b462..f9c0932 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,14 @@
2015-03-02 Jan Hubicka <hubicka@ucw.cz>
+ PR ipa/65130
+ * ipa-inline.c (check_callers): Looks for recursion.
+ (inline_to_all_callers): Give up on uninlinable or recursive edges.
+ * ipa-inline-analysis.c (inline_summary_t::duplicate): Do not update
+ summary of inline clones.
+ (do_estimate_growth_1): Fix recursion check.
+
+2015-03-02 Jan Hubicka <hubicka@ucw.cz>
+
PR ipa/64988
* ipa-inline-transform.c (clone_inlined_nodes): Do not dissolve
comdat groups.
diff --git a/gcc/ipa-inline-analysis.c b/gcc/ipa-inline-analysis.c
index be178ad..7a9c99c 100644
--- a/gcc/ipa-inline-analysis.c
+++ b/gcc/ipa-inline-analysis.c
@@ -1291,7 +1291,8 @@ inline_summary_t::duplicate (cgraph_node *src,
set_hint_predicate (&info->array_index, p);
}
}
- inline_update_overall_summary (dst);
+ if (!dst->global.inlined_to)
+ inline_update_overall_summary (dst);
}
@@ -3924,10 +3925,11 @@ do_estimate_growth_1 (struct cgraph_node *node, void *data)
continue;
}
- if (e->caller == d->node
- || (e->caller->global.inlined_to
- && e->caller->global.inlined_to == d->node))
- d->self_recursive = true;
+ if (e->recursive_p ())
+ {
+ d->self_recursive = true;
+ continue;
+ }
d->growth += estimate_edge_growth (e);
}
return false;
diff --git a/gcc/ipa-inline.c b/gcc/ipa-inline.c
index db77d12..0b38b4c 100644
--- a/gcc/ipa-inline.c
+++ b/gcc/ipa-inline.c
@@ -952,6 +952,8 @@ check_callers (struct cgraph_node *node, void *has_hot_call)
return true;
if (!can_inline_edge_p (e, true))
return true;
+ if (e->recursive_p ())
+ return true;
if (!(*(bool *)has_hot_call) && e->maybe_hot_p ())
*(bool *)has_hot_call = true;
}
@@ -2094,6 +2096,15 @@ inline_to_all_callers (struct cgraph_node *node, void *data)
{
struct cgraph_node *caller = node->callers->caller;
+ if (!can_inline_edge_p (node->callers, true)
+ || node->callers->recursive_p ())
+ {
+ if (dump_file)
+ fprintf (dump_file, "Uninlinable call found; giving up.\n");
+ *num_calls = 0;
+ return false;
+ }
+
if (dump_file)
{
fprintf (dump_file,
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 135f734..4555c13 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,11 @@
2015-03-02 Jan Hubicka <hubicka@ucw.cz>
+ PR ipa/65130
+ * gcc.dg/lto/pr65130_0.c: New testcase.
+ * gcc.dg/lto/pr65130_1.c: New testcase.
+
+2015-03-02 Jan Hubicka <hubicka@ucw.cz>
+
PR ipa/64988
* g++.dg/torture/pr64988.C: New testcase.
diff --git a/gcc/testsuite/gcc.dg/lto/pr65130_0.c b/gcc/testsuite/gcc.dg/lto/pr65130_0.c
new file mode 100644
index 0000000..5b68560
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/lto/pr65130_0.c
@@ -0,0 +1,19 @@
+/* { dg-lto-do link } */
+/* { dg-lto-options { { -flto -O1 -fdevirtualize } } } */
+extern void fn3 (void);
+
+void fn2(void)
+{
+ fn3();
+}
+
+void fn1(void)
+{
+ fn2();
+}
+
+void fn4(void)
+{
+ fn2();
+}
+
diff --git a/gcc/testsuite/gcc.dg/lto/pr65130_1.c b/gcc/testsuite/gcc.dg/lto/pr65130_1.c
new file mode 100644
index 0000000..1bfaa15
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/lto/pr65130_1.c
@@ -0,0 +1,17 @@
+/* { dg-options "-O2 -fdevirtualize" } */
+extern void fn1(void);
+extern void fn4 (void);
+
+int a;
+
+void fn3(void)
+{
+ for (; a;)
+ fn4();
+}
+
+int main() {
+ fn1();
+ return 0;
+}
+