mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-30 08:24:12 +00:00
Fix an exotic bug that only showed up in an internal test case.
SimpleRegisterCoalescing::JoinIntervals() uses CoalescerPair to determine if a copy is coalescable, and in very rare cases it can return true where LHS is not live - the coalescable copy can come from an alias of the physreg in LHS. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106021 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
669db04130
commit
1b2f94c621
@ -2310,7 +2310,8 @@ SimpleRegisterCoalescing::JoinIntervals(LiveInterval &LHS, LiveInterval &RHS,
|
||||
|
||||
// Figure out the value # from the RHS.
|
||||
LiveRange *lr = RHS.getLiveRangeContaining(VNI->def.getPrevSlot());
|
||||
assert(lr && "Cannot find live range");
|
||||
// The copy could be to an aliased physreg.
|
||||
if (!lr) continue;
|
||||
LHSValsDefinedFromRHS[VNI] = lr->valno;
|
||||
}
|
||||
|
||||
@ -2329,7 +2330,8 @@ SimpleRegisterCoalescing::JoinIntervals(LiveInterval &LHS, LiveInterval &RHS,
|
||||
|
||||
// Figure out the value # from the LHS.
|
||||
LiveRange *lr = LHS.getLiveRangeContaining(VNI->def.getPrevSlot());
|
||||
assert(lr && "Cannot find live range");
|
||||
// The copy could be to an aliased physreg.
|
||||
if (!lr) continue;
|
||||
RHSValsDefinedFromLHS[VNI] = lr->valno;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user