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 < %s | FileCheck %s 5 ; RUN: llc -march=mipsel -mattr=+msa,+fp64 < %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 16 define void @llvm_mips_add_a_b_test() nounwind { 17 entry: 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 25 declare <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 41 define void @llvm_mips_add_a_h_test() nounwind { 42 entry: 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 50 declare <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 66 define void @llvm_mips_add_a_w_test() nounwind { 67 entry: 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 75 declare <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 91 define void @llvm_mips_add_a_d_test() nounwind { 92 entry: 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 100 declare <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 116 define void @llvm_mips_adds_a_b_test() nounwind { 117 entry: 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 125 declare <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 141 define void @llvm_mips_adds_a_h_test() nounwind { 142 entry: 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 150 declare <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 166 define void @llvm_mips_adds_a_w_test() nounwind { 167 entry: 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 175 declare <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 191 define void @llvm_mips_adds_a_d_test() nounwind { 192 entry: 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 200 declare <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 216 define void @llvm_mips_adds_s_b_test() nounwind { 217 entry: 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 225 declare <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 241 define void @llvm_mips_adds_s_h_test() nounwind { 242 entry: 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 250 declare <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 266 define void @llvm_mips_adds_s_w_test() nounwind { 267 entry: 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 275 declare <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 291 define void @llvm_mips_adds_s_d_test() nounwind { 292 entry: 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 300 declare <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 316 define void @llvm_mips_adds_u_b_test() nounwind { 317 entry: 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 325 declare <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 341 define void @llvm_mips_adds_u_h_test() nounwind { 342 entry: 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 350 declare <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 366 define void @llvm_mips_adds_u_w_test() nounwind { 367 entry: 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 375 declare <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 391 define void @llvm_mips_adds_u_d_test() nounwind { 392 entry: 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 400 declare <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 416 define void @llvm_mips_addv_b_test() nounwind { 417 entry: 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 425 declare <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 441 define void @llvm_mips_addv_h_test() nounwind { 442 entry: 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 450 declare <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 466 define void @llvm_mips_addv_w_test() nounwind { 467 entry: 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 475 declare <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 491 define void @llvm_mips_addv_d_test() nounwind { 492 entry: 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 500 declare <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 513 define void @addv_b_test() nounwind { 514 entry: 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 533 define void @addv_h_test() nounwind { 534 entry: 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 553 define void @addv_w_test() nounwind { 554 entry: 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 573 define void @addv_d_test() nounwind { 574 entry: 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 596 define void @llvm_mips_asub_s_b_test() nounwind { 597 entry: 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 605 declare <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 621 define void @llvm_mips_asub_s_h_test() nounwind { 622 entry: 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 630 declare <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 646 define void @llvm_mips_asub_s_w_test() nounwind { 647 entry: 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 655 declare <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 671 define void @llvm_mips_asub_s_d_test() nounwind { 672 entry: 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 680 declare <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 696 define void @llvm_mips_asub_u_b_test() nounwind { 697 entry: 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 705 declare <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 721 define void @llvm_mips_asub_u_h_test() nounwind { 722 entry: 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 730 declare <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 746 define void @llvm_mips_asub_u_w_test() nounwind { 747 entry: 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 755 declare <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 771 define void @llvm_mips_asub_u_d_test() nounwind { 772 entry: 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 780 declare <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 796 define void @llvm_mips_ave_s_b_test() nounwind { 797 entry: 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 805 declare <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 821 define void @llvm_mips_ave_s_h_test() nounwind { 822 entry: 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 830 declare <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 846 define void @llvm_mips_ave_s_w_test() nounwind { 847 entry: 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 855 declare <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 871 define void @llvm_mips_ave_s_d_test() nounwind { 872 entry: 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 880 declare <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 896 define void @llvm_mips_ave_u_b_test() nounwind { 897 entry: 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 905 declare <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 921 define void @llvm_mips_ave_u_h_test() nounwind { 922 entry: 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 930 declare <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 946 define void @llvm_mips_ave_u_w_test() nounwind { 947 entry: 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 955 declare <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 971 define void @llvm_mips_ave_u_d_test() nounwind { 972 entry: 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 980 declare <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 996 define void @llvm_mips_aver_s_b_test() nounwind { 997 entry: 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 1005 declare <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 1021 define void @llvm_mips_aver_s_h_test() nounwind { 1022 entry: 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 1030 declare <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 1046 define void @llvm_mips_aver_s_w_test() nounwind { 1047 entry: 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 1055 declare <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 1071 define void @llvm_mips_aver_s_d_test() nounwind { 1072 entry: 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 1080 declare <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 1096 define void @llvm_mips_aver_u_b_test() nounwind { 1097 entry: 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 1105 declare <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 1121 define void @llvm_mips_aver_u_h_test() nounwind { 1122 entry: 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 1130 declare <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 1146 define void @llvm_mips_aver_u_w_test() nounwind { 1147 entry: 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 1155 declare <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 1171 define void @llvm_mips_aver_u_d_test() nounwind { 1172 entry: 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 1180 declare <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