1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-18 18:42:46 +02:00

Q.seenAllInterferences() must be called after Q.collectInterferingVRegs().

llvm-svn: 121774
This commit is contained in:
Jakob Stoklund Olesen 2010-12-14 17:47:36 +00:00
parent 3f9b9dc852
commit 74ba8b77e6

View File

@ -175,9 +175,9 @@ LiveInterval *RAGreedy::getSingleInterference(LiveInterval &VirtReg,
// Check direct interferences.
LiveIntervalUnion::Query &Q = query(VirtReg, PhysReg);
if (Q.checkInterference()) {
Q.collectInterferingVRegs(1);
if (!Q.seenAllInterferences())
return 0;
Q.collectInterferingVRegs(1);
Interference = Q.interferingVRegs().front();
}
@ -185,9 +185,11 @@ LiveInterval *RAGreedy::getSingleInterference(LiveInterval &VirtReg,
for (const unsigned *AliasI = TRI->getAliasSet(PhysReg); *AliasI; ++AliasI) {
LiveIntervalUnion::Query &Q = query(VirtReg, *AliasI);
if (Q.checkInterference()) {
if (Interference || !Q.seenAllInterferences())
if (Interference)
return 0;
Q.collectInterferingVRegs(1);
if (!Q.seenAllInterferences())
return 0;
Interference = Q.interferingVRegs().front();
}
}