mirror of
https://github.com/RPCSX/llvm.git
synced 2025-04-03 00:31:49 +00:00
Fix the sanitizer bootstrap error in r265547.
The iterators of SmallPtrSet SpillsInSubTreeMap[Child].first may be invalidated when SpillsInSubTreeMap grows. Rearrange the code to ensure the grow of SpillsInSubTreeMap only happens before getting the iterators of the SmallPtrSet. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@265639 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
928c8dac1c
commit
e0762dfa97
@ -1272,10 +1272,17 @@ void HoistSpillHelper::runHoistSpills(
|
||||
unsigned NumChildren = Children.size();
|
||||
for (unsigned i = 0; i != NumChildren; ++i) {
|
||||
MachineDomTreeNode *Child = Children[i];
|
||||
if (SpillsInSubTreeMap.find(Child) == SpillsInSubTreeMap.end())
|
||||
continue;
|
||||
// SpillsInSubTreeMap[*RIt].second += SpillsInSubTreeMap[Child].second
|
||||
// should be placed before getting the begin and end iterators of
|
||||
// SpillsInSubTreeMap[Child].first, or else the iterators may be
|
||||
// invalidated when SpillsInSubTreeMap[*RIt] is seen the first time
|
||||
// and the map grows and then the original buckets in the map are moved.
|
||||
SpillsInSubTreeMap[*RIt].second += SpillsInSubTreeMap[Child].second;
|
||||
auto BI = SpillsInSubTreeMap[Child].first.begin();
|
||||
auto EI = SpillsInSubTreeMap[Child].first.end();
|
||||
SpillsInSubTreeMap[*RIt].first.insert(BI, EI);
|
||||
SpillsInSubTreeMap[*RIt].second += SpillsInSubTreeMap[Child].second;
|
||||
SpillsInSubTreeMap.erase(Child);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user