xref: /aosp_15_r20/external/llvm/test/CodeGen/Mips/dsp-r1.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mipsel -mcpu=mips32 -mattr=+dsp -verify-machineinstrs < %s | \
2*9880d681SAndroid Build Coastguard Worker; RUN:     FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_w1(i32 %i0, i32, i64 %a0) nounwind {
5*9880d681SAndroid Build Coastguard Workerentry:
6*9880d681SAndroid Build Coastguard Worker; CHECK: extr.w
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.w(i64 %a0, i32 15)
9*9880d681SAndroid Build Coastguard Worker  ret i32 %1
10*9880d681SAndroid Build Coastguard Worker}
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extr.w(i64, i32) nounwind
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_w2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
15*9880d681SAndroid Build Coastguard Workerentry:
16*9880d681SAndroid Build Coastguard Worker; CHECK: extrv.w
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.w(i64 %a0, i32 %a1)
19*9880d681SAndroid Build Coastguard Worker  ret i32 %1
20*9880d681SAndroid Build Coastguard Worker}
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_r_w1(i32 %i0, i32, i64 %a0) nounwind {
23*9880d681SAndroid Build Coastguard Workerentry:
24*9880d681SAndroid Build Coastguard Worker; CHECK: extr_r.w
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.r.w(i64 %a0, i32 15)
27*9880d681SAndroid Build Coastguard Worker  ret i32 %1
28*9880d681SAndroid Build Coastguard Worker}
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extr.r.w(i64, i32) nounwind
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_s_h1(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
33*9880d681SAndroid Build Coastguard Workerentry:
34*9880d681SAndroid Build Coastguard Worker; CHECK: extrv_s.h
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.s.h(i64 %a0, i32 %a1)
37*9880d681SAndroid Build Coastguard Worker  ret i32 %1
38*9880d681SAndroid Build Coastguard Worker}
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extr.s.h(i64, i32) nounwind
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_rs_w1(i32 %i0, i32, i64 %a0) nounwind {
43*9880d681SAndroid Build Coastguard Workerentry:
44*9880d681SAndroid Build Coastguard Worker; CHECK: extr_rs.w
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.rs.w(i64 %a0, i32 15)
47*9880d681SAndroid Build Coastguard Worker  ret i32 %1
48*9880d681SAndroid Build Coastguard Worker}
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extr.rs.w(i64, i32) nounwind
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_rs_w2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
53*9880d681SAndroid Build Coastguard Workerentry:
54*9880d681SAndroid Build Coastguard Worker; CHECK: extrv_rs.w
55*9880d681SAndroid Build Coastguard Worker
56*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.rs.w(i64 %a0, i32 %a1)
57*9880d681SAndroid Build Coastguard Worker  ret i32 %1
58*9880d681SAndroid Build Coastguard Worker}
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_s_h2(i32 %i0, i32, i64 %a0) nounwind {
61*9880d681SAndroid Build Coastguard Workerentry:
62*9880d681SAndroid Build Coastguard Worker; CHECK: extr_s.h
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.s.h(i64 %a0, i32 15)
65*9880d681SAndroid Build Coastguard Worker  ret i32 %1
66*9880d681SAndroid Build Coastguard Worker}
67*9880d681SAndroid Build Coastguard Worker
68*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extr_r_w2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
69*9880d681SAndroid Build Coastguard Workerentry:
70*9880d681SAndroid Build Coastguard Worker; CHECK: extrv_r.w
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extr.r.w(i64 %a0, i32 %a1)
73*9880d681SAndroid Build Coastguard Worker  ret i32 %1
74*9880d681SAndroid Build Coastguard Worker}
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extp1(i32 %i0, i32, i64 %a0) nounwind {
77*9880d681SAndroid Build Coastguard Workerentry:
78*9880d681SAndroid Build Coastguard Worker; CHECK: extp ${{[0-9]+}}
79*9880d681SAndroid Build Coastguard Worker
80*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extp(i64 %a0, i32 15)
81*9880d681SAndroid Build Coastguard Worker  ret i32 %1
82*9880d681SAndroid Build Coastguard Worker}
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extp(i64, i32) nounwind
85*9880d681SAndroid Build Coastguard Worker
86*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extp2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
87*9880d681SAndroid Build Coastguard Workerentry:
88*9880d681SAndroid Build Coastguard Worker; CHECK: extpv
89*9880d681SAndroid Build Coastguard Worker
90*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extp(i64 %a0, i32 %a1)
91*9880d681SAndroid Build Coastguard Worker  ret i32 %1
92*9880d681SAndroid Build Coastguard Worker}
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extpdp1(i32 %i0, i32, i64 %a0) nounwind {
95*9880d681SAndroid Build Coastguard Workerentry:
96*9880d681SAndroid Build Coastguard Worker; CHECK: extpdp ${{[0-9]+}}
97*9880d681SAndroid Build Coastguard Worker
98*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extpdp(i64 %a0, i32 15)
99*9880d681SAndroid Build Coastguard Worker  ret i32 %1
100*9880d681SAndroid Build Coastguard Worker}
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.extpdp(i64, i32) nounwind
103*9880d681SAndroid Build Coastguard Worker
104*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_extpdp2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
105*9880d681SAndroid Build Coastguard Workerentry:
106*9880d681SAndroid Build Coastguard Worker; CHECK: extpdpv
107*9880d681SAndroid Build Coastguard Worker
108*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.extpdp(i64 %a0, i32 %a1)
109*9880d681SAndroid Build Coastguard Worker  ret i32 %1
110*9880d681SAndroid Build Coastguard Worker}
111*9880d681SAndroid Build Coastguard Worker
112*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpau_h_qbl1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind readnone {
113*9880d681SAndroid Build Coastguard Workerentry:
114*9880d681SAndroid Build Coastguard Worker; CHECK: dpau.h.qbl
115*9880d681SAndroid Build Coastguard Worker
116*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
117*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <4 x i8>
118*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpau.h.qbl(i64 %a0, <4 x i8> %1, <4 x i8> %2)
119*9880d681SAndroid Build Coastguard Worker  ret i64 %3
120*9880d681SAndroid Build Coastguard Worker}
121*9880d681SAndroid Build Coastguard Worker
122*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpau.h.qbl(i64, <4 x i8>, <4 x i8>) nounwind readnone
123*9880d681SAndroid Build Coastguard Worker
124*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpau_h_qbr1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind readnone {
125*9880d681SAndroid Build Coastguard Workerentry:
126*9880d681SAndroid Build Coastguard Worker; CHECK: dpau.h.qbr
127*9880d681SAndroid Build Coastguard Worker
128*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
129*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <4 x i8>
130*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpau.h.qbr(i64 %a0, <4 x i8> %1, <4 x i8> %2)
131*9880d681SAndroid Build Coastguard Worker  ret i64 %3
132*9880d681SAndroid Build Coastguard Worker}
133*9880d681SAndroid Build Coastguard Worker
134*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpau.h.qbr(i64, <4 x i8>, <4 x i8>) nounwind readnone
135*9880d681SAndroid Build Coastguard Worker
136*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpsu_h_qbl1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind readnone {
137*9880d681SAndroid Build Coastguard Workerentry:
138*9880d681SAndroid Build Coastguard Worker; CHECK: dpsu.h.qbl
139*9880d681SAndroid Build Coastguard Worker
140*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
141*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <4 x i8>
142*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpsu.h.qbl(i64 %a0, <4 x i8> %1, <4 x i8> %2)
143*9880d681SAndroid Build Coastguard Worker  ret i64 %3
144*9880d681SAndroid Build Coastguard Worker}
145*9880d681SAndroid Build Coastguard Worker
146*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpsu.h.qbl(i64, <4 x i8>, <4 x i8>) nounwind readnone
147*9880d681SAndroid Build Coastguard Worker
148*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpsu_h_qbr1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind readnone {
149*9880d681SAndroid Build Coastguard Workerentry:
150*9880d681SAndroid Build Coastguard Worker; CHECK: dpsu.h.qbr
151*9880d681SAndroid Build Coastguard Worker
152*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
153*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <4 x i8>
154*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpsu.h.qbr(i64 %a0, <4 x i8> %1, <4 x i8> %2)
155*9880d681SAndroid Build Coastguard Worker  ret i64 %3
156*9880d681SAndroid Build Coastguard Worker}
157*9880d681SAndroid Build Coastguard Worker
158*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpsu.h.qbr(i64, <4 x i8>, <4 x i8>) nounwind readnone
159*9880d681SAndroid Build Coastguard Worker
160*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpaq_s_w_ph1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
161*9880d681SAndroid Build Coastguard Workerentry:
162*9880d681SAndroid Build Coastguard Worker; CHECK: dpaq_s.w.ph
163*9880d681SAndroid Build Coastguard Worker
164*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
165*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
166*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpaq.s.w.ph(i64 %a0, <2 x i16> %1, <2 x i16> %2)
167*9880d681SAndroid Build Coastguard Worker  ret i64 %3
168*9880d681SAndroid Build Coastguard Worker}
169*9880d681SAndroid Build Coastguard Worker
170*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpaq.s.w.ph(i64, <2 x i16>, <2 x i16>) nounwind
171*9880d681SAndroid Build Coastguard Worker
172*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpaq_sa_l_w1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind {
173*9880d681SAndroid Build Coastguard Workerentry:
174*9880d681SAndroid Build Coastguard Worker; CHECK: dpaq_sa.l.w
175*9880d681SAndroid Build Coastguard Worker
176*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.dpaq.sa.l.w(i64 %a0, i32 %a1, i32 %a2)
177*9880d681SAndroid Build Coastguard Worker  ret i64 %1
178*9880d681SAndroid Build Coastguard Worker}
179*9880d681SAndroid Build Coastguard Worker
180*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpaq.sa.l.w(i64, i32, i32) nounwind
181*9880d681SAndroid Build Coastguard Worker
182*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpsq_s_w_ph1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
183*9880d681SAndroid Build Coastguard Workerentry:
184*9880d681SAndroid Build Coastguard Worker; CHECK: dpsq_s.w.ph
185*9880d681SAndroid Build Coastguard Worker
186*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
187*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
188*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.dpsq.s.w.ph(i64 %a0, <2 x i16> %1, <2 x i16> %2)
189*9880d681SAndroid Build Coastguard Worker  ret i64 %3
190*9880d681SAndroid Build Coastguard Worker}
191*9880d681SAndroid Build Coastguard Worker
192*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpsq.s.w.ph(i64, <2 x i16>, <2 x i16>) nounwind
193*9880d681SAndroid Build Coastguard Worker
194*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_dpsq_sa_l_w1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind {
195*9880d681SAndroid Build Coastguard Workerentry:
196*9880d681SAndroid Build Coastguard Worker; CHECK: dpsq_sa.l.w
197*9880d681SAndroid Build Coastguard Worker
198*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.dpsq.sa.l.w(i64 %a0, i32 %a1, i32 %a2)
199*9880d681SAndroid Build Coastguard Worker  ret i64 %1
200*9880d681SAndroid Build Coastguard Worker}
201*9880d681SAndroid Build Coastguard Worker
202*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.dpsq.sa.l.w(i64, i32, i32) nounwind
203*9880d681SAndroid Build Coastguard Worker
204*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_mulsaq_s_w_ph1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
205*9880d681SAndroid Build Coastguard Workerentry:
206*9880d681SAndroid Build Coastguard Worker; CHECK: mulsaq_s.w.ph
207*9880d681SAndroid Build Coastguard Worker
208*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
209*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
210*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.mulsaq.s.w.ph(i64 %a0, <2 x i16> %1, <2 x i16> %2)
211*9880d681SAndroid Build Coastguard Worker  ret i64 %3
212*9880d681SAndroid Build Coastguard Worker}
213*9880d681SAndroid Build Coastguard Worker
214*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.mulsaq.s.w.ph(i64, <2 x i16>, <2 x i16>) nounwind
215*9880d681SAndroid Build Coastguard Worker
216*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_maq_s_w_phl1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
217*9880d681SAndroid Build Coastguard Workerentry:
218*9880d681SAndroid Build Coastguard Worker; CHECK: maq_s.w.phl
219*9880d681SAndroid Build Coastguard Worker
220*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
221*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
222*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.maq.s.w.phl(i64 %a0, <2 x i16> %1, <2 x i16> %2)
223*9880d681SAndroid Build Coastguard Worker  ret i64 %3
224*9880d681SAndroid Build Coastguard Worker}
225*9880d681SAndroid Build Coastguard Worker
226*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.maq.s.w.phl(i64, <2 x i16>, <2 x i16>) nounwind
227*9880d681SAndroid Build Coastguard Worker
228*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_maq_s_w_phr1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
229*9880d681SAndroid Build Coastguard Workerentry:
230*9880d681SAndroid Build Coastguard Worker; CHECK: maq_s.w.phr
231*9880d681SAndroid Build Coastguard Worker
232*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
233*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
234*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.maq.s.w.phr(i64 %a0, <2 x i16> %1, <2 x i16> %2)
235*9880d681SAndroid Build Coastguard Worker  ret i64 %3
236*9880d681SAndroid Build Coastguard Worker}
237*9880d681SAndroid Build Coastguard Worker
238*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.maq.s.w.phr(i64, <2 x i16>, <2 x i16>) nounwind
239*9880d681SAndroid Build Coastguard Worker
240*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_maq_sa_w_phl1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
241*9880d681SAndroid Build Coastguard Workerentry:
242*9880d681SAndroid Build Coastguard Worker; CHECK: maq_sa.w.phl
243*9880d681SAndroid Build Coastguard Worker
244*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
245*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
246*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.maq.sa.w.phl(i64 %a0, <2 x i16> %1, <2 x i16> %2)
247*9880d681SAndroid Build Coastguard Worker  ret i64 %3
248*9880d681SAndroid Build Coastguard Worker}
249*9880d681SAndroid Build Coastguard Worker
250*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.maq.sa.w.phl(i64, <2 x i16>, <2 x i16>) nounwind
251*9880d681SAndroid Build Coastguard Worker
252*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_maq_sa_w_phr1(i32 %i0, i32, i64 %a0, i32 %a1.coerce, i32 %a2.coerce) nounwind {
253*9880d681SAndroid Build Coastguard Workerentry:
254*9880d681SAndroid Build Coastguard Worker; CHECK: maq_sa.w.phr
255*9880d681SAndroid Build Coastguard Worker
256*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
257*9880d681SAndroid Build Coastguard Worker  %2 = bitcast i32 %a2.coerce to <2 x i16>
258*9880d681SAndroid Build Coastguard Worker  %3 = tail call i64 @llvm.mips.maq.sa.w.phr(i64 %a0, <2 x i16> %1, <2 x i16> %2)
259*9880d681SAndroid Build Coastguard Worker  ret i64 %3
260*9880d681SAndroid Build Coastguard Worker}
261*9880d681SAndroid Build Coastguard Worker
262*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.maq.sa.w.phr(i64, <2 x i16>, <2 x i16>) nounwind
263*9880d681SAndroid Build Coastguard Worker
264*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_shilo1(i32 %i0, i32, i64 %a0) nounwind readnone {
265*9880d681SAndroid Build Coastguard Workerentry:
266*9880d681SAndroid Build Coastguard Worker; CHECK: shilo $ac{{[0-9]}}
267*9880d681SAndroid Build Coastguard Worker
268*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.shilo(i64 %a0, i32 0)
269*9880d681SAndroid Build Coastguard Worker  ret i64 %1
270*9880d681SAndroid Build Coastguard Worker}
271*9880d681SAndroid Build Coastguard Worker
272*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.shilo(i64, i32) nounwind readnone
273*9880d681SAndroid Build Coastguard Worker
274*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_shilo2(i32 %i0, i32, i64 %a0, i32 %a1) nounwind readnone {
275*9880d681SAndroid Build Coastguard Workerentry:
276*9880d681SAndroid Build Coastguard Worker; CHECK: shilov
277*9880d681SAndroid Build Coastguard Worker
278*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.shilo(i64 %a0, i32 %a1)
279*9880d681SAndroid Build Coastguard Worker  ret i64 %1
280*9880d681SAndroid Build Coastguard Worker}
281*9880d681SAndroid Build Coastguard Worker
282*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_mthlip1(i32 %i0, i32, i64 %a0, i32 %a1) nounwind {
283*9880d681SAndroid Build Coastguard Workerentry:
284*9880d681SAndroid Build Coastguard Worker; CHECK: mthlip ${{[0-9]+}}
285*9880d681SAndroid Build Coastguard Worker
286*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.mthlip(i64 %a0, i32 %a1)
287*9880d681SAndroid Build Coastguard Worker  ret i64 %1
288*9880d681SAndroid Build Coastguard Worker}
289*9880d681SAndroid Build Coastguard Worker
290*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.mthlip(i64, i32) nounwind
291*9880d681SAndroid Build Coastguard Worker
292*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_bposge321(i32 %i0) nounwind readonly {
293*9880d681SAndroid Build Coastguard Workerentry:
294*9880d681SAndroid Build Coastguard Worker; CHECK: bposge32 $BB{{[0-9]+}}
295*9880d681SAndroid Build Coastguard Worker
296*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.bposge32()
297*9880d681SAndroid Build Coastguard Worker  ret i32 %0
298*9880d681SAndroid Build Coastguard Worker}
299*9880d681SAndroid Build Coastguard Worker
300*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.bposge32() nounwind readonly
301*9880d681SAndroid Build Coastguard Worker
302*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_madd1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind readnone {
303*9880d681SAndroid Build Coastguard Workerentry:
304*9880d681SAndroid Build Coastguard Worker; CHECK: madd $ac{{[0-9]}}
305*9880d681SAndroid Build Coastguard Worker
306*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.madd(i64 %a0, i32 %a1, i32 %a2)
307*9880d681SAndroid Build Coastguard Worker  ret i64 %1
308*9880d681SAndroid Build Coastguard Worker}
309*9880d681SAndroid Build Coastguard Worker
310*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.madd(i64, i32, i32) nounwind readnone
311*9880d681SAndroid Build Coastguard Worker
312*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_maddu1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind readnone {
313*9880d681SAndroid Build Coastguard Workerentry:
314*9880d681SAndroid Build Coastguard Worker; CHECK: maddu $ac{{[0-9]}}
315*9880d681SAndroid Build Coastguard Worker
316*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.maddu(i64 %a0, i32 %a1, i32 %a2)
317*9880d681SAndroid Build Coastguard Worker  ret i64 %1
318*9880d681SAndroid Build Coastguard Worker}
319*9880d681SAndroid Build Coastguard Worker
320*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.maddu(i64, i32, i32) nounwind readnone
321*9880d681SAndroid Build Coastguard Worker
322*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_msub1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind readnone {
323*9880d681SAndroid Build Coastguard Workerentry:
324*9880d681SAndroid Build Coastguard Worker; CHECK: msub $ac{{[0-9]}}
325*9880d681SAndroid Build Coastguard Worker
326*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.msub(i64 %a0, i32 %a1, i32 %a2)
327*9880d681SAndroid Build Coastguard Worker  ret i64 %1
328*9880d681SAndroid Build Coastguard Worker}
329*9880d681SAndroid Build Coastguard Worker
330*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.msub(i64, i32, i32) nounwind readnone
331*9880d681SAndroid Build Coastguard Worker
332*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_msubu1(i32 %i0, i32, i64 %a0, i32 %a1, i32 %a2) nounwind readnone {
333*9880d681SAndroid Build Coastguard Workerentry:
334*9880d681SAndroid Build Coastguard Worker; CHECK: msubu $ac{{[0-9]}}
335*9880d681SAndroid Build Coastguard Worker
336*9880d681SAndroid Build Coastguard Worker  %1 = tail call i64 @llvm.mips.msubu(i64 %a0, i32 %a1, i32 %a2)
337*9880d681SAndroid Build Coastguard Worker  ret i64 %1
338*9880d681SAndroid Build Coastguard Worker}
339*9880d681SAndroid Build Coastguard Worker
340*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.msubu(i64, i32, i32) nounwind readnone
341*9880d681SAndroid Build Coastguard Worker
342*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_mult1(i32 %i0, i32 %a0, i32 %a1) nounwind readnone {
343*9880d681SAndroid Build Coastguard Workerentry:
344*9880d681SAndroid Build Coastguard Worker; CHECK: mult $ac{{[0-9]}}
345*9880d681SAndroid Build Coastguard Worker
346*9880d681SAndroid Build Coastguard Worker  %0 = tail call i64 @llvm.mips.mult(i32 %a0, i32 %a1)
347*9880d681SAndroid Build Coastguard Worker  ret i64 %0
348*9880d681SAndroid Build Coastguard Worker}
349*9880d681SAndroid Build Coastguard Worker
350*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.mult(i32, i32) nounwind readnone
351*9880d681SAndroid Build Coastguard Worker
352*9880d681SAndroid Build Coastguard Workerdefine i64 @test__builtin_mips_multu1(i32 %i0, i32 %a0, i32 %a1) nounwind readnone {
353*9880d681SAndroid Build Coastguard Workerentry:
354*9880d681SAndroid Build Coastguard Worker; CHECK: multu $ac{{[0-9]}}
355*9880d681SAndroid Build Coastguard Worker
356*9880d681SAndroid Build Coastguard Worker  %0 = tail call i64 @llvm.mips.multu(i32 %a0, i32 %a1)
357*9880d681SAndroid Build Coastguard Worker  ret i64 %0
358*9880d681SAndroid Build Coastguard Worker}
359*9880d681SAndroid Build Coastguard Worker
360*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.mips.multu(i32, i32) nounwind readnone
361*9880d681SAndroid Build Coastguard Worker
362*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_addq_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
363*9880d681SAndroid Build Coastguard Workerentry:
364*9880d681SAndroid Build Coastguard Worker; CHECK: addq.ph
365*9880d681SAndroid Build Coastguard Worker
366*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
367*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
368*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.addq.ph(<2 x i16> %0, <2 x i16> %1)
369*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
370*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
371*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
372*9880d681SAndroid Build Coastguard Worker}
373*9880d681SAndroid Build Coastguard Worker
374*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.addq.ph(<2 x i16>, <2 x i16>) nounwind
375*9880d681SAndroid Build Coastguard Worker
376*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_addq_s_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
377*9880d681SAndroid Build Coastguard Workerentry:
378*9880d681SAndroid Build Coastguard Worker; CHECK: addq_s.ph
379*9880d681SAndroid Build Coastguard Worker
380*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
381*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
382*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.addq.s.ph(<2 x i16> %0, <2 x i16> %1)
383*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
384*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
385*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
386*9880d681SAndroid Build Coastguard Worker}
387*9880d681SAndroid Build Coastguard Worker
388*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.addq.s.ph(<2 x i16>, <2 x i16>) nounwind
389*9880d681SAndroid Build Coastguard Worker
390*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_addq_s_w1(i32 %i0, i32 %a0, i32 %a1) nounwind {
391*9880d681SAndroid Build Coastguard Workerentry:
392*9880d681SAndroid Build Coastguard Worker; CHECK: addq_s.w
393*9880d681SAndroid Build Coastguard Worker
394*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.addq.s.w(i32 %a0, i32 %a1)
395*9880d681SAndroid Build Coastguard Worker  ret i32 %0
396*9880d681SAndroid Build Coastguard Worker}
397*9880d681SAndroid Build Coastguard Worker
398*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.addq.s.w(i32, i32) nounwind
399*9880d681SAndroid Build Coastguard Worker
400*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_addu_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
401*9880d681SAndroid Build Coastguard Workerentry:
402*9880d681SAndroid Build Coastguard Worker; CHECK: addu.qb
403*9880d681SAndroid Build Coastguard Worker
404*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
405*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
406*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.addu.qb(<4 x i8> %0, <4 x i8> %1)
407*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
408*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
409*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
410*9880d681SAndroid Build Coastguard Worker}
411*9880d681SAndroid Build Coastguard Worker
412*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.addu.qb(<4 x i8>, <4 x i8>) nounwind
413*9880d681SAndroid Build Coastguard Worker
414*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_addu_s_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
415*9880d681SAndroid Build Coastguard Workerentry:
416*9880d681SAndroid Build Coastguard Worker; CHECK: addu_s.qb
417*9880d681SAndroid Build Coastguard Worker
418*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
419*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
420*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.addu.s.qb(<4 x i8> %0, <4 x i8> %1)
421*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
422*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
423*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
424*9880d681SAndroid Build Coastguard Worker}
425*9880d681SAndroid Build Coastguard Worker
426*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.addu.s.qb(<4 x i8>, <4 x i8>) nounwind
427*9880d681SAndroid Build Coastguard Worker
428*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_subq_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
429*9880d681SAndroid Build Coastguard Workerentry:
430*9880d681SAndroid Build Coastguard Worker; CHECK: subq.ph
431*9880d681SAndroid Build Coastguard Worker
432*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
433*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
434*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.subq.ph(<2 x i16> %0, <2 x i16> %1)
435*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
436*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
437*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
438*9880d681SAndroid Build Coastguard Worker}
439*9880d681SAndroid Build Coastguard Worker
440*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.subq.ph(<2 x i16>, <2 x i16>) nounwind
441*9880d681SAndroid Build Coastguard Worker
442*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_subq_s_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
443*9880d681SAndroid Build Coastguard Workerentry:
444*9880d681SAndroid Build Coastguard Worker; CHECK: subq_s.ph
445*9880d681SAndroid Build Coastguard Worker
446*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
447*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
448*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.subq.s.ph(<2 x i16> %0, <2 x i16> %1)
449*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
450*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
451*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
452*9880d681SAndroid Build Coastguard Worker}
453*9880d681SAndroid Build Coastguard Worker
454*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.subq.s.ph(<2 x i16>, <2 x i16>) nounwind
455*9880d681SAndroid Build Coastguard Worker
456*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_subq_s_w1(i32 %i0, i32 %a0, i32 %a1) nounwind {
457*9880d681SAndroid Build Coastguard Workerentry:
458*9880d681SAndroid Build Coastguard Worker; CHECK: subq_s.w
459*9880d681SAndroid Build Coastguard Worker
460*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.subq.s.w(i32 %a0, i32 %a1)
461*9880d681SAndroid Build Coastguard Worker  ret i32 %0
462*9880d681SAndroid Build Coastguard Worker}
463*9880d681SAndroid Build Coastguard Worker
464*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.subq.s.w(i32, i32) nounwind
465*9880d681SAndroid Build Coastguard Worker
466*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_subu_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
467*9880d681SAndroid Build Coastguard Workerentry:
468*9880d681SAndroid Build Coastguard Worker; CHECK: subu.qb
469*9880d681SAndroid Build Coastguard Worker
470*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
471*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
472*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.subu.qb(<4 x i8> %0, <4 x i8> %1)
473*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
474*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
475*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
476*9880d681SAndroid Build Coastguard Worker}
477*9880d681SAndroid Build Coastguard Worker
478*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.subu.qb(<4 x i8>, <4 x i8>) nounwind
479*9880d681SAndroid Build Coastguard Worker
480*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_subu_s_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
481*9880d681SAndroid Build Coastguard Workerentry:
482*9880d681SAndroid Build Coastguard Worker; CHECK: subu_s.qb
483*9880d681SAndroid Build Coastguard Worker
484*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
485*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
486*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.subu.s.qb(<4 x i8> %0, <4 x i8> %1)
487*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
488*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
489*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
490*9880d681SAndroid Build Coastguard Worker}
491*9880d681SAndroid Build Coastguard Worker
492*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.subu.s.qb(<4 x i8>, <4 x i8>) nounwind
493*9880d681SAndroid Build Coastguard Worker
494*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_addsc1(i32 %i0, i32 %a0, i32 %a1) nounwind {
495*9880d681SAndroid Build Coastguard Workerentry:
496*9880d681SAndroid Build Coastguard Worker; CHECK: addsc ${{[0-9]+}}
497*9880d681SAndroid Build Coastguard Worker
498*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.addsc(i32 %a0, i32 %a1)
499*9880d681SAndroid Build Coastguard Worker  ret i32 %0
500*9880d681SAndroid Build Coastguard Worker}
501*9880d681SAndroid Build Coastguard Worker
502*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.addsc(i32, i32) nounwind
503*9880d681SAndroid Build Coastguard Worker
504*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_addwc1(i32 %i0, i32 %a0, i32 %a1) nounwind {
505*9880d681SAndroid Build Coastguard Workerentry:
506*9880d681SAndroid Build Coastguard Worker; CHECK: addwc ${{[0-9]+}}
507*9880d681SAndroid Build Coastguard Worker
508*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.addwc(i32 %a0, i32 %a1)
509*9880d681SAndroid Build Coastguard Worker  ret i32 %0
510*9880d681SAndroid Build Coastguard Worker}
511*9880d681SAndroid Build Coastguard Worker
512*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.addwc(i32, i32) nounwind
513*9880d681SAndroid Build Coastguard Worker
514*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_modsub1(i32 %i0, i32 %a0, i32 %a1) nounwind readnone {
515*9880d681SAndroid Build Coastguard Workerentry:
516*9880d681SAndroid Build Coastguard Worker; CHECK: modsub ${{[0-9]+}}
517*9880d681SAndroid Build Coastguard Worker
518*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.modsub(i32 %a0, i32 %a1)
519*9880d681SAndroid Build Coastguard Worker  ret i32 %0
520*9880d681SAndroid Build Coastguard Worker}
521*9880d681SAndroid Build Coastguard Worker
522*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.modsub(i32, i32) nounwind readnone
523*9880d681SAndroid Build Coastguard Worker
524*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_raddu_w_qb1(i32 %i0, i32 %a0.coerce) nounwind readnone {
525*9880d681SAndroid Build Coastguard Workerentry:
526*9880d681SAndroid Build Coastguard Worker; CHECK: raddu.w.qb
527*9880d681SAndroid Build Coastguard Worker
528*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
529*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.raddu.w.qb(<4 x i8> %0)
530*9880d681SAndroid Build Coastguard Worker  ret i32 %1
531*9880d681SAndroid Build Coastguard Worker}
532*9880d681SAndroid Build Coastguard Worker
533*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.raddu.w.qb(<4 x i8>) nounwind readnone
534*9880d681SAndroid Build Coastguard Worker
535*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_muleu_s_ph_qbl1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
536*9880d681SAndroid Build Coastguard Workerentry:
537*9880d681SAndroid Build Coastguard Worker; CHECK: muleu_s.ph.qbl
538*9880d681SAndroid Build Coastguard Worker
539*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
540*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
541*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.muleu.s.ph.qbl(<4 x i8> %0, <2 x i16> %1)
542*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
543*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
544*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
545*9880d681SAndroid Build Coastguard Worker}
546*9880d681SAndroid Build Coastguard Worker
547*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.muleu.s.ph.qbl(<4 x i8>, <2 x i16>) nounwind
548*9880d681SAndroid Build Coastguard Worker
549*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_muleu_s_ph_qbr1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
550*9880d681SAndroid Build Coastguard Workerentry:
551*9880d681SAndroid Build Coastguard Worker; CHECK: muleu_s.ph.qbr
552*9880d681SAndroid Build Coastguard Worker
553*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
554*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
555*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.muleu.s.ph.qbr(<4 x i8> %0, <2 x i16> %1)
556*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
557*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
558*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
559*9880d681SAndroid Build Coastguard Worker}
560*9880d681SAndroid Build Coastguard Worker
561*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.muleu.s.ph.qbr(<4 x i8>, <2 x i16>) nounwind
562*9880d681SAndroid Build Coastguard Worker
563*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_mulq_rs_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
564*9880d681SAndroid Build Coastguard Workerentry:
565*9880d681SAndroid Build Coastguard Worker; CHECK: mulq_rs.ph
566*9880d681SAndroid Build Coastguard Worker
567*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
568*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
569*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.mulq.rs.ph(<2 x i16> %0, <2 x i16> %1)
570*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
571*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
572*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
573*9880d681SAndroid Build Coastguard Worker}
574*9880d681SAndroid Build Coastguard Worker
575*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.mulq.rs.ph(<2 x i16>, <2 x i16>) nounwind
576*9880d681SAndroid Build Coastguard Worker
577*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_muleq_s_w_phl1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
578*9880d681SAndroid Build Coastguard Workerentry:
579*9880d681SAndroid Build Coastguard Worker; CHECK: muleq_s.w.phl
580*9880d681SAndroid Build Coastguard Worker
581*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
582*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
583*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.muleq.s.w.phl(<2 x i16> %0, <2 x i16> %1)
584*9880d681SAndroid Build Coastguard Worker  ret i32 %2
585*9880d681SAndroid Build Coastguard Worker}
586*9880d681SAndroid Build Coastguard Worker
587*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.muleq.s.w.phl(<2 x i16>, <2 x i16>) nounwind
588*9880d681SAndroid Build Coastguard Worker
589*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_muleq_s_w_phr1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
590*9880d681SAndroid Build Coastguard Workerentry:
591*9880d681SAndroid Build Coastguard Worker; CHECK: muleq_s.w.phr
592*9880d681SAndroid Build Coastguard Worker
593*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
594*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
595*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.muleq.s.w.phr(<2 x i16> %0, <2 x i16> %1)
596*9880d681SAndroid Build Coastguard Worker  ret i32 %2
597*9880d681SAndroid Build Coastguard Worker}
598*9880d681SAndroid Build Coastguard Worker
599*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.muleq.s.w.phr(<2 x i16>, <2 x i16>) nounwind
600*9880d681SAndroid Build Coastguard Worker
601*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precrq_qb_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind readnone {
602*9880d681SAndroid Build Coastguard Workerentry:
603*9880d681SAndroid Build Coastguard Worker; CHECK: precrq.qb.ph
604*9880d681SAndroid Build Coastguard Worker
605*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
606*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
607*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.precrq.qb.ph(<2 x i16> %0, <2 x i16> %1)
608*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
609*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
610*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
611*9880d681SAndroid Build Coastguard Worker}
612*9880d681SAndroid Build Coastguard Worker
613*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.precrq.qb.ph(<2 x i16>, <2 x i16>) nounwind readnone
614*9880d681SAndroid Build Coastguard Worker
615*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precrq_ph_w1(i32 %i0, i32 %a0, i32 %a1) nounwind readnone {
616*9880d681SAndroid Build Coastguard Workerentry:
617*9880d681SAndroid Build Coastguard Worker; CHECK: precrq.ph.w
618*9880d681SAndroid Build Coastguard Worker
619*9880d681SAndroid Build Coastguard Worker  %0 = tail call <2 x i16> @llvm.mips.precrq.ph.w(i32 %a0, i32 %a1)
620*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <2 x i16> %0 to i32
621*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
622*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
623*9880d681SAndroid Build Coastguard Worker}
624*9880d681SAndroid Build Coastguard Worker
625*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precrq.ph.w(i32, i32) nounwind readnone
626*9880d681SAndroid Build Coastguard Worker
627*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precrq_rs_ph_w1(i32 %i0, i32 %a0, i32 %a1) nounwind {
628*9880d681SAndroid Build Coastguard Workerentry:
629*9880d681SAndroid Build Coastguard Worker; CHECK: precrq_rs.ph.w
630*9880d681SAndroid Build Coastguard Worker
631*9880d681SAndroid Build Coastguard Worker  %0 = tail call <2 x i16> @llvm.mips.precrq.rs.ph.w(i32 %a0, i32 %a1)
632*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <2 x i16> %0 to i32
633*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
634*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
635*9880d681SAndroid Build Coastguard Worker}
636*9880d681SAndroid Build Coastguard Worker
637*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precrq.rs.ph.w(i32, i32) nounwind
638*9880d681SAndroid Build Coastguard Worker
639*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precrqu_s_qb_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
640*9880d681SAndroid Build Coastguard Workerentry:
641*9880d681SAndroid Build Coastguard Worker; CHECK: precrqu_s.qb.ph
642*9880d681SAndroid Build Coastguard Worker
643*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
644*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
645*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.precrqu.s.qb.ph(<2 x i16> %0, <2 x i16> %1)
646*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
647*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
648*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
649*9880d681SAndroid Build Coastguard Worker}
650*9880d681SAndroid Build Coastguard Worker
651*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.precrqu.s.qb.ph(<2 x i16>, <2 x i16>) nounwind
652*9880d681SAndroid Build Coastguard Worker
653*9880d681SAndroid Build Coastguard Worker
654*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpu_eq_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
655*9880d681SAndroid Build Coastguard Workerentry:
656*9880d681SAndroid Build Coastguard Worker; CHECK: cmpu.eq.qb
657*9880d681SAndroid Build Coastguard Worker
658*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
659*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
660*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmpu.eq.qb(<4 x i8> %0, <4 x i8> %1)
661*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
662*9880d681SAndroid Build Coastguard Worker  ret i32 %2
663*9880d681SAndroid Build Coastguard Worker}
664*9880d681SAndroid Build Coastguard Worker
665*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmpu.eq.qb(<4 x i8>, <4 x i8>) nounwind
666*9880d681SAndroid Build Coastguard Worker
667*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.rddsp(i32) nounwind readonly
668*9880d681SAndroid Build Coastguard Worker
669*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpu_lt_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
670*9880d681SAndroid Build Coastguard Workerentry:
671*9880d681SAndroid Build Coastguard Worker; CHECK: cmpu.lt.qb
672*9880d681SAndroid Build Coastguard Worker
673*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
674*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
675*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmpu.lt.qb(<4 x i8> %0, <4 x i8> %1)
676*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
677*9880d681SAndroid Build Coastguard Worker  ret i32 %2
678*9880d681SAndroid Build Coastguard Worker}
679*9880d681SAndroid Build Coastguard Worker
680*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmpu.lt.qb(<4 x i8>, <4 x i8>) nounwind
681*9880d681SAndroid Build Coastguard Worker
682*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpu_le_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
683*9880d681SAndroid Build Coastguard Workerentry:
684*9880d681SAndroid Build Coastguard Worker; CHECK: cmpu.le.qb
685*9880d681SAndroid Build Coastguard Worker
686*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
687*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
688*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmpu.le.qb(<4 x i8> %0, <4 x i8> %1)
689*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
690*9880d681SAndroid Build Coastguard Worker  ret i32 %2
691*9880d681SAndroid Build Coastguard Worker}
692*9880d681SAndroid Build Coastguard Worker
693*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmpu.le.qb(<4 x i8>, <4 x i8>) nounwind
694*9880d681SAndroid Build Coastguard Worker
695*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpgu_eq_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
696*9880d681SAndroid Build Coastguard Workerentry:
697*9880d681SAndroid Build Coastguard Worker; CHECK: cmpgu.eq.qb
698*9880d681SAndroid Build Coastguard Worker
699*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
700*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
701*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.cmpgu.eq.qb(<4 x i8> %0, <4 x i8> %1)
702*9880d681SAndroid Build Coastguard Worker  ret i32 %2
703*9880d681SAndroid Build Coastguard Worker}
704*9880d681SAndroid Build Coastguard Worker
705*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.cmpgu.eq.qb(<4 x i8>, <4 x i8>) nounwind
706*9880d681SAndroid Build Coastguard Worker
707*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpgu_lt_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
708*9880d681SAndroid Build Coastguard Workerentry:
709*9880d681SAndroid Build Coastguard Worker; CHECK: cmpgu.lt.qb
710*9880d681SAndroid Build Coastguard Worker
711*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
712*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
713*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.cmpgu.lt.qb(<4 x i8> %0, <4 x i8> %1)
714*9880d681SAndroid Build Coastguard Worker  ret i32 %2
715*9880d681SAndroid Build Coastguard Worker}
716*9880d681SAndroid Build Coastguard Worker
717*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.cmpgu.lt.qb(<4 x i8>, <4 x i8>) nounwind
718*9880d681SAndroid Build Coastguard Worker
719*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmpgu_le_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
720*9880d681SAndroid Build Coastguard Workerentry:
721*9880d681SAndroid Build Coastguard Worker; CHECK: cmpgu.le.qb
722*9880d681SAndroid Build Coastguard Worker
723*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
724*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
725*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.cmpgu.le.qb(<4 x i8> %0, <4 x i8> %1)
726*9880d681SAndroid Build Coastguard Worker  ret i32 %2
727*9880d681SAndroid Build Coastguard Worker}
728*9880d681SAndroid Build Coastguard Worker
729*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.cmpgu.le.qb(<4 x i8>, <4 x i8>) nounwind
730*9880d681SAndroid Build Coastguard Worker
731*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmp_eq_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
732*9880d681SAndroid Build Coastguard Workerentry:
733*9880d681SAndroid Build Coastguard Worker; CHECK: cmp.eq.ph
734*9880d681SAndroid Build Coastguard Worker
735*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
736*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
737*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmp.eq.ph(<2 x i16> %0, <2 x i16> %1)
738*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
739*9880d681SAndroid Build Coastguard Worker  ret i32 %2
740*9880d681SAndroid Build Coastguard Worker}
741*9880d681SAndroid Build Coastguard Worker
742*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmp.eq.ph(<2 x i16>, <2 x i16>) nounwind
743*9880d681SAndroid Build Coastguard Worker
744*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmp_lt_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
745*9880d681SAndroid Build Coastguard Workerentry:
746*9880d681SAndroid Build Coastguard Worker; CHECK: cmp.lt.ph
747*9880d681SAndroid Build Coastguard Worker
748*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
749*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
750*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmp.lt.ph(<2 x i16> %0, <2 x i16> %1)
751*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
752*9880d681SAndroid Build Coastguard Worker  ret i32 %2
753*9880d681SAndroid Build Coastguard Worker}
754*9880d681SAndroid Build Coastguard Worker
755*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmp.lt.ph(<2 x i16>, <2 x i16>) nounwind
756*9880d681SAndroid Build Coastguard Worker
757*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_cmp_le_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind {
758*9880d681SAndroid Build Coastguard Workerentry:
759*9880d681SAndroid Build Coastguard Worker; CHECK: cmp.le.ph
760*9880d681SAndroid Build Coastguard Worker
761*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
762*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
763*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.cmp.le.ph(<2 x i16> %0, <2 x i16> %1)
764*9880d681SAndroid Build Coastguard Worker  %2 = tail call i32 @llvm.mips.rddsp(i32 31)
765*9880d681SAndroid Build Coastguard Worker  ret i32 %2
766*9880d681SAndroid Build Coastguard Worker}
767*9880d681SAndroid Build Coastguard Worker
768*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.cmp.le.ph(<2 x i16>, <2 x i16>) nounwind
769*9880d681SAndroid Build Coastguard Worker
770*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_pick_qb1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind readonly {
771*9880d681SAndroid Build Coastguard Workerentry:
772*9880d681SAndroid Build Coastguard Worker; CHECK: pick.qb
773*9880d681SAndroid Build Coastguard Worker
774*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
775*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <4 x i8>
776*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.wrdsp(i32 %i0, i32 16)
777*9880d681SAndroid Build Coastguard Worker  %2 = tail call <4 x i8> @llvm.mips.pick.qb(<4 x i8> %0, <4 x i8> %1)
778*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <4 x i8> %2 to i32
779*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
780*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
781*9880d681SAndroid Build Coastguard Worker}
782*9880d681SAndroid Build Coastguard Worker
783*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.pick.qb(<4 x i8>, <4 x i8>) nounwind readonly
784*9880d681SAndroid Build Coastguard Worker
785*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_pick_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind readonly {
786*9880d681SAndroid Build Coastguard Workerentry:
787*9880d681SAndroid Build Coastguard Worker; CHECK: pick.ph
788*9880d681SAndroid Build Coastguard Worker
789*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
790*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
791*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.wrdsp(i32 %i0, i32 16)
792*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.pick.ph(<2 x i16> %0, <2 x i16> %1)
793*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
794*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
795*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
796*9880d681SAndroid Build Coastguard Worker}
797*9880d681SAndroid Build Coastguard Worker
798*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.pick.ph(<2 x i16>, <2 x i16>) nounwind readonly
799*9880d681SAndroid Build Coastguard Worker
800*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_packrl_ph1(i32 %i0, i32 %a0.coerce, i32 %a1.coerce) nounwind readnone {
801*9880d681SAndroid Build Coastguard Workerentry:
802*9880d681SAndroid Build Coastguard Worker; CHECK: packrl.ph
803*9880d681SAndroid Build Coastguard Worker
804*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
805*9880d681SAndroid Build Coastguard Worker  %1 = bitcast i32 %a1.coerce to <2 x i16>
806*9880d681SAndroid Build Coastguard Worker  %2 = tail call <2 x i16> @llvm.mips.packrl.ph(<2 x i16> %0, <2 x i16> %1)
807*9880d681SAndroid Build Coastguard Worker  %3 = bitcast <2 x i16> %2 to i32
808*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %3, 0
809*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
810*9880d681SAndroid Build Coastguard Worker}
811*9880d681SAndroid Build Coastguard Worker
812*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.packrl.ph(<2 x i16>, <2 x i16>) nounwind readnone
813*9880d681SAndroid Build Coastguard Worker
814*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_qb1(i32 %i0, i32 %a0.coerce) nounwind {
815*9880d681SAndroid Build Coastguard Workerentry:
816*9880d681SAndroid Build Coastguard Worker; CHECK: shll.qb
817*9880d681SAndroid Build Coastguard Worker
818*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
819*9880d681SAndroid Build Coastguard Worker  %1 = tail call <4 x i8> @llvm.mips.shll.qb(<4 x i8> %0, i32 3)
820*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <4 x i8> %1 to i32
821*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
822*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
823*9880d681SAndroid Build Coastguard Worker}
824*9880d681SAndroid Build Coastguard Worker
825*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.shll.qb(<4 x i8>, i32) nounwind
826*9880d681SAndroid Build Coastguard Worker
827*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_qb2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind {
828*9880d681SAndroid Build Coastguard Workerentry:
829*9880d681SAndroid Build Coastguard Worker; CHECK: shllv.qb
830*9880d681SAndroid Build Coastguard Worker
831*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
832*9880d681SAndroid Build Coastguard Worker  %1 = tail call <4 x i8> @llvm.mips.shll.qb(<4 x i8> %0, i32 %a1)
833*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <4 x i8> %1 to i32
834*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
835*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
836*9880d681SAndroid Build Coastguard Worker}
837*9880d681SAndroid Build Coastguard Worker
838*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_ph1(i32 %i0, i32 %a0.coerce) nounwind {
839*9880d681SAndroid Build Coastguard Workerentry:
840*9880d681SAndroid Build Coastguard Worker; CHECK: shll.ph
841*9880d681SAndroid Build Coastguard Worker
842*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
843*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shll.ph(<2 x i16> %0, i32 7)
844*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
845*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
846*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
847*9880d681SAndroid Build Coastguard Worker}
848*9880d681SAndroid Build Coastguard Worker
849*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.shll.ph(<2 x i16>, i32) nounwind
850*9880d681SAndroid Build Coastguard Worker
851*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_ph2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind {
852*9880d681SAndroid Build Coastguard Workerentry:
853*9880d681SAndroid Build Coastguard Worker; CHECK: shllv.ph
854*9880d681SAndroid Build Coastguard Worker
855*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
856*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shll.ph(<2 x i16> %0, i32 %a1)
857*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
858*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
859*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
860*9880d681SAndroid Build Coastguard Worker}
861*9880d681SAndroid Build Coastguard Worker
862*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_s_ph1(i32 %i0, i32 %a0.coerce) nounwind {
863*9880d681SAndroid Build Coastguard Workerentry:
864*9880d681SAndroid Build Coastguard Worker; CHECK: shll_s.ph
865*9880d681SAndroid Build Coastguard Worker
866*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
867*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shll.s.ph(<2 x i16> %0, i32 7)
868*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
869*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
870*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
871*9880d681SAndroid Build Coastguard Worker}
872*9880d681SAndroid Build Coastguard Worker
873*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.shll.s.ph(<2 x i16>, i32) nounwind
874*9880d681SAndroid Build Coastguard Worker
875*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shll_s_ph2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind {
876*9880d681SAndroid Build Coastguard Workerentry:
877*9880d681SAndroid Build Coastguard Worker; CHECK: shllv_s.ph
878*9880d681SAndroid Build Coastguard Worker
879*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
880*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shll.s.ph(<2 x i16> %0, i32 %a1)
881*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
882*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
883*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
884*9880d681SAndroid Build Coastguard Worker}
885*9880d681SAndroid Build Coastguard Worker
886*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_shll_s_w1(i32 %i0, i32 %a0) nounwind {
887*9880d681SAndroid Build Coastguard Workerentry:
888*9880d681SAndroid Build Coastguard Worker; CHECK: shll_s.w
889*9880d681SAndroid Build Coastguard Worker
890*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.shll.s.w(i32 %a0, i32 15)
891*9880d681SAndroid Build Coastguard Worker  ret i32 %0
892*9880d681SAndroid Build Coastguard Worker}
893*9880d681SAndroid Build Coastguard Worker
894*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.shll.s.w(i32, i32) nounwind
895*9880d681SAndroid Build Coastguard Worker
896*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_shll_s_w2(i32 %i0, i32 %a0, i32 %a1) nounwind {
897*9880d681SAndroid Build Coastguard Workerentry:
898*9880d681SAndroid Build Coastguard Worker; CHECK: shllv_s.w
899*9880d681SAndroid Build Coastguard Worker
900*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.shll.s.w(i32 %a0, i32 %a1)
901*9880d681SAndroid Build Coastguard Worker  ret i32 %0
902*9880d681SAndroid Build Coastguard Worker}
903*9880d681SAndroid Build Coastguard Worker
904*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shrl_qb1(i32 %i0, i32 %a0.coerce) nounwind readnone {
905*9880d681SAndroid Build Coastguard Workerentry:
906*9880d681SAndroid Build Coastguard Worker; CHECK: shrl.qb
907*9880d681SAndroid Build Coastguard Worker
908*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
909*9880d681SAndroid Build Coastguard Worker  %1 = tail call <4 x i8> @llvm.mips.shrl.qb(<4 x i8> %0, i32 3)
910*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <4 x i8> %1 to i32
911*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
912*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
913*9880d681SAndroid Build Coastguard Worker}
914*9880d681SAndroid Build Coastguard Worker
915*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.shrl.qb(<4 x i8>, i32) nounwind readnone
916*9880d681SAndroid Build Coastguard Worker
917*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shrl_qb2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind readnone {
918*9880d681SAndroid Build Coastguard Workerentry:
919*9880d681SAndroid Build Coastguard Worker; CHECK: shrlv.qb
920*9880d681SAndroid Build Coastguard Worker
921*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
922*9880d681SAndroid Build Coastguard Worker  %1 = tail call <4 x i8> @llvm.mips.shrl.qb(<4 x i8> %0, i32 %a1)
923*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <4 x i8> %1 to i32
924*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
925*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
926*9880d681SAndroid Build Coastguard Worker}
927*9880d681SAndroid Build Coastguard Worker
928*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shra_ph1(i32 %i0, i32 %a0.coerce) nounwind readnone {
929*9880d681SAndroid Build Coastguard Workerentry:
930*9880d681SAndroid Build Coastguard Worker; CHECK: shra.ph
931*9880d681SAndroid Build Coastguard Worker
932*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
933*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shra.ph(<2 x i16> %0, i32 7)
934*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
935*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
936*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
937*9880d681SAndroid Build Coastguard Worker}
938*9880d681SAndroid Build Coastguard Worker
939*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.shra.ph(<2 x i16>, i32) nounwind readnone
940*9880d681SAndroid Build Coastguard Worker
941*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shra_ph2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind readnone {
942*9880d681SAndroid Build Coastguard Workerentry:
943*9880d681SAndroid Build Coastguard Worker; CHECK: shrav.ph
944*9880d681SAndroid Build Coastguard Worker
945*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
946*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shra.ph(<2 x i16> %0, i32 %a1)
947*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
948*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
949*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
950*9880d681SAndroid Build Coastguard Worker}
951*9880d681SAndroid Build Coastguard Worker
952*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shra_r_ph1(i32 %i0, i32 %a0.coerce) nounwind readnone {
953*9880d681SAndroid Build Coastguard Workerentry:
954*9880d681SAndroid Build Coastguard Worker; CHECK: shra_r.ph
955*9880d681SAndroid Build Coastguard Worker
956*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
957*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shra.r.ph(<2 x i16> %0, i32 7)
958*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
959*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
960*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
961*9880d681SAndroid Build Coastguard Worker}
962*9880d681SAndroid Build Coastguard Worker
963*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.shra.r.ph(<2 x i16>, i32) nounwind readnone
964*9880d681SAndroid Build Coastguard Worker
965*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_shra_r_ph2(i32 %i0, i32 %a0.coerce, i32 %a1) nounwind readnone {
966*9880d681SAndroid Build Coastguard Workerentry:
967*9880d681SAndroid Build Coastguard Worker; CHECK: shrav_r.ph
968*9880d681SAndroid Build Coastguard Worker
969*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
970*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.shra.r.ph(<2 x i16> %0, i32 %a1)
971*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
972*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
973*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
974*9880d681SAndroid Build Coastguard Worker}
975*9880d681SAndroid Build Coastguard Worker
976*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_shra_r_w1(i32 %i0, i32 %a0) nounwind readnone {
977*9880d681SAndroid Build Coastguard Workerentry:
978*9880d681SAndroid Build Coastguard Worker; CHECK: shra_r.w
979*9880d681SAndroid Build Coastguard Worker
980*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.shra.r.w(i32 %a0, i32 15)
981*9880d681SAndroid Build Coastguard Worker  ret i32 %0
982*9880d681SAndroid Build Coastguard Worker}
983*9880d681SAndroid Build Coastguard Worker
984*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.shra.r.w(i32, i32) nounwind readnone
985*9880d681SAndroid Build Coastguard Worker
986*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_shra_r_w2(i32 %i0, i32 %a0, i32 %a1) nounwind readnone {
987*9880d681SAndroid Build Coastguard Workerentry:
988*9880d681SAndroid Build Coastguard Worker; CHECK: shrav_r.w
989*9880d681SAndroid Build Coastguard Worker
990*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.shra.r.w(i32 %a0, i32 %a1)
991*9880d681SAndroid Build Coastguard Worker  ret i32 %0
992*9880d681SAndroid Build Coastguard Worker}
993*9880d681SAndroid Build Coastguard Worker
994*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_absq_s_ph1(i32 %i0, i32 %a0.coerce) nounwind {
995*9880d681SAndroid Build Coastguard Workerentry:
996*9880d681SAndroid Build Coastguard Worker; CHECK: absq_s.ph
997*9880d681SAndroid Build Coastguard Worker
998*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
999*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.absq.s.ph(<2 x i16> %0)
1000*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1001*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1002*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1003*9880d681SAndroid Build Coastguard Worker}
1004*9880d681SAndroid Build Coastguard Worker
1005*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.absq.s.ph(<2 x i16>) nounwind
1006*9880d681SAndroid Build Coastguard Worker
1007*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_absq_s_w1(i32 %i0, i32 %a0) nounwind {
1008*9880d681SAndroid Build Coastguard Workerentry:
1009*9880d681SAndroid Build Coastguard Worker; CHECK: absq_s.w
1010*9880d681SAndroid Build Coastguard Worker
1011*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.absq.s.w(i32 %a0)
1012*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1013*9880d681SAndroid Build Coastguard Worker}
1014*9880d681SAndroid Build Coastguard Worker
1015*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.absq.s.w(i32) nounwind
1016*9880d681SAndroid Build Coastguard Worker
1017*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_preceq_w_phl1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1018*9880d681SAndroid Build Coastguard Workerentry:
1019*9880d681SAndroid Build Coastguard Worker; CHECK: preceq.w.phl
1020*9880d681SAndroid Build Coastguard Worker
1021*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
1022*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.preceq.w.phl(<2 x i16> %0)
1023*9880d681SAndroid Build Coastguard Worker  ret i32 %1
1024*9880d681SAndroid Build Coastguard Worker}
1025*9880d681SAndroid Build Coastguard Worker
1026*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.preceq.w.phl(<2 x i16>) nounwind readnone
1027*9880d681SAndroid Build Coastguard Worker
1028*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_preceq_w_phr1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1029*9880d681SAndroid Build Coastguard Workerentry:
1030*9880d681SAndroid Build Coastguard Worker; CHECK: preceq.w.phr
1031*9880d681SAndroid Build Coastguard Worker
1032*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <2 x i16>
1033*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @llvm.mips.preceq.w.phr(<2 x i16> %0)
1034*9880d681SAndroid Build Coastguard Worker  ret i32 %1
1035*9880d681SAndroid Build Coastguard Worker}
1036*9880d681SAndroid Build Coastguard Worker
1037*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.preceq.w.phr(<2 x i16>) nounwind readnone
1038*9880d681SAndroid Build Coastguard Worker
1039*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precequ_ph_qbl1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1040*9880d681SAndroid Build Coastguard Workerentry:
1041*9880d681SAndroid Build Coastguard Worker; CHECK: precequ.ph.qbl
1042*9880d681SAndroid Build Coastguard Worker
1043*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1044*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.precequ.ph.qbl(<4 x i8> %0)
1045*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1046*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1047*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1048*9880d681SAndroid Build Coastguard Worker}
1049*9880d681SAndroid Build Coastguard Worker
1050*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precequ.ph.qbl(<4 x i8>) nounwind readnone
1051*9880d681SAndroid Build Coastguard Worker
1052*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precequ_ph_qbr1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1053*9880d681SAndroid Build Coastguard Workerentry:
1054*9880d681SAndroid Build Coastguard Worker; CHECK: precequ.ph.qbr
1055*9880d681SAndroid Build Coastguard Worker
1056*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1057*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.precequ.ph.qbr(<4 x i8> %0)
1058*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1059*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1060*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1061*9880d681SAndroid Build Coastguard Worker}
1062*9880d681SAndroid Build Coastguard Worker
1063*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precequ.ph.qbr(<4 x i8>) nounwind readnone
1064*9880d681SAndroid Build Coastguard Worker
1065*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precequ_ph_qbla1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1066*9880d681SAndroid Build Coastguard Workerentry:
1067*9880d681SAndroid Build Coastguard Worker; CHECK: precequ.ph.qbla
1068*9880d681SAndroid Build Coastguard Worker
1069*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1070*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.precequ.ph.qbla(<4 x i8> %0)
1071*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1072*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1073*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1074*9880d681SAndroid Build Coastguard Worker}
1075*9880d681SAndroid Build Coastguard Worker
1076*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precequ.ph.qbla(<4 x i8>) nounwind readnone
1077*9880d681SAndroid Build Coastguard Worker
1078*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_precequ_ph_qbra1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1079*9880d681SAndroid Build Coastguard Workerentry:
1080*9880d681SAndroid Build Coastguard Worker; CHECK: precequ.ph.qbra
1081*9880d681SAndroid Build Coastguard Worker
1082*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1083*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.precequ.ph.qbra(<4 x i8> %0)
1084*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1085*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1086*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1087*9880d681SAndroid Build Coastguard Worker}
1088*9880d681SAndroid Build Coastguard Worker
1089*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.precequ.ph.qbra(<4 x i8>) nounwind readnone
1090*9880d681SAndroid Build Coastguard Worker
1091*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_preceu_ph_qbl1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1092*9880d681SAndroid Build Coastguard Workerentry:
1093*9880d681SAndroid Build Coastguard Worker; CHECK: preceu.ph.qbl
1094*9880d681SAndroid Build Coastguard Worker
1095*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1096*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.preceu.ph.qbl(<4 x i8> %0)
1097*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1098*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1099*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1100*9880d681SAndroid Build Coastguard Worker}
1101*9880d681SAndroid Build Coastguard Worker
1102*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.preceu.ph.qbl(<4 x i8>) nounwind readnone
1103*9880d681SAndroid Build Coastguard Worker
1104*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_preceu_ph_qbr1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1105*9880d681SAndroid Build Coastguard Workerentry:
1106*9880d681SAndroid Build Coastguard Worker; CHECK: preceu.ph.qbr
1107*9880d681SAndroid Build Coastguard Worker
1108*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1109*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.preceu.ph.qbr(<4 x i8> %0)
1110*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1111*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1112*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1113*9880d681SAndroid Build Coastguard Worker}
1114*9880d681SAndroid Build Coastguard Worker
1115*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.preceu.ph.qbr(<4 x i8>) nounwind readnone
1116*9880d681SAndroid Build Coastguard Worker
1117*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_preceu_ph_qbla1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1118*9880d681SAndroid Build Coastguard Workerentry:
1119*9880d681SAndroid Build Coastguard Worker; CHECK: preceu.ph.qbla
1120*9880d681SAndroid Build Coastguard Worker
1121*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1122*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.preceu.ph.qbla(<4 x i8> %0)
1123*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1124*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1125*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1126*9880d681SAndroid Build Coastguard Worker}
1127*9880d681SAndroid Build Coastguard Worker
1128*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.preceu.ph.qbla(<4 x i8>) nounwind readnone
1129*9880d681SAndroid Build Coastguard Worker
1130*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_preceu_ph_qbra1(i32 %i0, i32 %a0.coerce) nounwind readnone {
1131*9880d681SAndroid Build Coastguard Workerentry:
1132*9880d681SAndroid Build Coastguard Worker; CHECK: preceu.ph.qbra
1133*9880d681SAndroid Build Coastguard Worker
1134*9880d681SAndroid Build Coastguard Worker  %0 = bitcast i32 %a0.coerce to <4 x i8>
1135*9880d681SAndroid Build Coastguard Worker  %1 = tail call <2 x i16> @llvm.mips.preceu.ph.qbra(<4 x i8> %0)
1136*9880d681SAndroid Build Coastguard Worker  %2 = bitcast <2 x i16> %1 to i32
1137*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %2, 0
1138*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1139*9880d681SAndroid Build Coastguard Worker}
1140*9880d681SAndroid Build Coastguard Worker
1141*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.preceu.ph.qbra(<4 x i8>) nounwind readnone
1142*9880d681SAndroid Build Coastguard Worker
1143*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_repl_qb1(i32 %i0) nounwind readnone {
1144*9880d681SAndroid Build Coastguard Workerentry:
1145*9880d681SAndroid Build Coastguard Worker; CHECK: repl.qb
1146*9880d681SAndroid Build Coastguard Worker
1147*9880d681SAndroid Build Coastguard Worker  %0 = tail call <4 x i8> @llvm.mips.repl.qb(i32 127)
1148*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <4 x i8> %0 to i32
1149*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
1150*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1151*9880d681SAndroid Build Coastguard Worker}
1152*9880d681SAndroid Build Coastguard Worker
1153*9880d681SAndroid Build Coastguard Workerdeclare <4 x i8> @llvm.mips.repl.qb(i32) nounwind readnone
1154*9880d681SAndroid Build Coastguard Worker
1155*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_repl_qb2(i32 %i0, i32 %a0) nounwind readnone {
1156*9880d681SAndroid Build Coastguard Workerentry:
1157*9880d681SAndroid Build Coastguard Worker; CHECK: replv.qb
1158*9880d681SAndroid Build Coastguard Worker
1159*9880d681SAndroid Build Coastguard Worker  %0 = tail call <4 x i8> @llvm.mips.repl.qb(i32 %a0)
1160*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <4 x i8> %0 to i32
1161*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
1162*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1163*9880d681SAndroid Build Coastguard Worker}
1164*9880d681SAndroid Build Coastguard Worker
1165*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_repl_ph1(i32 %i0) nounwind readnone {
1166*9880d681SAndroid Build Coastguard Workerentry:
1167*9880d681SAndroid Build Coastguard Worker; CHECK: repl.ph
1168*9880d681SAndroid Build Coastguard Worker
1169*9880d681SAndroid Build Coastguard Worker  %0 = tail call <2 x i16> @llvm.mips.repl.ph(i32 0)
1170*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <2 x i16> %0 to i32
1171*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
1172*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1173*9880d681SAndroid Build Coastguard Worker}
1174*9880d681SAndroid Build Coastguard Worker
1175*9880d681SAndroid Build Coastguard Workerdeclare <2 x i16> @llvm.mips.repl.ph(i32) nounwind readnone
1176*9880d681SAndroid Build Coastguard Worker
1177*9880d681SAndroid Build Coastguard Workerdefine { i32 } @test__builtin_mips_repl_ph2(i32 %i0, i32 %a0) nounwind readnone {
1178*9880d681SAndroid Build Coastguard Workerentry:
1179*9880d681SAndroid Build Coastguard Worker; CHECK: replv.ph
1180*9880d681SAndroid Build Coastguard Worker
1181*9880d681SAndroid Build Coastguard Worker  %0 = tail call <2 x i16> @llvm.mips.repl.ph(i32 %a0)
1182*9880d681SAndroid Build Coastguard Worker  %1 = bitcast <2 x i16> %0 to i32
1183*9880d681SAndroid Build Coastguard Worker  %.fca.0.insert = insertvalue { i32 } undef, i32 %1, 0
1184*9880d681SAndroid Build Coastguard Worker  ret { i32 } %.fca.0.insert
1185*9880d681SAndroid Build Coastguard Worker}
1186*9880d681SAndroid Build Coastguard Worker
1187*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_bitrev1(i32 %i0, i32 %a0) nounwind readnone {
1188*9880d681SAndroid Build Coastguard Workerentry:
1189*9880d681SAndroid Build Coastguard Worker; CHECK: bitrev ${{[0-9]+}}
1190*9880d681SAndroid Build Coastguard Worker
1191*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.bitrev(i32 %a0)
1192*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1193*9880d681SAndroid Build Coastguard Worker}
1194*9880d681SAndroid Build Coastguard Worker
1195*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.bitrev(i32) nounwind readnone
1196*9880d681SAndroid Build Coastguard Worker
1197*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_lbux1(i32 %i0, i8* %a0, i32 %a1) nounwind readonly {
1198*9880d681SAndroid Build Coastguard Workerentry:
1199*9880d681SAndroid Build Coastguard Worker; CHECK: lbux ${{[0-9]+}}
1200*9880d681SAndroid Build Coastguard Worker
1201*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.lbux(i8* %a0, i32 %a1)
1202*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1203*9880d681SAndroid Build Coastguard Worker}
1204*9880d681SAndroid Build Coastguard Worker
1205*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.lbux(i8*, i32) nounwind readonly
1206*9880d681SAndroid Build Coastguard Worker
1207*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_lhx1(i32 %i0, i8* %a0, i32 %a1) nounwind readonly {
1208*9880d681SAndroid Build Coastguard Workerentry:
1209*9880d681SAndroid Build Coastguard Worker; CHECK: lhx ${{[0-9]+}}
1210*9880d681SAndroid Build Coastguard Worker
1211*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.lhx(i8* %a0, i32 %a1)
1212*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1213*9880d681SAndroid Build Coastguard Worker}
1214*9880d681SAndroid Build Coastguard Worker
1215*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.lhx(i8*, i32) nounwind readonly
1216*9880d681SAndroid Build Coastguard Worker
1217*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_lwx1(i32 %i0, i8* %a0, i32 %a1) nounwind readonly {
1218*9880d681SAndroid Build Coastguard Workerentry:
1219*9880d681SAndroid Build Coastguard Worker; CHECK: lwx ${{[0-9]+}}
1220*9880d681SAndroid Build Coastguard Worker
1221*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.lwx(i8* %a0, i32 %a1)
1222*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1223*9880d681SAndroid Build Coastguard Worker}
1224*9880d681SAndroid Build Coastguard Worker
1225*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.mips.lwx(i8*, i32) nounwind readonly
1226*9880d681SAndroid Build Coastguard Worker
1227*9880d681SAndroid Build Coastguard Workerdefine i32 @test__builtin_mips_wrdsp1(i32 %i0, i32 %a0) nounwind {
1228*9880d681SAndroid Build Coastguard Workerentry:
1229*9880d681SAndroid Build Coastguard Worker; CHECK: wrdsp ${{[0-9]+}}
1230*9880d681SAndroid Build Coastguard Worker; CHECK: rddsp ${{[0-9]+}}
1231*9880d681SAndroid Build Coastguard Worker
1232*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.mips.wrdsp(i32 %a0, i32 31)
1233*9880d681SAndroid Build Coastguard Worker  %0 = tail call i32 @llvm.mips.rddsp(i32 31)
1234*9880d681SAndroid Build Coastguard Worker  ret i32 %0
1235*9880d681SAndroid Build Coastguard Worker}
1236*9880d681SAndroid Build Coastguard Worker
1237*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.mips.wrdsp(i32, i32) nounwind
1238