xref: /aosp_15_r20/external/llvm/test/CodeGen/NVPTX/arithmetic-int.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=nvptx64 -mcpu=sm_20 | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker;; These tests should run for all targets
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker;;===-- Basic instruction selection tests ---------------------------------===;;
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Worker;;; i64
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Workerdefine i64 @add_i64(i64 %a, i64 %b) {
12*9880d681SAndroid Build Coastguard Worker; CHECK: add.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
13*9880d681SAndroid Build Coastguard Worker; CHECK: ret
14*9880d681SAndroid Build Coastguard Worker  %ret = add i64 %a, %b
15*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
16*9880d681SAndroid Build Coastguard Worker}
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerdefine i64 @sub_i64(i64 %a, i64 %b) {
19*9880d681SAndroid Build Coastguard Worker; CHECK: sub.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
20*9880d681SAndroid Build Coastguard Worker; CHECK: ret
21*9880d681SAndroid Build Coastguard Worker  %ret = sub i64 %a, %b
22*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
23*9880d681SAndroid Build Coastguard Worker}
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerdefine i64 @mul_i64(i64 %a, i64 %b) {
26*9880d681SAndroid Build Coastguard Worker; CHECK: mul.lo.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
27*9880d681SAndroid Build Coastguard Worker; CHECK: ret
28*9880d681SAndroid Build Coastguard Worker  %ret = mul i64 %a, %b
29*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
30*9880d681SAndroid Build Coastguard Worker}
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Workerdefine i64 @umul_lohi_i64(i64 %a) {
33*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: umul_lohi_i64(
34*9880d681SAndroid Build Coastguard Workerentry:
35*9880d681SAndroid Build Coastguard Worker  %0 = zext i64 %a to i128
36*9880d681SAndroid Build Coastguard Worker  %1 = mul i128 %0, 288
37*9880d681SAndroid Build Coastguard Worker; CHECK: mul.lo.{{u|s}}64
38*9880d681SAndroid Build Coastguard Worker; CHECK: mul.hi.{{u|s}}64
39*9880d681SAndroid Build Coastguard Worker  %2 = lshr i128 %1, 1
40*9880d681SAndroid Build Coastguard Worker  %3 = trunc i128 %2 to i64
41*9880d681SAndroid Build Coastguard Worker  ret i64 %3
42*9880d681SAndroid Build Coastguard Worker}
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Workerdefine i64 @smul_lohi_i64(i64 %a) {
45*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: smul_lohi_i64(
46*9880d681SAndroid Build Coastguard Workerentry:
47*9880d681SAndroid Build Coastguard Worker  %0 = sext i64 %a to i128
48*9880d681SAndroid Build Coastguard Worker  %1 = mul i128 %0, 288
49*9880d681SAndroid Build Coastguard Worker; CHECK: mul.lo.{{u|s}}64
50*9880d681SAndroid Build Coastguard Worker; CHECK: mul.hi.{{u|s}}64
51*9880d681SAndroid Build Coastguard Worker  %2 = ashr i128 %1, 1
52*9880d681SAndroid Build Coastguard Worker  %3 = trunc i128 %2 to i64
53*9880d681SAndroid Build Coastguard Worker  ret i64 %3
54*9880d681SAndroid Build Coastguard Worker}
55*9880d681SAndroid Build Coastguard Worker
56*9880d681SAndroid Build Coastguard Workerdefine i64 @sdiv_i64(i64 %a, i64 %b) {
57*9880d681SAndroid Build Coastguard Worker; CHECK: div.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
58*9880d681SAndroid Build Coastguard Worker; CHECK: ret
59*9880d681SAndroid Build Coastguard Worker  %ret = sdiv i64 %a, %b
60*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
61*9880d681SAndroid Build Coastguard Worker}
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Workerdefine i64 @udiv_i64(i64 %a, i64 %b) {
64*9880d681SAndroid Build Coastguard Worker; CHECK: div.u64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
65*9880d681SAndroid Build Coastguard Worker; CHECK: ret
66*9880d681SAndroid Build Coastguard Worker  %ret = udiv i64 %a, %b
67*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
68*9880d681SAndroid Build Coastguard Worker}
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Workerdefine i64 @srem_i64(i64 %a, i64 %b) {
71*9880d681SAndroid Build Coastguard Worker; CHECK: rem.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
72*9880d681SAndroid Build Coastguard Worker; CHECK: ret
73*9880d681SAndroid Build Coastguard Worker  %ret = srem i64 %a, %b
74*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
75*9880d681SAndroid Build Coastguard Worker}
76*9880d681SAndroid Build Coastguard Worker
77*9880d681SAndroid Build Coastguard Workerdefine i64 @urem_i64(i64 %a, i64 %b) {
78*9880d681SAndroid Build Coastguard Worker; CHECK: rem.u64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
79*9880d681SAndroid Build Coastguard Worker; CHECK: ret
80*9880d681SAndroid Build Coastguard Worker  %ret = urem i64 %a, %b
81*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
82*9880d681SAndroid Build Coastguard Worker}
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Workerdefine i64 @and_i64(i64 %a, i64 %b) {
85*9880d681SAndroid Build Coastguard Worker; CHECK: and.b64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
86*9880d681SAndroid Build Coastguard Worker; CHECK: ret
87*9880d681SAndroid Build Coastguard Worker  %ret = and i64 %a, %b
88*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
89*9880d681SAndroid Build Coastguard Worker}
90*9880d681SAndroid Build Coastguard Worker
91*9880d681SAndroid Build Coastguard Workerdefine i64 @or_i64(i64 %a, i64 %b) {
92*9880d681SAndroid Build Coastguard Worker; CHECK: or.b64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
93*9880d681SAndroid Build Coastguard Worker; CHECK: ret
94*9880d681SAndroid Build Coastguard Worker  %ret = or i64 %a, %b
95*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
96*9880d681SAndroid Build Coastguard Worker}
97*9880d681SAndroid Build Coastguard Worker
98*9880d681SAndroid Build Coastguard Workerdefine i64 @xor_i64(i64 %a, i64 %b) {
99*9880d681SAndroid Build Coastguard Worker; CHECK: xor.b64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %rd{{[0-9]+}}
100*9880d681SAndroid Build Coastguard Worker; CHECK: ret
101*9880d681SAndroid Build Coastguard Worker  %ret = xor i64 %a, %b
102*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
103*9880d681SAndroid Build Coastguard Worker}
104*9880d681SAndroid Build Coastguard Worker
105*9880d681SAndroid Build Coastguard Workerdefine i64 @shl_i64(i64 %a, i64 %b) {
106*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
107*9880d681SAndroid Build Coastguard Worker; CHECK: shl.b64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %r{{[0-9]+}}
108*9880d681SAndroid Build Coastguard Worker; CHECK: ret
109*9880d681SAndroid Build Coastguard Worker  %ret = shl i64 %a, %b
110*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
111*9880d681SAndroid Build Coastguard Worker}
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Workerdefine i64 @ashr_i64(i64 %a, i64 %b) {
114*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
115*9880d681SAndroid Build Coastguard Worker; CHECK: shr.s64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %r{{[0-9]+}}
116*9880d681SAndroid Build Coastguard Worker; CHECK: ret
117*9880d681SAndroid Build Coastguard Worker  %ret = ashr i64 %a, %b
118*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
119*9880d681SAndroid Build Coastguard Worker}
120*9880d681SAndroid Build Coastguard Worker
121*9880d681SAndroid Build Coastguard Workerdefine i64 @lshr_i64(i64 %a, i64 %b) {
122*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
123*9880d681SAndroid Build Coastguard Worker; CHECK: shr.u64 %rd{{[0-9]+}}, %rd{{[0-9]+}}, %r{{[0-9]+}}
124*9880d681SAndroid Build Coastguard Worker; CHECK: ret
125*9880d681SAndroid Build Coastguard Worker  %ret = lshr i64 %a, %b
126*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
127*9880d681SAndroid Build Coastguard Worker}
128*9880d681SAndroid Build Coastguard Worker
129*9880d681SAndroid Build Coastguard Worker
130*9880d681SAndroid Build Coastguard Worker;;; i32
131*9880d681SAndroid Build Coastguard Worker
132*9880d681SAndroid Build Coastguard Workerdefine i32 @add_i32(i32 %a, i32 %b) {
133*9880d681SAndroid Build Coastguard Worker; CHECK: add.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
134*9880d681SAndroid Build Coastguard Worker; CHECK: ret
135*9880d681SAndroid Build Coastguard Worker  %ret = add i32 %a, %b
136*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
137*9880d681SAndroid Build Coastguard Worker}
138*9880d681SAndroid Build Coastguard Worker
139*9880d681SAndroid Build Coastguard Workerdefine i32 @sub_i32(i32 %a, i32 %b) {
140*9880d681SAndroid Build Coastguard Worker; CHECK: sub.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
141*9880d681SAndroid Build Coastguard Worker; CHECK: ret
142*9880d681SAndroid Build Coastguard Worker  %ret = sub i32 %a, %b
143*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
144*9880d681SAndroid Build Coastguard Worker}
145*9880d681SAndroid Build Coastguard Worker
146*9880d681SAndroid Build Coastguard Workerdefine i32 @mul_i32(i32 %a, i32 %b) {
147*9880d681SAndroid Build Coastguard Worker; CHECK: mul.lo.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
148*9880d681SAndroid Build Coastguard Worker; CHECK: ret
149*9880d681SAndroid Build Coastguard Worker  %ret = mul i32 %a, %b
150*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
151*9880d681SAndroid Build Coastguard Worker}
152*9880d681SAndroid Build Coastguard Worker
153*9880d681SAndroid Build Coastguard Workerdefine i32 @sdiv_i32(i32 %a, i32 %b) {
154*9880d681SAndroid Build Coastguard Worker; CHECK: div.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
155*9880d681SAndroid Build Coastguard Worker; CHECK: ret
156*9880d681SAndroid Build Coastguard Worker  %ret = sdiv i32 %a, %b
157*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
158*9880d681SAndroid Build Coastguard Worker}
159*9880d681SAndroid Build Coastguard Worker
160*9880d681SAndroid Build Coastguard Workerdefine i32 @udiv_i32(i32 %a, i32 %b) {
161*9880d681SAndroid Build Coastguard Worker; CHECK: div.u32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
162*9880d681SAndroid Build Coastguard Worker; CHECK: ret
163*9880d681SAndroid Build Coastguard Worker  %ret = udiv i32 %a, %b
164*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
165*9880d681SAndroid Build Coastguard Worker}
166*9880d681SAndroid Build Coastguard Worker
167*9880d681SAndroid Build Coastguard Workerdefine i32 @srem_i32(i32 %a, i32 %b) {
168*9880d681SAndroid Build Coastguard Worker; CHECK: rem.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
169*9880d681SAndroid Build Coastguard Worker; CHECK: ret
170*9880d681SAndroid Build Coastguard Worker  %ret = srem i32 %a, %b
171*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
172*9880d681SAndroid Build Coastguard Worker}
173*9880d681SAndroid Build Coastguard Worker
174*9880d681SAndroid Build Coastguard Workerdefine i32 @urem_i32(i32 %a, i32 %b) {
175*9880d681SAndroid Build Coastguard Worker; CHECK: rem.u32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
176*9880d681SAndroid Build Coastguard Worker; CHECK: ret
177*9880d681SAndroid Build Coastguard Worker  %ret = urem i32 %a, %b
178*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
179*9880d681SAndroid Build Coastguard Worker}
180*9880d681SAndroid Build Coastguard Worker
181*9880d681SAndroid Build Coastguard Workerdefine i32 @and_i32(i32 %a, i32 %b) {
182*9880d681SAndroid Build Coastguard Worker; CHECK: and.b32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
183*9880d681SAndroid Build Coastguard Worker; CHECK: ret
184*9880d681SAndroid Build Coastguard Worker  %ret = and i32 %a, %b
185*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
186*9880d681SAndroid Build Coastguard Worker}
187*9880d681SAndroid Build Coastguard Worker
188*9880d681SAndroid Build Coastguard Workerdefine i32 @or_i32(i32 %a, i32 %b) {
189*9880d681SAndroid Build Coastguard Worker; CHECK: or.b32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
190*9880d681SAndroid Build Coastguard Worker; CHECK: ret
191*9880d681SAndroid Build Coastguard Worker  %ret = or i32 %a, %b
192*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
193*9880d681SAndroid Build Coastguard Worker}
194*9880d681SAndroid Build Coastguard Worker
195*9880d681SAndroid Build Coastguard Workerdefine i32 @xor_i32(i32 %a, i32 %b) {
196*9880d681SAndroid Build Coastguard Worker; CHECK: xor.b32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
197*9880d681SAndroid Build Coastguard Worker; CHECK: ret
198*9880d681SAndroid Build Coastguard Worker  %ret = xor i32 %a, %b
199*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
200*9880d681SAndroid Build Coastguard Worker}
201*9880d681SAndroid Build Coastguard Worker
202*9880d681SAndroid Build Coastguard Workerdefine i32 @shl_i32(i32 %a, i32 %b) {
203*9880d681SAndroid Build Coastguard Worker; CHECK: shl.b32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
204*9880d681SAndroid Build Coastguard Worker; CHECK: ret
205*9880d681SAndroid Build Coastguard Worker  %ret = shl i32 %a, %b
206*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
207*9880d681SAndroid Build Coastguard Worker}
208*9880d681SAndroid Build Coastguard Worker
209*9880d681SAndroid Build Coastguard Workerdefine i32 @ashr_i32(i32 %a, i32 %b) {
210*9880d681SAndroid Build Coastguard Worker; CHECK: shr.s32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
211*9880d681SAndroid Build Coastguard Worker; CHECK: ret
212*9880d681SAndroid Build Coastguard Worker  %ret = ashr i32 %a, %b
213*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
214*9880d681SAndroid Build Coastguard Worker}
215*9880d681SAndroid Build Coastguard Worker
216*9880d681SAndroid Build Coastguard Workerdefine i32 @lshr_i32(i32 %a, i32 %b) {
217*9880d681SAndroid Build Coastguard Worker; CHECK: shr.u32 %r{{[0-9]+}}, %r{{[0-9]+}}, %r{{[0-9]+}}
218*9880d681SAndroid Build Coastguard Worker; CHECK: ret
219*9880d681SAndroid Build Coastguard Worker  %ret = lshr i32 %a, %b
220*9880d681SAndroid Build Coastguard Worker  ret i32 %ret
221*9880d681SAndroid Build Coastguard Worker}
222*9880d681SAndroid Build Coastguard Worker
223*9880d681SAndroid Build Coastguard Worker;;; i16
224*9880d681SAndroid Build Coastguard Worker
225*9880d681SAndroid Build Coastguard Workerdefine i16 @add_i16(i16 %a, i16 %b) {
226*9880d681SAndroid Build Coastguard Worker; CHECK: add.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
227*9880d681SAndroid Build Coastguard Worker; CHECK: ret
228*9880d681SAndroid Build Coastguard Worker  %ret = add i16 %a, %b
229*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
230*9880d681SAndroid Build Coastguard Worker}
231*9880d681SAndroid Build Coastguard Worker
232*9880d681SAndroid Build Coastguard Workerdefine i16 @sub_i16(i16 %a, i16 %b) {
233*9880d681SAndroid Build Coastguard Worker; CHECK: sub.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
234*9880d681SAndroid Build Coastguard Worker; CHECK: ret
235*9880d681SAndroid Build Coastguard Worker  %ret = sub i16 %a, %b
236*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
237*9880d681SAndroid Build Coastguard Worker}
238*9880d681SAndroid Build Coastguard Worker
239*9880d681SAndroid Build Coastguard Workerdefine i16 @mul_i16(i16 %a, i16 %b) {
240*9880d681SAndroid Build Coastguard Worker; CHECK: mul.lo.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
241*9880d681SAndroid Build Coastguard Worker; CHECK: ret
242*9880d681SAndroid Build Coastguard Worker  %ret = mul i16 %a, %b
243*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
244*9880d681SAndroid Build Coastguard Worker}
245*9880d681SAndroid Build Coastguard Worker
246*9880d681SAndroid Build Coastguard Workerdefine i16 @sdiv_i16(i16 %a, i16 %b) {
247*9880d681SAndroid Build Coastguard Worker; CHECK: div.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
248*9880d681SAndroid Build Coastguard Worker; CHECK: ret
249*9880d681SAndroid Build Coastguard Worker  %ret = sdiv i16 %a, %b
250*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
251*9880d681SAndroid Build Coastguard Worker}
252*9880d681SAndroid Build Coastguard Worker
253*9880d681SAndroid Build Coastguard Workerdefine i16 @udiv_i16(i16 %a, i16 %b) {
254*9880d681SAndroid Build Coastguard Worker; CHECK: div.u16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
255*9880d681SAndroid Build Coastguard Worker; CHECK: ret
256*9880d681SAndroid Build Coastguard Worker  %ret = udiv i16 %a, %b
257*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
258*9880d681SAndroid Build Coastguard Worker}
259*9880d681SAndroid Build Coastguard Worker
260*9880d681SAndroid Build Coastguard Workerdefine i16 @srem_i16(i16 %a, i16 %b) {
261*9880d681SAndroid Build Coastguard Worker; CHECK: rem.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
262*9880d681SAndroid Build Coastguard Worker; CHECK: ret
263*9880d681SAndroid Build Coastguard Worker  %ret = srem i16 %a, %b
264*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
265*9880d681SAndroid Build Coastguard Worker}
266*9880d681SAndroid Build Coastguard Worker
267*9880d681SAndroid Build Coastguard Workerdefine i16 @urem_i16(i16 %a, i16 %b) {
268*9880d681SAndroid Build Coastguard Worker; CHECK: rem.u16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
269*9880d681SAndroid Build Coastguard Worker; CHECK: ret
270*9880d681SAndroid Build Coastguard Worker  %ret = urem i16 %a, %b
271*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
272*9880d681SAndroid Build Coastguard Worker}
273*9880d681SAndroid Build Coastguard Worker
274*9880d681SAndroid Build Coastguard Workerdefine i16 @and_i16(i16 %a, i16 %b) {
275*9880d681SAndroid Build Coastguard Worker; CHECK: and.b16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
276*9880d681SAndroid Build Coastguard Worker; CHECK: ret
277*9880d681SAndroid Build Coastguard Worker  %ret = and i16 %a, %b
278*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
279*9880d681SAndroid Build Coastguard Worker}
280*9880d681SAndroid Build Coastguard Worker
281*9880d681SAndroid Build Coastguard Workerdefine i16 @or_i16(i16 %a, i16 %b) {
282*9880d681SAndroid Build Coastguard Worker; CHECK: or.b16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
283*9880d681SAndroid Build Coastguard Worker; CHECK: ret
284*9880d681SAndroid Build Coastguard Worker  %ret = or i16 %a, %b
285*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
286*9880d681SAndroid Build Coastguard Worker}
287*9880d681SAndroid Build Coastguard Worker
288*9880d681SAndroid Build Coastguard Workerdefine i16 @xor_i16(i16 %a, i16 %b) {
289*9880d681SAndroid Build Coastguard Worker; CHECK: xor.b16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %rs{{[0-9]+}}
290*9880d681SAndroid Build Coastguard Worker; CHECK: ret
291*9880d681SAndroid Build Coastguard Worker  %ret = xor i16 %a, %b
292*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
293*9880d681SAndroid Build Coastguard Worker}
294*9880d681SAndroid Build Coastguard Worker
295*9880d681SAndroid Build Coastguard Workerdefine i16 @shl_i16(i16 %a, i16 %b) {
296*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
297*9880d681SAndroid Build Coastguard Worker; CHECK: shl.b16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %r{{[0-9]+}}
298*9880d681SAndroid Build Coastguard Worker; CHECK: ret
299*9880d681SAndroid Build Coastguard Worker  %ret = shl i16 %a, %b
300*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
301*9880d681SAndroid Build Coastguard Worker}
302*9880d681SAndroid Build Coastguard Worker
303*9880d681SAndroid Build Coastguard Workerdefine i16 @ashr_i16(i16 %a, i16 %b) {
304*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
305*9880d681SAndroid Build Coastguard Worker; CHECK: shr.s16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %r{{[0-9]+}}
306*9880d681SAndroid Build Coastguard Worker; CHECK: ret
307*9880d681SAndroid Build Coastguard Worker  %ret = ashr i16 %a, %b
308*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
309*9880d681SAndroid Build Coastguard Worker}
310*9880d681SAndroid Build Coastguard Worker
311*9880d681SAndroid Build Coastguard Workerdefine i16 @lshr_i16(i16 %a, i16 %b) {
312*9880d681SAndroid Build Coastguard Worker; PTX requires 32-bit shift amount
313*9880d681SAndroid Build Coastguard Worker; CHECK: shr.u16 %rs{{[0-9]+}}, %rs{{[0-9]+}}, %r{{[0-9]+}}
314*9880d681SAndroid Build Coastguard Worker; CHECK: ret
315*9880d681SAndroid Build Coastguard Worker  %ret = lshr i16 %a, %b
316*9880d681SAndroid Build Coastguard Worker  ret i16 %ret
317*9880d681SAndroid Build Coastguard Worker}
318