aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMartin Liska <mliska@suse.cz>2022-05-18 15:07:53 +0200
committerMartin Liska <mliska@suse.cz>2022-06-23 06:07:22 +0200
commit31ce821a790caec8a2849dd67a9847e78a33d14c (patch)
tree2f699ba08b481200366124665498f779bc55e712 /gcc
parent7f52df186de41284b9976ea461381e168da5749f (diff)
downloadgcc-31ce821a790caec8a2849dd67a9847e78a33d14c.zip
gcc-31ce821a790caec8a2849dd67a9847e78a33d14c.tar.gz
gcc-31ce821a790caec8a2849dd67a9847e78a33d14c.tar.bz2
ipa-icf: skip variables with body_removed
Similarly to cgraph_nodes, it may happen that body_removed is set during merging of symbols. PR ipa/105600 gcc/ChangeLog: * ipa-icf.cc (sem_item_optimizer::filter_removed_items): Skip variables with body_removed.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ipa-icf.cc7
1 files changed, 4 insertions, 3 deletions
diff --git a/gcc/ipa-icf.cc b/gcc/ipa-icf.cc
index 765ae74..6528a7a 100644
--- a/gcc/ipa-icf.cc
+++ b/gcc/ipa-icf.cc
@@ -2411,10 +2411,11 @@ sem_item_optimizer::filter_removed_items (void)
{
/* Filter out non-readonly variables. */
tree decl = item->decl;
- if (TREE_READONLY (decl))
- filtered.safe_push (item);
- else
+ varpool_node *vnode = static_cast <sem_variable *>(item)->get_node ();
+ if (!TREE_READONLY (decl) || vnode->body_removed)
remove_item (item);
+ else
+ filtered.safe_push (item);
}
}
}