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 'a'
3
4; RUN: llc -march=mips -mattr=+msa,+fp64 -relocation-model=pic < %s | FileCheck %s
5; RUN: llc -march=mipsel -mattr=+msa,+fp64 -relocation-model=pic < %s | FileCheck %s
6
7; It should fail to compile without fp64.
8; RUN: not llc -march=mips -mattr=+msa < %s 2>&1 | \
9; RUN:    FileCheck -check-prefix=FP32ERROR %s
10; FP32ERROR: LLVM ERROR: MSA requires a 64-bit FPU register file (FR=1 mode).
11
12@llvm_mips_add_a_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
13@llvm_mips_add_a_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
14@llvm_mips_add_a_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
15
16define void @llvm_mips_add_a_b_test() nounwind {
17entry:
18  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_add_a_b_ARG1
19  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_add_a_b_ARG2
20  %2 = tail call <16 x i8> @llvm.mips.add.a.b(<16 x i8> %0, <16 x i8> %1)
21  store <16 x i8> %2, <16 x i8>* @llvm_mips_add_a_b_RES
22  ret void
23}
24
25declare <16 x i8> @llvm.mips.add.a.b(<16 x i8>, <16 x i8>) nounwind
26
27; CHECK: llvm_mips_add_a_b_test:
28; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_add_a_b_ARG1)
29; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_add_a_b_ARG2)
30; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
31; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
32; CHECK-DAG: add_a.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
33; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_add_a_b_RES)
34; CHECK-DAG: st.b [[WD]], 0([[R3]])
35; CHECK: .size llvm_mips_add_a_b_test
36;
37@llvm_mips_add_a_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
38@llvm_mips_add_a_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
39@llvm_mips_add_a_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
40
41define void @llvm_mips_add_a_h_test() nounwind {
42entry:
43  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_add_a_h_ARG1
44  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_add_a_h_ARG2
45  %2 = tail call <8 x i16> @llvm.mips.add.a.h(<8 x i16> %0, <8 x i16> %1)
46  store <8 x i16> %2, <8 x i16>* @llvm_mips_add_a_h_RES
47  ret void
48}
49
50declare <8 x i16> @llvm.mips.add.a.h(<8 x i16>, <8 x i16>) nounwind
51
52; CHECK: llvm_mips_add_a_h_test:
53; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_add_a_h_ARG1)
54; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_add_a_h_ARG2)
55; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
56; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
57; CHECK-DAG: add_a.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
58; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_add_a_h_RES)
59; CHECK-DAG: st.h [[WD]], 0([[R3]])
60; CHECK: .size llvm_mips_add_a_h_test
61;
62@llvm_mips_add_a_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
63@llvm_mips_add_a_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
64@llvm_mips_add_a_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
65
66define void @llvm_mips_add_a_w_test() nounwind {
67entry:
68  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_add_a_w_ARG1
69  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_add_a_w_ARG2
70  %2 = tail call <4 x i32> @llvm.mips.add.a.w(<4 x i32> %0, <4 x i32> %1)
71  store <4 x i32> %2, <4 x i32>* @llvm_mips_add_a_w_RES
72  ret void
73}
74
75declare <4 x i32> @llvm.mips.add.a.w(<4 x i32>, <4 x i32>) nounwind
76
77; CHECK: llvm_mips_add_a_w_test:
78; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_add_a_w_ARG1)
79; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_add_a_w_ARG2)
80; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
81; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
82; CHECK-DAG: add_a.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
83; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_add_a_w_RES)
84; CHECK-DAG: st.w [[WD]], 0([[R3]])
85; CHECK: .size llvm_mips_add_a_w_test
86;
87@llvm_mips_add_a_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
88@llvm_mips_add_a_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
89@llvm_mips_add_a_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
90
91define void @llvm_mips_add_a_d_test() nounwind {
92entry:
93  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_add_a_d_ARG1
94  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_add_a_d_ARG2
95  %2 = tail call <2 x i64> @llvm.mips.add.a.d(<2 x i64> %0, <2 x i64> %1)
96  store <2 x i64> %2, <2 x i64>* @llvm_mips_add_a_d_RES
97  ret void
98}
99
100declare <2 x i64> @llvm.mips.add.a.d(<2 x i64>, <2 x i64>) nounwind
101
102; CHECK: llvm_mips_add_a_d_test:
103; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_add_a_d_ARG1)
104; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_add_a_d_ARG2)
105; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
106; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
107; CHECK-DAG: add_a.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
108; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_add_a_d_RES)
109; CHECK-DAG: st.d [[WD]], 0([[R3]])
110; CHECK: .size llvm_mips_add_a_d_test
111;
112@llvm_mips_adds_a_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
113@llvm_mips_adds_a_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
114@llvm_mips_adds_a_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
115
116define void @llvm_mips_adds_a_b_test() nounwind {
117entry:
118  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_a_b_ARG1
119  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_a_b_ARG2
120  %2 = tail call <16 x i8> @llvm.mips.adds.a.b(<16 x i8> %0, <16 x i8> %1)
121  store <16 x i8> %2, <16 x i8>* @llvm_mips_adds_a_b_RES
122  ret void
123}
124
125declare <16 x i8> @llvm.mips.adds.a.b(<16 x i8>, <16 x i8>) nounwind
126
127; CHECK: llvm_mips_adds_a_b_test:
128; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_a_b_ARG1)
129; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_a_b_ARG2)
130; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
131; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
132; CHECK-DAG: adds_a.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
133; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_a_b_RES)
134; CHECK-DAG: st.b [[WD]], 0([[R3]])
135; CHECK: .size llvm_mips_adds_a_b_test
136;
137@llvm_mips_adds_a_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
138@llvm_mips_adds_a_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
139@llvm_mips_adds_a_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
140
141define void @llvm_mips_adds_a_h_test() nounwind {
142entry:
143  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_a_h_ARG1
144  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_a_h_ARG2
145  %2 = tail call <8 x i16> @llvm.mips.adds.a.h(<8 x i16> %0, <8 x i16> %1)
146  store <8 x i16> %2, <8 x i16>* @llvm_mips_adds_a_h_RES
147  ret void
148}
149
150declare <8 x i16> @llvm.mips.adds.a.h(<8 x i16>, <8 x i16>) nounwind
151
152; CHECK: llvm_mips_adds_a_h_test:
153; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_a_h_ARG1)
154; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_a_h_ARG2)
155; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
156; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
157; CHECK-DAG: adds_a.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
158; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_a_h_RES)
159; CHECK-DAG: st.h [[WD]], 0([[R3]])
160; CHECK: .size llvm_mips_adds_a_h_test
161;
162@llvm_mips_adds_a_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
163@llvm_mips_adds_a_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
164@llvm_mips_adds_a_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
165
166define void @llvm_mips_adds_a_w_test() nounwind {
167entry:
168  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_a_w_ARG1
169  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_a_w_ARG2
170  %2 = tail call <4 x i32> @llvm.mips.adds.a.w(<4 x i32> %0, <4 x i32> %1)
171  store <4 x i32> %2, <4 x i32>* @llvm_mips_adds_a_w_RES
172  ret void
173}
174
175declare <4 x i32> @llvm.mips.adds.a.w(<4 x i32>, <4 x i32>) nounwind
176
177; CHECK: llvm_mips_adds_a_w_test:
178; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_a_w_ARG1)
179; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_a_w_ARG2)
180; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
181; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
182; CHECK-DAG: adds_a.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
183; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_a_w_RES)
184; CHECK-DAG: st.w [[WD]], 0([[R3]])
185; CHECK: .size llvm_mips_adds_a_w_test
186;
187@llvm_mips_adds_a_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
188@llvm_mips_adds_a_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
189@llvm_mips_adds_a_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
190
191define void @llvm_mips_adds_a_d_test() nounwind {
192entry:
193  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_a_d_ARG1
194  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_a_d_ARG2
195  %2 = tail call <2 x i64> @llvm.mips.adds.a.d(<2 x i64> %0, <2 x i64> %1)
196  store <2 x i64> %2, <2 x i64>* @llvm_mips_adds_a_d_RES
197  ret void
198}
199
200declare <2 x i64> @llvm.mips.adds.a.d(<2 x i64>, <2 x i64>) nounwind
201
202; CHECK: llvm_mips_adds_a_d_test:
203; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_a_d_ARG1)
204; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_a_d_ARG2)
205; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
206; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
207; CHECK-DAG: adds_a.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
208; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_a_d_RES)
209; CHECK-DAG: st.d [[WD]], 0([[R3]])
210; CHECK: .size llvm_mips_adds_a_d_test
211;
212@llvm_mips_adds_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
213@llvm_mips_adds_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
214@llvm_mips_adds_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
215
216define void @llvm_mips_adds_s_b_test() nounwind {
217entry:
218  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_s_b_ARG1
219  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_s_b_ARG2
220  %2 = tail call <16 x i8> @llvm.mips.adds.s.b(<16 x i8> %0, <16 x i8> %1)
221  store <16 x i8> %2, <16 x i8>* @llvm_mips_adds_s_b_RES
222  ret void
223}
224
225declare <16 x i8> @llvm.mips.adds.s.b(<16 x i8>, <16 x i8>) nounwind
226
227; CHECK: llvm_mips_adds_s_b_test:
228; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_s_b_ARG1)
229; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_s_b_ARG2)
230; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
231; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
232; CHECK-DAG: adds_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
233; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_s_b_RES)
234; CHECK-DAG: st.b [[WD]], 0([[R3]])
235; CHECK: .size llvm_mips_adds_s_b_test
236;
237@llvm_mips_adds_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
238@llvm_mips_adds_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
239@llvm_mips_adds_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
240
241define void @llvm_mips_adds_s_h_test() nounwind {
242entry:
243  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_s_h_ARG1
244  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_s_h_ARG2
245  %2 = tail call <8 x i16> @llvm.mips.adds.s.h(<8 x i16> %0, <8 x i16> %1)
246  store <8 x i16> %2, <8 x i16>* @llvm_mips_adds_s_h_RES
247  ret void
248}
249
250declare <8 x i16> @llvm.mips.adds.s.h(<8 x i16>, <8 x i16>) nounwind
251
252; CHECK: llvm_mips_adds_s_h_test:
253; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_s_h_ARG1)
254; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_s_h_ARG2)
255; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
256; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
257; CHECK-DAG: adds_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
258; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_s_h_RES)
259; CHECK-DAG: st.h [[WD]], 0([[R3]])
260; CHECK: .size llvm_mips_adds_s_h_test
261;
262@llvm_mips_adds_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
263@llvm_mips_adds_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
264@llvm_mips_adds_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
265
266define void @llvm_mips_adds_s_w_test() nounwind {
267entry:
268  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_s_w_ARG1
269  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_s_w_ARG2
270  %2 = tail call <4 x i32> @llvm.mips.adds.s.w(<4 x i32> %0, <4 x i32> %1)
271  store <4 x i32> %2, <4 x i32>* @llvm_mips_adds_s_w_RES
272  ret void
273}
274
275declare <4 x i32> @llvm.mips.adds.s.w(<4 x i32>, <4 x i32>) nounwind
276
277; CHECK: llvm_mips_adds_s_w_test:
278; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_s_w_ARG1)
279; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_s_w_ARG2)
280; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
281; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
282; CHECK-DAG: adds_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
283; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_s_w_RES)
284; CHECK-DAG: st.w [[WD]], 0([[R3]])
285; CHECK: .size llvm_mips_adds_s_w_test
286;
287@llvm_mips_adds_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
288@llvm_mips_adds_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
289@llvm_mips_adds_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
290
291define void @llvm_mips_adds_s_d_test() nounwind {
292entry:
293  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_s_d_ARG1
294  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_s_d_ARG2
295  %2 = tail call <2 x i64> @llvm.mips.adds.s.d(<2 x i64> %0, <2 x i64> %1)
296  store <2 x i64> %2, <2 x i64>* @llvm_mips_adds_s_d_RES
297  ret void
298}
299
300declare <2 x i64> @llvm.mips.adds.s.d(<2 x i64>, <2 x i64>) nounwind
301
302; CHECK: llvm_mips_adds_s_d_test:
303; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_s_d_ARG1)
304; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_s_d_ARG2)
305; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
306; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
307; CHECK-DAG: adds_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
308; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_s_d_RES)
309; CHECK-DAG: st.d [[WD]], 0([[R3]])
310; CHECK: .size llvm_mips_adds_s_d_test
311;
312@llvm_mips_adds_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
313@llvm_mips_adds_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
314@llvm_mips_adds_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
315
316define void @llvm_mips_adds_u_b_test() nounwind {
317entry:
318  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_u_b_ARG1
319  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_adds_u_b_ARG2
320  %2 = tail call <16 x i8> @llvm.mips.adds.u.b(<16 x i8> %0, <16 x i8> %1)
321  store <16 x i8> %2, <16 x i8>* @llvm_mips_adds_u_b_RES
322  ret void
323}
324
325declare <16 x i8> @llvm.mips.adds.u.b(<16 x i8>, <16 x i8>) nounwind
326
327; CHECK: llvm_mips_adds_u_b_test:
328; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_u_b_ARG1)
329; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_u_b_ARG2)
330; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
331; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
332; CHECK-DAG: adds_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
333; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_u_b_RES)
334; CHECK-DAG: st.b [[WD]], 0([[R3]])
335; CHECK: .size llvm_mips_adds_u_b_test
336;
337@llvm_mips_adds_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
338@llvm_mips_adds_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
339@llvm_mips_adds_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
340
341define void @llvm_mips_adds_u_h_test() nounwind {
342entry:
343  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_u_h_ARG1
344  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_adds_u_h_ARG2
345  %2 = tail call <8 x i16> @llvm.mips.adds.u.h(<8 x i16> %0, <8 x i16> %1)
346  store <8 x i16> %2, <8 x i16>* @llvm_mips_adds_u_h_RES
347  ret void
348}
349
350declare <8 x i16> @llvm.mips.adds.u.h(<8 x i16>, <8 x i16>) nounwind
351
352; CHECK: llvm_mips_adds_u_h_test:
353; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_u_h_ARG1)
354; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_u_h_ARG2)
355; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
356; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
357; CHECK-DAG: adds_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
358; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_u_h_RES)
359; CHECK-DAG: st.h [[WD]], 0([[R3]])
360; CHECK: .size llvm_mips_adds_u_h_test
361;
362@llvm_mips_adds_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
363@llvm_mips_adds_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
364@llvm_mips_adds_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
365
366define void @llvm_mips_adds_u_w_test() nounwind {
367entry:
368  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_u_w_ARG1
369  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_adds_u_w_ARG2
370  %2 = tail call <4 x i32> @llvm.mips.adds.u.w(<4 x i32> %0, <4 x i32> %1)
371  store <4 x i32> %2, <4 x i32>* @llvm_mips_adds_u_w_RES
372  ret void
373}
374
375declare <4 x i32> @llvm.mips.adds.u.w(<4 x i32>, <4 x i32>) nounwind
376
377; CHECK: llvm_mips_adds_u_w_test:
378; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_u_w_ARG1)
379; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_u_w_ARG2)
380; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
381; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
382; CHECK-DAG: adds_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
383; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_u_w_RES)
384; CHECK-DAG: st.w [[WD]], 0([[R3]])
385; CHECK: .size llvm_mips_adds_u_w_test
386;
387@llvm_mips_adds_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
388@llvm_mips_adds_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
389@llvm_mips_adds_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
390
391define void @llvm_mips_adds_u_d_test() nounwind {
392entry:
393  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_u_d_ARG1
394  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_adds_u_d_ARG2
395  %2 = tail call <2 x i64> @llvm.mips.adds.u.d(<2 x i64> %0, <2 x i64> %1)
396  store <2 x i64> %2, <2 x i64>* @llvm_mips_adds_u_d_RES
397  ret void
398}
399
400declare <2 x i64> @llvm.mips.adds.u.d(<2 x i64>, <2 x i64>) nounwind
401
402; CHECK: llvm_mips_adds_u_d_test:
403; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_adds_u_d_ARG1)
404; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_adds_u_d_ARG2)
405; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
406; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
407; CHECK-DAG: adds_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
408; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_adds_u_d_RES)
409; CHECK-DAG: st.d [[WD]], 0([[R3]])
410; CHECK: .size llvm_mips_adds_u_d_test
411;
412@llvm_mips_addv_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
413@llvm_mips_addv_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
414@llvm_mips_addv_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
415
416define void @llvm_mips_addv_b_test() nounwind {
417entry:
418  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_addv_b_ARG1
419  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_addv_b_ARG2
420  %2 = tail call <16 x i8> @llvm.mips.addv.b(<16 x i8> %0, <16 x i8> %1)
421  store <16 x i8> %2, <16 x i8>* @llvm_mips_addv_b_RES
422  ret void
423}
424
425declare <16 x i8> @llvm.mips.addv.b(<16 x i8>, <16 x i8>) nounwind
426
427; CHECK: llvm_mips_addv_b_test:
428; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_b_ARG1)
429; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_b_ARG2)
430; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
431; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
432; CHECK-DAG: addv.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
433; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_b_RES)
434; CHECK-DAG: st.b [[WD]], 0([[R3]])
435; CHECK: .size llvm_mips_addv_b_test
436;
437@llvm_mips_addv_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16
438@llvm_mips_addv_h_ARG2 = global <8 x i16> <i16 8, i16 9, i16 10, i16 11, i16 12, i16 13, i16 14, i16 15>, align 16
439@llvm_mips_addv_h_RES  = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16
440
441define void @llvm_mips_addv_h_test() nounwind {
442entry:
443  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_addv_h_ARG1
444  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_addv_h_ARG2
445  %2 = tail call <8 x i16> @llvm.mips.addv.h(<8 x i16> %0, <8 x i16> %1)
446  store <8 x i16> %2, <8 x i16>* @llvm_mips_addv_h_RES
447  ret void
448}
449
450declare <8 x i16> @llvm.mips.addv.h(<8 x i16>, <8 x i16>) nounwind
451
452; CHECK: llvm_mips_addv_h_test:
453; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_h_ARG1)
454; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_h_ARG2)
455; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
456; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
457; CHECK-DAG: addv.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
458; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_h_RES)
459; CHECK-DAG: st.h [[WD]], 0([[R3]])
460; CHECK: .size llvm_mips_addv_h_test
461;
462@llvm_mips_addv_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
463@llvm_mips_addv_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
464@llvm_mips_addv_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
465
466define void @llvm_mips_addv_w_test() nounwind {
467entry:
468  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_addv_w_ARG1
469  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_addv_w_ARG2
470  %2 = tail call <4 x i32> @llvm.mips.addv.w(<4 x i32> %0, <4 x i32> %1)
471  store <4 x i32> %2, <4 x i32>* @llvm_mips_addv_w_RES
472  ret void
473}
474
475declare <4 x i32> @llvm.mips.addv.w(<4 x i32>, <4 x i32>) nounwind
476
477; CHECK: llvm_mips_addv_w_test:
478; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_w_ARG1)
479; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_w_ARG2)
480; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
481; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
482; CHECK-DAG: addv.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
483; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_w_RES)
484; CHECK-DAG: st.w [[WD]], 0([[R3]])
485; CHECK: .size llvm_mips_addv_w_test
486;
487@llvm_mips_addv_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
488@llvm_mips_addv_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
489@llvm_mips_addv_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
490
491define void @llvm_mips_addv_d_test() nounwind {
492entry:
493  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_addv_d_ARG1
494  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_addv_d_ARG2
495  %2 = tail call <2 x i64> @llvm.mips.addv.d(<2 x i64> %0, <2 x i64> %1)
496  store <2 x i64> %2, <2 x i64>* @llvm_mips_addv_d_RES
497  ret void
498}
499
500declare <2 x i64> @llvm.mips.addv.d(<2 x i64>, <2 x i64>) nounwind
501
502; CHECK: llvm_mips_addv_d_test:
503; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_d_ARG1)
504; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_d_ARG2)
505; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
506; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
507; CHECK-DAG: addv.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
508; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_d_RES)
509; CHECK-DAG: st.d [[WD]], 0([[R3]])
510; CHECK: .size llvm_mips_addv_d_test
511;
512
513define void @addv_b_test() nounwind {
514entry:
515  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_addv_b_ARG1
516  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_addv_b_ARG2
517  %2 = add <16 x i8> %0, %1
518  store <16 x i8> %2, <16 x i8>* @llvm_mips_addv_b_RES
519  ret void
520}
521
522; CHECK: addv_b_test:
523; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_b_ARG1)
524; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_b_ARG2)
525; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
526; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
527; CHECK-DAG: addv.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
528; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_b_RES)
529; CHECK-DAG: st.b [[WD]], 0([[R3]])
530; CHECK: .size addv_b_test
531;
532
533define void @addv_h_test() nounwind {
534entry:
535  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_addv_h_ARG1
536  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_addv_h_ARG2
537  %2 = add <8 x i16> %0, %1
538  store <8 x i16> %2, <8 x i16>* @llvm_mips_addv_h_RES
539  ret void
540}
541
542; CHECK: addv_h_test:
543; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_h_ARG1)
544; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_h_ARG2)
545; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
546; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
547; CHECK-DAG: addv.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
548; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_h_RES)
549; CHECK-DAG: st.h [[WD]], 0([[R3]])
550; CHECK: .size addv_h_test
551;
552
553define void @addv_w_test() nounwind {
554entry:
555  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_addv_w_ARG1
556  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_addv_w_ARG2
557  %2 = add <4 x i32> %0, %1
558  store <4 x i32> %2, <4 x i32>* @llvm_mips_addv_w_RES
559  ret void
560}
561
562; CHECK: addv_w_test:
563; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_w_ARG1)
564; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_w_ARG2)
565; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
566; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
567; CHECK-DAG: addv.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
568; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_w_RES)
569; CHECK-DAG: st.w [[WD]], 0([[R3]])
570; CHECK: .size addv_w_test
571;
572
573define void @addv_d_test() nounwind {
574entry:
575  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_addv_d_ARG1
576  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_addv_d_ARG2
577  %2 = add <2 x i64> %0, %1
578  store <2 x i64> %2, <2 x i64>* @llvm_mips_addv_d_RES
579  ret void
580}
581
582; CHECK: addv_d_test:
583; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_addv_d_ARG1)
584; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_addv_d_ARG2)
585; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
586; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
587; CHECK-DAG: addv.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
588; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_addv_d_RES)
589; CHECK-DAG: st.d [[WD]], 0([[R3]])
590; CHECK: .size addv_d_test
591;
592@llvm_mips_asub_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
593@llvm_mips_asub_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
594@llvm_mips_asub_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
595
596define void @llvm_mips_asub_s_b_test() nounwind {
597entry:
598  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_asub_s_b_ARG1
599  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_asub_s_b_ARG2
600  %2 = tail call <16 x i8> @llvm.mips.asub.s.b(<16 x i8> %0, <16 x i8> %1)
601  store <16 x i8> %2, <16 x i8>* @llvm_mips_asub_s_b_RES
602  ret void
603}
604
605declare <16 x i8> @llvm.mips.asub.s.b(<16 x i8>, <16 x i8>) nounwind
606
607; CHECK: llvm_mips_asub_s_b_test:
608; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_s_b_ARG1)
609; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_s_b_ARG2)
610; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
611; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
612; CHECK-DAG: asub_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
613; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_s_b_RES)
614; CHECK-DAG: st.b [[WD]], 0([[R3]])
615; CHECK: .size llvm_mips_asub_s_b_test
616;
617@llvm_mips_asub_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
618@llvm_mips_asub_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
619@llvm_mips_asub_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
620
621define void @llvm_mips_asub_s_h_test() nounwind {
622entry:
623  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_asub_s_h_ARG1
624  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_asub_s_h_ARG2
625  %2 = tail call <8 x i16> @llvm.mips.asub.s.h(<8 x i16> %0, <8 x i16> %1)
626  store <8 x i16> %2, <8 x i16>* @llvm_mips_asub_s_h_RES
627  ret void
628}
629
630declare <8 x i16> @llvm.mips.asub.s.h(<8 x i16>, <8 x i16>) nounwind
631
632; CHECK: llvm_mips_asub_s_h_test:
633; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_s_h_ARG1)
634; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_s_h_ARG2)
635; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
636; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
637; CHECK-DAG: asub_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
638; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_s_h_RES)
639; CHECK-DAG: st.h [[WD]], 0([[R3]])
640; CHECK: .size llvm_mips_asub_s_h_test
641;
642@llvm_mips_asub_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
643@llvm_mips_asub_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
644@llvm_mips_asub_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
645
646define void @llvm_mips_asub_s_w_test() nounwind {
647entry:
648  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_asub_s_w_ARG1
649  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_asub_s_w_ARG2
650  %2 = tail call <4 x i32> @llvm.mips.asub.s.w(<4 x i32> %0, <4 x i32> %1)
651  store <4 x i32> %2, <4 x i32>* @llvm_mips_asub_s_w_RES
652  ret void
653}
654
655declare <4 x i32> @llvm.mips.asub.s.w(<4 x i32>, <4 x i32>) nounwind
656
657; CHECK: llvm_mips_asub_s_w_test:
658; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_s_w_ARG1)
659; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_s_w_ARG2)
660; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
661; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
662; CHECK-DAG: asub_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
663; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_s_w_RES)
664; CHECK-DAG: st.w [[WD]], 0([[R3]])
665; CHECK: .size llvm_mips_asub_s_w_test
666;
667@llvm_mips_asub_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
668@llvm_mips_asub_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
669@llvm_mips_asub_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
670
671define void @llvm_mips_asub_s_d_test() nounwind {
672entry:
673  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_asub_s_d_ARG1
674  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_asub_s_d_ARG2
675  %2 = tail call <2 x i64> @llvm.mips.asub.s.d(<2 x i64> %0, <2 x i64> %1)
676  store <2 x i64> %2, <2 x i64>* @llvm_mips_asub_s_d_RES
677  ret void
678}
679
680declare <2 x i64> @llvm.mips.asub.s.d(<2 x i64>, <2 x i64>) nounwind
681
682; CHECK: llvm_mips_asub_s_d_test:
683; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_s_d_ARG1)
684; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_s_d_ARG2)
685; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
686; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
687; CHECK-DAG: asub_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
688; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_s_d_RES)
689; CHECK-DAG: st.d [[WD]], 0([[R3]])
690; CHECK: .size llvm_mips_asub_s_d_test
691;
692@llvm_mips_asub_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
693@llvm_mips_asub_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
694@llvm_mips_asub_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
695
696define void @llvm_mips_asub_u_b_test() nounwind {
697entry:
698  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_asub_u_b_ARG1
699  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_asub_u_b_ARG2
700  %2 = tail call <16 x i8> @llvm.mips.asub.u.b(<16 x i8> %0, <16 x i8> %1)
701  store <16 x i8> %2, <16 x i8>* @llvm_mips_asub_u_b_RES
702  ret void
703}
704
705declare <16 x i8> @llvm.mips.asub.u.b(<16 x i8>, <16 x i8>) nounwind
706
707; CHECK: llvm_mips_asub_u_b_test:
708; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_u_b_ARG1)
709; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_u_b_ARG2)
710; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
711; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
712; CHECK-DAG: asub_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
713; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_u_b_RES)
714; CHECK-DAG: st.b [[WD]], 0([[R3]])
715; CHECK: .size llvm_mips_asub_u_b_test
716;
717@llvm_mips_asub_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
718@llvm_mips_asub_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
719@llvm_mips_asub_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
720
721define void @llvm_mips_asub_u_h_test() nounwind {
722entry:
723  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_asub_u_h_ARG1
724  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_asub_u_h_ARG2
725  %2 = tail call <8 x i16> @llvm.mips.asub.u.h(<8 x i16> %0, <8 x i16> %1)
726  store <8 x i16> %2, <8 x i16>* @llvm_mips_asub_u_h_RES
727  ret void
728}
729
730declare <8 x i16> @llvm.mips.asub.u.h(<8 x i16>, <8 x i16>) nounwind
731
732; CHECK: llvm_mips_asub_u_h_test:
733; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_u_h_ARG1)
734; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_u_h_ARG2)
735; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
736; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
737; CHECK-DAG: asub_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
738; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_u_h_RES)
739; CHECK-DAG: st.h [[WD]], 0([[R3]])
740; CHECK: .size llvm_mips_asub_u_h_test
741;
742@llvm_mips_asub_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
743@llvm_mips_asub_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
744@llvm_mips_asub_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
745
746define void @llvm_mips_asub_u_w_test() nounwind {
747entry:
748  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_asub_u_w_ARG1
749  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_asub_u_w_ARG2
750  %2 = tail call <4 x i32> @llvm.mips.asub.u.w(<4 x i32> %0, <4 x i32> %1)
751  store <4 x i32> %2, <4 x i32>* @llvm_mips_asub_u_w_RES
752  ret void
753}
754
755declare <4 x i32> @llvm.mips.asub.u.w(<4 x i32>, <4 x i32>) nounwind
756
757; CHECK: llvm_mips_asub_u_w_test:
758; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_u_w_ARG1)
759; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_u_w_ARG2)
760; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
761; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
762; CHECK-DAG: asub_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
763; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_u_w_RES)
764; CHECK-DAG: st.w [[WD]], 0([[R3]])
765; CHECK: .size llvm_mips_asub_u_w_test
766;
767@llvm_mips_asub_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
768@llvm_mips_asub_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
769@llvm_mips_asub_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
770
771define void @llvm_mips_asub_u_d_test() nounwind {
772entry:
773  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_asub_u_d_ARG1
774  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_asub_u_d_ARG2
775  %2 = tail call <2 x i64> @llvm.mips.asub.u.d(<2 x i64> %0, <2 x i64> %1)
776  store <2 x i64> %2, <2 x i64>* @llvm_mips_asub_u_d_RES
777  ret void
778}
779
780declare <2 x i64> @llvm.mips.asub.u.d(<2 x i64>, <2 x i64>) nounwind
781
782; CHECK: llvm_mips_asub_u_d_test:
783; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_asub_u_d_ARG1)
784; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_asub_u_d_ARG2)
785; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
786; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
787; CHECK-DAG: asub_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
788; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_asub_u_d_RES)
789; CHECK-DAG: st.d [[WD]], 0([[R3]])
790; CHECK: .size llvm_mips_asub_u_d_test
791;
792@llvm_mips_ave_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
793@llvm_mips_ave_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
794@llvm_mips_ave_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
795
796define void @llvm_mips_ave_s_b_test() nounwind {
797entry:
798  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_ave_s_b_ARG1
799  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_ave_s_b_ARG2
800  %2 = tail call <16 x i8> @llvm.mips.ave.s.b(<16 x i8> %0, <16 x i8> %1)
801  store <16 x i8> %2, <16 x i8>* @llvm_mips_ave_s_b_RES
802  ret void
803}
804
805declare <16 x i8> @llvm.mips.ave.s.b(<16 x i8>, <16 x i8>) nounwind
806
807; CHECK: llvm_mips_ave_s_b_test:
808; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_s_b_ARG1)
809; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_s_b_ARG2)
810; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
811; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
812; CHECK-DAG: ave_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
813; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_s_b_RES)
814; CHECK-DAG: st.b [[WD]], 0([[R3]])
815; CHECK: .size llvm_mips_ave_s_b_test
816;
817@llvm_mips_ave_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
818@llvm_mips_ave_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
819@llvm_mips_ave_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
820
821define void @llvm_mips_ave_s_h_test() nounwind {
822entry:
823  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_ave_s_h_ARG1
824  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_ave_s_h_ARG2
825  %2 = tail call <8 x i16> @llvm.mips.ave.s.h(<8 x i16> %0, <8 x i16> %1)
826  store <8 x i16> %2, <8 x i16>* @llvm_mips_ave_s_h_RES
827  ret void
828}
829
830declare <8 x i16> @llvm.mips.ave.s.h(<8 x i16>, <8 x i16>) nounwind
831
832; CHECK: llvm_mips_ave_s_h_test:
833; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_s_h_ARG1)
834; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_s_h_ARG2)
835; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
836; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
837; CHECK-DAG: ave_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
838; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_s_h_RES)
839; CHECK-DAG: st.h [[WD]], 0([[R3]])
840; CHECK: .size llvm_mips_ave_s_h_test
841;
842@llvm_mips_ave_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
843@llvm_mips_ave_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
844@llvm_mips_ave_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
845
846define void @llvm_mips_ave_s_w_test() nounwind {
847entry:
848  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_ave_s_w_ARG1
849  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_ave_s_w_ARG2
850  %2 = tail call <4 x i32> @llvm.mips.ave.s.w(<4 x i32> %0, <4 x i32> %1)
851  store <4 x i32> %2, <4 x i32>* @llvm_mips_ave_s_w_RES
852  ret void
853}
854
855declare <4 x i32> @llvm.mips.ave.s.w(<4 x i32>, <4 x i32>) nounwind
856
857; CHECK: llvm_mips_ave_s_w_test:
858; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_s_w_ARG1)
859; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_s_w_ARG2)
860; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
861; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
862; CHECK-DAG: ave_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
863; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_s_w_RES)
864; CHECK-DAG: st.w [[WD]], 0([[R3]])
865; CHECK: .size llvm_mips_ave_s_w_test
866;
867@llvm_mips_ave_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
868@llvm_mips_ave_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
869@llvm_mips_ave_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
870
871define void @llvm_mips_ave_s_d_test() nounwind {
872entry:
873  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_ave_s_d_ARG1
874  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_ave_s_d_ARG2
875  %2 = tail call <2 x i64> @llvm.mips.ave.s.d(<2 x i64> %0, <2 x i64> %1)
876  store <2 x i64> %2, <2 x i64>* @llvm_mips_ave_s_d_RES
877  ret void
878}
879
880declare <2 x i64> @llvm.mips.ave.s.d(<2 x i64>, <2 x i64>) nounwind
881
882; CHECK: llvm_mips_ave_s_d_test:
883; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_s_d_ARG1)
884; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_s_d_ARG2)
885; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
886; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
887; CHECK-DAG: ave_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
888; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_s_d_RES)
889; CHECK-DAG: st.d [[WD]], 0([[R3]])
890; CHECK: .size llvm_mips_ave_s_d_test
891;
892@llvm_mips_ave_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
893@llvm_mips_ave_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
894@llvm_mips_ave_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
895
896define void @llvm_mips_ave_u_b_test() nounwind {
897entry:
898  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_ave_u_b_ARG1
899  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_ave_u_b_ARG2
900  %2 = tail call <16 x i8> @llvm.mips.ave.u.b(<16 x i8> %0, <16 x i8> %1)
901  store <16 x i8> %2, <16 x i8>* @llvm_mips_ave_u_b_RES
902  ret void
903}
904
905declare <16 x i8> @llvm.mips.ave.u.b(<16 x i8>, <16 x i8>) nounwind
906
907; CHECK: llvm_mips_ave_u_b_test:
908; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_u_b_ARG1)
909; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_u_b_ARG2)
910; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
911; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
912; CHECK-DAG: ave_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
913; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_u_b_RES)
914; CHECK-DAG: st.b [[WD]], 0([[R3]])
915; CHECK: .size llvm_mips_ave_u_b_test
916;
917@llvm_mips_ave_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
918@llvm_mips_ave_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
919@llvm_mips_ave_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
920
921define void @llvm_mips_ave_u_h_test() nounwind {
922entry:
923  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_ave_u_h_ARG1
924  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_ave_u_h_ARG2
925  %2 = tail call <8 x i16> @llvm.mips.ave.u.h(<8 x i16> %0, <8 x i16> %1)
926  store <8 x i16> %2, <8 x i16>* @llvm_mips_ave_u_h_RES
927  ret void
928}
929
930declare <8 x i16> @llvm.mips.ave.u.h(<8 x i16>, <8 x i16>) nounwind
931
932; CHECK: llvm_mips_ave_u_h_test:
933; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_u_h_ARG1)
934; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_u_h_ARG2)
935; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
936; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
937; CHECK-DAG: ave_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
938; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_u_h_RES)
939; CHECK-DAG: st.h [[WD]], 0([[R3]])
940; CHECK: .size llvm_mips_ave_u_h_test
941;
942@llvm_mips_ave_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
943@llvm_mips_ave_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
944@llvm_mips_ave_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
945
946define void @llvm_mips_ave_u_w_test() nounwind {
947entry:
948  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_ave_u_w_ARG1
949  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_ave_u_w_ARG2
950  %2 = tail call <4 x i32> @llvm.mips.ave.u.w(<4 x i32> %0, <4 x i32> %1)
951  store <4 x i32> %2, <4 x i32>* @llvm_mips_ave_u_w_RES
952  ret void
953}
954
955declare <4 x i32> @llvm.mips.ave.u.w(<4 x i32>, <4 x i32>) nounwind
956
957; CHECK: llvm_mips_ave_u_w_test:
958; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_u_w_ARG1)
959; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_u_w_ARG2)
960; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
961; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
962; CHECK-DAG: ave_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
963; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_u_w_RES)
964; CHECK-DAG: st.w [[WD]], 0([[R3]])
965; CHECK: .size llvm_mips_ave_u_w_test
966;
967@llvm_mips_ave_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
968@llvm_mips_ave_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
969@llvm_mips_ave_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
970
971define void @llvm_mips_ave_u_d_test() nounwind {
972entry:
973  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_ave_u_d_ARG1
974  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_ave_u_d_ARG2
975  %2 = tail call <2 x i64> @llvm.mips.ave.u.d(<2 x i64> %0, <2 x i64> %1)
976  store <2 x i64> %2, <2 x i64>* @llvm_mips_ave_u_d_RES
977  ret void
978}
979
980declare <2 x i64> @llvm.mips.ave.u.d(<2 x i64>, <2 x i64>) nounwind
981
982; CHECK: llvm_mips_ave_u_d_test:
983; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_ave_u_d_ARG1)
984; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_ave_u_d_ARG2)
985; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
986; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
987; CHECK-DAG: ave_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
988; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_ave_u_d_RES)
989; CHECK-DAG: st.d [[WD]], 0([[R3]])
990; CHECK: .size llvm_mips_ave_u_d_test
991;
992@llvm_mips_aver_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
993@llvm_mips_aver_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
994@llvm_mips_aver_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
995
996define void @llvm_mips_aver_s_b_test() nounwind {
997entry:
998  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_aver_s_b_ARG1
999  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_aver_s_b_ARG2
1000  %2 = tail call <16 x i8> @llvm.mips.aver.s.b(<16 x i8> %0, <16 x i8> %1)
1001  store <16 x i8> %2, <16 x i8>* @llvm_mips_aver_s_b_RES
1002  ret void
1003}
1004
1005declare <16 x i8> @llvm.mips.aver.s.b(<16 x i8>, <16 x i8>) nounwind
1006
1007; CHECK: llvm_mips_aver_s_b_test:
1008; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_s_b_ARG1)
1009; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_s_b_ARG2)
1010; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1011; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1012; CHECK-DAG: aver_s.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1013; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_s_b_RES)
1014; CHECK-DAG: st.b [[WD]], 0([[R3]])
1015; CHECK: .size llvm_mips_aver_s_b_test
1016;
1017@llvm_mips_aver_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
1018@llvm_mips_aver_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
1019@llvm_mips_aver_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
1020
1021define void @llvm_mips_aver_s_h_test() nounwind {
1022entry:
1023  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_aver_s_h_ARG1
1024  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_aver_s_h_ARG2
1025  %2 = tail call <8 x i16> @llvm.mips.aver.s.h(<8 x i16> %0, <8 x i16> %1)
1026  store <8 x i16> %2, <8 x i16>* @llvm_mips_aver_s_h_RES
1027  ret void
1028}
1029
1030declare <8 x i16> @llvm.mips.aver.s.h(<8 x i16>, <8 x i16>) nounwind
1031
1032; CHECK: llvm_mips_aver_s_h_test:
1033; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_s_h_ARG1)
1034; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_s_h_ARG2)
1035; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1036; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1037; CHECK-DAG: aver_s.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1038; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_s_h_RES)
1039; CHECK-DAG: st.h [[WD]], 0([[R3]])
1040; CHECK: .size llvm_mips_aver_s_h_test
1041;
1042@llvm_mips_aver_s_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
1043@llvm_mips_aver_s_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
1044@llvm_mips_aver_s_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
1045
1046define void @llvm_mips_aver_s_w_test() nounwind {
1047entry:
1048  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_aver_s_w_ARG1
1049  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_aver_s_w_ARG2
1050  %2 = tail call <4 x i32> @llvm.mips.aver.s.w(<4 x i32> %0, <4 x i32> %1)
1051  store <4 x i32> %2, <4 x i32>* @llvm_mips_aver_s_w_RES
1052  ret void
1053}
1054
1055declare <4 x i32> @llvm.mips.aver.s.w(<4 x i32>, <4 x i32>) nounwind
1056
1057; CHECK: llvm_mips_aver_s_w_test:
1058; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_s_w_ARG1)
1059; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_s_w_ARG2)
1060; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1061; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1062; CHECK-DAG: aver_s.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1063; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_s_w_RES)
1064; CHECK-DAG: st.w [[WD]], 0([[R3]])
1065; CHECK: .size llvm_mips_aver_s_w_test
1066;
1067@llvm_mips_aver_s_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
1068@llvm_mips_aver_s_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
1069@llvm_mips_aver_s_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
1070
1071define void @llvm_mips_aver_s_d_test() nounwind {
1072entry:
1073  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_aver_s_d_ARG1
1074  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_aver_s_d_ARG2
1075  %2 = tail call <2 x i64> @llvm.mips.aver.s.d(<2 x i64> %0, <2 x i64> %1)
1076  store <2 x i64> %2, <2 x i64>* @llvm_mips_aver_s_d_RES
1077  ret void
1078}
1079
1080declare <2 x i64> @llvm.mips.aver.s.d(<2 x i64>, <2 x i64>) nounwind
1081
1082; CHECK: llvm_mips_aver_s_d_test:
1083; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_s_d_ARG1)
1084; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_s_d_ARG2)
1085; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1086; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1087; CHECK-DAG: aver_s.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1088; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_s_d_RES)
1089; CHECK-DAG: st.d [[WD]], 0([[R3]])
1090; CHECK: .size llvm_mips_aver_s_d_test
1091;
1092@llvm_mips_aver_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
1093@llvm_mips_aver_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
1094@llvm_mips_aver_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
1095
1096define void @llvm_mips_aver_u_b_test() nounwind {
1097entry:
1098  %0 = load <16 x i8>, <16 x i8>* @llvm_mips_aver_u_b_ARG1
1099  %1 = load <16 x i8>, <16 x i8>* @llvm_mips_aver_u_b_ARG2
1100  %2 = tail call <16 x i8> @llvm.mips.aver.u.b(<16 x i8> %0, <16 x i8> %1)
1101  store <16 x i8> %2, <16 x i8>* @llvm_mips_aver_u_b_RES
1102  ret void
1103}
1104
1105declare <16 x i8> @llvm.mips.aver.u.b(<16 x i8>, <16 x i8>) nounwind
1106
1107; CHECK: llvm_mips_aver_u_b_test:
1108; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_u_b_ARG1)
1109; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_u_b_ARG2)
1110; CHECK-DAG: ld.b [[WS:\$w[0-9]+]], 0([[R1]])
1111; CHECK-DAG: ld.b [[WT:\$w[0-9]+]], 0([[R2]])
1112; CHECK-DAG: aver_u.b [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1113; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_u_b_RES)
1114; CHECK-DAG: st.b [[WD]], 0([[R3]])
1115; CHECK: .size llvm_mips_aver_u_b_test
1116;
1117@llvm_mips_aver_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
1118@llvm_mips_aver_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
1119@llvm_mips_aver_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
1120
1121define void @llvm_mips_aver_u_h_test() nounwind {
1122entry:
1123  %0 = load <8 x i16>, <8 x i16>* @llvm_mips_aver_u_h_ARG1
1124  %1 = load <8 x i16>, <8 x i16>* @llvm_mips_aver_u_h_ARG2
1125  %2 = tail call <8 x i16> @llvm.mips.aver.u.h(<8 x i16> %0, <8 x i16> %1)
1126  store <8 x i16> %2, <8 x i16>* @llvm_mips_aver_u_h_RES
1127  ret void
1128}
1129
1130declare <8 x i16> @llvm.mips.aver.u.h(<8 x i16>, <8 x i16>) nounwind
1131
1132; CHECK: llvm_mips_aver_u_h_test:
1133; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_u_h_ARG1)
1134; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_u_h_ARG2)
1135; CHECK-DAG: ld.h [[WS:\$w[0-9]+]], 0([[R1]])
1136; CHECK-DAG: ld.h [[WT:\$w[0-9]+]], 0([[R2]])
1137; CHECK-DAG: aver_u.h [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1138; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_u_h_RES)
1139; CHECK-DAG: st.h [[WD]], 0([[R3]])
1140; CHECK: .size llvm_mips_aver_u_h_test
1141;
1142@llvm_mips_aver_u_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16
1143@llvm_mips_aver_u_w_ARG2 = global <4 x i32> <i32 4, i32 5, i32 6, i32 7>, align 16
1144@llvm_mips_aver_u_w_RES  = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16
1145
1146define void @llvm_mips_aver_u_w_test() nounwind {
1147entry:
1148  %0 = load <4 x i32>, <4 x i32>* @llvm_mips_aver_u_w_ARG1
1149  %1 = load <4 x i32>, <4 x i32>* @llvm_mips_aver_u_w_ARG2
1150  %2 = tail call <4 x i32> @llvm.mips.aver.u.w(<4 x i32> %0, <4 x i32> %1)
1151  store <4 x i32> %2, <4 x i32>* @llvm_mips_aver_u_w_RES
1152  ret void
1153}
1154
1155declare <4 x i32> @llvm.mips.aver.u.w(<4 x i32>, <4 x i32>) nounwind
1156
1157; CHECK: llvm_mips_aver_u_w_test:
1158; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_u_w_ARG1)
1159; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_u_w_ARG2)
1160; CHECK-DAG: ld.w [[WS:\$w[0-9]+]], 0([[R1]])
1161; CHECK-DAG: ld.w [[WT:\$w[0-9]+]], 0([[R2]])
1162; CHECK-DAG: aver_u.w [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1163; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_u_w_RES)
1164; CHECK-DAG: st.w [[WD]], 0([[R3]])
1165; CHECK: .size llvm_mips_aver_u_w_test
1166;
1167@llvm_mips_aver_u_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16
1168@llvm_mips_aver_u_d_ARG2 = global <2 x i64> <i64 2, i64 3>, align 16
1169@llvm_mips_aver_u_d_RES  = global <2 x i64> <i64 0, i64 0>, align 16
1170
1171define void @llvm_mips_aver_u_d_test() nounwind {
1172entry:
1173  %0 = load <2 x i64>, <2 x i64>* @llvm_mips_aver_u_d_ARG1
1174  %1 = load <2 x i64>, <2 x i64>* @llvm_mips_aver_u_d_ARG2
1175  %2 = tail call <2 x i64> @llvm.mips.aver.u.d(<2 x i64> %0, <2 x i64> %1)
1176  store <2 x i64> %2, <2 x i64>* @llvm_mips_aver_u_d_RES
1177  ret void
1178}
1179
1180declare <2 x i64> @llvm.mips.aver.u.d(<2 x i64>, <2 x i64>) nounwind
1181
1182; CHECK: llvm_mips_aver_u_d_test:
1183; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_aver_u_d_ARG1)
1184; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_aver_u_d_ARG2)
1185; CHECK-DAG: ld.d [[WS:\$w[0-9]+]], 0([[R1]])
1186; CHECK-DAG: ld.d [[WT:\$w[0-9]+]], 0([[R2]])
1187; CHECK-DAG: aver_u.d [[WD:\$w[0-9]+]], [[WS]], [[WT]]
1188; CHECK-DAG: lw [[R3:\$[0-9]+]], %got(llvm_mips_aver_u_d_RES)
1189; CHECK-DAG: st.d [[WD]], 0([[R3]])
1190; CHECK: .size llvm_mips_aver_u_d_test
1191;
1192