[llvm] r258616 - [PruneEH] Don't try to insert a terminator after another terminator

David Majnemer via llvm-commits llvm-commits at lists.llvm.org
Wed Feb 17 09:34:08 PST 2016


Could we get this merged into 3.8?

On Fri, Jan 22, 2016 at 10:00 PM, David Majnemer via llvm-commits <
llvm-commits at lists.llvm.org> wrote:

> Author: majnemer
> Date: Sat Jan 23 00:00:44 2016
> New Revision: 258616
>
> URL: http://llvm.org/viewvc/llvm-project?rev=258616&view=rev
> Log:
> [PruneEH] Don't try to insert a terminator after another terminator
>
> LLVM's BasicBlock has a single terminator, it is not valid to have two.
>
> Modified:
>     llvm/trunk/lib/Transforms/IPO/PruneEH.cpp
>     llvm/trunk/test/Transforms/PruneEH/pr26263.ll
>
> Modified: llvm/trunk/lib/Transforms/IPO/PruneEH.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/IPO/PruneEH.cpp?rev=258616&r1=258615&r2=258616&view=diff
>
> ==============================================================================
> --- llvm/trunk/lib/Transforms/IPO/PruneEH.cpp (original)
> +++ llvm/trunk/lib/Transforms/IPO/PruneEH.cpp Sat Jan 23 00:00:44 2016
> @@ -252,7 +252,8 @@ void PruneEH::DeleteBasicBlock(BasicBloc
>    }
>
>    if (TokenInst) {
> -    changeToUnreachable(TokenInst->getNextNode(), /*UseLLVMTrap=*/false);
> +    if (!isa<TerminatorInst>(TokenInst))
> +      changeToUnreachable(TokenInst->getNextNode(),
> /*UseLLVMTrap=*/false);
>    } else {
>      // Get the list of successors of this block.
>      std::vector<BasicBlock *> Succs(succ_begin(BB), succ_end(BB));
>
> Modified: llvm/trunk/test/Transforms/PruneEH/pr26263.ll
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/PruneEH/pr26263.ll?rev=258616&r1=258615&r2=258616&view=diff
>
> ==============================================================================
> --- llvm/trunk/test/Transforms/PruneEH/pr26263.ll (original)
> +++ llvm/trunk/test/Transforms/PruneEH/pr26263.ll Sat Jan 23 00:00:44 2016
> @@ -27,4 +27,30 @@ cleanupret:
>
>  ; CHECK: cleanupret from %[[cp]] unwind to caller
>
> +define void @test2() personality i32 (...)* @__CxxFrameHandler3 {
> +  invoke void @neverthrows()
> +          to label %try.cont unwind label %catchswitch
> +
> +try.cont:
> +  ret void
> +
> +catchswitch:
> +  %cs = catchswitch within none [label %catchpad] unwind to caller
> +
> +catchpad:
> +  %cp = catchpad within %cs []
> +  unreachable
> +
> +ret:
> +  ret void
> +}
> +
> +; CHECK-LABEL: define void @test2(
> +; CHECK: call void @neverthrows()
> +
> +; CHECK: %[[cs:.*]] = catchswitch within none [label
> +
> +; CHECK: catchpad within %[[cs]] []
> +; CHECK-NEXT: unreachable
> +
>  declare i32 @__CxxFrameHandler3(...)
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160217/ba048f4f/attachment.html>


More information about the llvm-commits mailing list