forked from OSchip/llvm-project
AArch64: avoid deleting the current iterator in a loop.
std::map invalidates the iterator to any element that gets deleted, which means we can't increment it correctly afterwards. This was causing Darwin test failures. llvm-svn: 215233
This commit is contained in:
parent
495bc3f5f6
commit
e42fac5191
|
@ -671,13 +671,14 @@ maybeKillChain(MachineOperand &MO, unsigned Idx,
|
||||||
} else if (MO.isRegMask()) {
|
} else if (MO.isRegMask()) {
|
||||||
|
|
||||||
for (auto I = ActiveChains.begin(), E = ActiveChains.end();
|
for (auto I = ActiveChains.begin(), E = ActiveChains.end();
|
||||||
I != E; ++I) {
|
I != E;) {
|
||||||
if (MO.clobbersPhysReg(I->first)) {
|
if (MO.clobbersPhysReg(I->first)) {
|
||||||
DEBUG(dbgs() << "Kill (regmask) seen for chain "
|
DEBUG(dbgs() << "Kill (regmask) seen for chain "
|
||||||
<< TRI->getName(I->first) << "\n");
|
<< TRI->getName(I->first) << "\n");
|
||||||
I->second->setKill(MI, Idx, /*Immutable=*/true);
|
I->second->setKill(MI, Idx, /*Immutable=*/true);
|
||||||
ActiveChains.erase(I);
|
ActiveChains.erase(I++);
|
||||||
}
|
} else
|
||||||
|
++I;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue