aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/ipa.c12
2 files changed, 18 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6c19064..29049bd 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,6 +1,12 @@
2015-02-04 Jan Hubicka <hubicka@ucw.cz>
PR ipa/61548
+ * ipa.c (symbol_table::remove_unreachable_nodes): Fix ordering issue
+ when removing varpool nodes.
+
+2015-02-04 Jan Hubicka <hubicka@ucw.cz>
+
+ PR ipa/61548
* varpool.c (varpool_node::remove): Fix order of variables.
2015-02-04 Jan Hubicka <hubicka@ucw.cz>
diff --git a/gcc/ipa.c b/gcc/ipa.c
index 3626417..9cbd2da 100644
--- a/gcc/ipa.c
+++ b/gcc/ipa.c
@@ -597,8 +597,20 @@ symbol_table::remove_unreachable_nodes (FILE *file)
or not. */
&& (!flag_ltrans || !DECL_EXTERNAL (vnode->decl)))
{
+ struct ipa_ref *ref = NULL;
+
+ /* First remove the aliases, so varpool::remove can possibly lookup
+ the constructor and save it for future use. */
+ while (vnode->iterate_direct_aliases (0, ref))
+ {
+ if (file)
+ fprintf (file, " %s/%i", ref->referred->name (),
+ ref->referred->order);
+ ref->referring->remove ();
+ }
if (file)
fprintf (file, " %s/%i", vnode->name (), vnode->order);
+ vnext = next_variable (vnode);
vnode->remove ();
changed = true;
}