1; Test the MSA intrinsics that are encoded with the 3R instruction format.
2; There are lots of these so this covers those beginning with 's'
3
4; RUN: llc -march=mips -mattr=+msa,+fp64,+mips32r2 -relocation-model=pic < %s | FileCheck %s
5; RUN: llc -march=mipsel -mattr=+msa,+fp64,+mips32r2 -relocation-model=pic < %s | FileCheck %s
6
7@llvm_mips_sld_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
8@llvm_mips_sld_b_ARG2 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
9@llvm_mips_sld_b_ARG3 = global i32 10, align 16
10@llvm_mips_sld_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
11
12define void @llvm_mips_sld_b_test() nounwind {
13entry:
14  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_sld_b_ARG1
15  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_sld_b_ARG2
16  %2 = load i32, i32* @llvm_mips_sld_b_ARG3
17  %3 = tail call <16 x i8> @llvm.mips.sld.b(<16 x i8> %0, <16 x i8> %1, i32 %2)
18  store <16 x i8> %3, <16 x i8>* @llvm_mips_sld_b_RES
19  ret void
20}
21
22declare <16 x i8> @llvm.mips.sld.b(<16 x i8>, <16 x i8>, i32) nounwind
23
24; CHECK: llvm_mips_sld_b_test:
25; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sld_b_ARG1)
26; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sld_b_ARG2)
27; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_sld_b_ARG3)
28; CHECK-DAG: ld.b [[WD:\$w[0-9]+]], 0([[R1]])
29; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R2]])
30; CHECK-DAG: lw [[RT:\$[0-9]+]], 0([[R3]])
31; CHECK-DAG: sld.b [[WD]], [[WS]]{{\[}}[[RT]]{{\]}}
32; CHECK-DAG: st.b [[WD]]
33; CHECK: .size llvm_mips_sld_b_test
34;
35@llvm_mips_sld_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
36@llvm_mips_sld_h_ARG2 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
37@llvm_mips_sld_h_ARG3 = global i32 10, align 16
38@llvm_mips_sld_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
39
40define void @llvm_mips_sld_h_test() nounwind {
41entry:
42  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_sld_h_ARG1
43  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_sld_h_ARG2
44  %2 = load i32, i32* @llvm_mips_sld_h_ARG3
45  %3 = tail call <8 x i16> @llvm.mips.sld.h(<8 x i16> %0, <8 x i16> %1, i32 %2)
46  store <8 x i16> %3, <8 x i16>* @llvm_mips_sld_h_RES
47  ret void
48}
49
50declare <8 x i16> @llvm.mips.sld.h(<8 x i16>, <8 x i16>, i32) nounwind
51
52; CHECK: llvm_mips_sld_h_test:
53; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sld_h_ARG1)
54; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sld_h_ARG2)
55; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_sld_h_ARG3)
56; CHECK-DAG: ld.h [[WD:\$w[0-9]+]], 0([[R1]])
57; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R2]])
58; CHECK-DAG: lw [[RT:\$[0-9]+]], 0([[R3]])
59; CHECK-DAG: sld.h [[WD]], [[WS]]{{\[}}[[RT]]{{\]}}
60; CHECK-DAG: st.h [[WD]]
61; CHECK: .size llvm_mips_sld_h_test
62;
63@llvm_mips_sld_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
64@llvm_mips_sld_w_ARG2 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
65@llvm_mips_sld_w_ARG3 = global i32 10, align 16
66@llvm_mips_sld_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
67
68define void @llvm_mips_sld_w_test() nounwind {
69entry:
70  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_sld_w_ARG1
71  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_sld_w_ARG2
72  %2 = load i32, i32* @llvm_mips_sld_w_ARG3
73  %3 = tail call <4 x i32> @llvm.mips.sld.w(<4 x i32> %0, <4 x i32> %1, i32 %2)
74  store <4 x i32> %3, <4 x i32>* @llvm_mips_sld_w_RES
75  ret void
76}
77
78declare <4 x i32> @llvm.mips.sld.w(<4 x i32>, <4 x i32>, i32) nounwind
79
80; CHECK: llvm_mips_sld_w_test:
81; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sld_w_ARG1)
82; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sld_w_ARG2)
83; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_sld_w_ARG3)
84; CHECK-DAG: ld.w [[WD:\$w[0-9]+]], 0([[R1]])
85; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R2]])
86; CHECK-DAG: lw [[RT:\$[0-9]+]], 0([[R3]])
87; CHECK-DAG: sld.w [[WD]], [[WS]]{{\[}}[[RT]]{{\]}}
88; CHECK-DAG: st.w [[WD]]
89; CHECK: .size llvm_mips_sld_w_test
90;
91@llvm_mips_sld_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
92@llvm_mips_sld_d_ARG2 = global <2 x i64> <i64 0, i64 1>, align 16
93@llvm_mips_sld_d_ARG3 = global i32 10, align 16
94@llvm_mips_sld_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
95
96define void @llvm_mips_sld_d_test() nounwind {
97entry:
98  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_sld_d_ARG1
99  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_sld_d_ARG2
100  %2 = load i32, i32* @llvm_mips_sld_d_ARG3
101  %3 = tail call <2 x i64> @llvm.mips.sld.d(<2 x i64> %0, <2 x i64> %1, i32 %2)
102  store <2 x i64> %3, <2 x i64>* @llvm_mips_sld_d_RES
103  ret void
104}
105
106declare <2 x i64> @llvm.mips.sld.d(<2 x i64>, <2 x i64>, i32) nounwind
107
108; CHECK: llvm_mips_sld_d_test:
109; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sld_d_ARG1)
110; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sld_d_ARG2)
111; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_sld_d_ARG3)
112; CHECK-DAG: ld.d [[WD:\$w[0-9]+]], 0([[R1]])
113; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R2]])
114; CHECK-DAG: lw [[RT:\$[0-9]+]], 0([[R3]])
115; CHECK-DAG: sld.d [[WD]], [[WS]]{{\[}}[[RT]]{{\]}}
116; CHECK-DAG: st.d [[WD]]
117; CHECK: .size llvm_mips_sld_d_test
118;
119@llvm_mips_sll_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
120@llvm_mips_sll_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
121@llvm_mips_sll_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
122
123define void @llvm_mips_sll_b_test() nounwind {
124entry:
125  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_sll_b_ARG1
126  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_sll_b_ARG2
127  %2 = tail call <16 x i8> @llvm.mips.sll.b(<16 x i8> %0, <16 x i8> %1)
128  store <16 x i8> %2, <16 x i8>* @llvm_mips_sll_b_RES
129  ret void
130}
131
132declare <16 x i8> @llvm.mips.sll.b(<16 x i8>, <16 x i8>) nounwind
133
134; CHECK: llvm_mips_sll_b_test:
135; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_b_ARG1)
136; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_b_ARG2)
137; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
138; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
139; CHECK-DAG: sll.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
140; CHECK-DAG: st.b [[WD]]
141; CHECK: .size llvm_mips_sll_b_test
142;
143@llvm_mips_sll_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
144@llvm_mips_sll_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
145@llvm_mips_sll_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
146
147define void @llvm_mips_sll_h_test() nounwind {
148entry:
149  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_sll_h_ARG1
150  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_sll_h_ARG2
151  %2 = tail call <8 x i16> @llvm.mips.sll.h(<8 x i16> %0, <8 x i16> %1)
152  store <8 x i16> %2, <8 x i16>* @llvm_mips_sll_h_RES
153  ret void
154}
155
156declare <8 x i16> @llvm.mips.sll.h(<8 x i16>, <8 x i16>) nounwind
157
158; CHECK: llvm_mips_sll_h_test:
159; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_h_ARG1)
160; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_h_ARG2)
161; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
162; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
163; CHECK-DAG: sll.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
164; CHECK-DAG: st.h [[WD]]
165; CHECK: .size llvm_mips_sll_h_test
166;
167@llvm_mips_sll_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
168@llvm_mips_sll_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
169@llvm_mips_sll_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
170
171define void @llvm_mips_sll_w_test() nounwind {
172entry:
173  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_sll_w_ARG1
174  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_sll_w_ARG2
175  %2 = tail call <4 x i32> @llvm.mips.sll.w(<4 x i32> %0, <4 x i32> %1)
176  store <4 x i32> %2, <4 x i32>* @llvm_mips_sll_w_RES
177  ret void
178}
179
180declare <4 x i32> @llvm.mips.sll.w(<4 x i32>, <4 x i32>) nounwind
181
182; CHECK: llvm_mips_sll_w_test:
183; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_w_ARG1)
184; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_w_ARG2)
185; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
186; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
187; CHECK-DAG: sll.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
188; CHECK-DAG: st.w [[WD]]
189; CHECK: .size llvm_mips_sll_w_test
190;
191@llvm_mips_sll_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
192@llvm_mips_sll_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
193@llvm_mips_sll_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
194
195define void @llvm_mips_sll_d_test() nounwind {
196entry:
197  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_sll_d_ARG1
198  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_sll_d_ARG2
199  %2 = tail call <2 x i64> @llvm.mips.sll.d(<2 x i64> %0, <2 x i64> %1)
200  store <2 x i64> %2, <2 x i64>* @llvm_mips_sll_d_RES
201  ret void
202}
203
204declare <2 x i64> @llvm.mips.sll.d(<2 x i64>, <2 x i64>) nounwind
205
206; CHECK: llvm_mips_sll_d_test:
207; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_d_ARG1)
208; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_d_ARG2)
209; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
210; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
211; CHECK-DAG: sll.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
212; CHECK-DAG: st.d [[WD]]
213; CHECK: .size llvm_mips_sll_d_test
214
215define void @sll_b_test() nounwind {
216entry:
217  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_sll_b_ARG1
218  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_sll_b_ARG2
219  %2 = shl <16 x i8> %0, %1
220  store <16 x i8> %2, <16 x i8>* @llvm_mips_sll_b_RES
221  ret void
222}
223
224; CHECK: sll_b_test:
225; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_b_ARG1)
226; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_b_ARG2)
227; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
228; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
229; CHECK-DAG: sll.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
230; CHECK-DAG: st.b [[WD]]
231; CHECK: .size sll_b_test
232
233define void @sll_h_test() nounwind {
234entry:
235  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_sll_h_ARG1
236  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_sll_h_ARG2
237  %2 = shl <8 x i16> %0, %1
238  store <8 x i16> %2, <8 x i16>* @llvm_mips_sll_h_RES
239  ret void
240}
241
242; CHECK: sll_h_test:
243; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_h_ARG1)
244; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_h_ARG2)
245; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
246; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
247; CHECK-DAG: sll.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
248; CHECK-DAG: st.h [[WD]]
249; CHECK: .size sll_h_test
250
251define void @sll_w_test() nounwind {
252entry:
253  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_sll_w_ARG1
254  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_sll_w_ARG2
255  %2 = shl <4 x i32> %0, %1
256  store <4 x i32> %2, <4 x i32>* @llvm_mips_sll_w_RES
257  ret void
258}
259
260; CHECK: sll_w_test:
261; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_w_ARG1)
262; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_w_ARG2)
263; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
264; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
265; CHECK-DAG: sll.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
266; CHECK-DAG: st.w [[WD]]
267; CHECK: .size sll_w_test
268
269define void @sll_d_test() nounwind {
270entry:
271  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_sll_d_ARG1
272  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_sll_d_ARG2
273  %2 = shl <2 x i64> %0, %1
274  store <2 x i64> %2, <2 x i64>* @llvm_mips_sll_d_RES
275  ret void
276}
277
278; CHECK: sll_d_test:
279; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sll_d_ARG1)
280; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sll_d_ARG2)
281; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
282; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
283; CHECK-DAG: sll.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
284; CHECK-DAG: st.d [[WD]]
285; CHECK: .size sll_d_test
286;
287@llvm_mips_sra_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
288@llvm_mips_sra_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
289@llvm_mips_sra_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
290
291define void @llvm_mips_sra_b_test() nounwind {
292entry:
293  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_sra_b_ARG1
294  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_sra_b_ARG2
295  %2 = tail call <16 x i8> @llvm.mips.sra.b(<16 x i8> %0, <16 x i8> %1)
296  store <16 x i8> %2, <16 x i8>* @llvm_mips_sra_b_RES
297  ret void
298}
299
300declare <16 x i8> @llvm.mips.sra.b(<16 x i8>, <16 x i8>) nounwind
301
302; CHECK: llvm_mips_sra_b_test:
303; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_b_ARG1)
304; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_b_ARG2)
305; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
306; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
307; CHECK-DAG: sra.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
308; CHECK-DAG: st.b [[WD]]
309; CHECK: .size llvm_mips_sra_b_test
310;
311@llvm_mips_sra_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
312@llvm_mips_sra_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
313@llvm_mips_sra_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
314
315define void @llvm_mips_sra_h_test() nounwind {
316entry:
317  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_sra_h_ARG1
318  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_sra_h_ARG2
319  %2 = tail call <8 x i16> @llvm.mips.sra.h(<8 x i16> %0, <8 x i16> %1)
320  store <8 x i16> %2, <8 x i16>* @llvm_mips_sra_h_RES
321  ret void
322}
323
324declare <8 x i16> @llvm.mips.sra.h(<8 x i16>, <8 x i16>) nounwind
325
326; CHECK: llvm_mips_sra_h_test:
327; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_h_ARG1)
328; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_h_ARG2)
329; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
330; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
331; CHECK-DAG: sra.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
332; CHECK-DAG: st.h [[WD]]
333; CHECK: .size llvm_mips_sra_h_test
334;
335@llvm_mips_sra_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
336@llvm_mips_sra_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
337@llvm_mips_sra_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
338
339define void @llvm_mips_sra_w_test() nounwind {
340entry:
341  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_sra_w_ARG1
342  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_sra_w_ARG2
343  %2 = tail call <4 x i32> @llvm.mips.sra.w(<4 x i32> %0, <4 x i32> %1)
344  store <4 x i32> %2, <4 x i32>* @llvm_mips_sra_w_RES
345  ret void
346}
347
348declare <4 x i32> @llvm.mips.sra.w(<4 x i32>, <4 x i32>) nounwind
349
350; CHECK: llvm_mips_sra_w_test:
351; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_w_ARG1)
352; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_w_ARG2)
353; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
354; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
355; CHECK-DAG: sra.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
356; CHECK-DAG: st.w [[WD]]
357; CHECK: .size llvm_mips_sra_w_test
358;
359@llvm_mips_sra_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
360@llvm_mips_sra_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
361@llvm_mips_sra_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
362
363define void @llvm_mips_sra_d_test() nounwind {
364entry:
365  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_sra_d_ARG1
366  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_sra_d_ARG2
367  %2 = tail call <2 x i64> @llvm.mips.sra.d(<2 x i64> %0, <2 x i64> %1)
368  store <2 x i64> %2, <2 x i64>* @llvm_mips_sra_d_RES
369  ret void
370}
371
372declare <2 x i64> @llvm.mips.sra.d(<2 x i64>, <2 x i64>) nounwind
373
374; CHECK: llvm_mips_sra_d_test:
375; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_d_ARG1)
376; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_d_ARG2)
377; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
378; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
379; CHECK-DAG: sra.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
380; CHECK-DAG: st.d [[WD]]
381; CHECK: .size llvm_mips_sra_d_test
382;
383
384define void @sra_b_test() nounwind {
385entry:
386  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_sra_b_ARG1
387  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_sra_b_ARG2
388  %2 = ashr <16 x i8> %0, %1
389  store <16 x i8> %2, <16 x i8>* @llvm_mips_sra_b_RES
390  ret void
391}
392
393; CHECK: sra_b_test:
394; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_b_ARG1)
395; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_b_ARG2)
396; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
397; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
398; CHECK-DAG: sra.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
399; CHECK-DAG: st.b [[WD]]
400; CHECK: .size sra_b_test
401
402define void @sra_h_test() nounwind {
403entry:
404  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_sra_h_ARG1
405  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_sra_h_ARG2
406  %2 = ashr <8 x i16> %0, %1
407  store <8 x i16> %2, <8 x i16>* @llvm_mips_sra_h_RES
408  ret void
409}
410
411; CHECK: sra_h_test:
412; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_h_ARG1)
413; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_h_ARG2)
414; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
415; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
416; CHECK-DAG: sra.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
417; CHECK-DAG: st.h [[WD]]
418; CHECK: .size sra_h_test
419
420define void @sra_w_test() nounwind {
421entry:
422  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_sra_w_ARG1
423  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_sra_w_ARG2
424  %2 = ashr <4 x i32> %0, %1
425  store <4 x i32> %2, <4 x i32>* @llvm_mips_sra_w_RES
426  ret void
427}
428
429; CHECK: sra_w_test:
430; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_w_ARG1)
431; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_w_ARG2)
432; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
433; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
434; CHECK-DAG: sra.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
435; CHECK-DAG: st.w [[WD]]
436; CHECK: .size sra_w_test
437
438define void @sra_d_test() nounwind {
439entry:
440  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_sra_d_ARG1
441  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_sra_d_ARG2
442  %2 = ashr <2 x i64> %0, %1
443  store <2 x i64> %2, <2 x i64>* @llvm_mips_sra_d_RES
444  ret void
445}
446
447; CHECK: sra_d_test:
448; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_sra_d_ARG1)
449; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_sra_d_ARG2)
450; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
451; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
452; CHECK-DAG: sra.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
453; CHECK-DAG: st.d [[WD]]
454; CHECK: .size sra_d_test
455
456@llvm_mips_srar_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
457@llvm_mips_srar_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
458@llvm_mips_srar_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
459
460define void @llvm_mips_srar_b_test() nounwind {
461entry:
462  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_srar_b_ARG1
463  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_srar_b_ARG2
464  %2 = tail call <16 x i8> @llvm.mips.srar.b(<16 x i8> %0, <16 x i8> %1)
465  store <16 x i8> %2, <16 x i8>* @llvm_mips_srar_b_RES
466  ret void
467}
468
469declare <16 x i8> @llvm.mips.srar.b(<16 x i8>, <16 x i8>) nounwind
470
471; CHECK: llvm_mips_srar_b_test:
472; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srar_b_ARG1)
473; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srar_b_ARG2)
474; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
475; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
476; CHECK-DAG: srar.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
477; CHECK-DAG: st.b [[WD]]
478; CHECK: .size llvm_mips_srar_b_test
479;
480@llvm_mips_srar_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
481@llvm_mips_srar_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
482@llvm_mips_srar_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
483
484define void @llvm_mips_srar_h_test() nounwind {
485entry:
486  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_srar_h_ARG1
487  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_srar_h_ARG2
488  %2 = tail call <8 x i16> @llvm.mips.srar.h(<8 x i16> %0, <8 x i16> %1)
489  store <8 x i16> %2, <8 x i16>* @llvm_mips_srar_h_RES
490  ret void
491}
492
493declare <8 x i16> @llvm.mips.srar.h(<8 x i16>, <8 x i16>) nounwind
494
495; CHECK: llvm_mips_srar_h_test:
496; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srar_h_ARG1)
497; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srar_h_ARG2)
498; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
499; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
500; CHECK-DAG: srar.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
501; CHECK-DAG: st.h [[WD]]
502; CHECK: .size llvm_mips_srar_h_test
503;
504@llvm_mips_srar_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
505@llvm_mips_srar_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
506@llvm_mips_srar_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
507
508define void @llvm_mips_srar_w_test() nounwind {
509entry:
510  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_srar_w_ARG1
511  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_srar_w_ARG2
512  %2 = tail call <4 x i32> @llvm.mips.srar.w(<4 x i32> %0, <4 x i32> %1)
513  store <4 x i32> %2, <4 x i32>* @llvm_mips_srar_w_RES
514  ret void
515}
516
517declare <4 x i32> @llvm.mips.srar.w(<4 x i32>, <4 x i32>) nounwind
518
519; CHECK: llvm_mips_srar_w_test:
520; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srar_w_ARG1)
521; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srar_w_ARG2)
522; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
523; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
524; CHECK-DAG: srar.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
525; CHECK-DAG: st.w [[WD]]
526; CHECK: .size llvm_mips_srar_w_test
527;
528@llvm_mips_srar_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
529@llvm_mips_srar_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
530@llvm_mips_srar_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
531
532define void @llvm_mips_srar_d_test() nounwind {
533entry:
534  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_srar_d_ARG1
535  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_srar_d_ARG2
536  %2 = tail call <2 x i64> @llvm.mips.srar.d(<2 x i64> %0, <2 x i64> %1)
537  store <2 x i64> %2, <2 x i64>* @llvm_mips_srar_d_RES
538  ret void
539}
540
541declare <2 x i64> @llvm.mips.srar.d(<2 x i64>, <2 x i64>) nounwind
542
543; CHECK: llvm_mips_srar_d_test:
544; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srar_d_ARG1)
545; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srar_d_ARG2)
546; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
547; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
548; CHECK-DAG: srar.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
549; CHECK-DAG: st.d [[WD]]
550; CHECK: .size llvm_mips_srar_d_test
551;
552@llvm_mips_srl_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
553@llvm_mips_srl_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
554@llvm_mips_srl_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
555
556define void @llvm_mips_srl_b_test() nounwind {
557entry:
558  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_srl_b_ARG1
559  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_srl_b_ARG2
560  %2 = tail call <16 x i8> @llvm.mips.srl.b(<16 x i8> %0, <16 x i8> %1)
561  store <16 x i8> %2, <16 x i8>* @llvm_mips_srl_b_RES
562  ret void
563}
564
565declare <16 x i8> @llvm.mips.srl.b(<16 x i8>, <16 x i8>) nounwind
566
567; CHECK: llvm_mips_srl_b_test:
568; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_b_ARG1)
569; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_b_ARG2)
570; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
571; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
572; CHECK-DAG: srl.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
573; CHECK-DAG: st.b [[WD]]
574; CHECK: .size llvm_mips_srl_b_test
575;
576@llvm_mips_srl_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
577@llvm_mips_srl_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
578@llvm_mips_srl_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
579
580define void @llvm_mips_srl_h_test() nounwind {
581entry:
582  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_srl_h_ARG1
583  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_srl_h_ARG2
584  %2 = tail call <8 x i16> @llvm.mips.srl.h(<8 x i16> %0, <8 x i16> %1)
585  store <8 x i16> %2, <8 x i16>* @llvm_mips_srl_h_RES
586  ret void
587}
588
589declare <8 x i16> @llvm.mips.srl.h(<8 x i16>, <8 x i16>) nounwind
590
591; CHECK: llvm_mips_srl_h_test:
592; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_h_ARG1)
593; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_h_ARG2)
594; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
595; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
596; CHECK-DAG: srl.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
597; CHECK-DAG: st.h [[WD]]
598; CHECK: .size llvm_mips_srl_h_test
599;
600@llvm_mips_srl_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
601@llvm_mips_srl_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
602@llvm_mips_srl_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
603
604define void @llvm_mips_srl_w_test() nounwind {
605entry:
606  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_srl_w_ARG1
607  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_srl_w_ARG2
608  %2 = tail call <4 x i32> @llvm.mips.srl.w(<4 x i32> %0, <4 x i32> %1)
609  store <4 x i32> %2, <4 x i32>* @llvm_mips_srl_w_RES
610  ret void
611}
612
613declare <4 x i32> @llvm.mips.srl.w(<4 x i32>, <4 x i32>) nounwind
614
615; CHECK: llvm_mips_srl_w_test:
616; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_w_ARG1)
617; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_w_ARG2)
618; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
619; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
620; CHECK-DAG: srl.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
621; CHECK-DAG: st.w [[WD]]
622; CHECK: .size llvm_mips_srl_w_test
623;
624@llvm_mips_srl_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
625@llvm_mips_srl_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
626@llvm_mips_srl_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
627
628define void @llvm_mips_srl_d_test() nounwind {
629entry:
630  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_srl_d_ARG1
631  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_srl_d_ARG2
632  %2 = tail call <2 x i64> @llvm.mips.srl.d(<2 x i64> %0, <2 x i64> %1)
633  store <2 x i64> %2, <2 x i64>* @llvm_mips_srl_d_RES
634  ret void
635}
636
637declare <2 x i64> @llvm.mips.srl.d(<2 x i64>, <2 x i64>) nounwind
638
639; CHECK: llvm_mips_srl_d_test:
640; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_d_ARG1)
641; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_d_ARG2)
642; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
643; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
644; CHECK-DAG: srl.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
645; CHECK-DAG: st.d [[WD]]
646; CHECK: .size llvm_mips_srl_d_test
647;
648@llvm_mips_srlr_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
649@llvm_mips_srlr_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
650@llvm_mips_srlr_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
651
652define void @llvm_mips_srlr_b_test() nounwind {
653entry:
654  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_srlr_b_ARG1
655  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_srlr_b_ARG2
656  %2 = tail call <16 x i8> @llvm.mips.srlr.b(<16 x i8> %0, <16 x i8> %1)
657  store <16 x i8> %2, <16 x i8>* @llvm_mips_srlr_b_RES
658  ret void
659}
660
661declare <16 x i8> @llvm.mips.srlr.b(<16 x i8>, <16 x i8>) nounwind
662
663; CHECK: llvm_mips_srlr_b_test:
664; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srlr_b_ARG1)
665; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srlr_b_ARG2)
666; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
667; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
668; CHECK-DAG: srlr.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
669; CHECK-DAG: st.b [[WD]]
670; CHECK: .size llvm_mips_srlr_b_test
671;
672@llvm_mips_srlr_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
673@llvm_mips_srlr_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
674@llvm_mips_srlr_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
675
676define void @llvm_mips_srlr_h_test() nounwind {
677entry:
678  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_srlr_h_ARG1
679  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_srlr_h_ARG2
680  %2 = tail call <8 x i16> @llvm.mips.srlr.h(<8 x i16> %0, <8 x i16> %1)
681  store <8 x i16> %2, <8 x i16>* @llvm_mips_srlr_h_RES
682  ret void
683}
684
685declare <8 x i16> @llvm.mips.srlr.h(<8 x i16>, <8 x i16>) nounwind
686
687; CHECK: llvm_mips_srlr_h_test:
688; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srlr_h_ARG1)
689; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srlr_h_ARG2)
690; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
691; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
692; CHECK-DAG: srlr.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
693; CHECK-DAG: st.h [[WD]]
694; CHECK: .size llvm_mips_srlr_h_test
695;
696@llvm_mips_srlr_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
697@llvm_mips_srlr_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
698@llvm_mips_srlr_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
699
700define void @llvm_mips_srlr_w_test() nounwind {
701entry:
702  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_srlr_w_ARG1
703  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_srlr_w_ARG2
704  %2 = tail call <4 x i32> @llvm.mips.srlr.w(<4 x i32> %0, <4 x i32> %1)
705  store <4 x i32> %2, <4 x i32>* @llvm_mips_srlr_w_RES
706  ret void
707}
708
709declare <4 x i32> @llvm.mips.srlr.w(<4 x i32>, <4 x i32>) nounwind
710
711; CHECK: llvm_mips_srlr_w_test:
712; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srlr_w_ARG1)
713; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srlr_w_ARG2)
714; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
715; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
716; CHECK-DAG: srlr.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
717; CHECK-DAG: st.w [[WD]]
718; CHECK: .size llvm_mips_srlr_w_test
719;
720@llvm_mips_srlr_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
721@llvm_mips_srlr_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
722@llvm_mips_srlr_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
723
724define void @llvm_mips_srlr_d_test() nounwind {
725entry:
726  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_srlr_d_ARG1
727  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_srlr_d_ARG2
728  %2 = tail call <2 x i64> @llvm.mips.srlr.d(<2 x i64> %0, <2 x i64> %1)
729  store <2 x i64> %2, <2 x i64>* @llvm_mips_srlr_d_RES
730  ret void
731}
732
733declare <2 x i64> @llvm.mips.srlr.d(<2 x i64>, <2 x i64>) nounwind
734
735; CHECK: llvm_mips_srlr_d_test:
736; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srlr_d_ARG1)
737; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srlr_d_ARG2)
738; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
739; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
740; CHECK-DAG: srlr.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
741; CHECK-DAG: st.d [[WD]]
742; CHECK: .size llvm_mips_srlr_d_test
743;
744
745define void @srl_b_test() nounwind {
746entry:
747  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_srl_b_ARG1
748  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_srl_b_ARG2
749  %2 = lshr <16 x i8> %0, %1
750  store <16 x i8> %2, <16 x i8>* @llvm_mips_srl_b_RES
751  ret void
752}
753
754; CHECK: srl_b_test:
755; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_b_ARG1)
756; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_b_ARG2)
757; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
758; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
759; CHECK-DAG: srl.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
760; CHECK-DAG: st.b [[WD]]
761; CHECK: .size srl_b_test
762
763define void @srl_h_test() nounwind {
764entry:
765  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_srl_h_ARG1
766  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_srl_h_ARG2
767  %2 = lshr <8 x i16> %0, %1
768  store <8 x i16> %2, <8 x i16>* @llvm_mips_srl_h_RES
769  ret void
770}
771
772; CHECK: srl_h_test:
773; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_h_ARG1)
774; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_h_ARG2)
775; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
776; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
777; CHECK-DAG: srl.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
778; CHECK-DAG: st.h [[WD]]
779; CHECK: .size srl_h_test
780
781define void @srl_w_test() nounwind {
782entry:
783  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_srl_w_ARG1
784  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_srl_w_ARG2
785  %2 = lshr <4 x i32> %0, %1
786  store <4 x i32> %2, <4 x i32>* @llvm_mips_srl_w_RES
787  ret void
788}
789
790; CHECK: srl_w_test:
791; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_w_ARG1)
792; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_w_ARG2)
793; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
794; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
795; CHECK-DAG: srl.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
796; CHECK-DAG: st.w [[WD]]
797; CHECK: .size srl_w_test
798
799define void @srl_d_test() nounwind {
800entry:
801  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_srl_d_ARG1
802  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_srl_d_ARG2
803  %2 = lshr <2 x i64> %0, %1
804  store <2 x i64> %2, <2 x i64>* @llvm_mips_srl_d_RES
805  ret void
806}
807
808; CHECK: srl_d_test:
809; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_srl_d_ARG1)
810; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_srl_d_ARG2)
811; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
812; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
813; CHECK-DAG: srl.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
814; CHECK-DAG: st.d [[WD]]
815; CHECK: .size srl_d_test
816
817@llvm_mips_subs_s_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
818@llvm_mips_subs_s_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
819@llvm_mips_subs_s_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
820
821define void @llvm_mips_subs_s_b_test() nounwind {
822entry:
823  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subs_s_b_ARG1
824  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subs_s_b_ARG2
825  %2 = tail call <16 x i8> @llvm.mips.subs.s.b(<16 x i8> %0, <16 x i8> %1)
826  store <16 x i8> %2, <16 x i8>* @llvm_mips_subs_s_b_RES
827  ret void
828}
829
830declare <16 x i8> @llvm.mips.subs.s.b(<16 x i8>, <16 x i8>) nounwind
831
832; CHECK: llvm_mips_subs_s_b_test:
833; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_s_b_ARG1)
834; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_s_b_ARG2)
835; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
836; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
837; CHECK-DAG: subs_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
838; CHECK-DAG: st.b [[WD]]
839; CHECK: .size llvm_mips_subs_s_b_test
840;
841@llvm_mips_subs_s_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
842@llvm_mips_subs_s_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
843@llvm_mips_subs_s_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
844
845define void @llvm_mips_subs_s_h_test() nounwind {
846entry:
847  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subs_s_h_ARG1
848  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subs_s_h_ARG2
849  %2 = tail call <8 x i16> @llvm.mips.subs.s.h(<8 x i16> %0, <8 x i16> %1)
850  store <8 x i16> %2, <8 x i16>* @llvm_mips_subs_s_h_RES
851  ret void
852}
853
854declare <8 x i16> @llvm.mips.subs.s.h(<8 x i16>, <8 x i16>) nounwind
855
856; CHECK: llvm_mips_subs_s_h_test:
857; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_s_h_ARG1)
858; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_s_h_ARG2)
859; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
860; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
861; CHECK-DAG: subs_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
862; CHECK-DAG: st.h [[WD]]
863; CHECK: .size llvm_mips_subs_s_h_test
864;
865@llvm_mips_subs_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
866@llvm_mips_subs_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
867@llvm_mips_subs_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
868
869define void @llvm_mips_subs_s_w_test() nounwind {
870entry:
871  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subs_s_w_ARG1
872  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subs_s_w_ARG2
873  %2 = tail call <4 x i32> @llvm.mips.subs.s.w(<4 x i32> %0, <4 x i32> %1)
874  store <4 x i32> %2, <4 x i32>* @llvm_mips_subs_s_w_RES
875  ret void
876}
877
878declare <4 x i32> @llvm.mips.subs.s.w(<4 x i32>, <4 x i32>) nounwind
879
880; CHECK: llvm_mips_subs_s_w_test:
881; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_s_w_ARG1)
882; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_s_w_ARG2)
883; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
884; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
885; CHECK-DAG: subs_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
886; CHECK-DAG: st.w [[WD]]
887; CHECK: .size llvm_mips_subs_s_w_test
888;
889@llvm_mips_subs_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
890@llvm_mips_subs_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
891@llvm_mips_subs_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
892
893define void @llvm_mips_subs_s_d_test() nounwind {
894entry:
895  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subs_s_d_ARG1
896  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subs_s_d_ARG2
897  %2 = tail call <2 x i64> @llvm.mips.subs.s.d(<2 x i64> %0, <2 x i64> %1)
898  store <2 x i64> %2, <2 x i64>* @llvm_mips_subs_s_d_RES
899  ret void
900}
901
902declare <2 x i64> @llvm.mips.subs.s.d(<2 x i64>, <2 x i64>) nounwind
903
904; CHECK: llvm_mips_subs_s_d_test:
905; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_s_d_ARG1)
906; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_s_d_ARG2)
907; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
908; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
909; CHECK-DAG: subs_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
910; CHECK-DAG: st.d [[WD]]
911; CHECK: .size llvm_mips_subs_s_d_test
912;
913@llvm_mips_subs_u_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
914@llvm_mips_subs_u_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
915@llvm_mips_subs_u_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
916
917define void @llvm_mips_subs_u_b_test() nounwind {
918entry:
919  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subs_u_b_ARG1
920  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subs_u_b_ARG2
921  %2 = tail call <16 x i8> @llvm.mips.subs.u.b(<16 x i8> %0, <16 x i8> %1)
922  store <16 x i8> %2, <16 x i8>* @llvm_mips_subs_u_b_RES
923  ret void
924}
925
926declare <16 x i8> @llvm.mips.subs.u.b(<16 x i8>, <16 x i8>) nounwind
927
928; CHECK: llvm_mips_subs_u_b_test:
929; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_u_b_ARG1)
930; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_u_b_ARG2)
931; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
932; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
933; CHECK-DAG: subs_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
934; CHECK-DAG: st.b [[WD]]
935; CHECK: .size llvm_mips_subs_u_b_test
936;
937@llvm_mips_subs_u_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
938@llvm_mips_subs_u_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
939@llvm_mips_subs_u_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
940
941define void @llvm_mips_subs_u_h_test() nounwind {
942entry:
943  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subs_u_h_ARG1
944  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subs_u_h_ARG2
945  %2 = tail call <8 x i16> @llvm.mips.subs.u.h(<8 x i16> %0, <8 x i16> %1)
946  store <8 x i16> %2, <8 x i16>* @llvm_mips_subs_u_h_RES
947  ret void
948}
949
950declare <8 x i16> @llvm.mips.subs.u.h(<8 x i16>, <8 x i16>) nounwind
951
952; CHECK: llvm_mips_subs_u_h_test:
953; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_u_h_ARG1)
954; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_u_h_ARG2)
955; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
956; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
957; CHECK-DAG: subs_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
958; CHECK-DAG: st.h [[WD]]
959; CHECK: .size llvm_mips_subs_u_h_test
960;
961@llvm_mips_subs_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
962@llvm_mips_subs_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
963@llvm_mips_subs_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
964
965define void @llvm_mips_subs_u_w_test() nounwind {
966entry:
967  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subs_u_w_ARG1
968  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subs_u_w_ARG2
969  %2 = tail call <4 x i32> @llvm.mips.subs.u.w(<4 x i32> %0, <4 x i32> %1)
970  store <4 x i32> %2, <4 x i32>* @llvm_mips_subs_u_w_RES
971  ret void
972}
973
974declare <4 x i32> @llvm.mips.subs.u.w(<4 x i32>, <4 x i32>) nounwind
975
976; CHECK: llvm_mips_subs_u_w_test:
977; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_u_w_ARG1)
978; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_u_w_ARG2)
979; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
980; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
981; CHECK-DAG: subs_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
982; CHECK-DAG: st.w [[WD]]
983; CHECK: .size llvm_mips_subs_u_w_test
984;
985@llvm_mips_subs_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
986@llvm_mips_subs_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
987@llvm_mips_subs_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
988
989define void @llvm_mips_subs_u_d_test() nounwind {
990entry:
991  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subs_u_d_ARG1
992  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subs_u_d_ARG2
993  %2 = tail call <2 x i64> @llvm.mips.subs.u.d(<2 x i64> %0, <2 x i64> %1)
994  store <2 x i64> %2, <2 x i64>* @llvm_mips_subs_u_d_RES
995  ret void
996}
997
998declare <2 x i64> @llvm.mips.subs.u.d(<2 x i64>, <2 x i64>) nounwind
999
1000; CHECK: llvm_mips_subs_u_d_test:
1001; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subs_u_d_ARG1)
1002; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subs_u_d_ARG2)
1003; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1004; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1005; CHECK-DAG: subs_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1006; CHECK-DAG: st.d [[WD]]
1007; CHECK: .size llvm_mips_subs_u_d_test
1008;
1009@llvm_mips_subsus_u_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
1010@llvm_mips_subsus_u_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
1011@llvm_mips_subsus_u_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
1012
1013define void @llvm_mips_subsus_u_b_test() nounwind {
1014entry:
1015  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subsus_u_b_ARG1
1016  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subsus_u_b_ARG2
1017  %2 = tail call <16 x i8> @llvm.mips.subsus.u.b(<16 x i8> %0, <16 x i8> %1)
1018  store <16 x i8> %2, <16 x i8>* @llvm_mips_subsus_u_b_RES
1019  ret void
1020}
1021
1022declare <16 x i8> @llvm.mips.subsus.u.b(<16 x i8>, <16 x i8>) nounwind
1023
1024; CHECK: llvm_mips_subsus_u_b_test:
1025; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsus_u_b_ARG1)
1026; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsus_u_b_ARG2)
1027; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1028; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1029; CHECK-DAG: subsus_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1030; CHECK-DAG: st.b [[WD]]
1031; CHECK: .size llvm_mips_subsus_u_b_test
1032;
1033@llvm_mips_subsus_u_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
1034@llvm_mips_subsus_u_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
1035@llvm_mips_subsus_u_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
1036
1037define void @llvm_mips_subsus_u_h_test() nounwind {
1038entry:
1039  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subsus_u_h_ARG1
1040  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subsus_u_h_ARG2
1041  %2 = tail call <8 x i16> @llvm.mips.subsus.u.h(<8 x i16> %0, <8 x i16> %1)
1042  store <8 x i16> %2, <8 x i16>* @llvm_mips_subsus_u_h_RES
1043  ret void
1044}
1045
1046declare <8 x i16> @llvm.mips.subsus.u.h(<8 x i16>, <8 x i16>) nounwind
1047
1048; CHECK: llvm_mips_subsus_u_h_test:
1049; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsus_u_h_ARG1)
1050; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsus_u_h_ARG2)
1051; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1052; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1053; CHECK-DAG: subsus_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1054; CHECK-DAG: st.h [[WD]]
1055; CHECK: .size llvm_mips_subsus_u_h_test
1056;
1057@llvm_mips_subsus_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
1058@llvm_mips_subsus_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
1059@llvm_mips_subsus_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
1060
1061define void @llvm_mips_subsus_u_w_test() nounwind {
1062entry:
1063  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subsus_u_w_ARG1
1064  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subsus_u_w_ARG2
1065  %2 = tail call <4 x i32> @llvm.mips.subsus.u.w(<4 x i32> %0, <4 x i32> %1)
1066  store <4 x i32> %2, <4 x i32>* @llvm_mips_subsus_u_w_RES
1067  ret void
1068}
1069
1070declare <4 x i32> @llvm.mips.subsus.u.w(<4 x i32>, <4 x i32>) nounwind
1071
1072; CHECK: llvm_mips_subsus_u_w_test:
1073; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsus_u_w_ARG1)
1074; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsus_u_w_ARG2)
1075; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1076; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1077; CHECK-DAG: subsus_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1078; CHECK-DAG: st.w [[WD]]
1079; CHECK: .size llvm_mips_subsus_u_w_test
1080;
1081@llvm_mips_subsus_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
1082@llvm_mips_subsus_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
1083@llvm_mips_subsus_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
1084
1085define void @llvm_mips_subsus_u_d_test() nounwind {
1086entry:
1087  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subsus_u_d_ARG1
1088  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subsus_u_d_ARG2
1089  %2 = tail call <2 x i64> @llvm.mips.subsus.u.d(<2 x i64> %0, <2 x i64> %1)
1090  store <2 x i64> %2, <2 x i64>* @llvm_mips_subsus_u_d_RES
1091  ret void
1092}
1093
1094declare <2 x i64> @llvm.mips.subsus.u.d(<2 x i64>, <2 x i64>) nounwind
1095
1096; CHECK: llvm_mips_subsus_u_d_test:
1097; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsus_u_d_ARG1)
1098; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsus_u_d_ARG2)
1099; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1100; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1101; CHECK-DAG: subsus_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1102; CHECK-DAG: st.d [[WD]]
1103; CHECK: .size llvm_mips_subsus_u_d_test
1104;
1105@llvm_mips_subsuu_s_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
1106@llvm_mips_subsuu_s_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
1107@llvm_mips_subsuu_s_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
1108
1109define void @llvm_mips_subsuu_s_b_test() nounwind {
1110entry:
1111  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subsuu_s_b_ARG1
1112  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subsuu_s_b_ARG2
1113  %2 = tail call <16 x i8> @llvm.mips.subsuu.s.b(<16 x i8> %0, <16 x i8> %1)
1114  store <16 x i8> %2, <16 x i8>* @llvm_mips_subsuu_s_b_RES
1115  ret void
1116}
1117
1118declare <16 x i8> @llvm.mips.subsuu.s.b(<16 x i8>, <16 x i8>) nounwind
1119
1120; CHECK: llvm_mips_subsuu_s_b_test:
1121; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsuu_s_b_ARG1)
1122; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsuu_s_b_ARG2)
1123; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1124; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1125; CHECK-DAG: subsuu_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1126; CHECK-DAG: st.b [[WD]]
1127; CHECK: .size llvm_mips_subsuu_s_b_test
1128;
1129@llvm_mips_subsuu_s_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
1130@llvm_mips_subsuu_s_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
1131@llvm_mips_subsuu_s_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
1132
1133define void @llvm_mips_subsuu_s_h_test() nounwind {
1134entry:
1135  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subsuu_s_h_ARG1
1136  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subsuu_s_h_ARG2
1137  %2 = tail call <8 x i16> @llvm.mips.subsuu.s.h(<8 x i16> %0, <8 x i16> %1)
1138  store <8 x i16> %2, <8 x i16>* @llvm_mips_subsuu_s_h_RES
1139  ret void
1140}
1141
1142declare <8 x i16> @llvm.mips.subsuu.s.h(<8 x i16>, <8 x i16>) nounwind
1143
1144; CHECK: llvm_mips_subsuu_s_h_test:
1145; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsuu_s_h_ARG1)
1146; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsuu_s_h_ARG2)
1147; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1148; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1149; CHECK-DAG: subsuu_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1150; CHECK-DAG: st.h [[WD]]
1151; CHECK: .size llvm_mips_subsuu_s_h_test
1152;
1153@llvm_mips_subsuu_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
1154@llvm_mips_subsuu_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
1155@llvm_mips_subsuu_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
1156
1157define void @llvm_mips_subsuu_s_w_test() nounwind {
1158entry:
1159  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subsuu_s_w_ARG1
1160  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subsuu_s_w_ARG2
1161  %2 = tail call <4 x i32> @llvm.mips.subsuu.s.w(<4 x i32> %0, <4 x i32> %1)
1162  store <4 x i32> %2, <4 x i32>* @llvm_mips_subsuu_s_w_RES
1163  ret void
1164}
1165
1166declare <4 x i32> @llvm.mips.subsuu.s.w(<4 x i32>, <4 x i32>) nounwind
1167
1168; CHECK: llvm_mips_subsuu_s_w_test:
1169; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsuu_s_w_ARG1)
1170; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsuu_s_w_ARG2)
1171; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1172; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1173; CHECK-DAG: subsuu_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1174; CHECK-DAG: st.w [[WD]]
1175; CHECK: .size llvm_mips_subsuu_s_w_test
1176;
1177@llvm_mips_subsuu_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
1178@llvm_mips_subsuu_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
1179@llvm_mips_subsuu_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
1180
1181define void @llvm_mips_subsuu_s_d_test() nounwind {
1182entry:
1183  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subsuu_s_d_ARG1
1184  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subsuu_s_d_ARG2
1185  %2 = tail call <2 x i64> @llvm.mips.subsuu.s.d(<2 x i64> %0, <2 x i64> %1)
1186  store <2 x i64> %2, <2 x i64>* @llvm_mips_subsuu_s_d_RES
1187  ret void
1188}
1189
1190declare <2 x i64> @llvm.mips.subsuu.s.d(<2 x i64>, <2 x i64>) nounwind
1191
1192; CHECK: llvm_mips_subsuu_s_d_test:
1193; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subsuu_s_d_ARG1)
1194; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subsuu_s_d_ARG2)
1195; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1196; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1197; CHECK-DAG: subsuu_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1198; CHECK-DAG: st.d [[WD]]
1199; CHECK: .size llvm_mips_subsuu_s_d_test
1200;
1201@llvm_mips_subv_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16
1202@llvm_mips_subv_b_ARG2 = global <16 x i8> <i8 16, i8 17, i8 18, i8 19, i8 20, i8 21, i8 22, i8 23, i8 24, i8 25, i8 26, i8 27, i8 28, i8 29, i8 30, i8 31>, align 16
1203@llvm_mips_subv_b_RES  = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16
1204
1205define void @llvm_mips_subv_b_test() nounwind {
1206entry:
1207  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subv_b_ARG1
1208  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subv_b_ARG2
1209  %2 = tail call <16 x i8> @llvm.mips.subv.b(<16 x i8> %0, <16 x i8> %1)
1210  store <16 x i8> %2, <16 x i8>* @llvm_mips_subv_b_RES
1211  ret void
1212}
1213
1214declare <16 x i8> @llvm.mips.subv.b(<16 x i8>, <16 x i8>) nounwind
1215
1216; CHECK: llvm_mips_subv_b_test:
1217; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_b_ARG1)
1218; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_b_ARG2)
1219; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1220; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1221; CHECK-DAG: subv.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1222; CHECK-DAG: st.b [[WD]]
1223; CHECK: .size llvm_mips_subv_b_test
1224;
1225@llvm_mips_subv_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
1226@llvm_mips_subv_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
1227@llvm_mips_subv_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
1228
1229define void @llvm_mips_subv_h_test() nounwind {
1230entry:
1231  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subv_h_ARG1
1232  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subv_h_ARG2
1233  %2 = tail call <8 x i16> @llvm.mips.subv.h(<8 x i16> %0, <8 x i16> %1)
1234  store <8 x i16> %2, <8 x i16>* @llvm_mips_subv_h_RES
1235  ret void
1236}
1237
1238declare <8 x i16> @llvm.mips.subv.h(<8 x i16>, <8 x i16>) nounwind
1239
1240; CHECK: llvm_mips_subv_h_test:
1241; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_h_ARG1)
1242; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_h_ARG2)
1243; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1244; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1245; CHECK-DAG: subv.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1246; CHECK-DAG: st.h [[WD]]
1247; CHECK: .size llvm_mips_subv_h_test
1248;
1249@llvm_mips_subv_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
1250@llvm_mips_subv_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
1251@llvm_mips_subv_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
1252
1253define void @llvm_mips_subv_w_test() nounwind {
1254entry:
1255  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subv_w_ARG1
1256  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subv_w_ARG2
1257  %2 = tail call <4 x i32> @llvm.mips.subv.w(<4 x i32> %0, <4 x i32> %1)
1258  store <4 x i32> %2, <4 x i32>* @llvm_mips_subv_w_RES
1259  ret void
1260}
1261
1262declare <4 x i32> @llvm.mips.subv.w(<4 x i32>, <4 x i32>) nounwind
1263
1264; CHECK: llvm_mips_subv_w_test:
1265; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_w_ARG1)
1266; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_w_ARG2)
1267; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1268; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1269; CHECK-DAG: subv.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1270; CHECK-DAG: st.w [[WD]]
1271; CHECK: .size llvm_mips_subv_w_test
1272;
1273@llvm_mips_subv_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
1274@llvm_mips_subv_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
1275@llvm_mips_subv_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
1276
1277define void @llvm_mips_subv_d_test() nounwind {
1278entry:
1279  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subv_d_ARG1
1280  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subv_d_ARG2
1281  %2 = tail call <2 x i64> @llvm.mips.subv.d(<2 x i64> %0, <2 x i64> %1)
1282  store <2 x i64> %2, <2 x i64>* @llvm_mips_subv_d_RES
1283  ret void
1284}
1285
1286declare <2 x i64> @llvm.mips.subv.d(<2 x i64>, <2 x i64>) nounwind
1287
1288; CHECK: llvm_mips_subv_d_test:
1289; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_d_ARG1)
1290; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_d_ARG2)
1291; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1292; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1293; CHECK-DAG: subv.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1294; CHECK-DAG: st.d [[WD]]
1295; CHECK: .size llvm_mips_subv_d_test
1296;
1297
1298define void @subv_b_test() nounwind {
1299entry:
1300  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_subv_b_ARG1
1301  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_subv_b_ARG2
1302  %2 = sub <16 x i8> %0, %1
1303  store <16 x i8> %2, <16 x i8>* @llvm_mips_subv_b_RES
1304  ret void
1305}
1306
1307; CHECK: subv_b_test:
1308; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_b_ARG1)
1309; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_b_ARG2)
1310; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1311; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1312; CHECK-DAG: subv.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1313; CHECK-DAG: st.b [[WD]]
1314; CHECK: .size subv_b_test
1315
1316define void @subv_h_test() nounwind {
1317entry:
1318  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_subv_h_ARG1
1319  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_subv_h_ARG2
1320  %2 = sub <8 x i16> %0, %1
1321  store <8 x i16> %2, <8 x i16>* @llvm_mips_subv_h_RES
1322  ret void
1323}
1324
1325; CHECK: subv_h_test:
1326; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_h_ARG1)
1327; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_h_ARG2)
1328; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1329; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1330; CHECK-DAG: subv.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1331; CHECK-DAG: st.h [[WD]]
1332; CHECK: .size subv_h_test
1333
1334define void @subv_w_test() nounwind {
1335entry:
1336  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_subv_w_ARG1
1337  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_subv_w_ARG2
1338  %2 = sub <4 x i32> %0, %1
1339  store <4 x i32> %2, <4 x i32>* @llvm_mips_subv_w_RES
1340  ret void
1341}
1342
1343; CHECK: subv_w_test:
1344; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_w_ARG1)
1345; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_w_ARG2)
1346; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1347; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1348; CHECK-DAG: subv.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1349; CHECK-DAG: st.w [[WD]]
1350; CHECK: .size subv_w_test
1351
1352define void @subv_d_test() nounwind {
1353entry:
1354  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_subv_d_ARG1
1355  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_subv_d_ARG2
1356  %2 = sub <2 x i64> %0, %1
1357  store <2 x i64> %2, <2 x i64>* @llvm_mips_subv_d_RES
1358  ret void
1359}
1360
1361; CHECK: subv_d_test:
1362; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_subv_d_ARG1)
1363; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_subv_d_ARG2)
1364; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1365; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1366; CHECK-DAG: subv.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1367; CHECK-DAG: st.d [[WD]]
1368; CHECK: .size subv_d_test
1369;
1370