diff options
| author | Sanjoy Das <sanjoy@playingwithpointers.com> | 2015-12-08 23:16:52 +0000 |
|---|---|---|
| committer | Sanjoy Das <sanjoy@playingwithpointers.com> | 2015-12-08 23:16:52 +0000 |
| commit | 48945cdc159e47349b28157375960a11809c117d (patch) | |
| tree | c0001b43e838fe1311a762f68c1d883e8c5e0c18 /llvm/lib | |
| parent | e6ccd7b66a55363bbc57a7efcff1c514081a6269 (diff) | |
| download | bcm5719-llvm-48945cdc159e47349b28157375960a11809c117d.tar.gz bcm5719-llvm-48945cdc159e47349b28157375960a11809c117d.zip | |
[OperandBundles] Have PruneEH work correct with operand bundles.
For an invoke with operand bundles, the [op_begin(), op_end()-3] range
can contain things other than invoke arguments. This change teaches
PruneEH to use arg_begin() and arg_end() explicitly.
llvm-svn: 255073
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/IPO/PruneEH.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/IPO/PruneEH.cpp b/llvm/lib/Transforms/IPO/PruneEH.cpp index 714e1d6e42d..c9c0b197eae 100644 --- a/llvm/lib/Transforms/IPO/PruneEH.cpp +++ b/llvm/lib/Transforms/IPO/PruneEH.cpp @@ -191,9 +191,14 @@ bool PruneEH::SimplifyFunction(Function *F) { for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) { if (InvokeInst *II = dyn_cast<InvokeInst>(BB->getTerminator())) if (II->doesNotThrow() && canSimplifyInvokeNoUnwind(F)) { - SmallVector<Value*, 8> Args(II->op_begin(), II->op_end() - 3); + CallSite CS(II); + SmallVector<Value*, 8> Args(CS.arg_begin(), CS.arg_end()); + SmallVector<OperandBundleDef, 1> OpBundles; + II->getOperandBundlesAsDefs(OpBundles); + // Insert a call instruction before the invoke. - CallInst *Call = CallInst::Create(II->getCalledValue(), Args, "", II); + CallInst *Call = CallInst::Create(II->getCalledValue(), Args, OpBundles, + "", II); Call->takeName(II); Call->setCallingConv(II->getCallingConv()); Call->setAttributes(II->getAttributes()); |

