mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-30 07:00:45 +00:00
5fd5b125ff
For example, on 32-bit architecture, don't promote all uses of the IV to 64-bits just because one use is a 64-bit cast. Alternate implementation of the patch by Arnaud de Grandmaison. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@127884 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
669 B
LLVM
22 lines
669 B
LLVM
; Check that the index of 'P[outer]' is pulled out of the loop.
|
|
; RUN: opt < %s -loop-reduce -S | \
|
|
; RUN: not grep {getelementptr.*%outer.*%INDVAR}
|
|
|
|
target datalayout = "e-p:32:32:32-n:32"
|
|
declare i1 @pred()
|
|
|
|
define void @test([10000 x i32]* %P, i32 %outer) {
|
|
; <label>:0
|
|
br label %Loop
|
|
Loop: ; preds = %Loop, %0
|
|
%INDVAR = phi i32 [ 0, %0 ], [ %INDVAR2, %Loop ] ; <i32> [#uses=2]
|
|
%STRRED = getelementptr [10000 x i32]* %P, i32 %outer, i32 %INDVAR ; <i32*> [#uses=1]
|
|
store i32 0, i32* %STRRED
|
|
%INDVAR2 = add i32 %INDVAR, 1 ; <i32> [#uses=1]
|
|
%cond = call i1 @pred( ) ; <i1> [#uses=1]
|
|
br i1 %cond, label %Loop, label %Out
|
|
Out: ; preds = %Loop
|
|
ret void
|
|
}
|
|
|