diff options
| author | Lang Hames <lhames@gmail.com> | 2012-01-27 22:36:19 +0000 |
|---|---|---|
| committer | Lang Hames <lhames@gmail.com> | 2012-01-27 22:36:19 +0000 |
| commit | ad33d5ace7cb51b1d6b6a7454f1dafc077871ef4 (patch) | |
| tree | f6256558431d0f792de293c55e8899dd45674419 /llvm/lib/CodeGen/MachineScheduler.cpp | |
| parent | 6f108d922977da544f9f8e5cd72e72fd3ab7e083 (diff) | |
| download | bcm5719-llvm-ad33d5ace7cb51b1d6b6a7454f1dafc077871ef4.tar.gz bcm5719-llvm-ad33d5ace7cb51b1d6b6a7454f1dafc077871ef4.zip | |
Add a "moveInstr" method to LiveIntervals. This can be used to move instructions
around within a basic block while maintaining live-intervals.
Updated ScheduleTopDownLive in MachineScheduler.cpp to use the moveInstr API
when reordering MIs.
llvm-svn: 149147
Diffstat (limited to 'llvm/lib/CodeGen/MachineScheduler.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/MachineScheduler.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/MachineScheduler.cpp b/llvm/lib/CodeGen/MachineScheduler.cpp index a14b3912236..73560bdc617 100644 --- a/llvm/lib/CodeGen/MachineScheduler.cpp +++ b/llvm/lib/CodeGen/MachineScheduler.cpp @@ -43,6 +43,7 @@ public: const TargetInstrInfo *TII; const MachineLoopInfo *MLI; const MachineDominatorTree *MDT; + LiveIntervals *LIS; MachineScheduler(); @@ -236,7 +237,7 @@ void ScheduleTopDownLive::Schedule() { if (&*InsertPos == MI) ++InsertPos; else { - BB->splice(InsertPos, BB, MI); + Pass->LIS->moveInstr(InsertPos, MI); if (Begin == InsertPos) Begin = MI; } @@ -253,6 +254,7 @@ bool MachineScheduler::runOnMachineFunction(MachineFunction &mf) { MF = &mf; MLI = &getAnalysis<MachineLoopInfo>(); MDT = &getAnalysis<MachineDominatorTree>(); + LIS = &getAnalysis<LiveIntervals>(); TII = MF->getTarget().getInstrInfo(); // Select the scheduler, or set the default. |

