diff options
author | Evan Cheng <evan.cheng@apple.com> | 2008-03-13 00:44:09 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2008-03-13 00:44:09 +0000 |
commit | b27087f5aa574f875598f4a309b7dd687c64a455 (patch) | |
tree | d004a308e8429297ce4869ba39213069f4a1d949 /lib/CodeGen/MachineSink.cpp | |
parent | d75686a471ee6ed5260e29d22d54f15152bbc9b4 (diff) |
Refactor some code out of MachineSink into a MachineInstr query.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48311 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/MachineSink.cpp')
-rw-r--r-- | lib/CodeGen/MachineSink.cpp | 25 |
1 files changed, 2 insertions, 23 deletions
diff --git a/lib/CodeGen/MachineSink.cpp b/lib/CodeGen/MachineSink.cpp index db2fab04f0..97a4df5497 100644 --- a/lib/CodeGen/MachineSink.cpp +++ b/lib/CodeGen/MachineSink.cpp @@ -132,30 +132,9 @@ bool MachineSinking::ProcessBlock(MachineBasicBlock &MBB) { /// SinkInstruction - Determine whether it is safe to sink the specified machine /// instruction out of its current block into a successor. bool MachineSinking::SinkInstruction(MachineInstr *MI, bool &SawStore) { - const TargetInstrDesc &TID = MI->getDesc(); - - // Ignore stuff that we obviously can't sink. - if (TID.mayStore() || TID.isCall()) { - SawStore = true; - return false; - } - if (TID.isReturn() || TID.isBranch() || TID.hasUnmodeledSideEffects()) + // Check if it's safe to move the instruction. + if (!MI->isSafeToMove(TII, SawStore)) return false; - - // See if this instruction does a load. If so, we have to guarantee that the - // loaded value doesn't change between the load and the end of block. The - // check for isInvariantLoad gives the targe the chance to classify the load - // as always returning a constant, e.g. a constant pool load. - if (TID.mayLoad() && !TII->isInvariantLoad(MI)) { - // Otherwise, this is a real load. If there is a store between the load and - // end of block, we can't sink the load. - // - // FIXME: we can't do this transformation until we know that the load is - // not volatile, and machineinstrs don't keep this info. :( - // - //if (SawStore) - return false; - } // FIXME: This should include support for sinking instructions within the // block they are currently in to shorten the live ranges. We often get |