aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/AMDGPU/complex-folding.ll
blob: 3d124e8cb7f4a04e40a696aaa73377db1de4db33 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
;RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s

; CHECK: {{^}}main:
; CHECK-NOT: MOV
define amdgpu_ps void @main(<4 x float> inreg %reg0) {
entry:
  %0 = extractelement <4 x float> %reg0, i32 0
  %1 = call float @fabsf(float %0)
  %2 = fptoui float %1 to i32
  %3 = bitcast i32 %2 to float
  %4 = insertelement <4 x float> poison, float %3, i32 0
  call void @llvm.r600.store.swizzle(<4 x float> %4, i32 0, i32 0)
  ret void
}

declare float @fabsf(float ) readnone
declare void @llvm.r600.store.swizzle(<4 x float>, i32, i32)