mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 20:34:38 +00:00
Fix bug in aggressive antidep breaking; liveness was not updated correctly for regions that do not have antidep candidates.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@86172 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
692ad8dd06
commit
7040d6e2f5
@ -630,12 +630,6 @@ unsigned AggressiveAntiDepBreaker::BreakAntiDependencies(
|
|||||||
std::multimap<unsigned, AggressiveAntiDepState::RegisterReference>&
|
std::multimap<unsigned, AggressiveAntiDepState::RegisterReference>&
|
||||||
RegRefs = State->GetRegRefs();
|
RegRefs = State->GetRegRefs();
|
||||||
|
|
||||||
// Nothing to do if no candidates.
|
|
||||||
if (Candidates.empty()) {
|
|
||||||
DEBUG(errs() << "\n===== No anti-dependency candidates\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// The code below assumes that there is at least one instruction,
|
// The code below assumes that there is at least one instruction,
|
||||||
// so just duck out immediately if the block is empty.
|
// so just duck out immediately if the block is empty.
|
||||||
if (SUnits.empty()) return 0;
|
if (SUnits.empty()) return 0;
|
||||||
@ -655,16 +649,19 @@ unsigned AggressiveAntiDepBreaker::BreakAntiDependencies(
|
|||||||
|
|
||||||
// ...need a map from MI to SUnit.
|
// ...need a map from MI to SUnit.
|
||||||
std::map<MachineInstr *, SUnit *> MISUnitMap;
|
std::map<MachineInstr *, SUnit *> MISUnitMap;
|
||||||
|
|
||||||
DEBUG(errs() << "\n===== Attempting to break " << Candidates.size() <<
|
|
||||||
" anti-dependencies\n");
|
|
||||||
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
|
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
|
||||||
SUnit *SU = &SUnits[i];
|
SUnit *SU = &SUnits[i];
|
||||||
MISUnitMap.insert(std::pair<MachineInstr *, SUnit *>(SU->getInstr(), SU));
|
MISUnitMap.insert(std::pair<MachineInstr *, SUnit *>(SU->getInstr(), SU));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Even if there are no anti-dependencies we still need to go
|
||||||
|
// through the instructions to update Def, Kills, etc.
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
{
|
if (Candidates.empty()) {
|
||||||
|
DEBUG(errs() << "\n===== No anti-dependency candidates\n");
|
||||||
|
} else {
|
||||||
|
DEBUG(errs() << "\n===== Attempting to break " << Candidates.size() <<
|
||||||
|
" anti-dependencies\n");
|
||||||
DEBUG(errs() << "Available regs:");
|
DEBUG(errs() << "Available regs:");
|
||||||
for (unsigned Reg = 0; Reg < TRI->getNumRegs(); ++Reg) {
|
for (unsigned Reg = 0; Reg < TRI->getNumRegs(); ++Reg) {
|
||||||
if (!State->IsLive(Reg))
|
if (!State->IsLive(Reg))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user