blob: 6d9aa5e33460eeb61982ac2bddb00f7993985a35 [file] [log] [blame]
Tom Stellard49f8bfd2015-01-06 18:00:21 +00001;RUN: llc < %s -march=amdgcn -mcpu=verde -verify-machineinstrs | FileCheck %s
Marek Olsak75170772015-01-27 17:27:15 +00002;RUN: llc < %s -march=amdgcn -mcpu=tonga -verify-machineinstrs | FileCheck %s
Marek Olsakd8ecaee2014-07-11 17:11:46 +00003
Tom Stellard79243d92014-10-01 17:15:17 +00004;CHECK-LABEL: {{^}}sample:
Tom Stellard326d6ec2014-11-05 14:50:53 +00005;CHECK: image_sample_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +00006define void @sample() #0 {
7main_body:
Marek Olsakeac50622014-07-11 17:11:52 +00008 %r = call <4 x float> @llvm.SI.image.sample.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +00009 %r0 = extractelement <4 x float> %r, i32 0
10 %r1 = extractelement <4 x float> %r, i32 1
11 %r2 = extractelement <4 x float> %r, i32 2
12 %r3 = extractelement <4 x float> %r, i32 3
13 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
14 ret void
15}
16
Tom Stellard79243d92014-10-01 17:15:17 +000017;CHECK-LABEL: {{^}}sample_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +000018;CHECK: image_sample_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000019define void @sample_cl() #0 {
20main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000021 %r = call <4 x float> @llvm.SI.image.sample.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000022 %r0 = extractelement <4 x float> %r, i32 0
23 %r1 = extractelement <4 x float> %r, i32 1
24 %r2 = extractelement <4 x float> %r, i32 2
25 %r3 = extractelement <4 x float> %r, i32 3
26 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
27 ret void
28}
29
Tom Stellard79243d92014-10-01 17:15:17 +000030;CHECK-LABEL: {{^}}sample_d:
Tom Stellard326d6ec2014-11-05 14:50:53 +000031;CHECK: image_sample_d_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000032define void @sample_d() #0 {
33main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000034 %r = call <4 x float> @llvm.SI.image.sample.d.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000035 %r0 = extractelement <4 x float> %r, i32 0
36 %r1 = extractelement <4 x float> %r, i32 1
37 %r2 = extractelement <4 x float> %r, i32 2
38 %r3 = extractelement <4 x float> %r, i32 3
39 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
40 ret void
41}
42
Tom Stellard79243d92014-10-01 17:15:17 +000043;CHECK-LABEL: {{^}}sample_d_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +000044;CHECK: image_sample_d_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000045define void @sample_d_cl() #0 {
46main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000047 %r = call <4 x float> @llvm.SI.image.sample.d.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000048 %r0 = extractelement <4 x float> %r, i32 0
49 %r1 = extractelement <4 x float> %r, i32 1
50 %r2 = extractelement <4 x float> %r, i32 2
51 %r3 = extractelement <4 x float> %r, i32 3
52 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
53 ret void
54}
55
Tom Stellard79243d92014-10-01 17:15:17 +000056;CHECK-LABEL: {{^}}sample_l:
Tom Stellard326d6ec2014-11-05 14:50:53 +000057;CHECK: image_sample_l_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000058define void @sample_l() #0 {
59main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000060 %r = call <4 x float> @llvm.SI.image.sample.l.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000061 %r0 = extractelement <4 x float> %r, i32 0
62 %r1 = extractelement <4 x float> %r, i32 1
63 %r2 = extractelement <4 x float> %r, i32 2
64 %r3 = extractelement <4 x float> %r, i32 3
65 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
66 ret void
67}
68
Tom Stellard79243d92014-10-01 17:15:17 +000069;CHECK-LABEL: {{^}}sample_b:
Tom Stellard326d6ec2014-11-05 14:50:53 +000070;CHECK: image_sample_b_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000071define void @sample_b() #0 {
72main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000073 %r = call <4 x float> @llvm.SI.image.sample.b.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000074 %r0 = extractelement <4 x float> %r, i32 0
75 %r1 = extractelement <4 x float> %r, i32 1
76 %r2 = extractelement <4 x float> %r, i32 2
77 %r3 = extractelement <4 x float> %r, i32 3
78 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
79 ret void
80}
81
Tom Stellard79243d92014-10-01 17:15:17 +000082;CHECK-LABEL: {{^}}sample_b_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +000083;CHECK: image_sample_b_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000084define void @sample_b_cl() #0 {
85main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000086 %r = call <4 x float> @llvm.SI.image.sample.b.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +000087 %r0 = extractelement <4 x float> %r, i32 0
88 %r1 = extractelement <4 x float> %r, i32 1
89 %r2 = extractelement <4 x float> %r, i32 2
90 %r3 = extractelement <4 x float> %r, i32 3
91 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
92 ret void
93}
94
Tom Stellard79243d92014-10-01 17:15:17 +000095;CHECK-LABEL: {{^}}sample_lz:
Tom Stellard326d6ec2014-11-05 14:50:53 +000096;CHECK: image_sample_lz_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +000097define void @sample_lz() #0 {
98main_body:
Marek Olsakeac50622014-07-11 17:11:52 +000099 %r = call <4 x float> @llvm.SI.image.sample.lz.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000100 %r0 = extractelement <4 x float> %r, i32 0
101 %r1 = extractelement <4 x float> %r, i32 1
102 %r2 = extractelement <4 x float> %r, i32 2
103 %r3 = extractelement <4 x float> %r, i32 3
104 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
105 ret void
106}
107
Tom Stellard79243d92014-10-01 17:15:17 +0000108;CHECK-LABEL: {{^}}sample_cd:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000109;CHECK: image_sample_cd_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000110define void @sample_cd() #0 {
111main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000112 %r = call <4 x float> @llvm.SI.image.sample.cd.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000113 %r0 = extractelement <4 x float> %r, i32 0
114 %r1 = extractelement <4 x float> %r, i32 1
115 %r2 = extractelement <4 x float> %r, i32 2
116 %r3 = extractelement <4 x float> %r, i32 3
117 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
118 ret void
119}
120
Tom Stellard79243d92014-10-01 17:15:17 +0000121;CHECK-LABEL: {{^}}sample_cd_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000122;CHECK: image_sample_cd_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000123define void @sample_cd_cl() #0 {
124main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000125 %r = call <4 x float> @llvm.SI.image.sample.cd.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000126 %r0 = extractelement <4 x float> %r, i32 0
127 %r1 = extractelement <4 x float> %r, i32 1
128 %r2 = extractelement <4 x float> %r, i32 2
129 %r3 = extractelement <4 x float> %r, i32 3
130 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
131 ret void
132}
133
Tom Stellard79243d92014-10-01 17:15:17 +0000134;CHECK-LABEL: {{^}}sample_c:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000135;CHECK: image_sample_c_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000136define void @sample_c() #0 {
137main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000138 %r = call <4 x float> @llvm.SI.image.sample.c.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000139 %r0 = extractelement <4 x float> %r, i32 0
140 %r1 = extractelement <4 x float> %r, i32 1
141 %r2 = extractelement <4 x float> %r, i32 2
142 %r3 = extractelement <4 x float> %r, i32 3
143 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
144 ret void
145}
146
Tom Stellard79243d92014-10-01 17:15:17 +0000147;CHECK-LABEL: {{^}}sample_c_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000148;CHECK: image_sample_c_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000149define void @sample_c_cl() #0 {
150main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000151 %r = call <4 x float> @llvm.SI.image.sample.c.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000152 %r0 = extractelement <4 x float> %r, i32 0
153 %r1 = extractelement <4 x float> %r, i32 1
154 %r2 = extractelement <4 x float> %r, i32 2
155 %r3 = extractelement <4 x float> %r, i32 3
156 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
157 ret void
158}
159
Tom Stellard79243d92014-10-01 17:15:17 +0000160;CHECK-LABEL: {{^}}sample_c_d:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000161;CHECK: image_sample_c_d_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000162define void @sample_c_d() #0 {
163main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000164 %r = call <4 x float> @llvm.SI.image.sample.c.d.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000165 %r0 = extractelement <4 x float> %r, i32 0
166 %r1 = extractelement <4 x float> %r, i32 1
167 %r2 = extractelement <4 x float> %r, i32 2
168 %r3 = extractelement <4 x float> %r, i32 3
169 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
170 ret void
171}
172
Tom Stellard79243d92014-10-01 17:15:17 +0000173;CHECK-LABEL: {{^}}sample_c_d_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000174;CHECK: image_sample_c_d_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000175define void @sample_c_d_cl() #0 {
176main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000177 %r = call <4 x float> @llvm.SI.image.sample.c.d.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000178 %r0 = extractelement <4 x float> %r, i32 0
179 %r1 = extractelement <4 x float> %r, i32 1
180 %r2 = extractelement <4 x float> %r, i32 2
181 %r3 = extractelement <4 x float> %r, i32 3
182 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
183 ret void
184}
185
Tom Stellard79243d92014-10-01 17:15:17 +0000186;CHECK-LABEL: {{^}}sample_c_l:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000187;CHECK: image_sample_c_l_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000188define void @sample_c_l() #0 {
189main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000190 %r = call <4 x float> @llvm.SI.image.sample.c.l.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000191 %r0 = extractelement <4 x float> %r, i32 0
192 %r1 = extractelement <4 x float> %r, i32 1
193 %r2 = extractelement <4 x float> %r, i32 2
194 %r3 = extractelement <4 x float> %r, i32 3
195 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
196 ret void
197}
198
Tom Stellard79243d92014-10-01 17:15:17 +0000199;CHECK-LABEL: {{^}}sample_c_b:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000200;CHECK: image_sample_c_b_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000201define void @sample_c_b() #0 {
202main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000203 %r = call <4 x float> @llvm.SI.image.sample.c.b.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000204 %r0 = extractelement <4 x float> %r, i32 0
205 %r1 = extractelement <4 x float> %r, i32 1
206 %r2 = extractelement <4 x float> %r, i32 2
207 %r3 = extractelement <4 x float> %r, i32 3
208 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
209 ret void
210}
211
Tom Stellard79243d92014-10-01 17:15:17 +0000212;CHECK-LABEL: {{^}}sample_c_b_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000213;CHECK: image_sample_c_b_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000214define void @sample_c_b_cl() #0 {
215main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000216 %r = call <4 x float> @llvm.SI.image.sample.c.b.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000217 %r0 = extractelement <4 x float> %r, i32 0
218 %r1 = extractelement <4 x float> %r, i32 1
219 %r2 = extractelement <4 x float> %r, i32 2
220 %r3 = extractelement <4 x float> %r, i32 3
221 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
222 ret void
223}
224
Tom Stellard79243d92014-10-01 17:15:17 +0000225;CHECK-LABEL: {{^}}sample_c_lz:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000226;CHECK: image_sample_c_lz_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000227define void @sample_c_lz() #0 {
228main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000229 %r = call <4 x float> @llvm.SI.image.sample.c.lz.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000230 %r0 = extractelement <4 x float> %r, i32 0
231 %r1 = extractelement <4 x float> %r, i32 1
232 %r2 = extractelement <4 x float> %r, i32 2
233 %r3 = extractelement <4 x float> %r, i32 3
234 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
235 ret void
236}
237
Tom Stellard79243d92014-10-01 17:15:17 +0000238;CHECK-LABEL: {{^}}sample_c_cd:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000239;CHECK: image_sample_c_cd_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000240define void @sample_c_cd() #0 {
241main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000242 %r = call <4 x float> @llvm.SI.image.sample.c.cd.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000243 %r0 = extractelement <4 x float> %r, i32 0
244 %r1 = extractelement <4 x float> %r, i32 1
245 %r2 = extractelement <4 x float> %r, i32 2
246 %r3 = extractelement <4 x float> %r, i32 3
247 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
248 ret void
249}
250
Tom Stellard79243d92014-10-01 17:15:17 +0000251;CHECK-LABEL: {{^}}sample_c_cd_cl:
Tom Stellard326d6ec2014-11-05 14:50:53 +0000252;CHECK: image_sample_c_cd_cl_o {{v\[[0-9]+:[0-9]+\]}}, 15, 0, 0, 0, 0, 0, 0, 0, {{v\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}, {{s\[[0-9]+:[0-9]+\]}}
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000253define void @sample_c_cd_cl() #0 {
254main_body:
Marek Olsakeac50622014-07-11 17:11:52 +0000255 %r = call <4 x float> @llvm.SI.image.sample.c.cd.cl.o.v4i32(<4 x i32> undef, <8 x i32> undef, <4 x i32> undef, i32 15, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0)
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000256 %r0 = extractelement <4 x float> %r, i32 0
257 %r1 = extractelement <4 x float> %r, i32 1
258 %r2 = extractelement <4 x float> %r, i32 2
259 %r3 = extractelement <4 x float> %r, i32 3
260 call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 0, i32 1, float %r0, float %r1, float %r2, float %r3)
261 ret void
262}
263
264
Marek Olsakeac50622014-07-11 17:11:52 +0000265declare <4 x float> @llvm.SI.image.sample.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
266declare <4 x float> @llvm.SI.image.sample.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
267declare <4 x float> @llvm.SI.image.sample.d.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
268declare <4 x float> @llvm.SI.image.sample.d.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
269declare <4 x float> @llvm.SI.image.sample.l.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
270declare <4 x float> @llvm.SI.image.sample.b.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
271declare <4 x float> @llvm.SI.image.sample.b.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
272declare <4 x float> @llvm.SI.image.sample.lz.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
273declare <4 x float> @llvm.SI.image.sample.cd.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
274declare <4 x float> @llvm.SI.image.sample.cd.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000275
Marek Olsakeac50622014-07-11 17:11:52 +0000276declare <4 x float> @llvm.SI.image.sample.c.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
277declare <4 x float> @llvm.SI.image.sample.c.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
278declare <4 x float> @llvm.SI.image.sample.c.d.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
279declare <4 x float> @llvm.SI.image.sample.c.d.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
280declare <4 x float> @llvm.SI.image.sample.c.l.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
281declare <4 x float> @llvm.SI.image.sample.c.b.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
282declare <4 x float> @llvm.SI.image.sample.c.b.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
283declare <4 x float> @llvm.SI.image.sample.c.lz.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
284declare <4 x float> @llvm.SI.image.sample.c.cd.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
285declare <4 x float> @llvm.SI.image.sample.c.cd.cl.o.v4i32(<4 x i32>, <8 x i32>, <4 x i32>, i32, i32, i32, i32, i32, i32, i32, i32) #1
Marek Olsakd8ecaee2014-07-11 17:11:46 +0000286
287declare void @llvm.SI.export(i32, i32, i32, i32, i32, float, float, float, float)
288
289attributes #0 = { "ShaderType"="0" }
290attributes #1 = { nounwind readnone }