mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-25 21:16:19 +00:00
Loop exit sets are no longer explicitly held, they are dynamically computed on demand.
llvm-svn: 13046
This commit is contained in:
parent
7174acca00
commit
8e42c6f409
@ -436,7 +436,8 @@ bool LICM::isLoopInvariantInst(Instruction &I) {
|
||||
void LICM::sink(Instruction &I) {
|
||||
DEBUG(std::cerr << "LICM sinking instruction: " << I);
|
||||
|
||||
const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
|
||||
std::vector<BasicBlock*> ExitBlocks;
|
||||
CurLoop->getExitBlocks(ExitBlocks);
|
||||
|
||||
if (isa<LoadInst>(I)) ++NumMovedLoads;
|
||||
else if (isa<CallInst>(I)) ++NumMovedCalls;
|
||||
@ -593,7 +594,8 @@ bool LICM::isSafeToExecuteUnconditionally(Instruction &Inst) {
|
||||
return true;
|
||||
|
||||
// Get the exit blocks for the current loop.
|
||||
const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
|
||||
std::vector<BasicBlock*> ExitBlocks;
|
||||
CurLoop->getExitBlocks(ExitBlocks);
|
||||
|
||||
// For each exit block, get the DT node and walk up the DT until the
|
||||
// instruction's basic block is found or we exit the loop.
|
||||
@ -667,7 +669,8 @@ void LICM::PromoteValuesInLoop() {
|
||||
//
|
||||
std::set<BasicBlock*> ProcessedBlocks;
|
||||
|
||||
const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
|
||||
std::vector<BasicBlock*> ExitBlocks;
|
||||
CurLoop->getExitBlocks(ExitBlocks);
|
||||
for (unsigned i = 0, e = ExitBlocks.size(); i != e; ++i)
|
||||
if (ProcessedBlocks.insert(ExitBlocks[i]).second) {
|
||||
// Copy all of the allocas into their memory locations...
|
||||
|
Loading…
Reference in New Issue
Block a user