; Test that if an invoked function is inlined, and if that function cannot
; throw, that the dead handler is now unreachable.
-; RUN: llvm-upgrade < %s | llvm-as | opt -inline -simplifycfg | llvm-dis | not grep UnreachableExceptionHandler
+; RUN: opt < %s -inline -simplifycfg -S | \
+; RUN: not grep UnreachableExceptionHandler
-declare void %might_throw()
+declare void @might_throw()
-implementation
+define internal i32 @callee() personality i32 (...)* @__gxx_personality_v0 {
+ invoke void @might_throw( )
+ to label %cont unwind label %exc
-internal int %callee() {
- invoke void %might_throw() to label %cont except label %exc
-cont:
- ret int 0
-exc:
- ; This just consumes the exception!
- ret int 1
+cont: ; preds = %0
+ ret i32 0
+
+exc: ; preds = %0
+ %exn = landingpad {i8*, i32}
+ cleanup
+ ret i32 1
}
; caller returns true if might_throw throws an exception... callee cannot throw.
-int %caller() {
- %X = invoke int %callee() to label %cont
- except label %UnreachableExceptionHandler
-cont:
- ret int %X
-UnreachableExceptionHandler:
- ret int -1 ; This is dead!
+define i32 @caller() personality i32 (...)* @__gxx_personality_v0 {
+ %X = invoke i32 @callee( )
+ to label %cont unwind label %UnreachableExceptionHandler ; <i32> [#uses=1]
+
+cont: ; preds = %0
+ ret i32 %X
+
+UnreachableExceptionHandler: ; preds = %0
+ %exn = landingpad {i8*, i32}
+ cleanup
+ ret i32 -1
}
+
+declare i32 @__gxx_personality_v0(...)