1 ; Test the MSA intrinsics that are encoded with the I5 instruction format. 2 ; There are lots of these so this covers those beginning with 'b' 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 @llvm_mips_bclri_b_ARG1 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16 8 @llvm_mips_bclri_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 9 10 define void @llvm_mips_bclri_b_test() nounwind { 11 entry: 12 %0 = load <16 x i8>, <16 x i8>* @llvm_mips_bclri_b_ARG1 13 %1 = tail call <16 x i8> @llvm.mips.bclri.b(<16 x i8> %0, i32 7) 14 store <16 x i8> %1, <16 x i8>* @llvm_mips_bclri_b_RES 15 ret void 16 } 17 18 declare <16 x i8> @llvm.mips.bclri.b(<16 x i8>, i32) nounwind 19 20 ; CHECK: llvm_mips_bclri_b_test: 21 ; CHECK: ld.b 22 ; andi.b is equivalent to bclri.b 23 ; CHECK: andi.b {{\$w[0-9]}}, {{\$w[0-9]}}, 127 24 ; CHECK: st.b 25 ; CHECK: .size llvm_mips_bclri_b_test 26 ; 27 @llvm_mips_bclri_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16 28 @llvm_mips_bclri_h_RES = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16 29 30 define void @llvm_mips_bclri_h_test() nounwind { 31 entry: 32 %0 = load <8 x i16>, <8 x i16>* @llvm_mips_bclri_h_ARG1 33 %1 = tail call <8 x i16> @llvm.mips.bclri.h(<8 x i16> %0, i32 7) 34 store <8 x i16> %1, <8 x i16>* @llvm_mips_bclri_h_RES 35 ret void 36 } 37 38 declare <8 x i16> @llvm.mips.bclri.h(<8 x i16>, i32) nounwind 39 40 ; CHECK: llvm_mips_bclri_h_test: 41 ; CHECK: ld.h 42 ; CHECK: bclri.h 43 ; CHECK: st.h 44 ; CHECK: .size llvm_mips_bclri_h_test 45 ; 46 @llvm_mips_bclri_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16 47 @llvm_mips_bclri_w_RES = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16 48 49 define void @llvm_mips_bclri_w_test() nounwind { 50 entry: 51 %0 = load <4 x i32>, <4 x i32>* @llvm_mips_bclri_w_ARG1 52 %1 = tail call <4 x i32> @llvm.mips.bclri.w(<4 x i32> %0, i32 7) 53 store <4 x i32> %1, <4 x i32>* @llvm_mips_bclri_w_RES 54 ret void 55 } 56 57 declare <4 x i32> @llvm.mips.bclri.w(<4 x i32>, i32) nounwind 58 59 ; CHECK: llvm_mips_bclri_w_test: 60 ; CHECK: ld.w 61 ; CHECK: bclri.w 62 ; CHECK: st.w 63 ; CHECK: .size llvm_mips_bclri_w_test 64 ; 65 @llvm_mips_bclri_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16 66 @llvm_mips_bclri_d_RES = global <2 x i64> <i64 0, i64 0>, align 16 67 68 define void @llvm_mips_bclri_d_test() nounwind { 69 entry: 70 %0 = load <2 x i64>, <2 x i64>* @llvm_mips_bclri_d_ARG1 71 %1 = tail call <2 x i64> @llvm.mips.bclri.d(<2 x i64> %0, i32 7) 72 store <2 x i64> %1, <2 x i64>* @llvm_mips_bclri_d_RES 73 ret void 74 } 75 76 declare <2 x i64> @llvm.mips.bclri.d(<2 x i64>, i32) nounwind 77 78 ; CHECK: llvm_mips_bclri_d_test: 79 ; CHECK: ld.d 80 ; CHECK: bclri.d 81 ; CHECK: st.d 82 ; CHECK: .size llvm_mips_bclri_d_test 83 ; 84 @llvm_mips_binsli_b_ARG1 = global <16 x i8> zeroinitializer, align 16 85 @llvm_mips_binsli_b_ARG2 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16 86 @llvm_mips_binsli_b_RES = global <16 x i8> zeroinitializer, align 16 87 88 define void @llvm_mips_binsli_b_test() nounwind { 89 entry: 90 %0 = load <16 x i8>, <16 x i8>* @llvm_mips_binsli_b_ARG1 91 %1 = load <16 x i8>, <16 x i8>* @llvm_mips_binsli_b_ARG2 92 %2 = tail call <16 x i8> @llvm.mips.binsli.b(<16 x i8> %0, <16 x i8> %1, i32 7) 93 store <16 x i8> %2, <16 x i8>* @llvm_mips_binsli_b_RES 94 ret void 95 } 96 97 declare <16 x i8> @llvm.mips.binsli.b(<16 x i8>, <16 x i8>, i32) nounwind 98 99 ; CHECK: llvm_mips_binsli_b_test: 100 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsli_b_ARG1)( 101 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsli_b_ARG2)( 102 ; CHECK-DAG: ld.b [[R3:\$w[0-9]+]], 0([[R1]]) 103 ; CHECK-DAG: ld.b [[R4:\$w[0-9]+]], 0([[R2]]) 104 ; CHECK-DAG: binsli.b [[R3]], [[R4]], 7 105 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsli_b_RES)( 106 ; CHECK-DAG: st.b [[R3]], 0([[R5]]) 107 ; CHECK: .size llvm_mips_binsli_b_test 108 109 @llvm_mips_binsli_h_ARG1 = global <8 x i16> zeroinitializer, align 16 110 @llvm_mips_binsli_h_ARG2 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16 111 @llvm_mips_binsli_h_RES = global <8 x i16> zeroinitializer, align 16 112 113 define void @llvm_mips_binsli_h_test() nounwind { 114 entry: 115 %0 = load <8 x i16>, <8 x i16>* @llvm_mips_binsli_h_ARG1 116 %1 = load <8 x i16>, <8 x i16>* @llvm_mips_binsli_h_ARG2 117 %2 = tail call <8 x i16> @llvm.mips.binsli.h(<8 x i16> %0, <8 x i16> %1, i32 7) 118 store <8 x i16> %2, <8 x i16>* @llvm_mips_binsli_h_RES 119 ret void 120 } 121 122 declare <8 x i16> @llvm.mips.binsli.h(<8 x i16>, <8 x i16>, i32) nounwind 123 124 ; CHECK: llvm_mips_binsli_h_test: 125 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsli_h_ARG1)( 126 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsli_h_ARG2)( 127 ; CHECK-DAG: ld.h [[R3:\$w[0-9]+]], 0([[R1]]) 128 ; CHECK-DAG: ld.h [[R4:\$w[0-9]+]], 0([[R2]]) 129 ; CHECK-DAG: binsli.h [[R3]], [[R4]], 7 130 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsli_h_RES)( 131 ; CHECK-DAG: st.h [[R3]], 0([[R5]]) 132 ; CHECK: .size llvm_mips_binsli_h_test 133 134 @llvm_mips_binsli_w_ARG1 = global <4 x i32> zeroinitializer, align 16 135 @llvm_mips_binsli_w_ARG2 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16 136 @llvm_mips_binsli_w_RES = global <4 x i32> zeroinitializer, align 16 137 138 define void @llvm_mips_binsli_w_test() nounwind { 139 entry: 140 %0 = load <4 x i32>, <4 x i32>* @llvm_mips_binsli_w_ARG1 141 %1 = load <4 x i32>, <4 x i32>* @llvm_mips_binsli_w_ARG2 142 %2 = tail call <4 x i32> @llvm.mips.binsli.w(<4 x i32> %0, <4 x i32> %1, i32 7) 143 store <4 x i32> %2, <4 x i32>* @llvm_mips_binsli_w_RES 144 ret void 145 } 146 147 declare <4 x i32> @llvm.mips.binsli.w(<4 x i32>, <4 x i32>, i32) nounwind 148 149 ; CHECK: llvm_mips_binsli_w_test: 150 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsli_w_ARG1)( 151 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsli_w_ARG2)( 152 ; CHECK-DAG: ld.w [[R3:\$w[0-9]+]], 0([[R1]]) 153 ; CHECK-DAG: ld.w [[R4:\$w[0-9]+]], 0([[R2]]) 154 ; CHECK-DAG: binsli.w [[R3]], [[R4]], 7 155 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsli_w_RES)( 156 ; CHECK-DAG: st.w [[R3]], 0([[R5]]) 157 ; CHECK: .size llvm_mips_binsli_w_test 158 159 @llvm_mips_binsli_d_ARG1 = global <2 x i64> zeroinitializer, align 16 160 @llvm_mips_binsli_d_ARG2 = global <2 x i64> <i64 0, i64 1>, align 16 161 @llvm_mips_binsli_d_RES = global <2 x i64> zeroinitializer, align 16 162 163 define void @llvm_mips_binsli_d_test() nounwind { 164 entry: 165 %0 = load <2 x i64>, <2 x i64>* @llvm_mips_binsli_d_ARG1 166 %1 = load <2 x i64>, <2 x i64>* @llvm_mips_binsli_d_ARG2 167 ; TODO: We use a particularly wide mask here to work around a legalization 168 ; issue. If the mask doesn't fit within a 10-bit immediate, it gets 169 ; legalized into a constant pool. We should add a test to cover the 170 ; other cases once they correctly select binsli.d. 171 %2 = tail call <2 x i64> @llvm.mips.binsli.d(<2 x i64> %0, <2 x i64> %1, i32 61) 172 store <2 x i64> %2, <2 x i64>* @llvm_mips_binsli_d_RES 173 ret void 174 } 175 176 declare <2 x i64> @llvm.mips.binsli.d(<2 x i64>, <2 x i64>, i32) nounwind 177 178 ; CHECK: llvm_mips_binsli_d_test: 179 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsli_d_ARG1)( 180 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsli_d_ARG2)( 181 ; CHECK-DAG: ld.d [[R3:\$w[0-9]+]], 0([[R1]]) 182 ; CHECK-DAG: ld.d [[R4:\$w[0-9]+]], 0([[R2]]) 183 ; CHECK-DAG: binsli.d [[R3]], [[R4]], 61 184 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsli_d_RES)( 185 ; CHECK-DAG: st.d [[R3]], 0([[R5]]) 186 ; CHECK: .size llvm_mips_binsli_d_test 187 188 @llvm_mips_binsri_b_ARG1 = global <16 x i8> zeroinitializer, align 16 189 @llvm_mips_binsri_b_ARG2 = global <16 x i8> <i8 0, i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15>, align 16 190 @llvm_mips_binsri_b_RES = global <16 x i8> zeroinitializer, align 16 191 192 define void @llvm_mips_binsri_b_test() nounwind { 193 entry: 194 %0 = load <16 x i8>, <16 x i8>* @llvm_mips_binsri_b_ARG1 195 %1 = load <16 x i8>, <16 x i8>* @llvm_mips_binsri_b_ARG2 196 %2 = tail call <16 x i8> @llvm.mips.binsri.b(<16 x i8> %0, <16 x i8> %1, i32 7) 197 store <16 x i8> %2, <16 x i8>* @llvm_mips_binsri_b_RES 198 ret void 199 } 200 201 declare <16 x i8> @llvm.mips.binsri.b(<16 x i8>, <16 x i8>, i32) nounwind 202 203 ; CHECK: llvm_mips_binsri_b_test: 204 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsri_b_ARG1)( 205 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsri_b_ARG2)( 206 ; CHECK-DAG: ld.b [[R3:\$w[0-9]+]], 0([[R1]]) 207 ; CHECK-DAG: ld.b [[R4:\$w[0-9]+]], 0([[R2]]) 208 ; CHECK-DAG: binsri.b [[R3]], [[R4]], 7 209 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsri_b_RES)( 210 ; CHECK-DAG: st.b [[R3]], 0([[R5]]) 211 ; CHECK: .size llvm_mips_binsri_b_test 212 213 @llvm_mips_binsri_h_ARG1 = global <8 x i16> zeroinitializer, align 16 214 @llvm_mips_binsri_h_ARG2 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16 215 @llvm_mips_binsri_h_RES = global <8 x i16> zeroinitializer, align 16 216 217 define void @llvm_mips_binsri_h_test() nounwind { 218 entry: 219 %0 = load <8 x i16>, <8 x i16>* @llvm_mips_binsri_h_ARG1 220 %1 = load <8 x i16>, <8 x i16>* @llvm_mips_binsri_h_ARG2 221 %2 = tail call <8 x i16> @llvm.mips.binsri.h(<8 x i16> %0, <8 x i16> %1, i32 7) 222 store <8 x i16> %2, <8 x i16>* @llvm_mips_binsri_h_RES 223 ret void 224 } 225 226 declare <8 x i16> @llvm.mips.binsri.h(<8 x i16>, <8 x i16>, i32) nounwind 227 228 ; CHECK: llvm_mips_binsri_h_test: 229 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsri_h_ARG1)( 230 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsri_h_ARG2)( 231 ; CHECK-DAG: ld.h [[R3:\$w[0-9]+]], 0([[R1]]) 232 ; CHECK-DAG: ld.h [[R4:\$w[0-9]+]], 0([[R2]]) 233 ; CHECK-DAG: binsri.h [[R3]], [[R4]], 7 234 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsri_h_RES)( 235 ; CHECK-DAG: st.h [[R3]], 0([[R5]]) 236 ; CHECK: .size llvm_mips_binsri_h_test 237 238 @llvm_mips_binsri_w_ARG1 = global <4 x i32> zeroinitializer, align 16 239 @llvm_mips_binsri_w_ARG2 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16 240 @llvm_mips_binsri_w_RES = global <4 x i32> zeroinitializer, align 16 241 242 define void @llvm_mips_binsri_w_test() nounwind { 243 entry: 244 %0 = load <4 x i32>, <4 x i32>* @llvm_mips_binsri_w_ARG1 245 %1 = load <4 x i32>, <4 x i32>* @llvm_mips_binsri_w_ARG2 246 %2 = tail call <4 x i32> @llvm.mips.binsri.w(<4 x i32> %0, <4 x i32> %1, i32 7) 247 store <4 x i32> %2, <4 x i32>* @llvm_mips_binsri_w_RES 248 ret void 249 } 250 251 declare <4 x i32> @llvm.mips.binsri.w(<4 x i32>, <4 x i32>, i32) nounwind 252 253 ; CHECK: llvm_mips_binsri_w_test: 254 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsri_w_ARG1)( 255 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsri_w_ARG2)( 256 ; CHECK-DAG: ld.w [[R3:\$w[0-9]+]], 0([[R1]]) 257 ; CHECK-DAG: ld.w [[R4:\$w[0-9]+]], 0([[R2]]) 258 ; CHECK-DAG: binsri.w [[R3]], [[R4]], 7 259 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsri_w_RES)( 260 ; CHECK-DAG: st.w [[R3]], 0([[R5]]) 261 ; CHECK: .size llvm_mips_binsri_w_test 262 263 @llvm_mips_binsri_d_ARG1 = global <2 x i64> zeroinitializer, align 16 264 @llvm_mips_binsri_d_ARG2 = global <2 x i64> <i64 0, i64 1>, align 16 265 @llvm_mips_binsri_d_RES = global <2 x i64> zeroinitializer, align 16 266 267 define void @llvm_mips_binsri_d_test() nounwind { 268 entry: 269 %0 = load <2 x i64>, <2 x i64>* @llvm_mips_binsri_d_ARG1 270 %1 = load <2 x i64>, <2 x i64>* @llvm_mips_binsri_d_ARG2 271 %2 = tail call <2 x i64> @llvm.mips.binsri.d(<2 x i64> %0, <2 x i64> %1, i32 7) 272 store <2 x i64> %2, <2 x i64>* @llvm_mips_binsri_d_RES 273 ret void 274 } 275 276 declare <2 x i64> @llvm.mips.binsri.d(<2 x i64>, <2 x i64>, i32) nounwind 277 278 ; CHECK: llvm_mips_binsri_d_test: 279 ; CHECK-DAG: lw [[R1:\$[0-9]+]], %got(llvm_mips_binsri_d_ARG1)( 280 ; CHECK-DAG: lw [[R2:\$[0-9]+]], %got(llvm_mips_binsri_d_ARG2)( 281 ; CHECK-DAG: ld.d [[R3:\$w[0-9]+]], 0([[R1]]) 282 ; CHECK-DAG: ld.d [[R4:\$w[0-9]+]], 0([[R2]]) 283 ; CHECK-DAG: binsri.d [[R3]], [[R4]], 7 284 ; CHECK-DAG: lw [[R5:\$[0-9]+]], %got(llvm_mips_binsri_d_RES)( 285 ; CHECK-DAG: st.d [[R3]], 0([[R5]]) 286 ; CHECK: .size llvm_mips_binsri_d_test 287 288 @llvm_mips_bnegi_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 289 @llvm_mips_bnegi_b_RES = global <16 x i8> <i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>, align 16 290 291 define void @llvm_mips_bnegi_b_test() nounwind { 292 entry: 293 %0 = load <16 x i8>, <16 x i8>* @llvm_mips_bnegi_b_ARG1 294 %1 = tail call <16 x i8> @llvm.mips.bnegi.b(<16 x i8> %0, i32 7) 295 store <16 x i8> %1, <16 x i8>* @llvm_mips_bnegi_b_RES 296 ret void 297 } 298 299 declare <16 x i8> @llvm.mips.bnegi.b(<16 x i8>, i32) nounwind 300 301 ; CHECK: llvm_mips_bnegi_b_test: 302 ; CHECK: ld.b 303 ; CHECK: bnegi.b 304 ; CHECK: st.b 305 ; CHECK: .size llvm_mips_bnegi_b_test 306 ; 307 @llvm_mips_bnegi_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16 308 @llvm_mips_bnegi_h_RES = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16 309 310 define void @llvm_mips_bnegi_h_test() nounwind { 311 entry: 312 %0 = load <8 x i16>, <8 x i16>* @llvm_mips_bnegi_h_ARG1 313 %1 = tail call <8 x i16> @llvm.mips.bnegi.h(<8 x i16> %0, i32 7) 314 store <8 x i16> %1, <8 x i16>* @llvm_mips_bnegi_h_RES 315 ret void 316 } 317 318 declare <8 x i16> @llvm.mips.bnegi.h(<8 x i16>, i32) nounwind 319 320 ; CHECK: llvm_mips_bnegi_h_test: 321 ; CHECK: ld.h 322 ; CHECK: bnegi.h 323 ; CHECK: st.h 324 ; CHECK: .size llvm_mips_bnegi_h_test 325 ; 326 @llvm_mips_bnegi_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16 327 @llvm_mips_bnegi_w_RES = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16 328 329 define void @llvm_mips_bnegi_w_test() nounwind { 330 entry: 331 %0 = load <4 x i32>, <4 x i32>* @llvm_mips_bnegi_w_ARG1 332 %1 = tail call <4 x i32> @llvm.mips.bnegi.w(<4 x i32> %0, i32 7) 333 store <4 x i32> %1, <4 x i32>* @llvm_mips_bnegi_w_RES 334 ret void 335 } 336 337 declare <4 x i32> @llvm.mips.bnegi.w(<4 x i32>, i32) nounwind 338 339 ; CHECK: llvm_mips_bnegi_w_test: 340 ; CHECK: ld.w 341 ; CHECK: bnegi.w 342 ; CHECK: st.w 343 ; CHECK: .size llvm_mips_bnegi_w_test 344 ; 345 @llvm_mips_bnegi_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16 346 @llvm_mips_bnegi_d_RES = global <2 x i64> <i64 0, i64 0>, align 16 347 348 define void @llvm_mips_bnegi_d_test() nounwind { 349 entry: 350 %0 = load <2 x i64>, <2 x i64>* @llvm_mips_bnegi_d_ARG1 351 %1 = tail call <2 x i64> @llvm.mips.bnegi.d(<2 x i64> %0, i32 7) 352 store <2 x i64> %1, <2 x i64>* @llvm_mips_bnegi_d_RES 353 ret void 354 } 355 356 declare <2 x i64> @llvm.mips.bnegi.d(<2 x i64>, i32) nounwind 357 358 ; CHECK: llvm_mips_bnegi_d_test: 359 ; CHECK: ld.d 360 ; CHECK: bnegi.d 361 ; CHECK: st.d 362 ; CHECK: .size llvm_mips_bnegi_d_test 363 ; 364 @llvm_mips_bseti_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 365 @llvm_mips_bseti_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 366 367 define void @llvm_mips_bseti_b_test() nounwind { 368 entry: 369 %0 = load <16 x i8>, <16 x i8>* @llvm_mips_bseti_b_ARG1 370 %1 = tail call <16 x i8> @llvm.mips.bseti.b(<16 x i8> %0, i32 7) 371 store <16 x i8> %1, <16 x i8>* @llvm_mips_bseti_b_RES 372 ret void 373 } 374 375 declare <16 x i8> @llvm.mips.bseti.b(<16 x i8>, i32) nounwind 376 377 ; CHECK: llvm_mips_bseti_b_test: 378 ; CHECK: ld.b 379 ; CHECK: bseti.b 380 ; CHECK: st.b 381 ; CHECK: .size llvm_mips_bseti_b_test 382 ; 383 @llvm_mips_bseti_h_ARG1 = global <8 x i16> <i16 0, i16 1, i16 2, i16 3, i16 4, i16 5, i16 6, i16 7>, align 16 384 @llvm_mips_bseti_h_RES = global <8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, align 16 385 386 define void @llvm_mips_bseti_h_test() nounwind { 387 entry: 388 %0 = load <8 x i16>, <8 x i16>* @llvm_mips_bseti_h_ARG1 389 %1 = tail call <8 x i16> @llvm.mips.bseti.h(<8 x i16> %0, i32 7) 390 store <8 x i16> %1, <8 x i16>* @llvm_mips_bseti_h_RES 391 ret void 392 } 393 394 declare <8 x i16> @llvm.mips.bseti.h(<8 x i16>, i32) nounwind 395 396 ; CHECK: llvm_mips_bseti_h_test: 397 ; CHECK: ld.h 398 ; CHECK: bseti.h 399 ; CHECK: st.h 400 ; CHECK: .size llvm_mips_bseti_h_test 401 ; 402 @llvm_mips_bseti_w_ARG1 = global <4 x i32> <i32 0, i32 1, i32 2, i32 3>, align 16 403 @llvm_mips_bseti_w_RES = global <4 x i32> <i32 0, i32 0, i32 0, i32 0>, align 16 404 405 define void @llvm_mips_bseti_w_test() nounwind { 406 entry: 407 %0 = load <4 x i32>, <4 x i32>* @llvm_mips_bseti_w_ARG1 408 %1 = tail call <4 x i32> @llvm.mips.bseti.w(<4 x i32> %0, i32 7) 409 store <4 x i32> %1, <4 x i32>* @llvm_mips_bseti_w_RES 410 ret void 411 } 412 413 declare <4 x i32> @llvm.mips.bseti.w(<4 x i32>, i32) nounwind 414 415 ; CHECK: llvm_mips_bseti_w_test: 416 ; CHECK: ld.w 417 ; CHECK: bseti.w 418 ; CHECK: st.w 419 ; CHECK: .size llvm_mips_bseti_w_test 420 ; 421 @llvm_mips_bseti_d_ARG1 = global <2 x i64> <i64 0, i64 1>, align 16 422 @llvm_mips_bseti_d_RES = global <2 x i64> <i64 0, i64 0>, align 16 423 424 define void @llvm_mips_bseti_d_test() nounwind { 425 entry: 426 %0 = load <2 x i64>, <2 x i64>* @llvm_mips_bseti_d_ARG1 427 %1 = tail call <2 x i64> @llvm.mips.bseti.d(<2 x i64> %0, i32 7) 428 store <2 x i64> %1, <2 x i64>* @llvm_mips_bseti_d_RES 429 ret void 430 } 431 432 declare <2 x i64> @llvm.mips.bseti.d(<2 x i64>, i32) nounwind 433 434 ; CHECK: llvm_mips_bseti_d_test: 435 ; CHECK: ld.d 436 ; CHECK: bseti.d 437 ; CHECK: st.d 438 ; CHECK: .size llvm_mips_bseti_d_test 439 ; 440