llvm/test/Transforms/SimplifyCFG/invoke_unwind.ll
Chris Lattner 11f15dbb28 change simplifycfg to not duplicate 'unwind' instructions. Hopefully
this will increase the likelihood of common code getting sunk towards
the unwind.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@83996 91177308-0d34-0410-b5e6-96231b3b80d8
2009-10-13 18:13:05 +00:00

34 lines
822 B
LLVM

; RUN: opt < %s -simplifycfg -S | FileCheck %s
declare void @bar()
; This testcase checks to see if the simplifycfg pass is converting invoke
; instructions to call instructions if the handler just rethrows the exception.
define i32 @test1() {
; CHECK: @test1
; CHECK-NEXT: call void @bar()
; CHECK-NEXT: ret i32 0
invoke void @bar( )
to label %Ok unwind label %Rethrow
Ok: ; preds = %0
ret i32 0
Rethrow: ; preds = %0
unwind
}
; Verify that simplifycfg isn't duplicating 'unwind' instructions. Doing this
; is bad because it discourages commoning.
define i32 @test2(i1 %c) {
; CHECK: @test2
; CHECK: T:
; CHECK-NEXT: call void @bar()
; CHECK-NEXT: br label %F
br i1 %c, label %T, label %F
T:
call void @bar()
br label %F
F:
unwind
}