2008-03-01 09:15:35 +00:00
|
|
|
; RUN: llvm-as < %s | opt -loop-extract -disable-output
|
2004-03-15 00:08:49 +00:00
|
|
|
; This testcase is failing the loop extractor because not all exit blocks
|
|
|
|
; are dominated by all of the live-outs.
|
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
define i32 @ab(i32 %alpha, i32 %beta) {
|
2004-03-15 00:08:49 +00:00
|
|
|
entry:
|
2008-03-01 09:15:35 +00:00
|
|
|
br label %loopentry.1.preheader
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
loopentry.1.preheader: ; preds = %entry
|
|
|
|
br label %loopentry.1
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
loopentry.1: ; preds = %no_exit.1, %loopentry.1.preheader
|
|
|
|
br i1 false, label %no_exit.1, label %loopexit.0.loopexit1
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
no_exit.1: ; preds = %loopentry.1
|
|
|
|
%tmp.53 = load i32* null ; <i32> [#uses=1]
|
|
|
|
br i1 false, label %shortcirc_next.2, label %loopentry.1
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
shortcirc_next.2: ; preds = %no_exit.1
|
|
|
|
%tmp.563 = call i32 @wins( i32 0, i32 %tmp.53, i32 3 ) ; <i32> [#uses=0]
|
|
|
|
ret i32 0
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
loopexit.0.loopexit1: ; preds = %loopentry.1
|
|
|
|
br label %loopexit.0
|
2004-03-15 00:08:49 +00:00
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
loopexit.0: ; preds = %loopexit.0.loopexit1
|
|
|
|
ret i32 0
|
2004-03-15 00:08:49 +00:00
|
|
|
}
|
|
|
|
|
2008-03-01 09:15:35 +00:00
|
|
|
declare i32 @wins(i32, i32, i32)
|
|
|
|
|
|
|
|
declare i16 @ab_code()
|
2004-03-15 00:08:49 +00:00
|
|
|
|