Chris Lattner 11acc44e66 this passes with the change in predicate
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23699 91177308-0d34-0410-b5e6-96231b3b80d8
2005-10-11 18:42:26 +00:00

22 lines
537 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 bool %pred(int)
void %test(sbyte* %PTR) {
br label %Loop
Loop:
%INDVAR = phi int [0, %0], [%INDVAR2, %Loop]
%STRRED = getelementptr sbyte* %PTR, int %INDVAR
store sbyte 0, sbyte* %STRRED
%INDVAR2 = add int %INDVAR, 1
%cond = call bool %pred(int %INDVAR2) ;; cannot eliminate indvar
br bool %cond, label %Loop, label %Out
Out:
ret void
}