mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
b1e1e82c54
of using llvm-as, now that opt supports this. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81226 91177308-0d34-0410-b5e6-96231b3b80d8
21 lines
620 B
LLVM
21 lines
620 B
LLVM
; Test that LICM works when there is not a loop-preheader
|
|
; RUN: opt %s -licm | llvm-dis
|
|
|
|
define void @testfunc(i32 %i.s, i1 %ifcond) {
|
|
br i1 %ifcond, label %Then, label %Else
|
|
Then: ; preds = %0
|
|
br label %Loop
|
|
Else: ; preds = %0
|
|
br label %Loop
|
|
Loop: ; preds = %Loop, %Else, %Then
|
|
%j = phi i32 [ 0, %Then ], [ 12, %Else ], [ %Next, %Loop ] ; <i32> [#uses=1]
|
|
%i = bitcast i32 %i.s to i32 ; <i32> [#uses=1]
|
|
%i2 = mul i32 %i, 17 ; <i32> [#uses=1]
|
|
%Next = add i32 %j, %i2 ; <i32> [#uses=2]
|
|
%cond = icmp eq i32 %Next, 0 ; <i1> [#uses=1]
|
|
br i1 %cond, label %Out, label %Loop
|
|
Out: ; preds = %Loop
|
|
ret void
|
|
}
|
|
|