1 ; RUN: llc -march=mips -mattr=+msa,+fp64 < %s | FileCheck -check-prefix=MIPS32-AE -check-prefix=MIPS32-BE %s 2 ; RUN: llc -march=mipsel -mattr=+msa,+fp64 < %s | FileCheck -check-prefix=MIPS32-AE -check-prefix=MIPS32-LE %s 3 4 define void @loadstore_v16i8_near() nounwind { 5 ; MIPS32-AE: loadstore_v16i8_near: 6 7 %1 = alloca <16 x i8> 8 %2 = load volatile <16 x i8>, <16 x i8>* %1 9 ; MIPS32-AE: ld.b [[R1:\$w[0-9]+]], 0($sp) 10 store volatile <16 x i8> %2, <16 x i8>* %1 11 ; MIPS32-AE: st.b [[R1]], 0($sp) 12 13 ret void 14 ; MIPS32-AE: .size loadstore_v16i8_near 15 } 16 17 define void @loadstore_v16i8_just_under_simm10() nounwind { 18 ; MIPS32-AE: loadstore_v16i8_just_under_simm10: 19 20 %1 = alloca <16 x i8> 21 %2 = alloca [496 x i8] ; Push the frame right up to 512 bytes 22 23 %3 = load volatile <16 x i8>, <16 x i8>* %1 24 ; MIPS32-AE: ld.b [[R1:\$w[0-9]+]], 496($sp) 25 store volatile <16 x i8> %3, <16 x i8>* %1 26 ; MIPS32-AE: st.b [[R1]], 496($sp) 27 28 ret void 29 ; MIPS32-AE: .size loadstore_v16i8_just_under_simm10 30 } 31 32 define void @loadstore_v16i8_just_over_simm10() nounwind { 33 ; MIPS32-AE: loadstore_v16i8_just_over_simm10: 34 35 %1 = alloca <16 x i8> 36 %2 = alloca [497 x i8] ; Push the frame just over 512 bytes 37 38 %3 = load volatile <16 x i8>, <16 x i8>* %1 39 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 512 40 ; MIPS32-AE: ld.b [[R1:\$w[0-9]+]], 0([[BASE]]) 41 store volatile <16 x i8> %3, <16 x i8>* %1 42 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 512 43 ; MIPS32-AE: st.b [[R1]], 0([[BASE]]) 44 45 ret void 46 ; MIPS32-AE: .size loadstore_v16i8_just_over_simm10 47 } 48 49 define void @loadstore_v16i8_just_under_simm16() nounwind { 50 ; MIPS32-AE: loadstore_v16i8_just_under_simm16: 51 52 %1 = alloca <16 x i8> 53 %2 = alloca [32752 x i8] ; Push the frame right up to 32768 bytes 54 55 %3 = load volatile <16 x i8>, <16 x i8>* %1 56 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 57 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 58 ; MIPS32-AE: ld.b [[R1:\$w[0-9]+]], 0([[BASE]]) 59 store volatile <16 x i8> %3, <16 x i8>* %1 60 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 61 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 62 ; MIPS32-AE: st.b [[R1]], 0([[BASE]]) 63 64 ret void 65 ; MIPS32-AE: .size loadstore_v16i8_just_under_simm16 66 } 67 68 define void @loadstore_v16i8_just_over_simm16() nounwind { 69 ; MIPS32-AE: loadstore_v16i8_just_over_simm16: 70 71 %1 = alloca <16 x i8> 72 %2 = alloca [32753 x i8] ; Push the frame just over 32768 bytes 73 74 %3 = load volatile <16 x i8>, <16 x i8>* %1 75 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 76 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 77 ; MIPS32-AE: ld.b [[R1:\$w[0-9]+]], 0([[BASE]]) 78 store volatile <16 x i8> %3, <16 x i8>* %1 79 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 80 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 81 ; MIPS32-AE: st.b [[R1]], 0([[BASE]]) 82 83 ret void 84 ; MIPS32-AE: .size loadstore_v16i8_just_over_simm16 85 } 86 87 define void @loadstore_v8i16_near() nounwind { 88 ; MIPS32-AE: loadstore_v8i16_near: 89 90 %1 = alloca <8 x i16> 91 %2 = load volatile <8 x i16>, <8 x i16>* %1 92 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 0($sp) 93 store volatile <8 x i16> %2, <8 x i16>* %1 94 ; MIPS32-AE: st.h [[R1]], 0($sp) 95 96 ret void 97 ; MIPS32-AE: .size loadstore_v8i16_near 98 } 99 100 define void @loadstore_v8i16_unaligned() nounwind { 101 ; MIPS32-AE: loadstore_v8i16_unaligned: 102 103 %1 = alloca [2 x <8 x i16>] 104 %2 = bitcast [2 x <8 x i16>]* %1 to i8* 105 %3 = getelementptr i8, i8* %2, i32 1 106 %4 = bitcast i8* %3 to [2 x <8 x i16>]* 107 %5 = getelementptr [2 x <8 x i16>], [2 x <8 x i16>]* %4, i32 0, i32 0 108 109 %6 = load volatile <8 x i16>, <8 x i16>* %5 110 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 111 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 0([[BASE]]) 112 store volatile <8 x i16> %6, <8 x i16>* %5 113 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 114 ; MIPS32-AE: st.h [[R1]], 0([[BASE]]) 115 116 ret void 117 ; MIPS32-AE: .size loadstore_v8i16_unaligned 118 } 119 120 define void @loadstore_v8i16_just_under_simm10() nounwind { 121 ; MIPS32-AE: loadstore_v8i16_just_under_simm10: 122 123 %1 = alloca <8 x i16> 124 %2 = alloca [1008 x i8] ; Push the frame right up to 1024 bytes 125 126 %3 = load volatile <8 x i16>, <8 x i16>* %1 127 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 1008($sp) 128 store volatile <8 x i16> %3, <8 x i16>* %1 129 ; MIPS32-AE: st.h [[R1]], 1008($sp) 130 131 ret void 132 ; MIPS32-AE: .size loadstore_v8i16_just_under_simm10 133 } 134 135 define void @loadstore_v8i16_just_over_simm10() nounwind { 136 ; MIPS32-AE: loadstore_v8i16_just_over_simm10: 137 138 %1 = alloca <8 x i16> 139 %2 = alloca [1009 x i8] ; Push the frame just over 1024 bytes 140 141 %3 = load volatile <8 x i16>, <8 x i16>* %1 142 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1024 143 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 0([[BASE]]) 144 store volatile <8 x i16> %3, <8 x i16>* %1 145 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1024 146 ; MIPS32-AE: st.h [[R1]], 0([[BASE]]) 147 148 ret void 149 ; MIPS32-AE: .size loadstore_v8i16_just_over_simm10 150 } 151 152 define void @loadstore_v8i16_just_under_simm16() nounwind { 153 ; MIPS32-AE: loadstore_v8i16_just_under_simm16: 154 155 %1 = alloca <8 x i16> 156 %2 = alloca [32752 x i8] ; Push the frame right up to 32768 bytes 157 158 %3 = load volatile <8 x i16>, <8 x i16>* %1 159 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 160 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 161 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 0([[BASE]]) 162 store volatile <8 x i16> %3, <8 x i16>* %1 163 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 164 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 165 ; MIPS32-AE: st.h [[R1]], 0([[BASE]]) 166 167 ret void 168 ; MIPS32-AE: .size loadstore_v8i16_just_under_simm16 169 } 170 171 define void @loadstore_v8i16_just_over_simm16() nounwind { 172 ; MIPS32-AE: loadstore_v8i16_just_over_simm16: 173 174 %1 = alloca <8 x i16> 175 %2 = alloca [32753 x i8] ; Push the frame just over 32768 bytes 176 177 %3 = load volatile <8 x i16>, <8 x i16>* %1 178 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 179 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 180 ; MIPS32-AE: ld.h [[R1:\$w[0-9]+]], 0([[BASE]]) 181 store volatile <8 x i16> %3, <8 x i16>* %1 182 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 183 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 184 ; MIPS32-AE: st.h [[R1]], 0([[BASE]]) 185 186 ret void 187 ; MIPS32-AE: .size loadstore_v8i16_just_over_simm16 188 } 189 190 define void @loadstore_v4i32_near() nounwind { 191 ; MIPS32-AE: loadstore_v4i32_near: 192 193 %1 = alloca <4 x i32> 194 %2 = load volatile <4 x i32>, <4 x i32>* %1 195 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 0($sp) 196 store volatile <4 x i32> %2, <4 x i32>* %1 197 ; MIPS32-AE: st.w [[R1]], 0($sp) 198 199 ret void 200 ; MIPS32-AE: .size loadstore_v4i32_near 201 } 202 203 define void @loadstore_v4i32_unaligned() nounwind { 204 ; MIPS32-AE: loadstore_v4i32_unaligned: 205 206 %1 = alloca [2 x <4 x i32>] 207 %2 = bitcast [2 x <4 x i32>]* %1 to i8* 208 %3 = getelementptr i8, i8* %2, i32 1 209 %4 = bitcast i8* %3 to [2 x <4 x i32>]* 210 %5 = getelementptr [2 x <4 x i32>], [2 x <4 x i32>]* %4, i32 0, i32 0 211 212 %6 = load volatile <4 x i32>, <4 x i32>* %5 213 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 214 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 0([[BASE]]) 215 store volatile <4 x i32> %6, <4 x i32>* %5 216 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 217 ; MIPS32-AE: st.w [[R1]], 0([[BASE]]) 218 219 ret void 220 ; MIPS32-AE: .size loadstore_v4i32_unaligned 221 } 222 223 define void @loadstore_v4i32_just_under_simm10() nounwind { 224 ; MIPS32-AE: loadstore_v4i32_just_under_simm10: 225 226 %1 = alloca <4 x i32> 227 %2 = alloca [2032 x i8] ; Push the frame right up to 2048 bytes 228 229 %3 = load volatile <4 x i32>, <4 x i32>* %1 230 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 2032($sp) 231 store volatile <4 x i32> %3, <4 x i32>* %1 232 ; MIPS32-AE: st.w [[R1]], 2032($sp) 233 234 ret void 235 ; MIPS32-AE: .size loadstore_v4i32_just_under_simm10 236 } 237 238 define void @loadstore_v4i32_just_over_simm10() nounwind { 239 ; MIPS32-AE: loadstore_v4i32_just_over_simm10: 240 241 %1 = alloca <4 x i32> 242 %2 = alloca [2033 x i8] ; Push the frame just over 2048 bytes 243 244 %3 = load volatile <4 x i32>, <4 x i32>* %1 245 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 2048 246 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 0([[BASE]]) 247 store volatile <4 x i32> %3, <4 x i32>* %1 248 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 2048 249 ; MIPS32-AE: st.w [[R1]], 0([[BASE]]) 250 251 ret void 252 ; MIPS32-AE: .size loadstore_v4i32_just_over_simm10 253 } 254 255 define void @loadstore_v4i32_just_under_simm16() nounwind { 256 ; MIPS32-AE: loadstore_v4i32_just_under_simm16: 257 258 %1 = alloca <4 x i32> 259 %2 = alloca [32752 x i8] ; Push the frame right up to 32768 bytes 260 261 %3 = load volatile <4 x i32>, <4 x i32>* %1 262 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 263 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 264 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 0([[BASE]]) 265 store volatile <4 x i32> %3, <4 x i32>* %1 266 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 267 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 268 ; MIPS32-AE: st.w [[R1]], 0([[BASE]]) 269 270 ret void 271 ; MIPS32-AE: .size loadstore_v4i32_just_under_simm16 272 } 273 274 define void @loadstore_v4i32_just_over_simm16() nounwind { 275 ; MIPS32-AE: loadstore_v4i32_just_over_simm16: 276 277 %1 = alloca <4 x i32> 278 %2 = alloca [32753 x i8] ; Push the frame just over 32768 bytes 279 280 %3 = load volatile <4 x i32>, <4 x i32>* %1 281 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 282 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 283 ; MIPS32-AE: ld.w [[R1:\$w[0-9]+]], 0([[BASE]]) 284 store volatile <4 x i32> %3, <4 x i32>* %1 285 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 286 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 287 ; MIPS32-AE: st.w [[R1]], 0([[BASE]]) 288 289 ret void 290 ; MIPS32-AE: .size loadstore_v4i32_just_over_simm16 291 } 292 293 define void @loadstore_v2i64_near() nounwind { 294 ; MIPS32-AE: loadstore_v2i64_near: 295 296 %1 = alloca <2 x i64> 297 %2 = load volatile <2 x i64>, <2 x i64>* %1 298 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 0($sp) 299 store volatile <2 x i64> %2, <2 x i64>* %1 300 ; MIPS32-AE: st.d [[R1]], 0($sp) 301 302 ret void 303 ; MIPS32-AE: .size loadstore_v2i64_near 304 } 305 306 define void @loadstore_v2i64_unaligned() nounwind { 307 ; MIPS32-AE: loadstore_v2i64_unaligned: 308 309 %1 = alloca [2 x <2 x i64>] 310 %2 = bitcast [2 x <2 x i64>]* %1 to i8* 311 %3 = getelementptr i8, i8* %2, i32 1 312 %4 = bitcast i8* %3 to [2 x <2 x i64>]* 313 %5 = getelementptr [2 x <2 x i64>], [2 x <2 x i64>]* %4, i32 0, i32 0 314 315 %6 = load volatile <2 x i64>, <2 x i64>* %5 316 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 317 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 0([[BASE]]) 318 store volatile <2 x i64> %6, <2 x i64>* %5 319 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 1 320 ; MIPS32-AE: st.d [[R1]], 0([[BASE]]) 321 322 ret void 323 ; MIPS32-AE: .size loadstore_v2i64_unaligned 324 } 325 326 define void @loadstore_v2i64_just_under_simm10() nounwind { 327 ; MIPS32-AE: loadstore_v2i64_just_under_simm10: 328 329 %1 = alloca <2 x i64> 330 %2 = alloca [4080 x i8] ; Push the frame right up to 4096 bytes 331 332 %3 = load volatile <2 x i64>, <2 x i64>* %1 333 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 4080($sp) 334 store volatile <2 x i64> %3, <2 x i64>* %1 335 ; MIPS32-AE: st.d [[R1]], 4080($sp) 336 337 ret void 338 ; MIPS32-AE: .size loadstore_v2i64_just_under_simm10 339 } 340 341 define void @loadstore_v2i64_just_over_simm10() nounwind { 342 ; MIPS32-AE: loadstore_v2i64_just_over_simm10: 343 344 %1 = alloca <2 x i64> 345 %2 = alloca [4081 x i8] ; Push the frame just over 4096 bytes 346 347 %3 = load volatile <2 x i64>, <2 x i64>* %1 348 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 4096 349 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 0([[BASE]]) 350 store volatile <2 x i64> %3, <2 x i64>* %1 351 ; MIPS32-AE: addiu [[BASE:\$([0-9]+|gp)]], $sp, 4096 352 ; MIPS32-AE: st.d [[R1]], 0([[BASE]]) 353 354 ret void 355 ; MIPS32-AE: .size loadstore_v2i64_just_over_simm10 356 } 357 358 define void @loadstore_v2i64_just_under_simm16() nounwind { 359 ; MIPS32-AE: loadstore_v2i64_just_under_simm16: 360 361 %1 = alloca <2 x i64> 362 %2 = alloca [32752 x i8] ; Push the frame right up to 32768 bytes 363 364 %3 = load volatile <2 x i64>, <2 x i64>* %1 365 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 366 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 367 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 0([[BASE]]) 368 store volatile <2 x i64> %3, <2 x i64>* %1 369 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 370 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 371 ; MIPS32-AE: st.d [[R1]], 0([[BASE]]) 372 373 ret void 374 ; MIPS32-AE: .size loadstore_v2i64_just_under_simm16 375 } 376 377 define void @loadstore_v2i64_just_over_simm16() nounwind { 378 ; MIPS32-AE: loadstore_v2i64_just_over_simm16: 379 380 %1 = alloca <2 x i64> 381 %2 = alloca [32753 x i8] ; Push the frame just over 32768 bytes 382 383 %3 = load volatile <2 x i64>, <2 x i64>* %1 384 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 385 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 386 ; MIPS32-AE: ld.d [[R1:\$w[0-9]+]], 0([[BASE]]) 387 store volatile <2 x i64> %3, <2 x i64>* %1 388 ; MIPS32-AE: ori [[R2:\$([0-9]+|gp)]], $zero, 32768 389 ; MIPS32-AE: addu [[BASE:\$([0-9]+|gp)]], $sp, [[R2]] 390 ; MIPS32-AE: st.d [[R1]], 0([[BASE]]) 391 392 ret void 393 ; MIPS32-AE: .size loadstore_v2i64_just_over_simm16 394 } 395