1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=mips -mcpu=mips2 -relocation-model=pic \
3 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP32,GP32R0R2
4 ; RUN: llc < %s -mtriple=mips -mcpu=mips32 -relocation-model=pic \
5 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP32,GP32R0R2
6 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r2 -relocation-model=pic \
7 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP32,GP32R2R5
8 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r3 -relocation-model=pic \
9 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP32,GP32R2R5
10 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r5 -relocation-model=pic \
11 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP32,GP32R2R5
12 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r6 -relocation-model=pic \
13 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefix=GP32R6
15 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips3 -relocation-model=pic \
16 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R0R1
17 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips4 -relocation-model=pic \
18 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R0R1
19 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips64 -relocation-model=pic \
20 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R0R1
21 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips64r2 -relocation-model=pic \
22 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R2R5
23 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips64r3 -relocation-model=pic \
24 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R2R5
25 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips64r5 -relocation-model=pic \
26 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefixes=GP64,GP64R2R5
27 ; RUN: llc < %s -mtriple=mips64 -mcpu=mips64r6 -relocation-model=pic \
28 ; RUN: -mips-jalr-reloc=false | FileCheck %s -check-prefix=GP64R6
30 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r3 -mattr=+micromips \
31 ; RUN: -relocation-model=pic -mips-jalr-reloc=false | \
32 ; RUN: FileCheck %s -check-prefix=MMR3
33 ; RUN: llc < %s -mtriple=mips -mcpu=mips32r6 -mattr=+micromips \
34 ; RUN: -relocation-model=pic -mips-jalr-reloc=false | \
35 ; RUN: FileCheck %s -check-prefix=MMR6
37 define signext i1 @srem_i1(i1 signext %a, i1 signext %b) {
38 ; GP32-LABEL: srem_i1:
39 ; GP32: # %bb.0: # %entry
41 ; GP32-NEXT: addiu $2, $zero, 0
43 ; GP32R6-LABEL: srem_i1:
44 ; GP32R6: # %bb.0: # %entry
46 ; GP32R6-NEXT: addiu $2, $zero, 0
48 ; GP64-LABEL: srem_i1:
49 ; GP64: # %bb.0: # %entry
51 ; GP64-NEXT: addiu $2, $zero, 0
53 ; GP64R6-LABEL: srem_i1:
54 ; GP64R6: # %bb.0: # %entry
56 ; GP64R6-NEXT: addiu $2, $zero, 0
58 ; MMR3-LABEL: srem_i1:
59 ; MMR3: # %bb.0: # %entry
60 ; MMR3-NEXT: li16 $2, 0
63 ; MMR6-LABEL: srem_i1:
64 ; MMR6: # %bb.0: # %entry
65 ; MMR6-NEXT: li16 $2, 0
72 define signext i8 @srem_i8(i8 signext %a, i8 signext %b) {
73 ; GP32R0R2-LABEL: srem_i8:
74 ; GP32R0R2: # %bb.0: # %entry
75 ; GP32R0R2-NEXT: div $zero, $4, $5
76 ; GP32R0R2-NEXT: teq $5, $zero, 7
77 ; GP32R0R2-NEXT: mfhi $1
78 ; GP32R0R2-NEXT: sll $1, $1, 24
79 ; GP32R0R2-NEXT: jr $ra
80 ; GP32R0R2-NEXT: sra $2, $1, 24
82 ; GP32R2R5-LABEL: srem_i8:
83 ; GP32R2R5: # %bb.0: # %entry
84 ; GP32R2R5-NEXT: div $zero, $4, $5
85 ; GP32R2R5-NEXT: teq $5, $zero, 7
86 ; GP32R2R5-NEXT: mfhi $1
87 ; GP32R2R5-NEXT: jr $ra
88 ; GP32R2R5-NEXT: seb $2, $1
90 ; GP32R6-LABEL: srem_i8:
91 ; GP32R6: # %bb.0: # %entry
92 ; GP32R6-NEXT: mod $1, $4, $5
93 ; GP32R6-NEXT: teq $5, $zero, 7
95 ; GP32R6-NEXT: seb $2, $1
97 ; GP64R0R1-LABEL: srem_i8:
98 ; GP64R0R1: # %bb.0: # %entry
99 ; GP64R0R1-NEXT: div $zero, $4, $5
100 ; GP64R0R1-NEXT: teq $5, $zero, 7
101 ; GP64R0R1-NEXT: mfhi $1
102 ; GP64R0R1-NEXT: sll $1, $1, 24
103 ; GP64R0R1-NEXT: jr $ra
104 ; GP64R0R1-NEXT: sra $2, $1, 24
106 ; GP64R2R5-LABEL: srem_i8:
107 ; GP64R2R5: # %bb.0: # %entry
108 ; GP64R2R5-NEXT: div $zero, $4, $5
109 ; GP64R2R5-NEXT: teq $5, $zero, 7
110 ; GP64R2R5-NEXT: mfhi $1
111 ; GP64R2R5-NEXT: jr $ra
112 ; GP64R2R5-NEXT: seb $2, $1
114 ; GP64R6-LABEL: srem_i8:
115 ; GP64R6: # %bb.0: # %entry
116 ; GP64R6-NEXT: mod $1, $4, $5
117 ; GP64R6-NEXT: teq $5, $zero, 7
118 ; GP64R6-NEXT: jr $ra
119 ; GP64R6-NEXT: seb $2, $1
121 ; MMR3-LABEL: srem_i8:
122 ; MMR3: # %bb.0: # %entry
123 ; MMR3-NEXT: div $zero, $4, $5
124 ; MMR3-NEXT: teq $5, $zero, 7
125 ; MMR3-NEXT: mfhi16 $1
127 ; MMR3-NEXT: seb $2, $1
129 ; MMR6-LABEL: srem_i8:
130 ; MMR6: # %bb.0: # %entry
131 ; MMR6-NEXT: mod $1, $4, $5
132 ; MMR6-NEXT: teq $5, $zero, 7
133 ; MMR6-NEXT: seb $2, $1
140 define signext i16 @srem_i16(i16 signext %a, i16 signext %b) {
141 ; GP32R0R2-LABEL: srem_i16:
142 ; GP32R0R2: # %bb.0: # %entry
143 ; GP32R0R2-NEXT: div $zero, $4, $5
144 ; GP32R0R2-NEXT: teq $5, $zero, 7
145 ; GP32R0R2-NEXT: mfhi $1
146 ; GP32R0R2-NEXT: sll $1, $1, 16
147 ; GP32R0R2-NEXT: jr $ra
148 ; GP32R0R2-NEXT: sra $2, $1, 16
150 ; GP32R2R5-LABEL: srem_i16:
151 ; GP32R2R5: # %bb.0: # %entry
152 ; GP32R2R5-NEXT: div $zero, $4, $5
153 ; GP32R2R5-NEXT: teq $5, $zero, 7
154 ; GP32R2R5-NEXT: mfhi $1
155 ; GP32R2R5-NEXT: jr $ra
156 ; GP32R2R5-NEXT: seh $2, $1
158 ; GP32R6-LABEL: srem_i16:
159 ; GP32R6: # %bb.0: # %entry
160 ; GP32R6-NEXT: mod $1, $4, $5
161 ; GP32R6-NEXT: teq $5, $zero, 7
162 ; GP32R6-NEXT: jr $ra
163 ; GP32R6-NEXT: seh $2, $1
165 ; GP64R0R1-LABEL: srem_i16:
166 ; GP64R0R1: # %bb.0: # %entry
167 ; GP64R0R1-NEXT: div $zero, $4, $5
168 ; GP64R0R1-NEXT: teq $5, $zero, 7
169 ; GP64R0R1-NEXT: mfhi $1
170 ; GP64R0R1-NEXT: sll $1, $1, 16
171 ; GP64R0R1-NEXT: jr $ra
172 ; GP64R0R1-NEXT: sra $2, $1, 16
174 ; GP64R2R5-LABEL: srem_i16:
175 ; GP64R2R5: # %bb.0: # %entry
176 ; GP64R2R5-NEXT: div $zero, $4, $5
177 ; GP64R2R5-NEXT: teq $5, $zero, 7
178 ; GP64R2R5-NEXT: mfhi $1
179 ; GP64R2R5-NEXT: jr $ra
180 ; GP64R2R5-NEXT: seh $2, $1
182 ; GP64R6-LABEL: srem_i16:
183 ; GP64R6: # %bb.0: # %entry
184 ; GP64R6-NEXT: mod $1, $4, $5
185 ; GP64R6-NEXT: teq $5, $zero, 7
186 ; GP64R6-NEXT: jr $ra
187 ; GP64R6-NEXT: seh $2, $1
189 ; MMR3-LABEL: srem_i16:
190 ; MMR3: # %bb.0: # %entry
191 ; MMR3-NEXT: div $zero, $4, $5
192 ; MMR3-NEXT: teq $5, $zero, 7
193 ; MMR3-NEXT: mfhi16 $1
195 ; MMR3-NEXT: seh $2, $1
197 ; MMR6-LABEL: srem_i16:
198 ; MMR6: # %bb.0: # %entry
199 ; MMR6-NEXT: mod $1, $4, $5
200 ; MMR6-NEXT: teq $5, $zero, 7
201 ; MMR6-NEXT: seh $2, $1
208 define signext i32 @srem_i32(i32 signext %a, i32 signext %b) {
209 ; GP32-LABEL: srem_i32:
210 ; GP32: # %bb.0: # %entry
211 ; GP32-NEXT: div $zero, $4, $5
212 ; GP32-NEXT: teq $5, $zero, 7
216 ; GP32R6-LABEL: srem_i32:
217 ; GP32R6: # %bb.0: # %entry
218 ; GP32R6-NEXT: mod $2, $4, $5
219 ; GP32R6-NEXT: teq $5, $zero, 7
220 ; GP32R6-NEXT: jrc $ra
222 ; GP64-LABEL: srem_i32:
223 ; GP64: # %bb.0: # %entry
224 ; GP64-NEXT: div $zero, $4, $5
225 ; GP64-NEXT: teq $5, $zero, 7
229 ; GP64R6-LABEL: srem_i32:
230 ; GP64R6: # %bb.0: # %entry
231 ; GP64R6-NEXT: mod $2, $4, $5
232 ; GP64R6-NEXT: teq $5, $zero, 7
233 ; GP64R6-NEXT: jrc $ra
235 ; MMR3-LABEL: srem_i32:
236 ; MMR3: # %bb.0: # %entry
237 ; MMR3-NEXT: div $zero, $4, $5
238 ; MMR3-NEXT: teq $5, $zero, 7
239 ; MMR3-NEXT: mfhi16 $2
242 ; MMR6-LABEL: srem_i32:
243 ; MMR6: # %bb.0: # %entry
244 ; MMR6-NEXT: mod $2, $4, $5
245 ; MMR6-NEXT: teq $5, $zero, 7
252 define signext i64 @srem_i64(i64 signext %a, i64 signext %b) {
253 ; GP32-LABEL: srem_i64:
254 ; GP32: # %bb.0: # %entry
255 ; GP32-NEXT: lui $2, %hi(_gp_disp)
256 ; GP32-NEXT: addiu $2, $2, %lo(_gp_disp)
257 ; GP32-NEXT: addiu $sp, $sp, -24
258 ; GP32-NEXT: .cfi_def_cfa_offset 24
259 ; GP32-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
260 ; GP32-NEXT: .cfi_offset 31, -4
261 ; GP32-NEXT: addu $gp, $2, $25
262 ; GP32-NEXT: lw $25, %call16(__moddi3)($gp)
263 ; GP32-NEXT: jalr $25
265 ; GP32-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
267 ; GP32-NEXT: addiu $sp, $sp, 24
269 ; GP32R6-LABEL: srem_i64:
270 ; GP32R6: # %bb.0: # %entry
271 ; GP32R6-NEXT: lui $2, %hi(_gp_disp)
272 ; GP32R6-NEXT: addiu $2, $2, %lo(_gp_disp)
273 ; GP32R6-NEXT: addiu $sp, $sp, -24
274 ; GP32R6-NEXT: .cfi_def_cfa_offset 24
275 ; GP32R6-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
276 ; GP32R6-NEXT: .cfi_offset 31, -4
277 ; GP32R6-NEXT: addu $gp, $2, $25
278 ; GP32R6-NEXT: lw $25, %call16(__moddi3)($gp)
279 ; GP32R6-NEXT: jalrc $25
280 ; GP32R6-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
281 ; GP32R6-NEXT: jr $ra
282 ; GP32R6-NEXT: addiu $sp, $sp, 24
284 ; GP64-LABEL: srem_i64:
285 ; GP64: # %bb.0: # %entry
286 ; GP64-NEXT: ddiv $zero, $4, $5
287 ; GP64-NEXT: teq $5, $zero, 7
291 ; GP64R6-LABEL: srem_i64:
292 ; GP64R6: # %bb.0: # %entry
293 ; GP64R6-NEXT: dmod $2, $4, $5
294 ; GP64R6-NEXT: teq $5, $zero, 7
295 ; GP64R6-NEXT: jrc $ra
297 ; MMR3-LABEL: srem_i64:
298 ; MMR3: # %bb.0: # %entry
299 ; MMR3-NEXT: lui $2, %hi(_gp_disp)
300 ; MMR3-NEXT: addiu $2, $2, %lo(_gp_disp)
301 ; MMR3-NEXT: addiusp -24
302 ; MMR3-NEXT: .cfi_def_cfa_offset 24
303 ; MMR3-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
304 ; MMR3-NEXT: .cfi_offset 31, -4
305 ; MMR3-NEXT: addu $2, $2, $25
306 ; MMR3-NEXT: lw $25, %call16(__moddi3)($2)
307 ; MMR3-NEXT: move $gp, $2
308 ; MMR3-NEXT: jalr $25
310 ; MMR3-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
311 ; MMR3-NEXT: addiusp 24
314 ; MMR6-LABEL: srem_i64:
315 ; MMR6: # %bb.0: # %entry
316 ; MMR6-NEXT: lui $2, %hi(_gp_disp)
317 ; MMR6-NEXT: addiu $2, $2, %lo(_gp_disp)
318 ; MMR6-NEXT: addiu $sp, $sp, -24
319 ; MMR6-NEXT: .cfi_def_cfa_offset 24
320 ; MMR6-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
321 ; MMR6-NEXT: .cfi_offset 31, -4
322 ; MMR6-NEXT: addu $2, $2, $25
323 ; MMR6-NEXT: lw $25, %call16(__moddi3)($2)
324 ; MMR6-NEXT: move $gp, $2
325 ; MMR6-NEXT: jalr $25
326 ; MMR6-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
327 ; MMR6-NEXT: addiu $sp, $sp, 24
334 define signext i128 @srem_i128(i128 signext %a, i128 signext %b) {
335 ; GP32-LABEL: srem_i128:
336 ; GP32: # %bb.0: # %entry
337 ; GP32-NEXT: lui $2, %hi(_gp_disp)
338 ; GP32-NEXT: addiu $2, $2, %lo(_gp_disp)
339 ; GP32-NEXT: addiu $sp, $sp, -40
340 ; GP32-NEXT: .cfi_def_cfa_offset 40
341 ; GP32-NEXT: sw $ra, 36($sp) # 4-byte Folded Spill
342 ; GP32-NEXT: .cfi_offset 31, -4
343 ; GP32-NEXT: addu $gp, $2, $25
344 ; GP32-NEXT: lw $1, 60($sp)
345 ; GP32-NEXT: lw $2, 64($sp)
346 ; GP32-NEXT: lw $3, 68($sp)
347 ; GP32-NEXT: sw $3, 28($sp)
348 ; GP32-NEXT: sw $2, 24($sp)
349 ; GP32-NEXT: sw $1, 20($sp)
350 ; GP32-NEXT: lw $1, 56($sp)
351 ; GP32-NEXT: sw $1, 16($sp)
352 ; GP32-NEXT: lw $25, %call16(__modti3)($gp)
353 ; GP32-NEXT: jalr $25
355 ; GP32-NEXT: lw $ra, 36($sp) # 4-byte Folded Reload
357 ; GP32-NEXT: addiu $sp, $sp, 40
359 ; GP32R6-LABEL: srem_i128:
360 ; GP32R6: # %bb.0: # %entry
361 ; GP32R6-NEXT: lui $2, %hi(_gp_disp)
362 ; GP32R6-NEXT: addiu $2, $2, %lo(_gp_disp)
363 ; GP32R6-NEXT: addiu $sp, $sp, -40
364 ; GP32R6-NEXT: .cfi_def_cfa_offset 40
365 ; GP32R6-NEXT: sw $ra, 36($sp) # 4-byte Folded Spill
366 ; GP32R6-NEXT: .cfi_offset 31, -4
367 ; GP32R6-NEXT: addu $gp, $2, $25
368 ; GP32R6-NEXT: lw $1, 60($sp)
369 ; GP32R6-NEXT: lw $2, 64($sp)
370 ; GP32R6-NEXT: lw $3, 68($sp)
371 ; GP32R6-NEXT: sw $3, 28($sp)
372 ; GP32R6-NEXT: sw $2, 24($sp)
373 ; GP32R6-NEXT: sw $1, 20($sp)
374 ; GP32R6-NEXT: lw $1, 56($sp)
375 ; GP32R6-NEXT: sw $1, 16($sp)
376 ; GP32R6-NEXT: lw $25, %call16(__modti3)($gp)
377 ; GP32R6-NEXT: jalrc $25
378 ; GP32R6-NEXT: lw $ra, 36($sp) # 4-byte Folded Reload
379 ; GP32R6-NEXT: jr $ra
380 ; GP32R6-NEXT: addiu $sp, $sp, 40
382 ; GP64-LABEL: srem_i128:
383 ; GP64: # %bb.0: # %entry
384 ; GP64-NEXT: daddiu $sp, $sp, -16
385 ; GP64-NEXT: .cfi_def_cfa_offset 16
386 ; GP64-NEXT: sd $ra, 8($sp) # 8-byte Folded Spill
387 ; GP64-NEXT: sd $gp, 0($sp) # 8-byte Folded Spill
388 ; GP64-NEXT: .cfi_offset 31, -8
389 ; GP64-NEXT: .cfi_offset 28, -16
390 ; GP64-NEXT: lui $1, %hi(%neg(%gp_rel(srem_i128)))
391 ; GP64-NEXT: daddu $1, $1, $25
392 ; GP64-NEXT: daddiu $gp, $1, %lo(%neg(%gp_rel(srem_i128)))
393 ; GP64-NEXT: ld $25, %call16(__modti3)($gp)
394 ; GP64-NEXT: jalr $25
396 ; GP64-NEXT: ld $gp, 0($sp) # 8-byte Folded Reload
397 ; GP64-NEXT: ld $ra, 8($sp) # 8-byte Folded Reload
399 ; GP64-NEXT: daddiu $sp, $sp, 16
401 ; GP64R6-LABEL: srem_i128:
402 ; GP64R6: # %bb.0: # %entry
403 ; GP64R6-NEXT: daddiu $sp, $sp, -16
404 ; GP64R6-NEXT: .cfi_def_cfa_offset 16
405 ; GP64R6-NEXT: sd $ra, 8($sp) # 8-byte Folded Spill
406 ; GP64R6-NEXT: sd $gp, 0($sp) # 8-byte Folded Spill
407 ; GP64R6-NEXT: .cfi_offset 31, -8
408 ; GP64R6-NEXT: .cfi_offset 28, -16
409 ; GP64R6-NEXT: lui $1, %hi(%neg(%gp_rel(srem_i128)))
410 ; GP64R6-NEXT: daddu $1, $1, $25
411 ; GP64R6-NEXT: daddiu $gp, $1, %lo(%neg(%gp_rel(srem_i128)))
412 ; GP64R6-NEXT: ld $25, %call16(__modti3)($gp)
413 ; GP64R6-NEXT: jalrc $25
414 ; GP64R6-NEXT: ld $gp, 0($sp) # 8-byte Folded Reload
415 ; GP64R6-NEXT: ld $ra, 8($sp) # 8-byte Folded Reload
416 ; GP64R6-NEXT: jr $ra
417 ; GP64R6-NEXT: daddiu $sp, $sp, 16
419 ; MMR3-LABEL: srem_i128:
420 ; MMR3: # %bb.0: # %entry
421 ; MMR3-NEXT: lui $2, %hi(_gp_disp)
422 ; MMR3-NEXT: addiu $2, $2, %lo(_gp_disp)
423 ; MMR3-NEXT: addiusp -48
424 ; MMR3-NEXT: .cfi_def_cfa_offset 48
425 ; MMR3-NEXT: sw $ra, 44($sp) # 4-byte Folded Spill
426 ; MMR3-NEXT: swp $16, 36($sp)
427 ; MMR3-NEXT: .cfi_offset 31, -4
428 ; MMR3-NEXT: .cfi_offset 17, -8
429 ; MMR3-NEXT: .cfi_offset 16, -12
430 ; MMR3-NEXT: addu $16, $2, $25
431 ; MMR3-NEXT: move $1, $7
432 ; MMR3-NEXT: lw $7, 68($sp)
433 ; MMR3-NEXT: lw $17, 72($sp)
434 ; MMR3-NEXT: lw $3, 76($sp)
435 ; MMR3-NEXT: move $2, $sp
436 ; MMR3-NEXT: sw16 $3, 28($2)
437 ; MMR3-NEXT: sw16 $17, 24($2)
438 ; MMR3-NEXT: sw16 $7, 20($2)
439 ; MMR3-NEXT: lw $3, 64($sp)
440 ; MMR3-NEXT: sw16 $3, 16($2)
441 ; MMR3-NEXT: lw $25, %call16(__modti3)($16)
442 ; MMR3-NEXT: move $7, $1
443 ; MMR3-NEXT: move $gp, $16
444 ; MMR3-NEXT: jalr $25
446 ; MMR3-NEXT: lwp $16, 36($sp)
447 ; MMR3-NEXT: lw $ra, 44($sp) # 4-byte Folded Reload
448 ; MMR3-NEXT: addiusp 48
451 ; MMR6-LABEL: srem_i128:
452 ; MMR6: # %bb.0: # %entry
453 ; MMR6-NEXT: lui $2, %hi(_gp_disp)
454 ; MMR6-NEXT: addiu $2, $2, %lo(_gp_disp)
455 ; MMR6-NEXT: addiu $sp, $sp, -48
456 ; MMR6-NEXT: .cfi_def_cfa_offset 48
457 ; MMR6-NEXT: sw $ra, 44($sp) # 4-byte Folded Spill
458 ; MMR6-NEXT: sw $17, 40($sp) # 4-byte Folded Spill
459 ; MMR6-NEXT: sw $16, 36($sp) # 4-byte Folded Spill
460 ; MMR6-NEXT: .cfi_offset 31, -4
461 ; MMR6-NEXT: .cfi_offset 17, -8
462 ; MMR6-NEXT: .cfi_offset 16, -12
463 ; MMR6-NEXT: addu $16, $2, $25
464 ; MMR6-NEXT: move $1, $7
465 ; MMR6-NEXT: lw $7, 68($sp)
466 ; MMR6-NEXT: lw $17, 72($sp)
467 ; MMR6-NEXT: lw $3, 76($sp)
468 ; MMR6-NEXT: move $2, $sp
469 ; MMR6-NEXT: sw16 $3, 28($2)
470 ; MMR6-NEXT: sw16 $17, 24($2)
471 ; MMR6-NEXT: sw16 $7, 20($2)
472 ; MMR6-NEXT: lw $3, 64($sp)
473 ; MMR6-NEXT: sw16 $3, 16($2)
474 ; MMR6-NEXT: lw $25, %call16(__modti3)($16)
475 ; MMR6-NEXT: move $7, $1
476 ; MMR6-NEXT: move $gp, $16
477 ; MMR6-NEXT: jalr $25
478 ; MMR6-NEXT: lw $16, 36($sp) # 4-byte Folded Reload
479 ; MMR6-NEXT: lw $17, 40($sp) # 4-byte Folded Reload
480 ; MMR6-NEXT: lw $ra, 44($sp) # 4-byte Folded Reload
481 ; MMR6-NEXT: addiu $sp, $sp, 48
484 %r = srem i128 %a, %b