mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-21 19:55:30 +00:00
[LCSSA] Don't insert tokens into the worklist at all.
We're gonna skip them anyway, so there's no point in inserting them in the first place. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@300452 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
603e72e193
commit
5c0006e064
@ -85,6 +85,7 @@ bool llvm::formLCSSAForInstructions(SmallVectorImpl<Instruction *> &Worklist,
|
||||
UsesToRewrite.clear();
|
||||
|
||||
Instruction *I = Worklist.pop_back_val();
|
||||
assert(!I->getType()->isTokenTy() && "Tokens shouldn't be in the worklist");
|
||||
BasicBlock *InstBB = I->getParent();
|
||||
Loop *L = LI.getLoopFor(InstBB);
|
||||
assert(L && "Instruction belongs to a BB that's not part of a loop");
|
||||
@ -96,13 +97,6 @@ bool llvm::formLCSSAForInstructions(SmallVectorImpl<Instruction *> &Worklist,
|
||||
if (ExitBlocks.empty())
|
||||
continue;
|
||||
|
||||
// Tokens cannot be used in PHI nodes, so we skip over them.
|
||||
// We can run into tokens which are live out of a loop with catchswitch
|
||||
// instructions in Windows EH if the catchswitch has one catchpad which
|
||||
// is inside the loop and another which is not.
|
||||
if (I->getType()->isTokenTy())
|
||||
continue;
|
||||
|
||||
for (Use &U : I->uses()) {
|
||||
Instruction *User = cast<Instruction>(U.getUser());
|
||||
BasicBlock *UserBB = User->getParent();
|
||||
@ -311,6 +305,13 @@ bool llvm::formLCSSA(Loop &L, DominatorTree &DT, LoopInfo *LI,
|
||||
!isa<PHINode>(I.user_back())))
|
||||
continue;
|
||||
|
||||
// Tokens cannot be used in PHI nodes, so we skip over them.
|
||||
// We can run into tokens which are live out of a loop with catchswitch
|
||||
// instructions in Windows EH if the catchswitch has one catchpad which
|
||||
// is inside the loop and another which is not.
|
||||
if (I.getType()->isTokenTy())
|
||||
continue;
|
||||
|
||||
Worklist.push_back(&I);
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user