diff options
author | Martin Liska <mliska@suse.cz> | 2022-05-18 15:07:53 +0200 |
---|---|---|
committer | Martin Liska <mliska@suse.cz> | 2022-06-23 06:07:22 +0200 |
commit | 31ce821a790caec8a2849dd67a9847e78a33d14c (patch) | |
tree | 2f699ba08b481200366124665498f779bc55e712 /gcc | |
parent | 7f52df186de41284b9976ea461381e168da5749f (diff) | |
download | gcc-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.cc | 7 |
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); } } } |