Commit 6c577667 by Richard Biener

Optimize alias subset recording

When an alias-set is an already existing subset there is no need
to re-record its children as childs of the parent.

2020-01-15  Richard Biener  <rguenther@suse.de>

	* alias.c (record_alias_subset): Avoid redundant work when
	subset is already recorded.
parent e2346a33
2020-01-15 Richard Biener <rguenther@suse.de>
* alias.c (record_alias_subset): Avoid redundant work when
subset is already recorded.
2020-01-14 David Malcolm <dmalcolm@redhat.com> 2020-01-14 David Malcolm <dmalcolm@redhat.com>
* doc/invoke.texi (-fdiagnostics-show-cwe): Add note that some of * doc/invoke.texi (-fdiagnostics-show-cwe): Add note that some of
......
...@@ -1164,10 +1164,16 @@ record_alias_subset (alias_set_type superset, alias_set_type subset) ...@@ -1164,10 +1164,16 @@ record_alias_subset (alias_set_type superset, alias_set_type subset)
superset_entry->has_zero_child = 1; superset_entry->has_zero_child = 1;
else else
{ {
subset_entry = get_alias_set_entry (subset);
if (!superset_entry->children) if (!superset_entry->children)
superset_entry->children superset_entry->children
= hash_map<alias_set_hash, int>::create_ggc (64); = hash_map<alias_set_hash, int>::create_ggc (64);
/* Enter the SUBSET itself as a child of the SUPERSET. If it was
already there we're done. */
if (superset_entry->children->put (subset, 0))
return;
subset_entry = get_alias_set_entry (subset);
/* If there is an entry for the subset, enter all of its children /* If there is an entry for the subset, enter all of its children
(if they are not already present) as children of the SUPERSET. */ (if they are not already present) as children of the SUPERSET. */
if (subset_entry) if (subset_entry)
...@@ -1185,9 +1191,6 @@ record_alias_subset (alias_set_type superset, alias_set_type subset) ...@@ -1185,9 +1191,6 @@ record_alias_subset (alias_set_type superset, alias_set_type subset)
superset_entry->children->put ((*iter).first, (*iter).second); superset_entry->children->put ((*iter).first, (*iter).second);
} }
} }
/* Enter the SUBSET itself as a child of the SUPERSET. */
superset_entry->children->put (subset, 0);
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment