Skip to content
Snippets Groups Projects
Commit d3c9d971 authored by Bill Wendling's avatar Bill Wendling
Browse files

If we are extracting a basic block that ends in an invoke call, we must also

extract the landing pad block. Otherwise, there will be a situation where the
invoke's unwind edge lands on a non-landing pad.

We also forbid the user from extracting the landing pad block by itself. Again,
this is not a valid transformation.

llvm-svn: 140083
parent f5028fd1
No related branches found
No related tags found
No related merge requests found
......@@ -664,7 +664,13 @@ ExtractCodeRegion(const std::vector<BasicBlock*> &code) {
// * Pass in uses as args
// 3) Move code region, add call instr to func
//
BlocksToExtract.insert(code.begin(), code.end());
for (std::vector<BasicBlock*>::const_iterator
I = code.begin(), E = code.end(); I != E; ++I) {
BasicBlock *BB = *I;
BlocksToExtract.insert(BB);
if (InvokeInst *II = dyn_cast<InvokeInst>(BB->getTerminator()))
BlocksToExtract.insert(II->getUnwindDest());
}
Values inputs, outputs;
......@@ -788,6 +794,7 @@ Function* llvm::ExtractLoop(DominatorTree &DT, Loop *L, bool AggregateArgs) {
/// ExtractBasicBlock - slurp a basic block into a brand new function
///
Function* llvm::ExtractBasicBlock(BasicBlock *BB, bool AggregateArgs) {
if (BB->isLandingPad()) return 0;
std::vector<BasicBlock*> Blocks;
Blocks.push_back(BB);
return CodeExtractor(0, AggregateArgs).ExtractCodeRegion(Blocks);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment