2003-12-09 21:40:36 +00:00
|
|
|
; This testcase ensures that we can sink instructions from loops with
|
|
|
|
; multiple exits.
|
|
|
|
;
|
2008-03-19 03:47:13 +00:00
|
|
|
; RUN: llvm-as < %s | opt -licm | llvm-dis | \
|
2007-04-15 08:30:33 +00:00
|
|
|
; RUN: %prcontext mul 1 | grep {Out\[12\]:}
|
2003-12-09 21:40:36 +00:00
|
|
|
|
2008-03-19 03:47:13 +00:00
|
|
|
define i32 @test(i32 %N, i1 %C) {
|
2003-12-09 21:40:36 +00:00
|
|
|
Entry:
|
|
|
|
br label %Loop
|
2008-03-19 03:47:13 +00:00
|
|
|
Loop: ; preds = %ContLoop, %Entry
|
|
|
|
%N_addr.0.pn = phi i32 [ %dec, %ContLoop ], [ %N, %Entry ] ; <i32> [#uses=3]
|
|
|
|
%tmp.6 = mul i32 %N, %N_addr.0.pn ; <i32> [#uses=1]
|
|
|
|
%tmp.7 = sub i32 %tmp.6, %N ; <i32> [#uses=2]
|
|
|
|
%dec = add i32 %N_addr.0.pn, -1 ; <i32> [#uses=1]
|
|
|
|
br i1 %C, label %ContLoop, label %Out1
|
|
|
|
ContLoop: ; preds = %Loop
|
|
|
|
%tmp.1 = icmp ne i32 %N_addr.0.pn, 1 ; <i1> [#uses=1]
|
|
|
|
br i1 %tmp.1, label %Loop, label %Out2
|
|
|
|
Out1: ; preds = %Loop
|
|
|
|
ret i32 %tmp.7
|
|
|
|
Out2: ; preds = %ContLoop
|
|
|
|
ret i32 %tmp.7
|
2003-12-09 21:40:36 +00:00
|
|
|
}
|
2008-03-19 03:47:13 +00:00
|
|
|
|