blob: fb1926eca25bc7144a55ca346134292b72d47972 [file] [log] [blame]
Chris Lattner5464da92003-08-27 01:05:19 +00001; The PHI cannot be eliminated from this testcase, SCCP is mishandling invoke's!
Dan Gohmanf2f6ce62009-09-11 18:01:28 +00002; RUN: opt < %s -sccp -S | grep phi
Chris Lattner5464da92003-08-27 01:05:19 +00003
Tanya Lattnerf396cc82008-03-19 04:14:49 +00004declare void @foo()
5
6define i32 @test(i1 %cond) {
Chris Lattner5464da92003-08-27 01:05:19 +00007Entry:
Tanya Lattnerf396cc82008-03-19 04:14:49 +00008 br i1 %cond, label %Inv, label %Cont
9Inv: ; preds = %Entry
10 invoke void @foo( )
Bill Wendlingb072dd92011-08-31 20:55:40 +000011 to label %Ok unwind label %LPad
Tanya Lattnerf396cc82008-03-19 04:14:49 +000012Ok: ; preds = %Inv
Chris Lattner5464da92003-08-27 01:05:19 +000013 br label %Cont
Bill Wendlingb072dd92011-08-31 20:55:40 +000014LPad:
15 %val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
16 catch i8* null
17 br label %Cont
Tanya Lattnerf396cc82008-03-19 04:14:49 +000018Cont: ; preds = %Ok, %Inv, %Entry
Bill Wendlingb072dd92011-08-31 20:55:40 +000019 %X = phi i32 [ 0, %Entry ], [ 1, %Ok ], [ 0, %LPad ] ; <i32> [#uses=1]
Tanya Lattnerf396cc82008-03-19 04:14:49 +000020 ret i32 %X
Chris Lattner5464da92003-08-27 01:05:19 +000021}
Tanya Lattnerf396cc82008-03-19 04:14:49 +000022
Bill Wendlingb072dd92011-08-31 20:55:40 +000023declare i32 @__gxx_personality_v0(...)