2002-05-21 19:22:10 +00:00
|
|
|
; CFG Simplification is making a loop dead, then changing the add into:
|
|
|
|
;
|
|
|
|
; %V1 = add int %V1, 1
|
|
|
|
;
|
|
|
|
; Which is not valid SSA
|
|
|
|
;
|
2008-03-10 07:21:50 +00:00
|
|
|
; RUN: llvm-as < %s | opt -simplifycfg | llvm-dis
|
2002-05-21 19:22:10 +00:00
|
|
|
|
2008-03-10 07:21:50 +00:00
|
|
|
define void @test() {
|
|
|
|
; <label>:0
|
|
|
|
br i1 true, label %end, label %Loop
|
|
|
|
Loop: ; preds = %Loop, %0
|
|
|
|
%V = phi i32 [ 0, %0 ], [ %V1, %Loop ] ; <i32> [#uses=1]
|
|
|
|
%V1 = add i32 %V, 1 ; <i32> [#uses=1]
|
2002-05-21 19:22:10 +00:00
|
|
|
br label %Loop
|
2008-03-10 07:21:50 +00:00
|
|
|
end: ; preds = %0
|
2002-05-21 19:22:10 +00:00
|
|
|
ret void
|
|
|
|
}
|
2008-03-10 07:21:50 +00:00
|
|
|
|