blob: 7a404241cb1481872ad80fa3b39245a8acc029ea [file] [log] [blame]
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001//===- CodeExtractor.cpp - Pull code region into a new function -----------===//
Misha Brukmanb1c93172005-04-21 23:48:37 +00002//
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattnerf3ebc3f2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Misha Brukmanb1c93172005-04-21 23:48:37 +00007//
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00008//===----------------------------------------------------------------------===//
9//
10// This file implements the interface to tear out a code region, such as an
11// individual loop or a parallel section, into a new function, replacing it with
12// a call to the new function.
13//
14//===----------------------------------------------------------------------===//
15
Chandler Carruth0fde0012012-05-04 10:18:49 +000016#include "llvm/Transforms/Utils/CodeExtractor.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000017#include "llvm/ADT/ArrayRef.h"
18#include "llvm/ADT/DenseMap.h"
19#include "llvm/ADT/Optional.h"
Jakub Staszakf23980a2013-02-09 01:04:28 +000020#include "llvm/ADT/STLExtras.h"
Chandler Carruth8a8cd2b2014-01-07 11:48:04 +000021#include "llvm/ADT/SetVector.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000022#include "llvm/ADT/SmallPtrSet.h"
23#include "llvm/ADT/SmallVector.h"
Sean Silvaf8015752016-08-02 02:15:45 +000024#include "llvm/Analysis/BlockFrequencyInfo.h"
25#include "llvm/Analysis/BlockFrequencyInfoImpl.h"
26#include "llvm/Analysis/BranchProbabilityInfo.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000027#include "llvm/Analysis/LoopInfo.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000028#include "llvm/IR/Argument.h"
29#include "llvm/IR/Attributes.h"
30#include "llvm/IR/BasicBlock.h"
31#include "llvm/IR/CFG.h"
32#include "llvm/IR/Constant.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000033#include "llvm/IR/Constants.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000034#include "llvm/IR/DataLayout.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000035#include "llvm/IR/DerivedTypes.h"
Chandler Carruth5ad5f152014-01-13 09:26:24 +000036#include "llvm/IR/Dominators.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000037#include "llvm/IR/Function.h"
38#include "llvm/IR/GlobalValue.h"
39#include "llvm/IR/InstrTypes.h"
40#include "llvm/IR/Instruction.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000041#include "llvm/IR/Instructions.h"
Xinliang David Li74480ad2017-05-30 21:22:18 +000042#include "llvm/IR/IntrinsicInst.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000043#include "llvm/IR/Intrinsics.h"
44#include "llvm/IR/LLVMContext.h"
Sean Silvaf8015752016-08-02 02:15:45 +000045#include "llvm/IR/MDBuilder.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000046#include "llvm/IR/Module.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000047#include "llvm/IR/Type.h"
48#include "llvm/IR/User.h"
49#include "llvm/IR/Value.h"
Chandler Carruth5ad5f152014-01-13 09:26:24 +000050#include "llvm/IR/Verifier.h"
Misha Brukmancaa1a5a2004-02-28 03:26:20 +000051#include "llvm/Pass.h"
Sean Silvaf8015752016-08-02 02:15:45 +000052#include "llvm/Support/BlockFrequency.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000053#include "llvm/Support/BranchProbability.h"
54#include "llvm/Support/Casting.h"
Reid Spencer7c16caa2004-09-01 22:55:40 +000055#include "llvm/Support/CommandLine.h"
56#include "llvm/Support/Debug.h"
Torok Edwinccb29cd2009-07-11 13:10:19 +000057#include "llvm/Support/ErrorHandling.h"
Chris Lattnerb25de3f2009-08-23 04:37:46 +000058#include "llvm/Support/raw_ostream.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000059#include "llvm/Transforms/Utils/BasicBlockUtils.h"
Eugene Zelenko286d5892017-10-11 21:41:43 +000060#include <cassert>
61#include <cstdint>
62#include <iterator>
63#include <map>
Chris Lattner9c431f62004-03-14 22:34:55 +000064#include <set>
Eugene Zelenko286d5892017-10-11 21:41:43 +000065#include <utility>
66#include <vector>
67
Misha Brukmancaa1a5a2004-02-28 03:26:20 +000068using namespace llvm;
69
Chandler Carruthe96dd892014-04-21 22:55:11 +000070#define DEBUG_TYPE "code-extractor"
71
Misha Brukman3596f0a2004-04-23 23:54:17 +000072// Provide a command-line option to aggregate function arguments into a struct
Misha Brukman234b44a2008-12-13 05:21:37 +000073// for functions produced by the code extractor. This is useful when converting
Misha Brukman3596f0a2004-04-23 23:54:17 +000074// extracted functions to pthread-based code, as only one argument (void*) can
75// be passed in to pthread_create().
76static cl::opt<bool>
77AggregateArgsOpt("aggregate-extracted-args", cl::Hidden,
78 cl::desc("Aggregate arguments to code-extracted functions"));
79
Chandler Carruth0fde0012012-05-04 10:18:49 +000080/// \brief Test whether a block is valid for extraction.
Florian Hahn0e9dec62017-11-13 10:35:52 +000081bool CodeExtractor::isBlockValidForExtraction(const BasicBlock &BB,
82 bool AllowVarArgs) {
Chandler Carruth0fde0012012-05-04 10:18:49 +000083 // Landing pads must be in the function where they were inserted for cleanup.
David Majnemereb518bd2015-08-04 08:21:40 +000084 if (BB.isEHPad())
Chandler Carruth0fde0012012-05-04 10:18:49 +000085 return false;
Serge Guelton7bc405a2017-06-27 18:57:53 +000086 // taking the address of a basic block moved to another function is illegal
87 if (BB.hasAddressTaken())
88 return false;
89
90 // don't hoist code that uses another basicblock address, as it's likely to
91 // lead to unexpected behavior, like cross-function jumps
92 SmallPtrSet<User const *, 16> Visited;
93 SmallVector<User const *, 16> ToVisit;
94
95 for (Instruction const &Inst : BB)
96 ToVisit.push_back(&Inst);
97
98 while (!ToVisit.empty()) {
99 User const *Curr = ToVisit.pop_back_val();
100 if (!Visited.insert(Curr).second)
101 continue;
102 if (isa<BlockAddress const>(Curr))
103 return false; // even a reference to self is likely to be not compatible
104
105 if (isa<Instruction>(Curr) && cast<Instruction>(Curr)->getParent() != &BB)
106 continue;
107
108 for (auto const &U : Curr->operands()) {
109 if (auto *UU = dyn_cast<User>(U))
110 ToVisit.push_back(UU);
111 }
112 }
Chris Lattner37de2572004-03-18 03:49:40 +0000113
Florian Hahn0e9dec62017-11-13 10:35:52 +0000114 // Don't hoist code containing allocas or invokes. If explicitly requested,
115 // allow vastart.
Chandler Carruth0fde0012012-05-04 10:18:49 +0000116 for (BasicBlock::const_iterator I = BB.begin(), E = BB.end(); I != E; ++I) {
117 if (isa<AllocaInst>(I) || isa<InvokeInst>(I))
Chris Lattner3b2917b2004-05-12 06:01:40 +0000118 return false;
Chandler Carruth0fde0012012-05-04 10:18:49 +0000119 if (const CallInst *CI = dyn_cast<CallInst>(I))
120 if (const Function *F = CI->getCalledFunction())
Florian Hahn0e9dec62017-11-13 10:35:52 +0000121 if (F->getIntrinsicID() == Intrinsic::vastart) {
122 if (AllowVarArgs)
123 continue;
124 else
125 return false;
126 }
Chandler Carruth0fde0012012-05-04 10:18:49 +0000127 }
128
129 return true;
130}
131
132/// \brief Build a set of blocks to extract if the input blocks are viable.
Davide Italiano059574c2017-04-21 00:21:09 +0000133static SetVector<BasicBlock *>
Florian Hahn0e9dec62017-11-13 10:35:52 +0000134buildExtractionBlockSet(ArrayRef<BasicBlock *> BBs, DominatorTree *DT,
135 bool AllowVarArgs) {
Davide Italianofa15de32017-04-21 04:25:00 +0000136 assert(!BBs.empty() && "The set of blocks to extract must be non-empty");
Davide Italiano059574c2017-04-21 00:21:09 +0000137 SetVector<BasicBlock *> Result;
Chandler Carruth2f5d0192012-05-04 10:26:45 +0000138
Chandler Carruth0fde0012012-05-04 10:18:49 +0000139 // Loop over the blocks, adding them to our set-vector, and aborting with an
140 // empty set if we encounter invalid blocks.
Davide Italianofa15de32017-04-21 04:25:00 +0000141 for (BasicBlock *BB : BBs) {
Davide Italianofa15de32017-04-21 04:25:00 +0000142 // If this block is dead, don't process it.
143 if (DT && !DT->isReachableFromEntry(BB))
144 continue;
145
146 if (!Result.insert(BB))
147 llvm_unreachable("Repeated basic blocks in extraction input");
Florian Hahn0e9dec62017-11-13 10:35:52 +0000148 if (!CodeExtractor::isBlockValidForExtraction(*BB, AllowVarArgs)) {
Chandler Carruth0fde0012012-05-04 10:18:49 +0000149 Result.clear();
Chandler Carruth0a570552012-05-04 11:14:19 +0000150 return Result;
Chris Lattner3b2917b2004-05-12 06:01:40 +0000151 }
Davide Italianofa15de32017-04-21 04:25:00 +0000152 }
Misha Brukmanb1c93172005-04-21 23:48:37 +0000153
Chandler Carruth2f5d0192012-05-04 10:26:45 +0000154#ifndef NDEBUG
Benjamin Kramerb6d0bd42014-03-02 12:27:27 +0000155 for (SetVector<BasicBlock *>::iterator I = std::next(Result.begin()),
Chandler Carruth67818212012-05-04 21:33:30 +0000156 E = Result.end();
Chandler Carruth2f5d0192012-05-04 10:26:45 +0000157 I != E; ++I)
Duncan P. N. Exon Smith6c990152014-07-21 17:06:51 +0000158 for (pred_iterator PI = pred_begin(*I), PE = pred_end(*I);
159 PI != PE; ++PI)
160 assert(Result.count(*PI) &&
Chandler Carruth2f5d0192012-05-04 10:26:45 +0000161 "No blocks in this region may have entries from outside the region"
162 " except for the first block!");
163#endif
164
Chandler Carruth0fde0012012-05-04 10:18:49 +0000165 return Result;
166}
Chris Lattner3b2917b2004-05-12 06:01:40 +0000167
Chandler Carruth0fde0012012-05-04 10:18:49 +0000168CodeExtractor::CodeExtractor(ArrayRef<BasicBlock *> BBs, DominatorTree *DT,
Sean Silvaf8015752016-08-02 02:15:45 +0000169 bool AggregateArgs, BlockFrequencyInfo *BFI,
Florian Hahn0e9dec62017-11-13 10:35:52 +0000170 BranchProbabilityInfo *BPI, bool AllowVarArgs)
Sean Silvaf8015752016-08-02 02:15:45 +0000171 : DT(DT), AggregateArgs(AggregateArgs || AggregateArgsOpt), BFI(BFI),
Florian Hahn0e9dec62017-11-13 10:35:52 +0000172 BPI(BPI), AllowVarArgs(AllowVarArgs),
173 Blocks(buildExtractionBlockSet(BBs, DT, AllowVarArgs)) {}
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000174
Sean Silvaf8015752016-08-02 02:15:45 +0000175CodeExtractor::CodeExtractor(DominatorTree &DT, Loop &L, bool AggregateArgs,
176 BlockFrequencyInfo *BFI,
177 BranchProbabilityInfo *BPI)
178 : DT(&DT), AggregateArgs(AggregateArgs || AggregateArgsOpt), BFI(BFI),
Florian Hahn71147552017-11-13 11:08:47 +0000179 BPI(BPI), AllowVarArgs(false),
180 Blocks(buildExtractionBlockSet(L.getBlocks(), &DT,
181 /* AllowVarArgs */ false)) {}
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000182
Chandler Carruth0fde0012012-05-04 10:18:49 +0000183/// definedInRegion - Return true if the specified value is defined in the
184/// extracted region.
185static bool definedInRegion(const SetVector<BasicBlock *> &Blocks, Value *V) {
186 if (Instruction *I = dyn_cast<Instruction>(V))
187 if (Blocks.count(I->getParent()))
188 return true;
189 return false;
190}
191
192/// definedInCaller - Return true if the specified value is defined in the
193/// function being code extracted, but not in the region being extracted.
194/// These values must be passed in as live-ins to the function.
195static bool definedInCaller(const SetVector<BasicBlock *> &Blocks, Value *V) {
196 if (isa<Argument>(V)) return true;
197 if (Instruction *I = dyn_cast<Instruction>(V))
198 if (!Blocks.count(I->getParent()))
199 return true;
200 return false;
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000201}
202
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000203static BasicBlock *getCommonExitBlock(const SetVector<BasicBlock *> &Blocks) {
204 BasicBlock *CommonExitBlock = nullptr;
205 auto hasNonCommonExitSucc = [&](BasicBlock *Block) {
206 for (auto *Succ : successors(Block)) {
207 // Internal edges, ok.
208 if (Blocks.count(Succ))
209 continue;
210 if (!CommonExitBlock) {
211 CommonExitBlock = Succ;
212 continue;
213 }
214 if (CommonExitBlock == Succ)
215 continue;
216
217 return true;
218 }
219 return false;
220 };
221
222 if (any_of(Blocks, hasNonCommonExitSucc))
223 return nullptr;
224
225 return CommonExitBlock;
226}
227
228bool CodeExtractor::isLegalToShrinkwrapLifetimeMarkers(
229 Instruction *Addr) const {
230 AllocaInst *AI = cast<AllocaInst>(Addr->stripInBoundsConstantOffsets());
Xinliang David Li74480ad2017-05-30 21:22:18 +0000231 Function *Func = (*Blocks.begin())->getParent();
232 for (BasicBlock &BB : *Func) {
233 if (Blocks.count(&BB))
234 continue;
235 for (Instruction &II : BB) {
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000236 if (isa<DbgInfoIntrinsic>(II))
237 continue;
238
239 unsigned Opcode = II.getOpcode();
240 Value *MemAddr = nullptr;
241 switch (Opcode) {
242 case Instruction::Store:
243 case Instruction::Load: {
244 if (Opcode == Instruction::Store) {
245 StoreInst *SI = cast<StoreInst>(&II);
246 MemAddr = SI->getPointerOperand();
247 } else {
248 LoadInst *LI = cast<LoadInst>(&II);
249 MemAddr = LI->getPointerOperand();
250 }
251 // Global variable can not be aliased with locals.
252 if (dyn_cast<Constant>(MemAddr))
253 break;
254 Value *Base = MemAddr->stripInBoundsConstantOffsets();
255 if (!dyn_cast<AllocaInst>(Base) || Base == AI)
256 return false;
257 break;
258 }
259 default: {
260 IntrinsicInst *IntrInst = dyn_cast<IntrinsicInst>(&II);
261 if (IntrInst) {
262 if (IntrInst->getIntrinsicID() == Intrinsic::lifetime_start ||
263 IntrInst->getIntrinsicID() == Intrinsic::lifetime_end)
264 break;
265 return false;
266 }
267 // Treat all the other cases conservatively if it has side effects.
268 if (II.mayHaveSideEffects())
269 return false;
270 }
271 }
272 }
273 }
274
275 return true;
276}
277
278BasicBlock *
279CodeExtractor::findOrCreateBlockForHoisting(BasicBlock *CommonExitBlock) {
280 BasicBlock *SinglePredFromOutlineRegion = nullptr;
281 assert(!Blocks.count(CommonExitBlock) &&
282 "Expect a block outside the region!");
283 for (auto *Pred : predecessors(CommonExitBlock)) {
284 if (!Blocks.count(Pred))
285 continue;
286 if (!SinglePredFromOutlineRegion) {
287 SinglePredFromOutlineRegion = Pred;
288 } else if (SinglePredFromOutlineRegion != Pred) {
289 SinglePredFromOutlineRegion = nullptr;
290 break;
291 }
292 }
293
294 if (SinglePredFromOutlineRegion)
295 return SinglePredFromOutlineRegion;
296
297#ifndef NDEBUG
298 auto getFirstPHI = [](BasicBlock *BB) {
299 BasicBlock::iterator I = BB->begin();
300 PHINode *FirstPhi = nullptr;
301 while (I != BB->end()) {
302 PHINode *Phi = dyn_cast<PHINode>(I);
303 if (!Phi)
304 break;
305 if (!FirstPhi) {
306 FirstPhi = Phi;
307 break;
308 }
309 }
310 return FirstPhi;
311 };
312 // If there are any phi nodes, the single pred either exists or has already
313 // be created before code extraction.
314 assert(!getFirstPHI(CommonExitBlock) && "Phi not expected");
315#endif
316
317 BasicBlock *NewExitBlock = CommonExitBlock->splitBasicBlock(
318 CommonExitBlock->getFirstNonPHI()->getIterator());
319
Florian Hahnb93c0632017-11-01 09:48:12 +0000320 for (auto PI = pred_begin(CommonExitBlock), PE = pred_end(CommonExitBlock);
321 PI != PE;) {
322 BasicBlock *Pred = *PI++;
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000323 if (Blocks.count(Pred))
324 continue;
325 Pred->getTerminator()->replaceUsesOfWith(CommonExitBlock, NewExitBlock);
326 }
327 // Now add the old exit block to the outline region.
328 Blocks.insert(CommonExitBlock);
329 return CommonExitBlock;
330}
331
332void CodeExtractor::findAllocas(ValueSet &SinkCands, ValueSet &HoistCands,
333 BasicBlock *&ExitBlock) const {
334 Function *Func = (*Blocks.begin())->getParent();
335 ExitBlock = getCommonExitBlock(Blocks);
336
337 for (BasicBlock &BB : *Func) {
338 if (Blocks.count(&BB))
339 continue;
340 for (Instruction &II : BB) {
Xinliang David Li74480ad2017-05-30 21:22:18 +0000341 auto *AI = dyn_cast<AllocaInst>(&II);
342 if (!AI)
343 continue;
344
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000345 // Find the pair of life time markers for address 'Addr' that are either
346 // defined inside the outline region or can legally be shrinkwrapped into
347 // the outline region. If there are not other untracked uses of the
348 // address, return the pair of markers if found; otherwise return a pair
349 // of nullptr.
350 auto GetLifeTimeMarkers =
351 [&](Instruction *Addr, bool &SinkLifeStart,
352 bool &HoistLifeEnd) -> std::pair<Instruction *, Instruction *> {
Xinliang David Li74480ad2017-05-30 21:22:18 +0000353 Instruction *LifeStart = nullptr, *LifeEnd = nullptr;
Xinliang David Li74480ad2017-05-30 21:22:18 +0000354
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000355 for (User *U : Addr->users()) {
Xinliang David Li74480ad2017-05-30 21:22:18 +0000356 IntrinsicInst *IntrInst = dyn_cast<IntrinsicInst>(U);
357 if (IntrInst) {
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000358 if (IntrInst->getIntrinsicID() == Intrinsic::lifetime_start) {
359 // Do not handle the case where AI has multiple start markers.
360 if (LifeStart)
361 return std::make_pair<Instruction *>(nullptr, nullptr);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000362 LifeStart = IntrInst;
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000363 }
364 if (IntrInst->getIntrinsicID() == Intrinsic::lifetime_end) {
365 if (LifeEnd)
366 return std::make_pair<Instruction *>(nullptr, nullptr);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000367 LifeEnd = IntrInst;
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000368 }
369 continue;
Xinliang David Li74480ad2017-05-30 21:22:18 +0000370 }
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000371 // Find untracked uses of the address, bail.
372 if (!definedInRegion(Blocks, U))
373 return std::make_pair<Instruction *>(nullptr, nullptr);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000374 }
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000375
376 if (!LifeStart || !LifeEnd)
377 return std::make_pair<Instruction *>(nullptr, nullptr);
378
379 SinkLifeStart = !definedInRegion(Blocks, LifeStart);
380 HoistLifeEnd = !definedInRegion(Blocks, LifeEnd);
381 // Do legality Check.
382 if ((SinkLifeStart || HoistLifeEnd) &&
383 !isLegalToShrinkwrapLifetimeMarkers(Addr))
384 return std::make_pair<Instruction *>(nullptr, nullptr);
385
386 // Check to see if we have a place to do hoisting, if not, bail.
387 if (HoistLifeEnd && !ExitBlock)
388 return std::make_pair<Instruction *>(nullptr, nullptr);
389
390 return std::make_pair(LifeStart, LifeEnd);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000391 };
392
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000393 bool SinkLifeStart = false, HoistLifeEnd = false;
394 auto Markers = GetLifeTimeMarkers(AI, SinkLifeStart, HoistLifeEnd);
395
396 if (Markers.first) {
397 if (SinkLifeStart)
398 SinkCands.insert(Markers.first);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000399 SinkCands.insert(AI);
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000400 if (HoistLifeEnd)
401 HoistCands.insert(Markers.second);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000402 continue;
403 }
404
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000405 // Follow the bitcast.
Xinliang David Li74480ad2017-05-30 21:22:18 +0000406 Instruction *MarkerAddr = nullptr;
407 for (User *U : AI->users()) {
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000408 if (U->stripInBoundsConstantOffsets() == AI) {
409 SinkLifeStart = false;
410 HoistLifeEnd = false;
Xinliang David Li74480ad2017-05-30 21:22:18 +0000411 Instruction *Bitcast = cast<Instruction>(U);
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000412 Markers = GetLifeTimeMarkers(Bitcast, SinkLifeStart, HoistLifeEnd);
413 if (Markers.first) {
Xinliang David Li74480ad2017-05-30 21:22:18 +0000414 MarkerAddr = Bitcast;
415 continue;
416 }
417 }
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000418
419 // Found unknown use of AI.
Xinliang David Li74480ad2017-05-30 21:22:18 +0000420 if (!definedInRegion(Blocks, U)) {
421 MarkerAddr = nullptr;
422 break;
423 }
424 }
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000425
Xinliang David Li74480ad2017-05-30 21:22:18 +0000426 if (MarkerAddr) {
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000427 if (SinkLifeStart)
428 SinkCands.insert(Markers.first);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000429 if (!definedInRegion(Blocks, MarkerAddr))
430 SinkCands.insert(MarkerAddr);
431 SinkCands.insert(AI);
Xinliang David Li7ed6cd32017-06-11 20:46:05 +0000432 if (HoistLifeEnd)
433 HoistCands.insert(Markers.second);
Xinliang David Li74480ad2017-05-30 21:22:18 +0000434 }
435 }
436 }
437}
438
439void CodeExtractor::findInputsOutputs(ValueSet &Inputs, ValueSet &Outputs,
440 const ValueSet &SinkCands) const {
Benjamin Kramer135f7352016-06-26 12:28:59 +0000441 for (BasicBlock *BB : Blocks) {
Chandler Carruth14316fc2012-05-04 11:20:27 +0000442 // If a used value is defined outside the region, it's an input. If an
443 // instruction is used outside the region, it's an output.
Benjamin Kramer135f7352016-06-26 12:28:59 +0000444 for (Instruction &II : *BB) {
445 for (User::op_iterator OI = II.op_begin(), OE = II.op_end(); OI != OE;
Xinliang David Li74480ad2017-05-30 21:22:18 +0000446 ++OI) {
447 Value *V = *OI;
448 if (!SinkCands.count(V) && definedInCaller(Blocks, V))
449 Inputs.insert(V);
450 }
Chandler Carruth14316fc2012-05-04 11:20:27 +0000451
Benjamin Kramer135f7352016-06-26 12:28:59 +0000452 for (User *U : II.users())
Chandler Carruthcdf47882014-03-09 03:16:01 +0000453 if (!definedInRegion(Blocks, U)) {
Benjamin Kramer135f7352016-06-26 12:28:59 +0000454 Outputs.insert(&II);
Chandler Carruth14316fc2012-05-04 11:20:27 +0000455 break;
456 }
457 }
458 }
459}
460
Chris Lattner3b2917b2004-05-12 06:01:40 +0000461/// severSplitPHINodes - If a PHI node has multiple inputs from outside of the
462/// region, we need to split the entry block of the region so that the PHI node
463/// is easier to deal with.
464void CodeExtractor::severSplitPHINodes(BasicBlock *&Header) {
Jay Foade0938d82011-03-30 11:19:20 +0000465 unsigned NumPredsFromRegion = 0;
Chris Lattner795c9932004-05-12 15:29:13 +0000466 unsigned NumPredsOutsideRegion = 0;
Chris Lattner3b2917b2004-05-12 06:01:40 +0000467
Dan Gohmandcb291f2007-03-22 16:38:57 +0000468 if (Header != &Header->getParent()->getEntryBlock()) {
Chris Lattner795c9932004-05-12 15:29:13 +0000469 PHINode *PN = dyn_cast<PHINode>(Header->begin());
470 if (!PN) return; // No PHI nodes.
Chris Lattner3b2917b2004-05-12 06:01:40 +0000471
Chris Lattner795c9932004-05-12 15:29:13 +0000472 // If the header node contains any PHI nodes, check to see if there is more
473 // than one entry from outside the region. If so, we need to sever the
474 // header block into two.
475 for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
Chandler Carruth0fde0012012-05-04 10:18:49 +0000476 if (Blocks.count(PN->getIncomingBlock(i)))
Jay Foade0938d82011-03-30 11:19:20 +0000477 ++NumPredsFromRegion;
Chris Lattner795c9932004-05-12 15:29:13 +0000478 else
479 ++NumPredsOutsideRegion;
480
481 // If there is one (or fewer) predecessor from outside the region, we don't
482 // need to do anything special.
483 if (NumPredsOutsideRegion <= 1) return;
484 }
485
486 // Otherwise, we need to split the header block into two pieces: one
487 // containing PHI nodes merging values from outside of the region, and a
488 // second that contains all of the code for the block and merges back any
489 // incoming values from inside of the region.
Eugene Zelenko286d5892017-10-11 21:41:43 +0000490 BasicBlock *NewBB = SplitBlock(Header, Header->getFirstNonPHI(), DT);
Chris Lattner795c9932004-05-12 15:29:13 +0000491
492 // We only want to code extract the second block now, and it becomes the new
493 // header of the region.
494 BasicBlock *OldPred = Header;
Chandler Carruth0fde0012012-05-04 10:18:49 +0000495 Blocks.remove(OldPred);
496 Blocks.insert(NewBB);
Chris Lattner795c9932004-05-12 15:29:13 +0000497 Header = NewBB;
498
Chris Lattner795c9932004-05-12 15:29:13 +0000499 // Okay, now we need to adjust the PHI nodes and any branches from within the
500 // region to go to the new header block instead of the old header block.
Jay Foade0938d82011-03-30 11:19:20 +0000501 if (NumPredsFromRegion) {
Chris Lattner795c9932004-05-12 15:29:13 +0000502 PHINode *PN = cast<PHINode>(OldPred->begin());
503 // Loop over all of the predecessors of OldPred that are in the region,
504 // changing them to branch to NewBB instead.
505 for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
Chandler Carruth0fde0012012-05-04 10:18:49 +0000506 if (Blocks.count(PN->getIncomingBlock(i))) {
Chris Lattner795c9932004-05-12 15:29:13 +0000507 TerminatorInst *TI = PN->getIncomingBlock(i)->getTerminator();
508 TI->replaceUsesOfWith(OldPred, NewBB);
509 }
510
Chris Lattner0ab5e2c2011-04-15 05:18:47 +0000511 // Okay, everything within the region is now branching to the right block, we
Chris Lattner795c9932004-05-12 15:29:13 +0000512 // just have to update the PHI nodes now, inserting PHI nodes into NewBB.
Xinliang David Li99e3ca12017-04-20 21:40:22 +0000513 BasicBlock::iterator AfterPHIs;
Reid Spencer66149462004-09-15 17:06:42 +0000514 for (AfterPHIs = OldPred->begin(); isa<PHINode>(AfterPHIs); ++AfterPHIs) {
515 PHINode *PN = cast<PHINode>(AfterPHIs);
Chris Lattner795c9932004-05-12 15:29:13 +0000516 // Create a new PHI node in the new region, which has an incoming value
517 // from OldPred of PN.
Jay Foad52131342011-03-30 11:28:46 +0000518 PHINode *NewPN = PHINode::Create(PN->getType(), 1 + NumPredsFromRegion,
Duncan P. N. Exon Smith5b4c8372015-10-13 02:39:05 +0000519 PN->getName() + ".ce", &NewBB->front());
Xinliang David Lif12a0fa2017-04-25 04:51:19 +0000520 PN->replaceAllUsesWith(NewPN);
Chris Lattner795c9932004-05-12 15:29:13 +0000521 NewPN->addIncoming(PN, OldPred);
522
523 // Loop over all of the incoming value in PN, moving them to NewPN if they
524 // are from the extracted region.
525 for (unsigned i = 0; i != PN->getNumIncomingValues(); ++i) {
Chandler Carruth0fde0012012-05-04 10:18:49 +0000526 if (Blocks.count(PN->getIncomingBlock(i))) {
Chris Lattner795c9932004-05-12 15:29:13 +0000527 NewPN->addIncoming(PN->getIncomingValue(i), PN->getIncomingBlock(i));
528 PN->removeIncomingValue(i);
529 --i;
530 }
531 }
532 }
533 }
Chris Lattner13d2ddf2004-05-12 16:07:41 +0000534}
Chris Lattner795c9932004-05-12 15:29:13 +0000535
Chris Lattner13d2ddf2004-05-12 16:07:41 +0000536void CodeExtractor::splitReturnBlocks() {
Benjamin Kramer135f7352016-06-26 12:28:59 +0000537 for (BasicBlock *Block : Blocks)
538 if (ReturnInst *RI = dyn_cast<ReturnInst>(Block->getTerminator())) {
Duncan P. N. Exon Smith5b4c8372015-10-13 02:39:05 +0000539 BasicBlock *New =
Benjamin Kramer135f7352016-06-26 12:28:59 +0000540 Block->splitBasicBlock(RI->getIterator(), Block->getName() + ".ret");
Owen Andersonb4aa5b12009-08-24 23:32:14 +0000541 if (DT) {
Gabor Greif2f5f6962010-09-10 22:25:58 +0000542 // Old dominates New. New node dominates all other nodes dominated
543 // by Old.
Benjamin Kramer135f7352016-06-26 12:28:59 +0000544 DomTreeNode *OldNode = DT->getNode(Block);
545 SmallVector<DomTreeNode *, 8> Children(OldNode->begin(),
546 OldNode->end());
Owen Andersonb4aa5b12009-08-24 23:32:14 +0000547
Benjamin Kramer135f7352016-06-26 12:28:59 +0000548 DomTreeNode *NewNode = DT->addNewBlock(New, Block);
Owen Andersonb4aa5b12009-08-24 23:32:14 +0000549
Benjamin Kramer135f7352016-06-26 12:28:59 +0000550 for (DomTreeNode *I : Children)
551 DT->changeImmediateDominator(I, NewNode);
Owen Andersonb4aa5b12009-08-24 23:32:14 +0000552 }
553 }
Chris Lattner3b2917b2004-05-12 06:01:40 +0000554}
555
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000556/// constructFunction - make a function based on inputs and outputs, as follows:
557/// f(in0, ..., inN, out0, ..., outN)
Chandler Carruth0fde0012012-05-04 10:18:49 +0000558Function *CodeExtractor::constructFunction(const ValueSet &inputs,
559 const ValueSet &outputs,
Chris Lattner320d59f2004-03-18 05:28:49 +0000560 BasicBlock *header,
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000561 BasicBlock *newRootNode,
562 BasicBlock *newHeader,
Chris Lattner320d59f2004-03-18 05:28:49 +0000563 Function *oldFunction,
564 Module *M) {
David Greene0ad6dce2010-01-05 01:26:44 +0000565 DEBUG(dbgs() << "inputs: " << inputs.size() << "\n");
566 DEBUG(dbgs() << "outputs: " << outputs.size() << "\n");
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000567
568 // This function returns unsigned, outputs will go back by reference.
Chris Lattnerffc49262004-05-12 04:14:24 +0000569 switch (NumExitBlocks) {
570 case 0:
Owen Anderson55f1c092009-08-13 21:58:54 +0000571 case 1: RetTy = Type::getVoidTy(header->getContext()); break;
572 case 2: RetTy = Type::getInt1Ty(header->getContext()); break;
573 default: RetTy = Type::getInt16Ty(header->getContext()); break;
Chris Lattnerffc49262004-05-12 04:14:24 +0000574 }
575
Eugene Zelenko286d5892017-10-11 21:41:43 +0000576 std::vector<Type *> paramTy;
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000577
578 // Add the types of the input values to the function's argument list
Benjamin Kramer135f7352016-06-26 12:28:59 +0000579 for (Value *value : inputs) {
David Greene0ad6dce2010-01-05 01:26:44 +0000580 DEBUG(dbgs() << "value used in func: " << *value << "\n");
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000581 paramTy.push_back(value->getType());
582 }
583
Chris Lattner37de2572004-03-18 03:49:40 +0000584 // Add the types of the output values to the function's argument list.
Benjamin Kramer135f7352016-06-26 12:28:59 +0000585 for (Value *output : outputs) {
586 DEBUG(dbgs() << "instr used in func: " << *output << "\n");
Misha Brukman3596f0a2004-04-23 23:54:17 +0000587 if (AggregateArgs)
Benjamin Kramer135f7352016-06-26 12:28:59 +0000588 paramTy.push_back(output->getType());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000589 else
Benjamin Kramer135f7352016-06-26 12:28:59 +0000590 paramTy.push_back(PointerType::getUnqual(output->getType()));
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000591 }
592
Benjamin Kramer706e48832016-06-26 13:39:33 +0000593 DEBUG({
594 dbgs() << "Function type: " << *RetTy << " f(";
595 for (Type *i : paramTy)
596 dbgs() << *i << ", ";
597 dbgs() << ")\n";
598 });
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000599
David Blaikie741c8f82015-03-14 01:53:18 +0000600 StructType *StructTy;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000601 if (AggregateArgs && (inputs.size() + outputs.size() > 0)) {
David Blaikie741c8f82015-03-14 01:53:18 +0000602 StructTy = StructType::get(M->getContext(), paramTy);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000603 paramTy.clear();
David Blaikie741c8f82015-03-14 01:53:18 +0000604 paramTy.push_back(PointerType::getUnqual(StructTy));
Misha Brukman3596f0a2004-04-23 23:54:17 +0000605 }
Chris Lattner229907c2011-07-18 04:54:35 +0000606 FunctionType *funcType =
Florian Hahn0e9dec62017-11-13 10:35:52 +0000607 FunctionType::get(RetTy, paramTy,
608 AllowVarArgs && oldFunction->isVarArg());
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000609
610 // Create the new function
Gabor Greife9ecc682008-04-06 20:25:17 +0000611 Function *newFunction = Function::Create(funcType,
612 GlobalValue::InternalLinkage,
613 oldFunction->getName() + "_" +
614 header->getName(), M);
Chris Lattner4caf5eb2008-12-18 05:52:56 +0000615 // If the old function is no-throw, so is the new one.
616 if (oldFunction->doesNotThrow())
Bill Wendlingf319e992012-10-10 03:12:49 +0000617 newFunction->setDoesNotThrow();
Sean Silvaa0a802a2016-08-01 03:15:32 +0000618
619 // Inherit the uwtable attribute if we need to.
620 if (oldFunction->hasUWTable())
621 newFunction->setHasUWTable();
622
623 // Inherit all of the target dependent attributes.
624 // (e.g. If the extracted region contains a call to an x86.sse
625 // instruction we need to make sure that the extracted region has the
626 // "target-features" attribute allowing it to be lowered.
627 // FIXME: This should be changed to check to see if a specific
628 // attribute can not be inherited.
Reid Klecknereb9dd5b2017-04-10 23:31:05 +0000629 AttrBuilder AB(oldFunction->getAttributes().getFnAttributes());
Sean Silva9011aca2017-02-22 06:34:04 +0000630 for (const auto &Attr : AB.td_attrs())
Sean Silvaa0a802a2016-08-01 03:15:32 +0000631 newFunction->addFnAttr(Attr.first, Attr.second);
632
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000633 newFunction->getBasicBlockList().push_back(newRootNode);
634
Chris Lattner37de2572004-03-18 03:49:40 +0000635 // Create an iterator to name all of the arguments we inserted.
Chris Lattner531f9e92005-03-15 04:54:21 +0000636 Function::arg_iterator AI = newFunction->arg_begin();
Chris Lattner37de2572004-03-18 03:49:40 +0000637
638 // Rewrite all users of the inputs in the extracted region to use the
Misha Brukman3596f0a2004-04-23 23:54:17 +0000639 // arguments (or appropriate addressing into struct) instead.
640 for (unsigned i = 0, e = inputs.size(); i != e; ++i) {
641 Value *RewriteVal;
642 if (AggregateArgs) {
David Greenec656cbb2007-09-04 15:46:09 +0000643 Value *Idx[2];
Owen Anderson55f1c092009-08-13 21:58:54 +0000644 Idx[0] = Constant::getNullValue(Type::getInt32Ty(header->getContext()));
645 Idx[1] = ConstantInt::get(Type::getInt32Ty(header->getContext()), i);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000646 TerminatorInst *TI = newFunction->begin()->getTerminator();
David Blaikie741c8f82015-03-14 01:53:18 +0000647 GetElementPtrInst *GEP = GetElementPtrInst::Create(
Duncan P. N. Exon Smith5b4c8372015-10-13 02:39:05 +0000648 StructTy, &*AI, Idx, "gep_" + inputs[i]->getName(), TI);
Daniel Dunbar123686852009-07-24 08:24:36 +0000649 RewriteVal = new LoadInst(GEP, "loadgep_" + inputs[i]->getName(), TI);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000650 } else
Duncan P. N. Exon Smith5b4c8372015-10-13 02:39:05 +0000651 RewriteVal = &*AI++;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000652
Eugene Zelenko286d5892017-10-11 21:41:43 +0000653 std::vector<User *> Users(inputs[i]->user_begin(), inputs[i]->user_end());
Benjamin Kramer135f7352016-06-26 12:28:59 +0000654 for (User *use : Users)
655 if (Instruction *inst = dyn_cast<Instruction>(use))
Chandler Carruth0fde0012012-05-04 10:18:49 +0000656 if (Blocks.count(inst->getParent()))
Misha Brukman3596f0a2004-04-23 23:54:17 +0000657 inst->replaceUsesOfWith(inputs[i], RewriteVal);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000658 }
659
Misha Brukman3596f0a2004-04-23 23:54:17 +0000660 // Set names for input and output arguments.
661 if (!AggregateArgs) {
Chris Lattner531f9e92005-03-15 04:54:21 +0000662 AI = newFunction->arg_begin();
Misha Brukman3596f0a2004-04-23 23:54:17 +0000663 for (unsigned i = 0, e = inputs.size(); i != e; ++i, ++AI)
Owen Anderson7629b712008-04-14 17:38:21 +0000664 AI->setName(inputs[i]->getName());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000665 for (unsigned i = 0, e = outputs.size(); i != e; ++i, ++AI)
Misha Brukmanb1c93172005-04-21 23:48:37 +0000666 AI->setName(outputs[i]->getName()+".out");
Misha Brukman3596f0a2004-04-23 23:54:17 +0000667 }
Chris Lattner37de2572004-03-18 03:49:40 +0000668
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000669 // Rewrite branches to basic blocks outside of the loop to new dummy blocks
670 // within the new function. This must be done before we lose track of which
671 // blocks were originally in the code region.
Eugene Zelenko286d5892017-10-11 21:41:43 +0000672 std::vector<User *> Users(header->user_begin(), header->user_end());
Chris Lattner320d59f2004-03-18 05:28:49 +0000673 for (unsigned i = 0, e = Users.size(); i != e; ++i)
674 // The BasicBlock which contains the branch is not in the region
675 // modify the branch target to a new block
676 if (TerminatorInst *TI = dyn_cast<TerminatorInst>(Users[i]))
Chandler Carruth0fde0012012-05-04 10:18:49 +0000677 if (!Blocks.count(TI->getParent()) &&
Chris Lattner320d59f2004-03-18 05:28:49 +0000678 TI->getParent()->getParent() == oldFunction)
679 TI->replaceUsesOfWith(header, newHeader);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000680
681 return newFunction;
682}
683
Chris Lattner3b2917b2004-05-12 06:01:40 +0000684/// emitCallAndSwitchStatement - This method sets up the caller side by adding
685/// the call instruction, splitting any PHI nodes in the header block as
686/// necessary.
687void CodeExtractor::
688emitCallAndSwitchStatement(Function *newFunction, BasicBlock *codeReplacer,
Chandler Carruth0fde0012012-05-04 10:18:49 +0000689 ValueSet &inputs, ValueSet &outputs) {
Chris Lattner3b2917b2004-05-12 06:01:40 +0000690 // Emit a call to the new function, passing in: *pointer to struct (if
691 // aggregating parameters), or plan inputs and allocated memory for outputs
Eugene Zelenko286d5892017-10-11 21:41:43 +0000692 std::vector<Value *> params, StructValues, ReloadOutputs, Reloads;
Matt Arsenault3c1fc762017-04-10 22:27:50 +0000693
694 Module *M = newFunction->getParent();
695 LLVMContext &Context = M->getContext();
696 const DataLayout &DL = M->getDataLayout();
Chris Lattnerd8017a32004-03-18 04:12:05 +0000697
Misha Brukman3596f0a2004-04-23 23:54:17 +0000698 // Add inputs as params, or to be filled into the struct
Benjamin Kramer135f7352016-06-26 12:28:59 +0000699 for (Value *input : inputs)
Misha Brukman3596f0a2004-04-23 23:54:17 +0000700 if (AggregateArgs)
Benjamin Kramer135f7352016-06-26 12:28:59 +0000701 StructValues.push_back(input);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000702 else
Benjamin Kramer135f7352016-06-26 12:28:59 +0000703 params.push_back(input);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000704
705 // Create allocas for the outputs
Benjamin Kramer135f7352016-06-26 12:28:59 +0000706 for (Value *output : outputs) {
Misha Brukman3596f0a2004-04-23 23:54:17 +0000707 if (AggregateArgs) {
Benjamin Kramer135f7352016-06-26 12:28:59 +0000708 StructValues.push_back(output);
Misha Brukman3596f0a2004-04-23 23:54:17 +0000709 } else {
710 AllocaInst *alloca =
Matt Arsenault3c1fc762017-04-10 22:27:50 +0000711 new AllocaInst(output->getType(), DL.getAllocaAddrSpace(),
712 nullptr, output->getName() + ".loc",
713 &codeReplacer->getParent()->front().front());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000714 ReloadOutputs.push_back(alloca);
715 params.push_back(alloca);
716 }
717 }
718
David Blaikie741c8f82015-03-14 01:53:18 +0000719 StructType *StructArgTy = nullptr;
Craig Topperf40110f2014-04-25 05:29:35 +0000720 AllocaInst *Struct = nullptr;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000721 if (AggregateArgs && (inputs.size() + outputs.size() > 0)) {
Eugene Zelenko286d5892017-10-11 21:41:43 +0000722 std::vector<Type *> ArgTypes;
Chandler Carruth0fde0012012-05-04 10:18:49 +0000723 for (ValueSet::iterator v = StructValues.begin(),
Misha Brukman3596f0a2004-04-23 23:54:17 +0000724 ve = StructValues.end(); v != ve; ++v)
725 ArgTypes.push_back((*v)->getType());
726
727 // Allocate a struct at the beginning of this function
David Blaikie741c8f82015-03-14 01:53:18 +0000728 StructArgTy = StructType::get(newFunction->getContext(), ArgTypes);
Matt Arsenault3c1fc762017-04-10 22:27:50 +0000729 Struct = new AllocaInst(StructArgTy, DL.getAllocaAddrSpace(), nullptr,
730 "structArg",
Duncan P. N. Exon Smith5b4c8372015-10-13 02:39:05 +0000731 &codeReplacer->getParent()->front().front());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000732 params.push_back(Struct);
733
734 for (unsigned i = 0, e = inputs.size(); i != e; ++i) {
David Greenec656cbb2007-09-04 15:46:09 +0000735 Value *Idx[2];
Owen Anderson55f1c092009-08-13 21:58:54 +0000736 Idx[0] = Constant::getNullValue(Type::getInt32Ty(Context));
737 Idx[1] = ConstantInt::get(Type::getInt32Ty(Context), i);
David Blaikie741c8f82015-03-14 01:53:18 +0000738 GetElementPtrInst *GEP = GetElementPtrInst::Create(
739 StructArgTy, Struct, Idx, "gep_" + StructValues[i]->getName());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000740 codeReplacer->getInstList().push_back(GEP);
741 StoreInst *SI = new StoreInst(StructValues[i], GEP);
742 codeReplacer->getInstList().push_back(SI);
743 }
Misha Brukmanb1c93172005-04-21 23:48:37 +0000744 }
Misha Brukman3596f0a2004-04-23 23:54:17 +0000745
746 // Emit the call to the function
Jay Foad5bd375a2011-07-15 08:37:34 +0000747 CallInst *call = CallInst::Create(newFunction, params,
Gabor Greife9ecc682008-04-06 20:25:17 +0000748 NumExitBlocks > 1 ? "targetBlock" : "");
Florian Hahne5089e22017-12-08 21:49:03 +0000749 // Add debug location to the new call, if the original function has debug
750 // info. In that case, the terminator of the entry block of the extracted
751 // function contains the first debug location of the extracted function,
752 // set in extractCodeRegion.
753 if (codeReplacer->getParent()->getSubprogram()) {
754 if (auto DL = newFunction->getEntryBlock().getTerminator()->getDebugLoc())
755 call->setDebugLoc(DL);
756 }
Misha Brukman3596f0a2004-04-23 23:54:17 +0000757 codeReplacer->getInstList().push_back(call);
758
Chris Lattner531f9e92005-03-15 04:54:21 +0000759 Function::arg_iterator OutputArgBegin = newFunction->arg_begin();
Misha Brukman3596f0a2004-04-23 23:54:17 +0000760 unsigned FirstOut = inputs.size();
761 if (!AggregateArgs)
762 std::advance(OutputArgBegin, inputs.size());
763
Jakub Kuderskicbe9fae2017-10-06 03:37:06 +0000764 // Reload the outputs passed in by reference.
765 Function::arg_iterator OAI = OutputArgBegin;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000766 for (unsigned i = 0, e = outputs.size(); i != e; ++i) {
Craig Topperf40110f2014-04-25 05:29:35 +0000767 Value *Output = nullptr;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000768 if (AggregateArgs) {
David Greenec656cbb2007-09-04 15:46:09 +0000769 Value *Idx[2];
Owen Anderson55f1c092009-08-13 21:58:54 +0000770 Idx[0] = Constant::getNullValue(Type::getInt32Ty(Context));
771 Idx[1] = ConstantInt::get(Type::getInt32Ty(Context), FirstOut + i);
David Blaikie741c8f82015-03-14 01:53:18 +0000772 GetElementPtrInst *GEP = GetElementPtrInst::Create(
773 StructArgTy, Struct, Idx, "gep_reload_" + outputs[i]->getName());
Misha Brukman3596f0a2004-04-23 23:54:17 +0000774 codeReplacer->getInstList().push_back(GEP);
775 Output = GEP;
776 } else {
777 Output = ReloadOutputs[i];
778 }
779 LoadInst *load = new LoadInst(Output, outputs[i]->getName()+".reload");
Owen Anderson34e61482009-08-25 00:54:39 +0000780 Reloads.push_back(load);
Chris Lattner37de2572004-03-18 03:49:40 +0000781 codeReplacer->getInstList().push_back(load);
Eugene Zelenko286d5892017-10-11 21:41:43 +0000782 std::vector<User *> Users(outputs[i]->user_begin(), outputs[i]->user_end());
Chris Lattner37de2572004-03-18 03:49:40 +0000783 for (unsigned u = 0, e = Users.size(); u != e; ++u) {
784 Instruction *inst = cast<Instruction>(Users[u]);
Chandler Carruth0fde0012012-05-04 10:18:49 +0000785 if (!Blocks.count(inst->getParent()))
Chris Lattner37de2572004-03-18 03:49:40 +0000786 inst->replaceUsesOfWith(outputs[i], load);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000787 }
Jakub Kuderskicbe9fae2017-10-06 03:37:06 +0000788
789 // Store to argument right after the definition of output value.
790 auto *OutI = dyn_cast<Instruction>(outputs[i]);
791 if (!OutI)
792 continue;
793 // Find proper insertion point.
794 Instruction *InsertPt = OutI->getNextNode();
795 // Let's assume that there is no other guy interleave non-PHI in PHIs.
796 if (isa<PHINode>(InsertPt))
797 InsertPt = InsertPt->getParent()->getFirstNonPHI();
798
799 assert(OAI != newFunction->arg_end() &&
800 "Number of output arguments should match "
801 "the amount of defined values");
802 if (AggregateArgs) {
803 Value *Idx[2];
804 Idx[0] = Constant::getNullValue(Type::getInt32Ty(Context));
805 Idx[1] = ConstantInt::get(Type::getInt32Ty(Context), FirstOut + i);
806 GetElementPtrInst *GEP = GetElementPtrInst::Create(
807 StructArgTy, &*OAI, Idx, "gep_" + outputs[i]->getName(), InsertPt);
808 new StoreInst(outputs[i], GEP, InsertPt);
809 // Since there should be only one struct argument aggregating
810 // all the output values, we shouldn't increment OAI, which always
811 // points to the struct argument, in this case.
812 } else {
813 new StoreInst(outputs[i], &*OAI, InsertPt);
814 ++OAI;
815 }
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000816 }
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000817
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000818 // Now we can emit a switch statement using the call as a value.
Chris Lattnerffc49262004-05-12 04:14:24 +0000819 SwitchInst *TheSwitch =
Owen Anderson55f1c092009-08-13 21:58:54 +0000820 SwitchInst::Create(Constant::getNullValue(Type::getInt16Ty(Context)),
Gabor Greife9ecc682008-04-06 20:25:17 +0000821 codeReplacer, 0, codeReplacer);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000822
823 // Since there may be multiple exits from the original region, make the new
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000824 // function return an unsigned, switch on that number. This loop iterates
825 // over all of the blocks in the extracted region, updating any terminator
826 // instructions in the to-be-extracted region that branch to blocks that are
827 // not in the region to be extracted.
Eugene Zelenko286d5892017-10-11 21:41:43 +0000828 std::map<BasicBlock *, BasicBlock *> ExitBlockMap;
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000829
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000830 unsigned switchVal = 0;
Benjamin Kramer135f7352016-06-26 12:28:59 +0000831 for (BasicBlock *Block : Blocks) {
832 TerminatorInst *TI = Block->getTerminator();
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000833 for (unsigned i = 0, e = TI->getNumSuccessors(); i != e; ++i)
Chandler Carruth0fde0012012-05-04 10:18:49 +0000834 if (!Blocks.count(TI->getSuccessor(i))) {
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000835 BasicBlock *OldTarget = TI->getSuccessor(i);
836 // add a new basic block which returns the appropriate value
837 BasicBlock *&NewTarget = ExitBlockMap[OldTarget];
838 if (!NewTarget) {
839 // If we don't already have an exit stub for this non-extracted
840 // destination, create one now!
Owen Anderson55f1c092009-08-13 21:58:54 +0000841 NewTarget = BasicBlock::Create(Context,
842 OldTarget->getName() + ".exitStub",
Gabor Greife9ecc682008-04-06 20:25:17 +0000843 newFunction);
Chris Lattnerffc49262004-05-12 04:14:24 +0000844 unsigned SuccNum = switchVal++;
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000845
Craig Topperf40110f2014-04-25 05:29:35 +0000846 Value *brVal = nullptr;
Chris Lattnerffc49262004-05-12 04:14:24 +0000847 switch (NumExitBlocks) {
848 case 0:
849 case 1: break; // No value needed.
850 case 2: // Conditional branch, return a bool
Owen Anderson55f1c092009-08-13 21:58:54 +0000851 brVal = ConstantInt::get(Type::getInt1Ty(Context), !SuccNum);
Chris Lattnerffc49262004-05-12 04:14:24 +0000852 break;
853 default:
Owen Anderson55f1c092009-08-13 21:58:54 +0000854 brVal = ConstantInt::get(Type::getInt16Ty(Context), SuccNum);
Chris Lattnerffc49262004-05-12 04:14:24 +0000855 break;
856 }
857
Jakub Kuderskicbe9fae2017-10-06 03:37:06 +0000858 ReturnInst::Create(Context, brVal, NewTarget);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000859
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000860 // Update the switch instruction.
Owen Anderson55f1c092009-08-13 21:58:54 +0000861 TheSwitch->addCase(ConstantInt::get(Type::getInt16Ty(Context),
862 SuccNum),
Chris Lattnerffc49262004-05-12 04:14:24 +0000863 OldTarget);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000864 }
Chris Lattnerb4d8bf32004-03-14 23:05:49 +0000865
866 // rewrite the original branch instruction with this new target
867 TI->setSuccessor(i, NewTarget);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000868 }
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000869 }
Chris Lattner5b2072e2004-03-14 23:43:24 +0000870
Chris Lattner3d1ca672004-05-12 03:22:33 +0000871 // Now that we've done the deed, simplify the switch instruction.
Chris Lattner229907c2011-07-18 04:54:35 +0000872 Type *OldFnRetTy = TheSwitch->getParent()->getParent()->getReturnType();
Chris Lattnerffc49262004-05-12 04:14:24 +0000873 switch (NumExitBlocks) {
874 case 0:
Chris Lattner7f1c7ed2004-08-12 03:17:02 +0000875 // There are no successors (the block containing the switch itself), which
Misha Brukman3596f0a2004-04-23 23:54:17 +0000876 // means that previously this was the last part of the function, and hence
877 // this should be rewritten as a `ret'
Misha Brukmanb1c93172005-04-21 23:48:37 +0000878
Misha Brukman3596f0a2004-04-23 23:54:17 +0000879 // Check if the function should return a value
Benjamin Kramerccce8ba2010-01-05 13:12:22 +0000880 if (OldFnRetTy->isVoidTy()) {
Craig Topperf40110f2014-04-25 05:29:35 +0000881 ReturnInst::Create(Context, nullptr, TheSwitch); // Return void
Chris Lattner7f1c7ed2004-08-12 03:17:02 +0000882 } else if (OldFnRetTy == TheSwitch->getCondition()->getType()) {
Misha Brukman3596f0a2004-04-23 23:54:17 +0000883 // return what we have
Owen Anderson55f1c092009-08-13 21:58:54 +0000884 ReturnInst::Create(Context, TheSwitch->getCondition(), TheSwitch);
Chris Lattner7f1c7ed2004-08-12 03:17:02 +0000885 } else {
886 // Otherwise we must have code extracted an unwind or something, just
887 // return whatever we want.
Owen Anderson55f1c092009-08-13 21:58:54 +0000888 ReturnInst::Create(Context,
889 Constant::getNullValue(OldFnRetTy), TheSwitch);
Chris Lattner7f1c7ed2004-08-12 03:17:02 +0000890 }
Misha Brukman3596f0a2004-04-23 23:54:17 +0000891
Dan Gohman158ff2c2008-06-21 22:08:46 +0000892 TheSwitch->eraseFromParent();
Chris Lattnerffc49262004-05-12 04:14:24 +0000893 break;
894 case 1:
895 // Only a single destination, change the switch into an unconditional
896 // branch.
Gabor Greife9ecc682008-04-06 20:25:17 +0000897 BranchInst::Create(TheSwitch->getSuccessor(1), TheSwitch);
Dan Gohman158ff2c2008-06-21 22:08:46 +0000898 TheSwitch->eraseFromParent();
Chris Lattnerffc49262004-05-12 04:14:24 +0000899 break;
900 case 2:
Gabor Greife9ecc682008-04-06 20:25:17 +0000901 BranchInst::Create(TheSwitch->getSuccessor(1), TheSwitch->getSuccessor(2),
902 call, TheSwitch);
Dan Gohman158ff2c2008-06-21 22:08:46 +0000903 TheSwitch->eraseFromParent();
Chris Lattnerffc49262004-05-12 04:14:24 +0000904 break;
905 default:
906 // Otherwise, make the default destination of the switch instruction be one
907 // of the other successors.
Stepan Dyatkovskiy513aaa52012-02-01 07:49:51 +0000908 TheSwitch->setCondition(call);
909 TheSwitch->setDefaultDest(TheSwitch->getSuccessor(NumExitBlocks));
Stepan Dyatkovskiy5b648af2012-03-08 07:06:20 +0000910 // Remove redundant case
Bob Wilsone4077362013-09-09 19:14:35 +0000911 TheSwitch->removeCase(SwitchInst::CaseIt(TheSwitch, NumExitBlocks-1));
Chris Lattnerffc49262004-05-12 04:14:24 +0000912 break;
Chris Lattner5b2072e2004-03-14 23:43:24 +0000913 }
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000914}
915
Chris Lattner3b2917b2004-05-12 06:01:40 +0000916void CodeExtractor::moveCodeToFunction(Function *newFunction) {
Chandler Carruth0fde0012012-05-04 10:18:49 +0000917 Function *oldFunc = (*Blocks.begin())->getParent();
Chris Lattner3b2917b2004-05-12 06:01:40 +0000918 Function::BasicBlockListType &oldBlocks = oldFunc->getBasicBlockList();
919 Function::BasicBlockListType &newBlocks = newFunction->getBasicBlockList();
920
Benjamin Kramer135f7352016-06-26 12:28:59 +0000921 for (BasicBlock *Block : Blocks) {
Chris Lattner3b2917b2004-05-12 06:01:40 +0000922 // Delete the basic block from the old function, and the list of blocks
Benjamin Kramer135f7352016-06-26 12:28:59 +0000923 oldBlocks.remove(Block);
Chris Lattner3b2917b2004-05-12 06:01:40 +0000924
925 // Insert this basic block into the new function
Benjamin Kramer135f7352016-06-26 12:28:59 +0000926 newBlocks.push_back(Block);
Chris Lattner3b2917b2004-05-12 06:01:40 +0000927 }
928}
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000929
Sean Silvaf8015752016-08-02 02:15:45 +0000930void CodeExtractor::calculateNewCallTerminatorWeights(
931 BasicBlock *CodeReplacer,
932 DenseMap<BasicBlock *, BlockFrequency> &ExitWeights,
933 BranchProbabilityInfo *BPI) {
Eugene Zelenko286d5892017-10-11 21:41:43 +0000934 using Distribution = BlockFrequencyInfoImplBase::Distribution;
935 using BlockNode = BlockFrequencyInfoImplBase::BlockNode;
Sean Silvaf8015752016-08-02 02:15:45 +0000936
937 // Update the branch weights for the exit block.
938 TerminatorInst *TI = CodeReplacer->getTerminator();
939 SmallVector<unsigned, 8> BranchWeights(TI->getNumSuccessors(), 0);
940
941 // Block Frequency distribution with dummy node.
942 Distribution BranchDist;
943
944 // Add each of the frequencies of the successors.
945 for (unsigned i = 0, e = TI->getNumSuccessors(); i < e; ++i) {
946 BlockNode ExitNode(i);
947 uint64_t ExitFreq = ExitWeights[TI->getSuccessor(i)].getFrequency();
948 if (ExitFreq != 0)
949 BranchDist.addExit(ExitNode, ExitFreq);
950 else
951 BPI->setEdgeProbability(CodeReplacer, i, BranchProbability::getZero());
952 }
953
954 // Check for no total weight.
955 if (BranchDist.Total == 0)
956 return;
957
958 // Normalize the distribution so that they can fit in unsigned.
959 BranchDist.normalize();
960
961 // Create normalized branch weights and set the metadata.
962 for (unsigned I = 0, E = BranchDist.Weights.size(); I < E; ++I) {
963 const auto &Weight = BranchDist.Weights[I];
964
965 // Get the weight and update the current BFI.
966 BranchWeights[Weight.TargetNode.Index] = Weight.Amount;
967 BranchProbability BP(Weight.Amount, BranchDist.Total);
968 BPI->setEdgeProbability(CodeReplacer, Weight.TargetNode.Index, BP);
969 }
970 TI->setMetadata(
971 LLVMContext::MD_prof,
972 MDBuilder(TI->getContext()).createBranchWeights(BranchWeights));
973}
974
Chandler Carruth0fde0012012-05-04 10:18:49 +0000975Function *CodeExtractor::extractCodeRegion() {
976 if (!isEligible())
Craig Topperf40110f2014-04-25 05:29:35 +0000977 return nullptr;
Misha Brukman3596f0a2004-04-23 23:54:17 +0000978
Misha Brukmancaa1a5a2004-02-28 03:26:20 +0000979 // Assumption: this is a single-entry code region, and the header is the first
Chris Lattner73ab1fa2004-03-15 01:18:23 +0000980 // block in the region.
Chandler Carruth0fde0012012-05-04 10:18:49 +0000981 BasicBlock *header = *Blocks.begin();
Florian Hahn0e9dec62017-11-13 10:35:52 +0000982 Function *oldFunction = header->getParent();
983
984 // For functions with varargs, check that varargs handling is only done in the
985 // outlined function, i.e vastart and vaend are only used in outlined blocks.
986 if (AllowVarArgs && oldFunction->getFunctionType()->isVarArg()) {
987 auto containsVarArgIntrinsic = [](Instruction &I) {
988 if (const CallInst *CI = dyn_cast<CallInst>(&I))
989 if (const Function *F = CI->getCalledFunction())
990 return F->getIntrinsicID() == Intrinsic::vastart ||
991 F->getIntrinsicID() == Intrinsic::vaend;
992 return false;
993 };
994
995 for (auto &BB : *oldFunction) {
996 if (Blocks.count(&BB))
997 continue;
998 if (llvm::any_of(BB, containsVarArgIntrinsic))
999 return nullptr;
1000 }
1001 }
1002 ValueSet inputs, outputs, SinkingCands, HoistingCands;
1003 BasicBlock *CommonExit = nullptr;
Chris Lattner3b2917b2004-05-12 06:01:40 +00001004
Sean Silvaf8015752016-08-02 02:15:45 +00001005 // Calculate the entry frequency of the new function before we change the root
1006 // block.
1007 BlockFrequency EntryFreq;
1008 if (BFI) {
1009 assert(BPI && "Both BPI and BFI are required to preserve profile info");
1010 for (BasicBlock *Pred : predecessors(header)) {
1011 if (Blocks.count(Pred))
1012 continue;
1013 EntryFreq +=
1014 BFI->getBlockFreq(Pred) * BPI->getEdgeProbability(Pred, header);
1015 }
1016 }
1017
Chris Lattner13d2ddf2004-05-12 16:07:41 +00001018 // If we have to split PHI nodes or the entry block, do so now.
Chris Lattner795c9932004-05-12 15:29:13 +00001019 severSplitPHINodes(header);
1020
Chris Lattner13d2ddf2004-05-12 16:07:41 +00001021 // If we have any return instructions in the region, split those blocks so
1022 // that the return is not in the region.
1023 splitReturnBlocks();
1024
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001025 // This takes place of the original loop
Owen Anderson55f1c092009-08-13 21:58:54 +00001026 BasicBlock *codeReplacer = BasicBlock::Create(header->getContext(),
1027 "codeRepl", oldFunction,
Gabor Greif697e94c2008-05-15 10:04:30 +00001028 header);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001029
1030 // The new function needs a root node because other nodes can branch to the
Chris Lattner3b2917b2004-05-12 06:01:40 +00001031 // head of the region, but the entry node of a function cannot have preds.
Owen Anderson55f1c092009-08-13 21:58:54 +00001032 BasicBlock *newFuncRoot = BasicBlock::Create(header->getContext(),
1033 "newFuncRoot");
Florian Hahne5089e22017-12-08 21:49:03 +00001034 auto *BranchI = BranchInst::Create(header);
1035 // If the original function has debug info, we have to add a debug location
1036 // to the new branch instruction from the artificial entry block.
1037 // We use the debug location of the first instruction in the extracted
1038 // blocks, as there is no other equivalent line in the source code.
1039 if (oldFunction->getSubprogram()) {
1040 any_of(Blocks, [&BranchI](const BasicBlock *BB) {
1041 return any_of(*BB, [&BranchI](const Instruction &I) {
1042 if (!I.getDebugLoc())
1043 return false;
1044 BranchI->setDebugLoc(I.getDebugLoc());
1045 return true;
1046 });
1047 });
1048 }
1049 newFuncRoot->getInstList().push_back(BranchI);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001050
Xinliang David Li7ed6cd32017-06-11 20:46:05 +00001051 findAllocas(SinkingCands, HoistingCands, CommonExit);
1052 assert(HoistingCands.empty() || CommonExit);
Xinliang David Li74480ad2017-05-30 21:22:18 +00001053
Chris Lattner3b2917b2004-05-12 06:01:40 +00001054 // Find inputs to, outputs from the code region.
Xinliang David Li74480ad2017-05-30 21:22:18 +00001055 findInputsOutputs(inputs, outputs, SinkingCands);
1056
1057 // Now sink all instructions which only have non-phi uses inside the region
1058 for (auto *II : SinkingCands)
1059 cast<Instruction>(II)->moveBefore(*newFuncRoot,
1060 newFuncRoot->getFirstInsertionPt());
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001061
Xinliang David Li7ed6cd32017-06-11 20:46:05 +00001062 if (!HoistingCands.empty()) {
1063 auto *HoistToBlock = findOrCreateBlockForHoisting(CommonExit);
1064 Instruction *TI = HoistToBlock->getTerminator();
1065 for (auto *II : HoistingCands)
1066 cast<Instruction>(II)->moveBefore(TI);
1067 }
1068
Sean Silvaf8015752016-08-02 02:15:45 +00001069 // Calculate the exit blocks for the extracted region and the total exit
Eugene Zelenko286d5892017-10-11 21:41:43 +00001070 // weights for each of those blocks.
Sean Silvaf8015752016-08-02 02:15:45 +00001071 DenseMap<BasicBlock *, BlockFrequency> ExitWeights;
Chandler Carruth14316fc2012-05-04 11:20:27 +00001072 SmallPtrSet<BasicBlock *, 1> ExitBlocks;
Sean Silvaf8015752016-08-02 02:15:45 +00001073 for (BasicBlock *Block : Blocks) {
Benjamin Kramer135f7352016-06-26 12:28:59 +00001074 for (succ_iterator SI = succ_begin(Block), SE = succ_end(Block); SI != SE;
Sean Silvaf8015752016-08-02 02:15:45 +00001075 ++SI) {
1076 if (!Blocks.count(*SI)) {
1077 // Update the branch weight for this successor.
1078 if (BFI) {
1079 BlockFrequency &BF = ExitWeights[*SI];
1080 BF += BFI->getBlockFreq(Block) * BPI->getEdgeProbability(Block, *SI);
1081 }
Duncan P. N. Exon Smith6c990152014-07-21 17:06:51 +00001082 ExitBlocks.insert(*SI);
Sean Silvaf8015752016-08-02 02:15:45 +00001083 }
1084 }
1085 }
Chandler Carruth14316fc2012-05-04 11:20:27 +00001086 NumExitBlocks = ExitBlocks.size();
1087
Chris Lattner3b2917b2004-05-12 06:01:40 +00001088 // Construct new function based on inputs/outputs & add allocas for all defs.
Chris Lattner795c9932004-05-12 15:29:13 +00001089 Function *newFunction = constructFunction(inputs, outputs, header,
Misha Brukmanb1c93172005-04-21 23:48:37 +00001090 newFuncRoot,
Chris Lattner73ab1fa2004-03-15 01:18:23 +00001091 codeReplacer, oldFunction,
1092 oldFunction->getParent());
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001093
Sean Silvaf8015752016-08-02 02:15:45 +00001094 // Update the entry count of the function.
1095 if (BFI) {
1096 Optional<uint64_t> EntryCount =
1097 BFI->getProfileCountFromFreq(EntryFreq.getFrequency());
1098 if (EntryCount.hasValue())
1099 newFunction->setEntryCount(EntryCount.getValue());
1100 BFI->setBlockFreq(codeReplacer, EntryFreq.getFrequency());
1101 }
1102
Chris Lattner9c431f62004-03-14 22:34:55 +00001103 emitCallAndSwitchStatement(newFunction, codeReplacer, inputs, outputs);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001104
Chris Lattner9c431f62004-03-14 22:34:55 +00001105 moveCodeToFunction(newFunction);
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001106
Sean Silvaf8015752016-08-02 02:15:45 +00001107 // Update the branch weights for the exit block.
1108 if (BFI && NumExitBlocks > 1)
1109 calculateNewCallTerminatorWeights(codeReplacer, ExitWeights, BPI);
1110
Chris Lattner795c9932004-05-12 15:29:13 +00001111 // Loop over all of the PHI nodes in the header block, and change any
Chris Lattner320d59f2004-03-18 05:28:49 +00001112 // references to the old incoming edge to be the new incoming edge.
Reid Spencer66149462004-09-15 17:06:42 +00001113 for (BasicBlock::iterator I = header->begin(); isa<PHINode>(I); ++I) {
1114 PHINode *PN = cast<PHINode>(I);
Chris Lattner320d59f2004-03-18 05:28:49 +00001115 for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
Chandler Carruth0fde0012012-05-04 10:18:49 +00001116 if (!Blocks.count(PN->getIncomingBlock(i)))
Chris Lattner320d59f2004-03-18 05:28:49 +00001117 PN->setIncomingBlock(i, newFuncRoot);
Reid Spencer66149462004-09-15 17:06:42 +00001118 }
Misha Brukmanb1c93172005-04-21 23:48:37 +00001119
Chris Lattneracd75982004-03-18 05:38:31 +00001120 // Look at all successors of the codeReplacer block. If any of these blocks
1121 // had PHI nodes in them, we need to update the "from" block to be the code
1122 // replacer, not the original block in the extracted region.
Eugene Zelenko286d5892017-10-11 21:41:43 +00001123 std::vector<BasicBlock *> Succs(succ_begin(codeReplacer),
1124 succ_end(codeReplacer));
Chris Lattneracd75982004-03-18 05:38:31 +00001125 for (unsigned i = 0, e = Succs.size(); i != e; ++i)
Reid Spencer66149462004-09-15 17:06:42 +00001126 for (BasicBlock::iterator I = Succs[i]->begin(); isa<PHINode>(I); ++I) {
1127 PHINode *PN = cast<PHINode>(I);
Chris Lattner56273822004-08-13 03:27:07 +00001128 std::set<BasicBlock*> ProcessedPreds;
Chris Lattneracd75982004-03-18 05:38:31 +00001129 for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
Chandler Carruth0fde0012012-05-04 10:18:49 +00001130 if (Blocks.count(PN->getIncomingBlock(i))) {
Chris Lattner56273822004-08-13 03:27:07 +00001131 if (ProcessedPreds.insert(PN->getIncomingBlock(i)).second)
1132 PN->setIncomingBlock(i, codeReplacer);
1133 else {
1134 // There were multiple entries in the PHI for this block, now there
1135 // is only one, so remove the duplicated entries.
1136 PN->removeIncomingValue(i, false);
1137 --i; --e;
1138 }
Anton Korobeynikov1bfd1212008-02-20 11:26:25 +00001139 }
Chris Lattner56273822004-08-13 03:27:07 +00001140 }
Misha Brukmanb1c93172005-04-21 23:48:37 +00001141
Torok Edwinccb29cd2009-07-11 13:10:19 +00001142 DEBUG(if (verifyFunction(*newFunction))
Chris Lattner2104b8d2010-04-07 22:58:41 +00001143 report_fatal_error("verifyFunction failed!"));
Misha Brukmancaa1a5a2004-02-28 03:26:20 +00001144 return newFunction;
1145}