mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-11 15:26:07 +00:00
Fix an overly strict assertion. Source register of a copy may not be killed, it may be killed by an implicit super-register use.
llvm-svn: 55762
This commit is contained in:
parent
53ce5fa5ce
commit
dcce925eb1
@ -1730,7 +1730,8 @@ void LocalSpiller::RewriteMBB(MachineBasicBlock &MBB, VirtRegMap &VRM) {
|
||||
SmallVector<unsigned, 2> KillRegs;
|
||||
InvalidateKills(MI, RegKills, KillOps, &KillRegs);
|
||||
if (MO.isDead() && !KillRegs.empty()) {
|
||||
assert(KillRegs[0] == Dst);
|
||||
// Source register or an implicit super-register use is killed.
|
||||
assert(KillRegs[0] == Dst || TRI->isSubRegister(KillRegs[0], Dst));
|
||||
// Last def is now dead.
|
||||
TransferDeadness(&MBB, Dist, Src, RegKills, KillOps);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user