mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 01:31:05 +00:00
Fix PR404 try #2
This version takes about 1s longer than the previous one (down to 2.35s), but on the positive side, it actually works :) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14856 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5e87754250
commit
fed22aac43
@ -43,6 +43,7 @@
|
||||
#include "llvm/Support/CFG.h"
|
||||
#include "llvm/Transforms/Utils/Local.h"
|
||||
#include "Support/SetOperations.h"
|
||||
#include "Support/SetVector.h"
|
||||
#include "Support/Statistic.h"
|
||||
#include "Support/DepthFirstIterator.h"
|
||||
using namespace llvm;
|
||||
@ -153,21 +154,20 @@ bool LoopSimplify::ProcessLoop(Loop *L) {
|
||||
// predecessors from outside of the loop, split the edge now.
|
||||
std::vector<BasicBlock*> ExitBlocks;
|
||||
L->getExitBlocks(ExitBlocks);
|
||||
for (unsigned i = 0, e = ExitBlocks.size(); i != e; ++i) {
|
||||
BasicBlock *ExitBlock = ExitBlocks[i];
|
||||
|
||||
SetVector<BasicBlock*> ExitBlockSet(ExitBlocks.begin(), ExitBlocks.end());
|
||||
for (SetVector<BasicBlock*>::iterator I = ExitBlockSet.begin(),
|
||||
E = ExitBlockSet.end(); I != E; ++I) {
|
||||
BasicBlock *ExitBlock = *I;
|
||||
for (pred_iterator PI = pred_begin(ExitBlock), PE = pred_end(ExitBlock);
|
||||
PI != PE; ++PI)
|
||||
if (!L->contains(*PI)) {
|
||||
BasicBlock *NewBB = RewriteLoopExitBlock(L, ExitBlock);
|
||||
for (unsigned j = i; j != ExitBlocks.size(); ++j)
|
||||
if (ExitBlocks[j] == ExitBlock)
|
||||
ExitBlocks[j] = NewBB;
|
||||
|
||||
RewriteLoopExitBlock(L, ExitBlock);
|
||||
NumInserted++;
|
||||
Changed = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// If the header has more than two predecessors at this point (from the
|
||||
// preheader and from multiple backedges), we must adjust the loop.
|
||||
|
Loading…
x
Reference in New Issue
Block a user