blob: cb020a04774103d6a340580de589df441967a88c [file] [log] [blame]
Vincent Lejeune4d143322013-06-07 23:30:26 +00001;RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s
2
3;CHECK: TEX
4;CHECK-NEXT: ALU
5
Nicolai Haehnledf3a20c2016-04-06 19:40:20 +00006define amdgpu_vs void @test(<4 x float> inreg %reg0) {
Vincent Lejeunef143af32013-11-11 22:10:24 +00007 %1 = extractelement <4 x float> %reg0, i32 0
8 %2 = extractelement <4 x float> %reg0, i32 1
9 %3 = extractelement <4 x float> %reg0, i32 2
10 %4 = extractelement <4 x float> %reg0, i32 3
Vincent Lejeune4d143322013-06-07 23:30:26 +000011 %5 = insertelement <4 x float> undef, float %1, i32 0
12 %6 = insertelement <4 x float> %5, float %2, i32 1
13 %7 = insertelement <4 x float> %6, float %3, i32 2
14 %8 = insertelement <4 x float> %7, float %4, i32 3
Matt Arsenault59bd3012016-01-22 19:00:09 +000015 %9 = call <4 x float> @llvm.r600.tex(<4 x float> %8, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
16 %10 = call <4 x float> @llvm.r600.tex(<4 x float> %8, i32 1, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Vincent Lejeune4d143322013-06-07 23:30:26 +000017 %11 = fadd <4 x float> %9, %10
18 call void @llvm.R600.store.swizzle(<4 x float> %11, i32 0, i32 0)
19 ret void
20}
21
Matt Arsenault59bd3012016-01-22 19:00:09 +000022declare <4 x float> @llvm.r600.tex(<4 x float>, i32, i32, i32, i32, i32, i32, i32, i32, i32) readnone
Vincent Lejeune4d143322013-06-07 23:30:26 +000023declare void @llvm.R600.store.swizzle(<4 x float>, i32, i32)