mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
026230b0a9
they are lowered to instruction sequences more complex than a simple load, such that CodeGen cannot rematerialize them, a reload from a spill slot is likely to be cheaper than the complex sequence. llvm-svn: 89374
40 lines
1018 B
LLVM
40 lines
1018 B
LLVM
; RUN: opt < %s -licm -S | FileCheck %s
|
|
|
|
@a = external constant float*
|
|
|
|
define void @test(i32 %count) {
|
|
entry:
|
|
br label %forcond
|
|
|
|
; CHECK: %tmp3 = load float** @a
|
|
; CHECK: br label %forcond
|
|
|
|
forcond:
|
|
%i.0 = phi i32 [ 0, %entry ], [ %inc, %forbody ]
|
|
%cmp = icmp ult i32 %i.0, %count
|
|
br i1 %cmp, label %forbody, label %afterfor
|
|
|
|
; CHECK: %i.0 = phi i32 [ 0, %entry ], [ %inc, %forbody ]
|
|
; CHECK: %cmp = icmp ult i32 %i.0, %count
|
|
; CHECK: br i1 %cmp, label %forbody, label %afterfor
|
|
|
|
forbody:
|
|
%tmp3 = load float** @a
|
|
%arrayidx = getelementptr float* %tmp3, i32 %i.0
|
|
%tmp7 = uitofp i32 %i.0 to float
|
|
store float %tmp7, float* %arrayidx
|
|
%inc = add i32 %i.0, 1
|
|
br label %forcond
|
|
|
|
; CHECK: %arrayidx = getelementptr float* %tmp3, i32 %i.0
|
|
; CHECK: %tmp7 = uitofp i32 %i.0 to float
|
|
; CHECK: store float %tmp7, float* %arrayidx
|
|
; CHECK: %inc = add i32 %i.0, 1
|
|
; CHECK: br label %forcond
|
|
|
|
afterfor:
|
|
ret void
|
|
}
|
|
|
|
; CHECK: ret void
|