mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-16 12:24:03 +00:00
Break false dependencies before partial register updates.
Two new TargetInstrInfo hooks lets the target tell ExecutionDepsFix about instructions with partial register updates causing false unwanted dependencies. The ExecutionDepsFix pass will break the false dependencies if the updated register was written in the previoius N instructions. The small loop added to sse-domains.ll runs twice as fast with dependency-breaking instructions inserted. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144602 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -471,11 +471,34 @@ void ExeDepsFix::processDefs(MachineInstr *MI, bool Kill) {
|
||||
DEBUG(dbgs() << TRI->getName(RC->getRegister(rx)) << ":\t" << CurInstr
|
||||
<< '\t' << *MI);
|
||||
|
||||
// How many instructions since rx was last written?
|
||||
unsigned Clearance = CurInstr - LiveRegs[rx].Def;
|
||||
LiveRegs[rx].Def = CurInstr;
|
||||
|
||||
// Kill off domains redefined by generic instructions.
|
||||
if (Kill)
|
||||
kill(rx);
|
||||
|
||||
// Verify clearance before partial register updates.
|
||||
unsigned Pref = TII->getPartialRegUpdateClearance(MI, i, TRI);
|
||||
if (!Pref)
|
||||
continue;
|
||||
DEBUG(dbgs() << "Clearance: " << Clearance << ", want " << Pref);
|
||||
if (Pref > Clearance) {
|
||||
DEBUG(dbgs() << ": Break dependency.\n");
|
||||
TII->breakPartialRegDependency(MI, i, TRI);
|
||||
continue;
|
||||
}
|
||||
|
||||
// The current clearance seems OK, but we may be ignoring a def from a
|
||||
// back-edge.
|
||||
if (!SeenUnknownBackEdge || Pref <= unsigned(CurInstr)) {
|
||||
DEBUG(dbgs() << ": OK.\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
// A def from an unprocessed back-edge may make us break this dependency.
|
||||
DEBUG(dbgs() << ": Wait for back-edge to resolve.\n");
|
||||
}
|
||||
|
||||
++CurInstr;
|
||||
@ -663,6 +686,10 @@ bool ExeDepsFix::runOnMachineFunction(MachineFunction &mf) {
|
||||
for (unsigned i = 0, e = Loops.size(); i != e; ++i) {
|
||||
MachineBasicBlock *MBB = Loops[i];
|
||||
enterBasicBlock(MBB);
|
||||
for (MachineBasicBlock::iterator I = MBB->begin(), E = MBB->end(); I != E;
|
||||
++I)
|
||||
if (!I->isDebugValue())
|
||||
processDefs(I, false);
|
||||
leaveBasicBlock(MBB);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user