annotate test/CodeGen/AMDGPU/llvm.amdgcn.image.getlod.ll @ 128:c347d3398279 default tip

fix
author mir3636
date Wed, 06 Dec 2017 14:37:17 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 ; RUN: llc < %s -march=amdgcn -mcpu=verde -verify-machineinstrs | FileCheck --check-prefix=GCN %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 ; RUN: llc < %s -march=amdgcn -mcpu=tonga -verify-machineinstrs | FileCheck --check-prefix=GCN %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 ; GCN-LABEL: {{^}}getlod:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 ; GCN: image_get_lod {{v\[[0-9]+:[0-9]+\]}}, {{v[0-9]+}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}} dmask:0xf da
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
6 define amdgpu_kernel void @getlod(<4 x float> addrspace(1)* %out) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 main_body:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 %r = call <4 x float> @llvm.amdgcn.image.getlod.v4f32.f32.v8i32(float undef, <8 x i32> undef, <4 x i32> undef, i32 15, i1 0, i1 0, i1 0, i1 0, i1 1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 store <4 x float> %r, <4 x float> addrspace(1)* %out
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 ; GCN-LABEL: {{^}}getlod_v2:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 ; GCN: image_get_lod {{v\[[0-9]+:[0-9]+\]}}, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}} dmask:0xf da
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
15 define amdgpu_kernel void @getlod_v2(<4 x float> addrspace(1)* %out) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 main_body:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 %r = call <4 x float> @llvm.amdgcn.image.getlod.v4f32.v2f32.v8i32(<2 x float> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i1 0, i1 0, i1 0, i1 0, i1 1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 store <4 x float> %r, <4 x float> addrspace(1)* %out
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 ; GCN-LABEL: {{^}}getlod_v4:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 ; GCN: image_get_lod {{v\[[0-9]+:[0-9]+\]}}, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}} dmask:0xf da
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
24 define amdgpu_kernel void @getlod_v4(<4 x float> addrspace(1)* %out) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25 main_body:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 %r = call <4 x float> @llvm.amdgcn.image.getlod.v4f32.v4f32.v8i32(<4 x float> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i1 0, i1 0, i1 0, i1 0, i1 1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 store <4 x float> %r, <4 x float> addrspace(1)* %out
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
31 ; GCN-LABEL: {{^}}adjust_writemask_getlod_none_enabled:
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
32 ; GCN-NOT: image
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
33 ; GCN-NOT: store
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
34 define amdgpu_kernel void @adjust_writemask_getlod_none_enabled(float addrspace(1)* %out) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
35 main_body:
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
36 %r = call <4 x float> @llvm.amdgcn.image.getlod.v4f32.v4f32.v8i32(<4 x float> undef, <8 x i32> undef, <4 x i32> undef, i32 0, i1 false, i1 false, i1 false, i1 false, i1 false)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
37 %elt0 = extractelement <4 x float> %r, i32 0
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
38 store float %elt0, float addrspace(1)* %out
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
39 ret void
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
40 }
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 declare <4 x float> @llvm.amdgcn.image.getlod.v4f32.f32.v8i32(float, <8 x i32>, <4 x i32>, i32, i1, i1, i1, i1, i1) #0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 declare <4 x float> @llvm.amdgcn.image.getlod.v4f32.v2f32.v8i32(<2 x float>, <8 x i32>, <4 x i32>, i32, i1, i1, i1, i1, i1) #0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 declare <4 x float> @llvm.amdgcn.image.getlod.v4f32.v4f32.v8i32(<4 x float>, <8 x i32>, <4 x i32>, i32, i1, i1, i1, i1, i1) #0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 attributes #0 = { nounwind readnone }