mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-30 02:32:08 +00:00
e6d5d39c07
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48538 91177308-0d34-0410-b5e6-96231b3b80d8
23 lines
663 B
LLVM
23 lines
663 B
LLVM
; Don't reduce the byte access to P[i], at least not on targets that
|
|
; support an efficient 'mem[r1+r2]' addressing mode.
|
|
|
|
; RUN: llvm-as < %s | opt -loop-reduce -disable-output
|
|
|
|
|
|
declare i1 @pred(i32)
|
|
|
|
define void @test(i8* %PTR) {
|
|
; <label>:0
|
|
br label %Loop
|
|
Loop: ; preds = %Loop, %0
|
|
%INDVAR = phi i32 [ 0, %0 ], [ %INDVAR2, %Loop ] ; <i32> [#uses=2]
|
|
%STRRED = getelementptr i8* %PTR, i32 %INDVAR ; <i8*> [#uses=1]
|
|
store i8 0, i8* %STRRED
|
|
%INDVAR2 = add i32 %INDVAR, 1 ; <i32> [#uses=2]
|
|
;; cannot eliminate indvar
|
|
%cond = call i1 @pred( i32 %INDVAR2 ) ; <i1> [#uses=1]
|
|
br i1 %cond, label %Loop, label %Out
|
|
Out: ; preds = %Loop
|
|
ret void
|
|
}
|