2002-05-22 03:22:10 +08:00
|
|
|
; CFG Simplification is making a loop dead, then changing the add into:
|
|
|
|
;
|
|
|
|
; %V1 = add int %V1, 1
|
|
|
|
;
|
|
|
|
; Which is not valid SSA
|
|
|
|
;
|
2009-09-12 02:01:28 +08:00
|
|
|
; RUN: opt < %s -simplifycfg | llvm-dis
|
2002-05-22 03:22:10 +08:00
|
|
|
|
2008-03-10 15:21:50 +08: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-22 03:22:10 +08:00
|
|
|
br label %Loop
|
2008-03-10 15:21:50 +08:00
|
|
|
end: ; preds = %0
|
2002-05-22 03:22:10 +08:00
|
|
|
ret void
|
|
|
|
}
|
2008-03-10 15:21:50 +08:00
|
|
|
|