| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 1 | //===-- MachineSink.cpp - Sinking for machine instructions ----------------===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
|  | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
|  | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 10 | // This pass moves instructions into successor blocks when possible, so that | 
| Dan Gohman | 5d79a2c | 2009-08-05 01:19:01 +0000 | [diff] [blame] | 11 | // they aren't executed on paths where their results aren't needed. | 
|  | 12 | // | 
|  | 13 | // This pass is not intended to be a replacement or a complete alternative | 
|  | 14 | // for an LLVM-IR-level sinking pass. It is only designed to sink simple | 
|  | 15 | // constructs that are not exposed before lowering and instruction selection. | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 16 | // | 
|  | 17 | //===----------------------------------------------------------------------===// | 
|  | 18 |  | 
|  | 19 | #define DEBUG_TYPE "machine-sink" | 
|  | 20 | #include "llvm/CodeGen/Passes.h" | 
|  | 21 | #include "llvm/CodeGen/MachineRegisterInfo.h" | 
|  | 22 | #include "llvm/CodeGen/MachineDominators.h" | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 23 | #include "llvm/CodeGen/MachineLoopInfo.h" | 
| Dan Gohman | 87b02d5 | 2009-10-09 23:27:56 +0000 | [diff] [blame] | 24 | #include "llvm/Analysis/AliasAnalysis.h" | 
| Dan Gohman | 3a4be0f | 2008-02-10 18:45:23 +0000 | [diff] [blame] | 25 | #include "llvm/Target/TargetRegisterInfo.h" | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 26 | #include "llvm/Target/TargetInstrInfo.h" | 
|  | 27 | #include "llvm/Target/TargetMachine.h" | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 28 | #include "llvm/ADT/SmallSet.h" | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 29 | #include "llvm/ADT/Statistic.h" | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 30 | #include "llvm/Support/CommandLine.h" | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 31 | #include "llvm/Support/Debug.h" | 
| Bill Wendling | 63aa000 | 2009-08-22 20:26:23 +0000 | [diff] [blame] | 32 | #include "llvm/Support/raw_ostream.h" | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 33 | using namespace llvm; | 
|  | 34 |  | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 35 | static cl::opt<bool> | 
|  | 36 | SplitEdges("machine-sink-split", | 
|  | 37 | cl::desc("Split critical edges during machine sinking"), | 
| Evan Cheng | f3e9a48 | 2010-09-20 22:52:00 +0000 | [diff] [blame] | 38 | cl::init(true), cl::Hidden); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 39 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 40 | STATISTIC(NumSunk,      "Number of machine instructions sunk"); | 
|  | 41 | STATISTIC(NumSplit,     "Number of critical edges split"); | 
|  | 42 | STATISTIC(NumCoalesces, "Number of copies coalesced"); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 43 |  | 
|  | 44 | namespace { | 
| Nick Lewycky | 02d5f77 | 2009-10-25 06:33:48 +0000 | [diff] [blame] | 45 | class MachineSinking : public MachineFunctionPass { | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 46 | const TargetInstrInfo *TII; | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 47 | const TargetRegisterInfo *TRI; | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 48 | MachineRegisterInfo  *MRI;  // Machine register information | 
| Dan Gohman | 5d79a2c | 2009-08-05 01:19:01 +0000 | [diff] [blame] | 49 | MachineDominatorTree *DT;   // Machine dominator tree | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 50 | MachineLoopInfo *LI; | 
| Dan Gohman | 87b02d5 | 2009-10-09 23:27:56 +0000 | [diff] [blame] | 51 | AliasAnalysis *AA; | 
| Dan Gohman | 2f5bdcb | 2009-09-26 02:34:00 +0000 | [diff] [blame] | 52 | BitVector AllocatableSet;   // Which physregs are allocatable? | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 53 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 54 | // Remember which edges have been considered for breaking. | 
|  | 55 | SmallSet<std::pair<MachineBasicBlock*,MachineBasicBlock*>, 8> | 
|  | 56 | CEBCandidates; | 
|  | 57 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 58 | public: | 
|  | 59 | static char ID; // Pass identification | 
| Owen Anderson | 6c18d1a | 2010-10-19 17:21:58 +0000 | [diff] [blame] | 60 | MachineSinking() : MachineFunctionPass(ID) { | 
|  | 61 | initializeMachineSinkingPass(*PassRegistry::getPassRegistry()); | 
|  | 62 | } | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 63 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 64 | virtual bool runOnMachineFunction(MachineFunction &MF); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 65 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 66 | virtual void getAnalysisUsage(AnalysisUsage &AU) const { | 
| Dan Gohman | 0402315 | 2009-07-31 23:37:33 +0000 | [diff] [blame] | 67 | AU.setPreservesCFG(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 68 | MachineFunctionPass::getAnalysisUsage(AU); | 
| Dan Gohman | 87b02d5 | 2009-10-09 23:27:56 +0000 | [diff] [blame] | 69 | AU.addRequired<AliasAnalysis>(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 70 | AU.addRequired<MachineDominatorTree>(); | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 71 | AU.addRequired<MachineLoopInfo>(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 72 | AU.addPreserved<MachineDominatorTree>(); | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 73 | AU.addPreserved<MachineLoopInfo>(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 74 | } | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 75 |  | 
|  | 76 | virtual void releaseMemory() { | 
|  | 77 | CEBCandidates.clear(); | 
|  | 78 | } | 
|  | 79 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 80 | private: | 
|  | 81 | bool ProcessBlock(MachineBasicBlock &MBB); | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 82 | bool isWorthBreakingCriticalEdge(MachineInstr *MI, | 
|  | 83 | MachineBasicBlock *From, | 
|  | 84 | MachineBasicBlock *To); | 
|  | 85 | MachineBasicBlock *SplitCriticalEdge(MachineInstr *MI, | 
|  | 86 | MachineBasicBlock *From, | 
|  | 87 | MachineBasicBlock *To, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 88 | bool BreakPHIEdge); | 
| Chris Lattner | 08af5a9 | 2008-01-12 00:17:41 +0000 | [diff] [blame] | 89 | bool SinkInstruction(MachineInstr *MI, bool &SawStore); | 
| Evan Cheng | 25b6068 | 2010-08-18 23:09:25 +0000 | [diff] [blame] | 90 | bool AllUsesDominatedByBlock(unsigned Reg, MachineBasicBlock *MBB, | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 91 | MachineBasicBlock *DefMBB, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 92 | bool &BreakPHIEdge, bool &LocalUse) const; | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 93 | bool PerformTrivialForwardCoalescing(MachineInstr *MI, | 
|  | 94 | MachineBasicBlock *MBB); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 95 | }; | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 96 | } // end anonymous namespace | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 97 |  | 
| Dan Gohman | d78c400 | 2008-05-13 00:00:25 +0000 | [diff] [blame] | 98 | char MachineSinking::ID = 0; | 
| Owen Anderson | 8ac477f | 2010-10-12 19:48:12 +0000 | [diff] [blame] | 99 | INITIALIZE_PASS_BEGIN(MachineSinking, "machine-sink", | 
|  | 100 | "Machine code sinking", false, false) | 
|  | 101 | INITIALIZE_PASS_DEPENDENCY(MachineDominatorTree) | 
|  | 102 | INITIALIZE_PASS_DEPENDENCY(MachineLoopInfo) | 
|  | 103 | INITIALIZE_AG_DEPENDENCY(AliasAnalysis) | 
|  | 104 | INITIALIZE_PASS_END(MachineSinking, "machine-sink", | 
| Owen Anderson | df7a4f2 | 2010-10-07 22:25:06 +0000 | [diff] [blame] | 105 | "Machine code sinking", false, false) | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 106 |  | 
|  | 107 | FunctionPass *llvm::createMachineSinkingPass() { return new MachineSinking(); } | 
|  | 108 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 109 | bool MachineSinking::PerformTrivialForwardCoalescing(MachineInstr *MI, | 
|  | 110 | MachineBasicBlock *MBB) { | 
|  | 111 | if (!MI->isCopy()) | 
|  | 112 | return false; | 
|  | 113 |  | 
|  | 114 | unsigned SrcReg = MI->getOperand(1).getReg(); | 
|  | 115 | unsigned DstReg = MI->getOperand(0).getReg(); | 
|  | 116 | if (!TargetRegisterInfo::isVirtualRegister(SrcReg) || | 
|  | 117 | !TargetRegisterInfo::isVirtualRegister(DstReg) || | 
|  | 118 | !MRI->hasOneNonDBGUse(SrcReg)) | 
|  | 119 | return false; | 
|  | 120 |  | 
|  | 121 | const TargetRegisterClass *SRC = MRI->getRegClass(SrcReg); | 
|  | 122 | const TargetRegisterClass *DRC = MRI->getRegClass(DstReg); | 
|  | 123 | if (SRC != DRC) | 
|  | 124 | return false; | 
|  | 125 |  | 
|  | 126 | MachineInstr *DefMI = MRI->getVRegDef(SrcReg); | 
|  | 127 | if (DefMI->isCopyLike()) | 
|  | 128 | return false; | 
|  | 129 | DEBUG(dbgs() << "Coalescing: " << *DefMI); | 
|  | 130 | DEBUG(dbgs() << "*** to: " << *MI); | 
|  | 131 | MRI->replaceRegWith(DstReg, SrcReg); | 
|  | 132 | MI->eraseFromParent(); | 
|  | 133 | ++NumCoalesces; | 
|  | 134 | return true; | 
|  | 135 | } | 
|  | 136 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 137 | /// AllUsesDominatedByBlock - Return true if all uses of the specified register | 
| Evan Cheng | 25b6068 | 2010-08-18 23:09:25 +0000 | [diff] [blame] | 138 | /// occur in blocks dominated by the specified block. If any use is in the | 
|  | 139 | /// definition block, then return false since it is never legal to move def | 
|  | 140 | /// after uses. | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 141 | bool | 
|  | 142 | MachineSinking::AllUsesDominatedByBlock(unsigned Reg, | 
|  | 143 | MachineBasicBlock *MBB, | 
|  | 144 | MachineBasicBlock *DefMBB, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 145 | bool &BreakPHIEdge, | 
|  | 146 | bool &LocalUse) const { | 
| Dan Gohman | 3a4be0f | 2008-02-10 18:45:23 +0000 | [diff] [blame] | 147 | assert(TargetRegisterInfo::isVirtualRegister(Reg) && | 
|  | 148 | "Only makes sense for vregs"); | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 149 |  | 
|  | 150 | if (MRI->use_nodbg_empty(Reg)) | 
|  | 151 | return true; | 
|  | 152 |  | 
| Dale Johannesen | 2061c84 | 2010-03-05 00:02:59 +0000 | [diff] [blame] | 153 | // Ignoring debug uses is necessary so debug info doesn't affect the code. | 
|  | 154 | // This may leave a referencing dbg_value in the original block, before | 
|  | 155 | // the definition of the vreg.  Dwarf generator handles this although the | 
|  | 156 | // user might not get the right info at runtime. | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 157 |  | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 158 | // BreakPHIEdge is true if all the uses are in the successor MBB being sunken | 
|  | 159 | // into and they are all PHI nodes. In this case, machine-sink must break | 
|  | 160 | // the critical edge first. e.g. | 
|  | 161 | // | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 162 | // BB#1: derived from LLVM BB %bb4.preheader | 
|  | 163 | //   Predecessors according to CFG: BB#0 | 
|  | 164 | //     ... | 
|  | 165 | //     %reg16385<def> = DEC64_32r %reg16437, %EFLAGS<imp-def,dead> | 
|  | 166 | //     ... | 
|  | 167 | //     JE_4 <BB#37>, %EFLAGS<imp-use> | 
|  | 168 | //   Successors according to CFG: BB#37 BB#2 | 
|  | 169 | // | 
|  | 170 | // BB#2: derived from LLVM BB %bb.nph | 
|  | 171 | //   Predecessors according to CFG: BB#0 BB#1 | 
|  | 172 | //     %reg16386<def> = PHI %reg16434, <BB#0>, %reg16385, <BB#1> | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 173 | BreakPHIEdge = true; | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 174 | for (MachineRegisterInfo::use_nodbg_iterator | 
|  | 175 | I = MRI->use_nodbg_begin(Reg), E = MRI->use_nodbg_end(); | 
|  | 176 | I != E; ++I) { | 
|  | 177 | MachineInstr *UseInst = &*I; | 
|  | 178 | MachineBasicBlock *UseBlock = UseInst->getParent(); | 
|  | 179 | if (!(UseBlock == MBB && UseInst->isPHI() && | 
|  | 180 | UseInst->getOperand(I.getOperandNo()+1).getMBB() == DefMBB)) { | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 181 | BreakPHIEdge = false; | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 182 | break; | 
|  | 183 | } | 
|  | 184 | } | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 185 | if (BreakPHIEdge) | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 186 | return true; | 
|  | 187 |  | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 188 | for (MachineRegisterInfo::use_nodbg_iterator | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 189 | I = MRI->use_nodbg_begin(Reg), E = MRI->use_nodbg_end(); | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 190 | I != E; ++I) { | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 191 | // Determine the block of the use. | 
|  | 192 | MachineInstr *UseInst = &*I; | 
|  | 193 | MachineBasicBlock *UseBlock = UseInst->getParent(); | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 194 | if (UseInst->isPHI()) { | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 195 | // PHI nodes use the operand in the predecessor block, not the block with | 
|  | 196 | // the PHI. | 
|  | 197 | UseBlock = UseInst->getOperand(I.getOperandNo()+1).getMBB(); | 
| Evan Cheng | 361b9be | 2010-08-19 18:33:29 +0000 | [diff] [blame] | 198 | } else if (UseBlock == DefMBB) { | 
|  | 199 | LocalUse = true; | 
|  | 200 | return false; | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 201 | } | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 202 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 203 | // Check that it dominates. | 
|  | 204 | if (!DT->dominates(MBB, UseBlock)) | 
|  | 205 | return false; | 
|  | 206 | } | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 207 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 208 | return true; | 
|  | 209 | } | 
|  | 210 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 211 | bool MachineSinking::runOnMachineFunction(MachineFunction &MF) { | 
| David Greene | 4b7aa24 | 2010-01-05 01:26:00 +0000 | [diff] [blame] | 212 | DEBUG(dbgs() << "******** Machine Sinking ********\n"); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 213 |  | 
| Dan Gohman | 20a327b | 2009-10-19 14:52:05 +0000 | [diff] [blame] | 214 | const TargetMachine &TM = MF.getTarget(); | 
|  | 215 | TII = TM.getInstrInfo(); | 
|  | 216 | TRI = TM.getRegisterInfo(); | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 217 | MRI = &MF.getRegInfo(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 218 | DT = &getAnalysis<MachineDominatorTree>(); | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 219 | LI = &getAnalysis<MachineLoopInfo>(); | 
| Dan Gohman | 87b02d5 | 2009-10-09 23:27:56 +0000 | [diff] [blame] | 220 | AA = &getAnalysis<AliasAnalysis>(); | 
| Dan Gohman | 20a327b | 2009-10-19 14:52:05 +0000 | [diff] [blame] | 221 | AllocatableSet = TRI->getAllocatableSet(MF); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 222 |  | 
|  | 223 | bool EverMadeChange = false; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 224 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 225 | while (1) { | 
|  | 226 | bool MadeChange = false; | 
|  | 227 |  | 
|  | 228 | // Process all basic blocks. | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 229 | CEBCandidates.clear(); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 230 | for (MachineFunction::iterator I = MF.begin(), E = MF.end(); | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 231 | I != E; ++I) | 
|  | 232 | MadeChange |= ProcessBlock(*I); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 233 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 234 | // If this iteration over the code changed anything, keep iterating. | 
|  | 235 | if (!MadeChange) break; | 
|  | 236 | EverMadeChange = true; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 237 | } | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 238 | return EverMadeChange; | 
|  | 239 | } | 
|  | 240 |  | 
|  | 241 | bool MachineSinking::ProcessBlock(MachineBasicBlock &MBB) { | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 242 | // Can't sink anything out of a block that has less than two successors. | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 243 | if (MBB.succ_size() <= 1 || MBB.empty()) return false; | 
|  | 244 |  | 
| Dan Gohman | 918a90a | 2010-04-05 19:17:22 +0000 | [diff] [blame] | 245 | // Don't bother sinking code out of unreachable blocks. In addition to being | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 246 | // unprofitable, it can also lead to infinite looping, because in an | 
|  | 247 | // unreachable loop there may be nowhere to stop. | 
| Dan Gohman | 918a90a | 2010-04-05 19:17:22 +0000 | [diff] [blame] | 248 | if (!DT->isReachableFromEntry(&MBB)) return false; | 
|  | 249 |  | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 250 | bool MadeChange = false; | 
|  | 251 |  | 
| Chris Lattner | 08af5a9 | 2008-01-12 00:17:41 +0000 | [diff] [blame] | 252 | // Walk the basic block bottom-up.  Remember if we saw a store. | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 253 | MachineBasicBlock::iterator I = MBB.end(); | 
|  | 254 | --I; | 
|  | 255 | bool ProcessedBegin, SawStore = false; | 
|  | 256 | do { | 
|  | 257 | MachineInstr *MI = I;  // The instruction to sink. | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 258 |  | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 259 | // Predecrement I (if it's not begin) so that it isn't invalidated by | 
|  | 260 | // sinking. | 
|  | 261 | ProcessedBegin = I == MBB.begin(); | 
|  | 262 | if (!ProcessedBegin) | 
|  | 263 | --I; | 
| Dale Johannesen | 2061c84 | 2010-03-05 00:02:59 +0000 | [diff] [blame] | 264 |  | 
|  | 265 | if (MI->isDebugValue()) | 
|  | 266 | continue; | 
|  | 267 |  | 
| Evan Cheng | fe917ef | 2011-04-11 18:47:20 +0000 | [diff] [blame] | 268 | bool Joined = PerformTrivialForwardCoalescing(MI, &MBB); | 
|  | 269 | if (Joined) { | 
|  | 270 | MadeChange = true; | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 271 | continue; | 
| Evan Cheng | fe917ef | 2011-04-11 18:47:20 +0000 | [diff] [blame] | 272 | } | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 273 |  | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 274 | if (SinkInstruction(MI, SawStore)) | 
|  | 275 | ++NumSunk, MadeChange = true; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 276 |  | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 277 | // If we just processed the first instruction in the block, we're done. | 
|  | 278 | } while (!ProcessedBegin); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 279 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 280 | return MadeChange; | 
|  | 281 | } | 
|  | 282 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 283 | bool MachineSinking::isWorthBreakingCriticalEdge(MachineInstr *MI, | 
|  | 284 | MachineBasicBlock *From, | 
|  | 285 | MachineBasicBlock *To) { | 
|  | 286 | // FIXME: Need much better heuristics. | 
|  | 287 |  | 
|  | 288 | // If the pass has already considered breaking this edge (during this pass | 
|  | 289 | // through the function), then let's go ahead and break it. This means | 
|  | 290 | // sinking multiple "cheap" instructions into the same block. | 
|  | 291 | if (!CEBCandidates.insert(std::make_pair(From, To))) | 
|  | 292 | return true; | 
|  | 293 |  | 
| Evan Cheng | d4b31a7 | 2010-09-23 06:53:00 +0000 | [diff] [blame] | 294 | if (!MI->isCopy() && !MI->getDesc().isAsCheapAsAMove()) | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 295 | return true; | 
|  | 296 |  | 
|  | 297 | // MI is cheap, we probably don't want to break the critical edge for it. | 
|  | 298 | // However, if this would allow some definitions of its source operands | 
|  | 299 | // to be sunk then it's probably worth it. | 
|  | 300 | for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { | 
|  | 301 | const MachineOperand &MO = MI->getOperand(i); | 
|  | 302 | if (!MO.isReg()) continue; | 
|  | 303 | unsigned Reg = MO.getReg(); | 
|  | 304 | if (Reg == 0 || !TargetRegisterInfo::isPhysicalRegister(Reg)) | 
|  | 305 | continue; | 
|  | 306 | if (MRI->hasOneNonDBGUse(Reg)) | 
|  | 307 | return true; | 
|  | 308 | } | 
|  | 309 |  | 
|  | 310 | return false; | 
|  | 311 | } | 
|  | 312 |  | 
|  | 313 | MachineBasicBlock *MachineSinking::SplitCriticalEdge(MachineInstr *MI, | 
|  | 314 | MachineBasicBlock *FromBB, | 
|  | 315 | MachineBasicBlock *ToBB, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 316 | bool BreakPHIEdge) { | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 317 | if (!isWorthBreakingCriticalEdge(MI, FromBB, ToBB)) | 
|  | 318 | return 0; | 
|  | 319 |  | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 320 | // Avoid breaking back edge. From == To means backedge for single BB loop. | 
| Evan Cheng | f3e9a48 | 2010-09-20 22:52:00 +0000 | [diff] [blame] | 321 | if (!SplitEdges || FromBB == ToBB) | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 322 | return 0; | 
|  | 323 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 324 | // Check for backedges of more "complex" loops. | 
|  | 325 | if (LI->getLoopFor(FromBB) == LI->getLoopFor(ToBB) && | 
|  | 326 | LI->isLoopHeader(ToBB)) | 
|  | 327 | return 0; | 
|  | 328 |  | 
|  | 329 | // It's not always legal to break critical edges and sink the computation | 
|  | 330 | // to the edge. | 
|  | 331 | // | 
|  | 332 | // BB#1: | 
|  | 333 | // v1024 | 
|  | 334 | // Beq BB#3 | 
|  | 335 | // <fallthrough> | 
|  | 336 | // BB#2: | 
|  | 337 | // ... no uses of v1024 | 
|  | 338 | // <fallthrough> | 
|  | 339 | // BB#3: | 
|  | 340 | // ... | 
|  | 341 | //       = v1024 | 
|  | 342 | // | 
|  | 343 | // If BB#1 -> BB#3 edge is broken and computation of v1024 is inserted: | 
|  | 344 | // | 
|  | 345 | // BB#1: | 
|  | 346 | // ... | 
|  | 347 | // Bne BB#2 | 
|  | 348 | // BB#4: | 
|  | 349 | // v1024 = | 
|  | 350 | // B BB#3 | 
|  | 351 | // BB#2: | 
|  | 352 | // ... no uses of v1024 | 
|  | 353 | // <fallthrough> | 
|  | 354 | // BB#3: | 
|  | 355 | // ... | 
|  | 356 | //       = v1024 | 
|  | 357 | // | 
|  | 358 | // This is incorrect since v1024 is not computed along the BB#1->BB#2->BB#3 | 
|  | 359 | // flow. We need to ensure the new basic block where the computation is | 
|  | 360 | // sunk to dominates all the uses. | 
|  | 361 | // It's only legal to break critical edge and sink the computation to the | 
|  | 362 | // new block if all the predecessors of "To", except for "From", are | 
|  | 363 | // not dominated by "From". Given SSA property, this means these | 
|  | 364 | // predecessors are dominated by "To". | 
|  | 365 | // | 
|  | 366 | // There is no need to do this check if all the uses are PHI nodes. PHI | 
|  | 367 | // sources are only defined on the specific predecessor edges. | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 368 | if (!BreakPHIEdge) { | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 369 | for (MachineBasicBlock::pred_iterator PI = ToBB->pred_begin(), | 
|  | 370 | E = ToBB->pred_end(); PI != E; ++PI) { | 
|  | 371 | if (*PI == FromBB) | 
|  | 372 | continue; | 
|  | 373 | if (!DT->dominates(ToBB, *PI)) | 
|  | 374 | return 0; | 
|  | 375 | } | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 376 | } | 
|  | 377 |  | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 378 | return FromBB->SplitCriticalEdge(ToBB, this); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 379 | } | 
|  | 380 |  | 
| Evan Cheng | d4b31a7 | 2010-09-23 06:53:00 +0000 | [diff] [blame] | 381 | static bool AvoidsSinking(MachineInstr *MI, MachineRegisterInfo *MRI) { | 
|  | 382 | return MI->isInsertSubreg() || MI->isSubregToReg() || MI->isRegSequence(); | 
|  | 383 | } | 
|  | 384 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 385 | /// SinkInstruction - Determine whether it is safe to sink the specified machine | 
|  | 386 | /// instruction out of its current block into a successor. | 
| Chris Lattner | 08af5a9 | 2008-01-12 00:17:41 +0000 | [diff] [blame] | 387 | bool MachineSinking::SinkInstruction(MachineInstr *MI, bool &SawStore) { | 
| Evan Cheng | d4b31a7 | 2010-09-23 06:53:00 +0000 | [diff] [blame] | 388 | // Don't sink insert_subreg, subreg_to_reg, reg_sequence. These are meant to | 
|  | 389 | // be close to the source to make it easier to coalesce. | 
|  | 390 | if (AvoidsSinking(MI, MRI)) | 
|  | 391 | return false; | 
|  | 392 |  | 
| Evan Cheng | 399e110 | 2008-03-13 00:44:09 +0000 | [diff] [blame] | 393 | // Check if it's safe to move the instruction. | 
| Evan Cheng | 62e795a | 2010-03-02 19:03:01 +0000 | [diff] [blame] | 394 | if (!MI->isSafeToMove(TII, AA, SawStore)) | 
| Chris Lattner | 08af5a9 | 2008-01-12 00:17:41 +0000 | [diff] [blame] | 395 | return false; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 396 |  | 
| Chris Lattner | ee61d14 | 2008-01-05 06:47:58 +0000 | [diff] [blame] | 397 | // FIXME: This should include support for sinking instructions within the | 
|  | 398 | // block they are currently in to shorten the live ranges.  We often get | 
|  | 399 | // instructions sunk into the top of a large block, but it would be better to | 
|  | 400 | // also sink them down before their first use in the block.  This xform has to | 
|  | 401 | // be careful not to *increase* register pressure though, e.g. sinking | 
|  | 402 | // "x = y + z" down if it kills y and z would increase the live ranges of y | 
| Dan Gohman | 5d79a2c | 2009-08-05 01:19:01 +0000 | [diff] [blame] | 403 | // and z and only shrink the live range of x. | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 404 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 405 | // Loop over all the operands of the specified instruction.  If there is | 
|  | 406 | // anything we can't handle, bail out. | 
|  | 407 | MachineBasicBlock *ParentBlock = MI->getParent(); | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 408 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 409 | // SuccToSinkTo - This is the successor to sink this instruction to, once we | 
|  | 410 | // decide. | 
|  | 411 | MachineBasicBlock *SuccToSinkTo = 0; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 412 |  | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 413 | bool BreakPHIEdge = false; | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 414 | for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { | 
|  | 415 | const MachineOperand &MO = MI->getOperand(i); | 
| Dan Gohman | 0d1e9a8 | 2008-10-03 15:45:36 +0000 | [diff] [blame] | 416 | if (!MO.isReg()) continue;  // Ignore non-register operands. | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 417 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 418 | unsigned Reg = MO.getReg(); | 
|  | 419 | if (Reg == 0) continue; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 420 |  | 
| Dan Gohman | 3a4be0f | 2008-02-10 18:45:23 +0000 | [diff] [blame] | 421 | if (TargetRegisterInfo::isPhysicalRegister(Reg)) { | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 422 | if (MO.isUse()) { | 
|  | 423 | // If the physreg has no defs anywhere, it's just an ambient register | 
| Dan Gohman | 2f5bdcb | 2009-09-26 02:34:00 +0000 | [diff] [blame] | 424 | // and we can freely move its uses. Alternatively, if it's allocatable, | 
|  | 425 | // it could get allocated to something with a def during allocation. | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 426 | if (!MRI->def_empty(Reg)) | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 427 | return false; | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 428 |  | 
| Dan Gohman | 2f5bdcb | 2009-09-26 02:34:00 +0000 | [diff] [blame] | 429 | if (AllocatableSet.test(Reg)) | 
|  | 430 | return false; | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 431 |  | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 432 | // Check for a def among the register's aliases too. | 
| Dan Gohman | 2f5bdcb | 2009-09-26 02:34:00 +0000 | [diff] [blame] | 433 | for (const unsigned *Alias = TRI->getAliasSet(Reg); *Alias; ++Alias) { | 
|  | 434 | unsigned AliasReg = *Alias; | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 435 | if (!MRI->def_empty(AliasReg)) | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 436 | return false; | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 437 |  | 
| Dan Gohman | 2f5bdcb | 2009-09-26 02:34:00 +0000 | [diff] [blame] | 438 | if (AllocatableSet.test(AliasReg)) | 
|  | 439 | return false; | 
|  | 440 | } | 
| Bill Wendling | e41e40f | 2010-06-25 20:48:10 +0000 | [diff] [blame] | 441 | } else if (!MO.isDead()) { | 
|  | 442 | // A def that isn't dead. We can't move it. | 
|  | 443 | return false; | 
| Dan Gohman | a317687 | 2009-09-25 22:53:29 +0000 | [diff] [blame] | 444 | } | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 445 | } else { | 
|  | 446 | // Virtual register uses are always safe to sink. | 
|  | 447 | if (MO.isUse()) continue; | 
| Evan Cheng | 47a65a1 | 2009-02-07 01:21:47 +0000 | [diff] [blame] | 448 |  | 
|  | 449 | // If it's not safe to move defs of the register class, then abort. | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 450 | if (!TII->isSafeToMoveRegClassDefs(MRI->getRegClass(Reg))) | 
| Evan Cheng | 47a65a1 | 2009-02-07 01:21:47 +0000 | [diff] [blame] | 451 | return false; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 452 |  | 
| Chris Lattner | ee61d14 | 2008-01-05 06:47:58 +0000 | [diff] [blame] | 453 | // FIXME: This picks a successor to sink into based on having one | 
|  | 454 | // successor that dominates all the uses.  However, there are cases where | 
|  | 455 | // sinking can happen but where the sink point isn't a successor.  For | 
|  | 456 | // example: | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 457 | // | 
| Chris Lattner | ee61d14 | 2008-01-05 06:47:58 +0000 | [diff] [blame] | 458 | //   x = computation | 
|  | 459 | //   if () {} else {} | 
|  | 460 | //   use x | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 461 | // | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 462 | // the instruction could be sunk over the whole diamond for the | 
| Chris Lattner | ee61d14 | 2008-01-05 06:47:58 +0000 | [diff] [blame] | 463 | // if/then/else (or loop, etc), allowing it to be sunk into other blocks | 
|  | 464 | // after that. | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 465 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 466 | // Virtual register defs can only be sunk if all their uses are in blocks | 
|  | 467 | // dominated by one of the successors. | 
|  | 468 | if (SuccToSinkTo) { | 
|  | 469 | // If a previous operand picked a block to sink to, then this operand | 
|  | 470 | // must be sinkable to the same block. | 
| Evan Cheng | 361b9be | 2010-08-19 18:33:29 +0000 | [diff] [blame] | 471 | bool LocalUse = false; | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 472 | if (!AllUsesDominatedByBlock(Reg, SuccToSinkTo, ParentBlock, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 473 | BreakPHIEdge, LocalUse)) | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 474 | return false; | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 475 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 476 | continue; | 
|  | 477 | } | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 478 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 479 | // Otherwise, we should look at all the successors and decide which one | 
|  | 480 | // we should sink to. | 
|  | 481 | for (MachineBasicBlock::succ_iterator SI = ParentBlock->succ_begin(), | 
|  | 482 | E = ParentBlock->succ_end(); SI != E; ++SI) { | 
| Evan Cheng | 361b9be | 2010-08-19 18:33:29 +0000 | [diff] [blame] | 483 | bool LocalUse = false; | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 484 | if (AllUsesDominatedByBlock(Reg, *SI, ParentBlock, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 485 | BreakPHIEdge, LocalUse)) { | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 486 | SuccToSinkTo = *SI; | 
|  | 487 | break; | 
|  | 488 | } | 
| Evan Cheng | 25b6068 | 2010-08-18 23:09:25 +0000 | [diff] [blame] | 489 | if (LocalUse) | 
|  | 490 | // Def is used locally, it's never safe to move this def. | 
|  | 491 | return false; | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 492 | } | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 493 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 494 | // If we couldn't find a block to sink to, ignore this instruction. | 
|  | 495 | if (SuccToSinkTo == 0) | 
|  | 496 | return false; | 
|  | 497 | } | 
|  | 498 | } | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 499 |  | 
| Chris Lattner | 6ec7827 | 2008-01-05 01:39:17 +0000 | [diff] [blame] | 500 | // If there are no outputs, it must have side-effects. | 
|  | 501 | if (SuccToSinkTo == 0) | 
|  | 502 | return false; | 
| Evan Cheng | 2510436 | 2009-02-15 08:36:12 +0000 | [diff] [blame] | 503 |  | 
|  | 504 | // It's not safe to sink instructions to EH landing pad. Control flow into | 
|  | 505 | // landing pad is implicitly defined. | 
|  | 506 | if (SuccToSinkTo->isLandingPad()) | 
|  | 507 | return false; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 508 |  | 
| Dan Gohman | b0db991 | 2009-10-19 14:56:05 +0000 | [diff] [blame] | 509 | // It is not possible to sink an instruction into its own block.  This can | 
| Chris Lattner | 30c3de6 | 2009-04-10 16:38:36 +0000 | [diff] [blame] | 510 | // happen with loops. | 
|  | 511 | if (MI->getParent() == SuccToSinkTo) | 
|  | 512 | return false; | 
| Bill Wendling | f82aea6 | 2010-06-03 07:54:20 +0000 | [diff] [blame] | 513 |  | 
| Daniel Dunbar | ef5a438 | 2010-06-23 00:48:25 +0000 | [diff] [blame] | 514 | // If the instruction to move defines a dead physical register which is live | 
|  | 515 | // when leaving the basic block, don't move it because it could turn into a | 
|  | 516 | // "zombie" define of that preg. E.g., EFLAGS. (<rdar://problem/8030636>) | 
| Bill Wendling | e41e40f | 2010-06-25 20:48:10 +0000 | [diff] [blame] | 517 | for (unsigned I = 0, E = MI->getNumOperands(); I != E; ++I) { | 
|  | 518 | const MachineOperand &MO = MI->getOperand(I); | 
|  | 519 | if (!MO.isReg()) continue; | 
|  | 520 | unsigned Reg = MO.getReg(); | 
|  | 521 | if (Reg == 0 || !TargetRegisterInfo::isPhysicalRegister(Reg)) continue; | 
|  | 522 | if (SuccToSinkTo->isLiveIn(Reg)) | 
| Bill Wendling | f82aea6 | 2010-06-03 07:54:20 +0000 | [diff] [blame] | 523 | return false; | 
| Bill Wendling | e41e40f | 2010-06-25 20:48:10 +0000 | [diff] [blame] | 524 | } | 
| Bill Wendling | f82aea6 | 2010-06-03 07:54:20 +0000 | [diff] [blame] | 525 |  | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 526 | DEBUG(dbgs() << "Sink instr " << *MI << "\tinto block " << *SuccToSinkTo); | 
|  | 527 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 528 | // If the block has multiple predecessors, this would introduce computation on | 
|  | 529 | // a path that it doesn't already exist.  We could split the critical edge, | 
|  | 530 | // but for now we just punt. | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 531 | if (SuccToSinkTo->pred_size() > 1) { | 
| Jakob Stoklund Olesen | 20b71e2 | 2010-04-13 19:06:14 +0000 | [diff] [blame] | 532 | // We cannot sink a load across a critical edge - there may be stores in | 
|  | 533 | // other code paths. | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 534 | bool TryBreak = false; | 
| Jakob Stoklund Olesen | 20b71e2 | 2010-04-13 19:06:14 +0000 | [diff] [blame] | 535 | bool store = true; | 
|  | 536 | if (!MI->isSafeToMove(TII, AA, store)) { | 
| Evan Cheng | e5af930 | 2010-08-19 23:33:02 +0000 | [diff] [blame] | 537 | DEBUG(dbgs() << " *** NOTE: Won't sink load along critical edge.\n"); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 538 | TryBreak = true; | 
| Jakob Stoklund Olesen | 20b71e2 | 2010-04-13 19:06:14 +0000 | [diff] [blame] | 539 | } | 
|  | 540 |  | 
|  | 541 | // We don't want to sink across a critical edge if we don't dominate the | 
|  | 542 | // successor. We could be introducing calculations to new code paths. | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 543 | if (!TryBreak && !DT->dominates(ParentBlock, SuccToSinkTo)) { | 
| Evan Cheng | e5af930 | 2010-08-19 23:33:02 +0000 | [diff] [blame] | 544 | DEBUG(dbgs() << " *** NOTE: Critical edge found\n"); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 545 | TryBreak = true; | 
| Jakob Stoklund Olesen | 20b71e2 | 2010-04-13 19:06:14 +0000 | [diff] [blame] | 546 | } | 
|  | 547 |  | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 548 | // Don't sink instructions into a loop. | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 549 | if (!TryBreak && LI->isLoopHeader(SuccToSinkTo)) { | 
| Evan Cheng | e5af930 | 2010-08-19 23:33:02 +0000 | [diff] [blame] | 550 | DEBUG(dbgs() << " *** NOTE: Loop header found\n"); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 551 | TryBreak = true; | 
| Jakob Stoklund Olesen | cdc3df4 | 2010-04-15 23:41:02 +0000 | [diff] [blame] | 552 | } | 
|  | 553 |  | 
| Jakob Stoklund Olesen | 20b71e2 | 2010-04-13 19:06:14 +0000 | [diff] [blame] | 554 | // Otherwise we are OK with sinking along a critical edge. | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 555 | if (!TryBreak) | 
|  | 556 | DEBUG(dbgs() << "Sinking along critical edge.\n"); | 
|  | 557 | else { | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 558 | MachineBasicBlock *NewSucc = | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 559 | SplitCriticalEdge(MI, ParentBlock, SuccToSinkTo, BreakPHIEdge); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 560 | if (!NewSucc) { | 
| Evan Cheng | e53ab6d | 2010-09-17 22:28:18 +0000 | [diff] [blame] | 561 | DEBUG(dbgs() << " *** PUNTING: Not legal or profitable to " | 
|  | 562 | "break critical edge\n"); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 563 | return false; | 
|  | 564 | } else { | 
| Evan Cheng | e5af930 | 2010-08-19 23:33:02 +0000 | [diff] [blame] | 565 | DEBUG(dbgs() << " *** Splitting critical edge:" | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 566 | " BB#" << ParentBlock->getNumber() | 
|  | 567 | << " -- BB#" << NewSucc->getNumber() | 
|  | 568 | << " -- BB#" << SuccToSinkTo->getNumber() << '\n'); | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 569 | SuccToSinkTo = NewSucc; | 
|  | 570 | ++NumSplit; | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 571 | BreakPHIEdge = false; | 
| Evan Cheng | ae9939c | 2010-08-19 17:33:11 +0000 | [diff] [blame] | 572 | } | 
|  | 573 | } | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 574 | } | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 575 |  | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 576 | if (BreakPHIEdge) { | 
|  | 577 | // BreakPHIEdge is true if all the uses are in the successor MBB being | 
|  | 578 | // sunken into and they are all PHI nodes. In this case, machine-sink must | 
|  | 579 | // break the critical edge first. | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 580 | MachineBasicBlock *NewSucc = SplitCriticalEdge(MI, ParentBlock, | 
| Evan Cheng | 2031b76 | 2010-09-20 19:12:55 +0000 | [diff] [blame] | 581 | SuccToSinkTo, BreakPHIEdge); | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 582 | if (!NewSucc) { | 
|  | 583 | DEBUG(dbgs() << " *** PUNTING: Not legal or profitable to " | 
|  | 584 | "break critical edge\n"); | 
|  | 585 | return false; | 
|  | 586 | } | 
|  | 587 |  | 
|  | 588 | DEBUG(dbgs() << " *** Splitting critical edge:" | 
|  | 589 | " BB#" << ParentBlock->getNumber() | 
|  | 590 | << " -- BB#" << NewSucc->getNumber() | 
|  | 591 | << " -- BB#" << SuccToSinkTo->getNumber() << '\n'); | 
|  | 592 | SuccToSinkTo = NewSucc; | 
|  | 593 | ++NumSplit; | 
|  | 594 | } | 
|  | 595 |  | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 596 | // Determine where to insert into. Skip phi nodes. | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 597 | MachineBasicBlock::iterator InsertPos = SuccToSinkTo->begin(); | 
| Evan Cheng | b339f3d | 2010-09-18 06:42:17 +0000 | [diff] [blame] | 598 | while (InsertPos != SuccToSinkTo->end() && InsertPos->isPHI()) | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 599 | ++InsertPos; | 
| Jim Grosbach | 01edd68 | 2010-06-03 23:49:57 +0000 | [diff] [blame] | 600 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 601 | // Move the instruction. | 
|  | 602 | SuccToSinkTo->splice(InsertPos, ParentBlock, MI, | 
|  | 603 | ++MachineBasicBlock::iterator(MI)); | 
| Dan Gohman | c90f51c | 2010-05-13 20:34:42 +0000 | [diff] [blame] | 604 |  | 
| Bill Wendling | 7ee730e | 2010-06-02 23:04:26 +0000 | [diff] [blame] | 605 | // Conservatively, clear any kill flags, since it's possible that they are no | 
|  | 606 | // longer correct. | 
| Dan Gohman | c90f51c | 2010-05-13 20:34:42 +0000 | [diff] [blame] | 607 | MI->clearKillInfo(); | 
|  | 608 |  | 
| Chris Lattner | f3edc09 | 2008-01-04 07:36:53 +0000 | [diff] [blame] | 609 | return true; | 
|  | 610 | } |