mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-11 23:38:05 +00:00
Fix a bug in the A57FPLoadBalancing register tracking/scavenger.
The code in AArch64A57FPLoadBalancing::scavengeRegister() to handle dead defs was not correctly handling aliased registers. E.g. if the dead def was of D2, then S2 was not being marked as unavailable, so it could potentially be used across a live-range in which it would be clobbered. Patch by Geoff Berry <gberry@codeaurora.org>! Phabricator: http://reviews.llvm.org/D10900 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241449 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
159946938f
commit
ac244651b2
@ -510,9 +510,17 @@ int AArch64A57FPLoadBalancing::scavengeRegister(Chain *G, Color C,
|
||||
if (J.isRegMask())
|
||||
AvailableRegs.clearBitsNotInMask(J.getRegMask());
|
||||
|
||||
if (J.isReg() && J.isDef() && AvailableRegs[J.getReg()]) {
|
||||
assert(J.isDead() && "Non-dead def should have been removed by now!");
|
||||
AvailableRegs.reset(J.getReg());
|
||||
if (J.isReg() && J.isDef()) {
|
||||
MCRegAliasIterator AI(J.getReg(), TRI, /*IncludeSelf=*/true);
|
||||
if (J.isDead())
|
||||
for (; AI.isValid(); ++AI)
|
||||
AvailableRegs.reset(*AI);
|
||||
#ifndef NDEBUG
|
||||
else
|
||||
for (; AI.isValid(); ++AI)
|
||||
assert(!AvailableRegs[*AI] &&
|
||||
"Non-dead def should have been removed by now!");
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user