1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2# RUN: llc -mtriple=mips-img-linux-gnu -mcpu=mips32r6 -o - %s -start-before mips-delay-slot-filler -stop-after mips-branch-expansion | FileCheck %s --check-prefix=R6
3# RUN: llc -mtriple=mips-img-linux-gnu -mcpu=mips32r6 -o - %s -start-before mips-delay-slot-filler -stop-after mips-branch-expansion -relocation-model=pic | FileCheck %s --check-prefix=PIC
4
5# Test the long branch expansion of various branches
6
7--- |
8  define void @expand_BEQC(i1 %a) {
9    br i1 %a, label %iftrue, label %tail
10
11  iftrue:
12    call void asm sideeffect ".space 131068", ""()
13    br label %tail
14
15  tail:
16    ret void
17  }
18
19  define void @expand_BNEC(i1 %a) {
20    br i1 %a, label %iftrue, label %tail
21
22  iftrue:
23    call void asm sideeffect ".space 131068", ""()
24    br label %tail
25
26  tail:
27    ret void
28  }
29
30  define void @expand_BGEC(i1 %a) {
31    br i1 %a, label %iftrue, label %tail
32
33  iftrue:
34    call void asm sideeffect ".space 131068", ""()
35    br label %tail
36
37  tail:
38    ret void
39  }
40
41  define void @expand_BGEUC(i1 %a) {
42    br i1 %a, label %iftrue, label %tail
43
44  iftrue:
45    call void asm sideeffect ".space 131068", ""()
46    br label %tail
47
48  tail:
49    ret void
50  }
51
52  define void @expand_BGEZC(i1 %a) {
53    br i1 %a, label %iftrue, label %tail
54
55  iftrue:
56    call void asm sideeffect ".space 131068", ""()
57    br label %tail
58
59  tail:
60    ret void
61  }
62
63  define void @expand_BGTZC(i1 %a) {
64    br i1 %a, label %iftrue, label %tail
65
66  iftrue:
67    call void asm sideeffect ".space 131068", ""()
68    br label %tail
69
70  tail:
71    ret void
72  }
73
74  define void @expand_BLEZC(i1 %a) {
75    br i1 %a, label %iftrue, label %tail
76
77  iftrue:
78    call void asm sideeffect ".space 131068", ""()
79    br label %tail
80
81  tail:
82    ret void
83  }
84
85  define void @expand_BLTC(i1 %a) {
86    br i1 %a, label %iftrue, label %tail
87
88  iftrue:
89    call void asm sideeffect ".space 131068", ""()
90    br label %tail
91
92  tail:
93    ret void
94  }
95
96  define void @expand_BLTUC(i1 %a) {
97    br i1 %a, label %iftrue, label %tail
98
99  iftrue:
100    call void asm sideeffect ".space 131068", ""()
101    br label %tail
102
103  tail:
104    ret void
105  }
106
107  define void @expand_BLTZC(i1 %a) {
108    br i1 %a, label %iftrue, label %tail
109
110  iftrue:
111    call void asm sideeffect ".space 131068", ""()
112    br label %tail
113
114  tail:
115    ret void
116  }
117
118  define void @expand_BEQZC(i1 %a) {
119    br i1 %a, label %iftrue, label %tail
120
121  iftrue:
122    call void asm sideeffect ".space 8388608", ""()
123    br label %tail
124
125  tail:
126    ret void
127  }
128
129  define void @expand_BNEZC(i1 %a) {
130    br i1 %a, label %iftrue, label %tail
131
132  iftrue:
133    call void asm sideeffect ".space 8388608", ""()
134    br label %tail
135
136  tail:
137    ret void
138  }
139
140...
141---
142
143name:            expand_BEQC
144alignment:       2
145exposesReturnsTwice: false
146legalized:       false
147regBankSelected: false
148selected:        false
149failedISel:      false
150tracksRegLiveness: true
151registers:
152liveins:
153  - { reg: '$a0', virtual-reg: '' }
154frameInfo:
155  isFrameAddressTaken: false
156  isReturnAddressTaken: false
157  hasStackMap:     false
158  hasPatchPoint:   false
159  stackSize:       0
160  offsetAdjustment: 0
161  maxAlignment:    1
162  adjustsStack:    false
163  hasCalls:        false
164  stackProtector:  ''
165  maxCallFrameSize: 0
166  hasOpaqueSPAdjustment: false
167  hasVAStart:      false
168  hasMustTailInVarArgFunc: false
169  localFrameSize:  0
170  savePoint:       ''
171  restorePoint:    ''
172fixedStack:
173stack:
174constants:
175body:             |
176  ; R6-LABEL: name: expand_BEQC
177  ; R6: bb.0 (%ir-block.0):
178  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
179  ; R6:   renamable $at = ANDi killed renamable $a0, 1
180  ; R6:   BNEC $at, $zero, %bb.2, implicit-def $at
181  ; R6: bb.1 (%ir-block.0):
182  ; R6:   successors: %bb.3(0x80000000)
183  ; R6:   BC %bb.3
184  ; R6: bb.2.iftrue:
185  ; R6:   successors: %bb.3(0x80000000)
186  ; R6:   INLINEASM &".space 131068", 1
187  ; R6: bb.3.tail:
188  ; R6:   JIC undef $ra, 0, implicit-def $at
189  ; PIC-LABEL: name: expand_BEQC
190  ; PIC: bb.0 (%ir-block.0):
191  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
192  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
193  ; PIC:   BNEC $at, $zero, %bb.3, implicit-def $at
194  ; PIC: bb.1 (%ir-block.0):
195  ; PIC:   successors: %bb.2(0x80000000)
196  ; PIC:   $sp = ADDiu $sp, -8
197  ; PIC:   SW $ra, $sp, 0
198  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
199  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
200  ; PIC:   BALC %bb.2, implicit-def $ra
201  ; PIC: bb.2 (%ir-block.0):
202  ; PIC:   successors: %bb.4(0x80000000)
203  ; PIC:   $at = ADDu $ra, $at
204  ; PIC:   $ra = LW $sp, 0
205  ; PIC:   $sp = ADDiu $sp, 8
206  ; PIC:   JIC $at, 0, implicit-def $at
207  ; PIC: bb.3.iftrue:
208  ; PIC:   successors: %bb.4(0x80000000)
209  ; PIC:   INLINEASM &".space 131068", 1
210  ; PIC: bb.4.tail:
211  ; PIC:   JIC undef $ra, 0, implicit-def $at
212  bb.0 (%ir-block.0):
213    successors: %bb.1(0x40000000), %bb.2(0x40000000)
214    liveins: $a0
215
216    renamable $at = ANDi killed renamable $a0, 1
217    BEQC killed renamable $at, $zero, %bb.2, implicit-def $at
218
219  bb.1.iftrue:
220    successors: %bb.2(0x80000000)
221
222    INLINEASM &".space 131068", 1
223
224  bb.2.tail:
225    PseudoReturn undef $ra
226
227...
228---
229
230name:            expand_BNEC
231alignment:       2
232exposesReturnsTwice: false
233legalized:       false
234regBankSelected: false
235selected:        false
236failedISel:      false
237tracksRegLiveness: true
238registers:
239liveins:
240  - { reg: '$a0', virtual-reg: '' }
241frameInfo:
242  isFrameAddressTaken: false
243  isReturnAddressTaken: false
244  hasStackMap:     false
245  hasPatchPoint:   false
246  stackSize:       0
247  offsetAdjustment: 0
248  maxAlignment:    1
249  adjustsStack:    false
250  hasCalls:        false
251  stackProtector:  ''
252  maxCallFrameSize: 0
253  hasOpaqueSPAdjustment: false
254  hasVAStart:      false
255  hasMustTailInVarArgFunc: false
256  localFrameSize:  0
257  savePoint:       ''
258  restorePoint:    ''
259fixedStack:
260stack:
261constants:
262body:             |
263  ; R6-LABEL: name: expand_BNEC
264  ; R6: bb.0 (%ir-block.0):
265  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
266  ; R6:   renamable $at = ANDi killed renamable $a0, 1
267  ; R6:   BEQC $at, $zero, %bb.2, implicit-def $at
268  ; R6: bb.1 (%ir-block.0):
269  ; R6:   successors: %bb.3(0x80000000)
270  ; R6:   BC %bb.3
271  ; R6: bb.2.iftrue:
272  ; R6:   successors: %bb.3(0x80000000)
273  ; R6:   INLINEASM &".space 131068", 1
274  ; R6: bb.3.tail:
275  ; R6:   JIC undef $ra, 0, implicit-def $at
276  ; PIC-LABEL: name: expand_BNEC
277  ; PIC: bb.0 (%ir-block.0):
278  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
279  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
280  ; PIC:   BEQC $at, $zero, %bb.3, implicit-def $at
281  ; PIC: bb.1 (%ir-block.0):
282  ; PIC:   successors: %bb.2(0x80000000)
283  ; PIC:   $sp = ADDiu $sp, -8
284  ; PIC:   SW $ra, $sp, 0
285  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
286  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
287  ; PIC:   BALC %bb.2, implicit-def $ra
288  ; PIC: bb.2 (%ir-block.0):
289  ; PIC:   successors: %bb.4(0x80000000)
290  ; PIC:   $at = ADDu $ra, $at
291  ; PIC:   $ra = LW $sp, 0
292  ; PIC:   $sp = ADDiu $sp, 8
293  ; PIC:   JIC $at, 0, implicit-def $at
294  ; PIC: bb.3.iftrue:
295  ; PIC:   successors: %bb.4(0x80000000)
296  ; PIC:   INLINEASM &".space 131068", 1
297  ; PIC: bb.4.tail:
298  ; PIC:   JIC undef $ra, 0, implicit-def $at
299  bb.0 (%ir-block.0):
300    successors: %bb.1(0x40000000), %bb.2(0x40000000)
301    liveins: $a0
302
303    renamable $at = ANDi killed renamable $a0, 1
304    BNEC killed renamable $at, $zero, %bb.2, implicit-def $at
305
306  bb.1.iftrue:
307    successors: %bb.2(0x80000000)
308
309    INLINEASM &".space 131068", 1
310
311  bb.2.tail:
312    PseudoReturn undef $ra
313
314...
315---
316
317name:            expand_BGEC
318alignment:       2
319exposesReturnsTwice: false
320legalized:       false
321regBankSelected: false
322selected:        false
323failedISel:      false
324tracksRegLiveness: true
325registers:
326liveins:
327  - { reg: '$a0', virtual-reg: '' }
328frameInfo:
329  isFrameAddressTaken: false
330  isReturnAddressTaken: false
331  hasStackMap:     false
332  hasPatchPoint:   false
333  stackSize:       0
334  offsetAdjustment: 0
335  maxAlignment:    1
336  adjustsStack:    false
337  hasCalls:        false
338  stackProtector:  ''
339  maxCallFrameSize: 0
340  hasOpaqueSPAdjustment: false
341  hasVAStart:      false
342  hasMustTailInVarArgFunc: false
343  localFrameSize:  0
344  savePoint:       ''
345  restorePoint:    ''
346fixedStack:
347stack:
348constants:
349body:             |
350  ; R6-LABEL: name: expand_BGEC
351  ; R6: bb.0 (%ir-block.0):
352  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
353  ; R6:   renamable $at = ANDi killed renamable $a0, 1
354  ; R6:   BLTC $at, $zero, %bb.2, implicit-def $at
355  ; R6: bb.1 (%ir-block.0):
356  ; R6:   successors: %bb.3(0x80000000)
357  ; R6:   BC %bb.3
358  ; R6: bb.2.iftrue:
359  ; R6:   successors: %bb.3(0x80000000)
360  ; R6:   INLINEASM &".space 131068", 1
361  ; R6: bb.3.tail:
362  ; R6:   JIC undef $ra, 0, implicit-def $at
363  ; PIC-LABEL: name: expand_BGEC
364  ; PIC: bb.0 (%ir-block.0):
365  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
366  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
367  ; PIC:   BLTC $at, $zero, %bb.3, implicit-def $at
368  ; PIC: bb.1 (%ir-block.0):
369  ; PIC:   successors: %bb.2(0x80000000)
370  ; PIC:   $sp = ADDiu $sp, -8
371  ; PIC:   SW $ra, $sp, 0
372  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
373  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
374  ; PIC:   BALC %bb.2, implicit-def $ra
375  ; PIC: bb.2 (%ir-block.0):
376  ; PIC:   successors: %bb.4(0x80000000)
377  ; PIC:   $at = ADDu $ra, $at
378  ; PIC:   $ra = LW $sp, 0
379  ; PIC:   $sp = ADDiu $sp, 8
380  ; PIC:   JIC $at, 0, implicit-def $at
381  ; PIC: bb.3.iftrue:
382  ; PIC:   successors: %bb.4(0x80000000)
383  ; PIC:   INLINEASM &".space 131068", 1
384  ; PIC: bb.4.tail:
385  ; PIC:   JIC undef $ra, 0, implicit-def $at
386  bb.0 (%ir-block.0):
387    successors: %bb.1(0x40000000), %bb.2(0x40000000)
388    liveins: $a0
389
390    renamable $at = ANDi killed renamable $a0, 1
391    BGEC killed renamable $at, $zero, %bb.2, implicit-def $at
392
393  bb.1.iftrue:
394    successors: %bb.2(0x80000000)
395
396    INLINEASM &".space 131068", 1
397
398  bb.2.tail:
399    PseudoReturn undef $ra
400
401...
402---
403
404name:            expand_BGEUC
405alignment:       2
406exposesReturnsTwice: false
407legalized:       false
408regBankSelected: false
409selected:        false
410failedISel:      false
411tracksRegLiveness: true
412registers:
413liveins:
414  - { reg: '$a0', virtual-reg: '' }
415frameInfo:
416  isFrameAddressTaken: false
417  isReturnAddressTaken: false
418  hasStackMap:     false
419  hasPatchPoint:   false
420  stackSize:       0
421  offsetAdjustment: 0
422  maxAlignment:    1
423  adjustsStack:    false
424  hasCalls:        false
425  stackProtector:  ''
426  maxCallFrameSize: 0
427  hasOpaqueSPAdjustment: false
428  hasVAStart:      false
429  hasMustTailInVarArgFunc: false
430  localFrameSize:  0
431  savePoint:       ''
432  restorePoint:    ''
433fixedStack:
434stack:
435constants:
436body:             |
437  ; R6-LABEL: name: expand_BGEUC
438  ; R6: bb.0 (%ir-block.0):
439  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
440  ; R6:   renamable $at = ANDi killed renamable $a0, 1
441  ; R6:   BLTUC $at, $zero, %bb.2, implicit-def $at
442  ; R6: bb.1 (%ir-block.0):
443  ; R6:   successors: %bb.3(0x80000000)
444  ; R6:   BC %bb.3
445  ; R6: bb.2.iftrue:
446  ; R6:   successors: %bb.3(0x80000000)
447  ; R6:   INLINEASM &".space 131068", 1
448  ; R6: bb.3.tail:
449  ; R6:   JIC undef $ra, 0, implicit-def $at
450  ; PIC-LABEL: name: expand_BGEUC
451  ; PIC: bb.0 (%ir-block.0):
452  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
453  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
454  ; PIC:   BLTUC $at, $zero, %bb.3, implicit-def $at
455  ; PIC: bb.1 (%ir-block.0):
456  ; PIC:   successors: %bb.2(0x80000000)
457  ; PIC:   $sp = ADDiu $sp, -8
458  ; PIC:   SW $ra, $sp, 0
459  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
460  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
461  ; PIC:   BALC %bb.2, implicit-def $ra
462  ; PIC: bb.2 (%ir-block.0):
463  ; PIC:   successors: %bb.4(0x80000000)
464  ; PIC:   $at = ADDu $ra, $at
465  ; PIC:   $ra = LW $sp, 0
466  ; PIC:   $sp = ADDiu $sp, 8
467  ; PIC:   JIC $at, 0, implicit-def $at
468  ; PIC: bb.3.iftrue:
469  ; PIC:   successors: %bb.4(0x80000000)
470  ; PIC:   INLINEASM &".space 131068", 1
471  ; PIC: bb.4.tail:
472  ; PIC:   JIC undef $ra, 0, implicit-def $at
473  bb.0 (%ir-block.0):
474    successors: %bb.1(0x40000000), %bb.2(0x40000000)
475    liveins: $a0
476
477    renamable $at = ANDi killed renamable $a0, 1
478    BGEUC killed renamable $at, $zero, %bb.2, implicit-def $at
479
480  bb.1.iftrue:
481    successors: %bb.2(0x80000000)
482
483    INLINEASM &".space 131068", 1
484
485  bb.2.tail:
486    PseudoReturn undef $ra
487
488...
489---
490
491name:            expand_BGEZC
492alignment:       2
493exposesReturnsTwice: false
494legalized:       false
495regBankSelected: false
496selected:        false
497failedISel:      false
498tracksRegLiveness: true
499registers:
500liveins:
501  - { reg: '$a0', virtual-reg: '' }
502frameInfo:
503  isFrameAddressTaken: false
504  isReturnAddressTaken: false
505  hasStackMap:     false
506  hasPatchPoint:   false
507  stackSize:       0
508  offsetAdjustment: 0
509  maxAlignment:    1
510  adjustsStack:    false
511  hasCalls:        false
512  stackProtector:  ''
513  maxCallFrameSize: 0
514  hasOpaqueSPAdjustment: false
515  hasVAStart:      false
516  hasMustTailInVarArgFunc: false
517  localFrameSize:  0
518  savePoint:       ''
519  restorePoint:    ''
520fixedStack:
521stack:
522constants:
523body:             |
524  ; R6-LABEL: name: expand_BGEZC
525  ; R6: bb.0 (%ir-block.0):
526  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
527  ; R6:   renamable $at = ANDi killed renamable $a0, 1
528  ; R6:   BLTZC $at, %bb.2, implicit-def $at
529  ; R6: bb.1 (%ir-block.0):
530  ; R6:   successors: %bb.3(0x80000000)
531  ; R6:   BC %bb.3
532  ; R6: bb.2.iftrue:
533  ; R6:   successors: %bb.3(0x80000000)
534  ; R6:   INLINEASM &".space 131068", 1
535  ; R6: bb.3.tail:
536  ; R6:   JIC undef $ra, 0, implicit-def $at
537  ; PIC-LABEL: name: expand_BGEZC
538  ; PIC: bb.0 (%ir-block.0):
539  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
540  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
541  ; PIC:   BLTZC $at, %bb.3, implicit-def $at
542  ; PIC: bb.1 (%ir-block.0):
543  ; PIC:   successors: %bb.2(0x80000000)
544  ; PIC:   $sp = ADDiu $sp, -8
545  ; PIC:   SW $ra, $sp, 0
546  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
547  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
548  ; PIC:   BALC %bb.2, implicit-def $ra
549  ; PIC: bb.2 (%ir-block.0):
550  ; PIC:   successors: %bb.4(0x80000000)
551  ; PIC:   $at = ADDu $ra, $at
552  ; PIC:   $ra = LW $sp, 0
553  ; PIC:   $sp = ADDiu $sp, 8
554  ; PIC:   JIC $at, 0, implicit-def $at
555  ; PIC: bb.3.iftrue:
556  ; PIC:   successors: %bb.4(0x80000000)
557  ; PIC:   INLINEASM &".space 131068", 1
558  ; PIC: bb.4.tail:
559  ; PIC:   JIC undef $ra, 0, implicit-def $at
560  bb.0 (%ir-block.0):
561    successors: %bb.1(0x40000000), %bb.2(0x40000000)
562    liveins: $a0
563
564    renamable $at = ANDi killed renamable $a0, 1
565    BGEZC killed renamable $at, %bb.2, implicit-def $at
566
567  bb.1.iftrue:
568    successors: %bb.2(0x80000000)
569
570    INLINEASM &".space 131068", 1
571
572  bb.2.tail:
573    PseudoReturn undef $ra
574
575...
576---
577
578name:            expand_BGTZC
579alignment:       2
580exposesReturnsTwice: false
581legalized:       false
582regBankSelected: false
583selected:        false
584failedISel:      false
585tracksRegLiveness: true
586registers:
587liveins:
588  - { reg: '$a0', virtual-reg: '' }
589frameInfo:
590  isFrameAddressTaken: false
591  isReturnAddressTaken: false
592  hasStackMap:     false
593  hasPatchPoint:   false
594  stackSize:       0
595  offsetAdjustment: 0
596  maxAlignment:    1
597  adjustsStack:    false
598  hasCalls:        false
599  stackProtector:  ''
600  maxCallFrameSize: 0
601  hasOpaqueSPAdjustment: false
602  hasVAStart:      false
603  hasMustTailInVarArgFunc: false
604  localFrameSize:  0
605  savePoint:       ''
606  restorePoint:    ''
607fixedStack:
608stack:
609constants:
610body:             |
611  ; R6-LABEL: name: expand_BGTZC
612  ; R6: bb.0 (%ir-block.0):
613  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
614  ; R6:   renamable $at = ANDi killed renamable $a0, 1
615  ; R6:   BLEZC $at, %bb.2, implicit-def $at
616  ; R6: bb.1 (%ir-block.0):
617  ; R6:   successors: %bb.3(0x80000000)
618  ; R6:   BC %bb.3
619  ; R6: bb.2.iftrue:
620  ; R6:   successors: %bb.3(0x80000000)
621  ; R6:   INLINEASM &".space 131068", 1
622  ; R6: bb.3.tail:
623  ; R6:   JIC undef $ra, 0, implicit-def $at
624  ; PIC-LABEL: name: expand_BGTZC
625  ; PIC: bb.0 (%ir-block.0):
626  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
627  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
628  ; PIC:   BLEZC $at, %bb.3, implicit-def $at
629  ; PIC: bb.1 (%ir-block.0):
630  ; PIC:   successors: %bb.2(0x80000000)
631  ; PIC:   $sp = ADDiu $sp, -8
632  ; PIC:   SW $ra, $sp, 0
633  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
634  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
635  ; PIC:   BALC %bb.2, implicit-def $ra
636  ; PIC: bb.2 (%ir-block.0):
637  ; PIC:   successors: %bb.4(0x80000000)
638  ; PIC:   $at = ADDu $ra, $at
639  ; PIC:   $ra = LW $sp, 0
640  ; PIC:   $sp = ADDiu $sp, 8
641  ; PIC:   JIC $at, 0, implicit-def $at
642  ; PIC: bb.3.iftrue:
643  ; PIC:   successors: %bb.4(0x80000000)
644  ; PIC:   INLINEASM &".space 131068", 1
645  ; PIC: bb.4.tail:
646  ; PIC:   JIC undef $ra, 0, implicit-def $at
647  bb.0 (%ir-block.0):
648    successors: %bb.1(0x40000000), %bb.2(0x40000000)
649    liveins: $a0
650
651    renamable $at = ANDi killed renamable $a0, 1
652    BGTZC killed renamable $at, %bb.2, implicit-def $at
653
654  bb.1.iftrue:
655    successors: %bb.2(0x80000000)
656
657    INLINEASM &".space 131068", 1
658
659  bb.2.tail:
660    PseudoReturn undef $ra
661
662...
663---
664
665name:            expand_BLEZC
666alignment:       2
667exposesReturnsTwice: false
668legalized:       false
669regBankSelected: false
670selected:        false
671failedISel:      false
672tracksRegLiveness: true
673registers:
674liveins:
675  - { reg: '$a0', virtual-reg: '' }
676frameInfo:
677  isFrameAddressTaken: false
678  isReturnAddressTaken: false
679  hasStackMap:     false
680  hasPatchPoint:   false
681  stackSize:       0
682  offsetAdjustment: 0
683  maxAlignment:    1
684  adjustsStack:    false
685  hasCalls:        false
686  stackProtector:  ''
687  maxCallFrameSize: 0
688  hasOpaqueSPAdjustment: false
689  hasVAStart:      false
690  hasMustTailInVarArgFunc: false
691  localFrameSize:  0
692  savePoint:       ''
693  restorePoint:    ''
694fixedStack:
695stack:
696constants:
697body:             |
698  ; R6-LABEL: name: expand_BLEZC
699  ; R6: bb.0 (%ir-block.0):
700  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
701  ; R6:   renamable $at = ANDi killed renamable $a0, 1
702  ; R6:   BGTZC $at, %bb.2, implicit-def $at
703  ; R6: bb.1 (%ir-block.0):
704  ; R6:   successors: %bb.3(0x80000000)
705  ; R6:   BC %bb.3
706  ; R6: bb.2.iftrue:
707  ; R6:   successors: %bb.3(0x80000000)
708  ; R6:   INLINEASM &".space 131068", 1
709  ; R6: bb.3.tail:
710  ; R6:   JIC undef $ra, 0, implicit-def $at
711  ; PIC-LABEL: name: expand_BLEZC
712  ; PIC: bb.0 (%ir-block.0):
713  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
714  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
715  ; PIC:   BGTZC $at, %bb.3, implicit-def $at
716  ; PIC: bb.1 (%ir-block.0):
717  ; PIC:   successors: %bb.2(0x80000000)
718  ; PIC:   $sp = ADDiu $sp, -8
719  ; PIC:   SW $ra, $sp, 0
720  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
721  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
722  ; PIC:   BALC %bb.2, implicit-def $ra
723  ; PIC: bb.2 (%ir-block.0):
724  ; PIC:   successors: %bb.4(0x80000000)
725  ; PIC:   $at = ADDu $ra, $at
726  ; PIC:   $ra = LW $sp, 0
727  ; PIC:   $sp = ADDiu $sp, 8
728  ; PIC:   JIC $at, 0, implicit-def $at
729  ; PIC: bb.3.iftrue:
730  ; PIC:   successors: %bb.4(0x80000000)
731  ; PIC:   INLINEASM &".space 131068", 1
732  ; PIC: bb.4.tail:
733  ; PIC:   JIC undef $ra, 0, implicit-def $at
734  bb.0 (%ir-block.0):
735    successors: %bb.1(0x40000000), %bb.2(0x40000000)
736    liveins: $a0
737
738    renamable $at = ANDi killed renamable $a0, 1
739    BLEZC killed renamable $at, %bb.2, implicit-def $at
740
741  bb.1.iftrue:
742    successors: %bb.2(0x80000000)
743
744    INLINEASM &".space 131068", 1
745
746  bb.2.tail:
747    PseudoReturn undef $ra
748
749...
750---
751
752name:            expand_BLTC
753alignment:       2
754exposesReturnsTwice: false
755legalized:       false
756regBankSelected: false
757selected:        false
758failedISel:      false
759tracksRegLiveness: true
760registers:
761liveins:
762  - { reg: '$a0', virtual-reg: '' }
763frameInfo:
764  isFrameAddressTaken: false
765  isReturnAddressTaken: false
766  hasStackMap:     false
767  hasPatchPoint:   false
768  stackSize:       0
769  offsetAdjustment: 0
770  maxAlignment:    1
771  adjustsStack:    false
772  hasCalls:        false
773  stackProtector:  ''
774  maxCallFrameSize: 0
775  hasOpaqueSPAdjustment: false
776  hasVAStart:      false
777  hasMustTailInVarArgFunc: false
778  localFrameSize:  0
779  savePoint:       ''
780  restorePoint:    ''
781fixedStack:
782stack:
783constants:
784body:             |
785  ; R6-LABEL: name: expand_BLTC
786  ; R6: bb.0 (%ir-block.0):
787  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
788  ; R6:   renamable $at = ANDi killed renamable $a0, 1
789  ; R6:   BGEC $at, $zero, %bb.2, implicit-def $at
790  ; R6: bb.1 (%ir-block.0):
791  ; R6:   successors: %bb.3(0x80000000)
792  ; R6:   BC %bb.3
793  ; R6: bb.2.iftrue:
794  ; R6:   successors: %bb.3(0x80000000)
795  ; R6:   INLINEASM &".space 131068", 1
796  ; R6: bb.3.tail:
797  ; R6:   JIC undef $ra, 0, implicit-def $at
798  ; PIC-LABEL: name: expand_BLTC
799  ; PIC: bb.0 (%ir-block.0):
800  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
801  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
802  ; PIC:   BGEC $at, $zero, %bb.3, implicit-def $at
803  ; PIC: bb.1 (%ir-block.0):
804  ; PIC:   successors: %bb.2(0x80000000)
805  ; PIC:   $sp = ADDiu $sp, -8
806  ; PIC:   SW $ra, $sp, 0
807  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
808  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
809  ; PIC:   BALC %bb.2, implicit-def $ra
810  ; PIC: bb.2 (%ir-block.0):
811  ; PIC:   successors: %bb.4(0x80000000)
812  ; PIC:   $at = ADDu $ra, $at
813  ; PIC:   $ra = LW $sp, 0
814  ; PIC:   $sp = ADDiu $sp, 8
815  ; PIC:   JIC $at, 0, implicit-def $at
816  ; PIC: bb.3.iftrue:
817  ; PIC:   successors: %bb.4(0x80000000)
818  ; PIC:   INLINEASM &".space 131068", 1
819  ; PIC: bb.4.tail:
820  ; PIC:   JIC undef $ra, 0, implicit-def $at
821  bb.0 (%ir-block.0):
822    successors: %bb.1(0x40000000), %bb.2(0x40000000)
823    liveins: $a0
824
825    renamable $at = ANDi killed renamable $a0, 1
826    BLTC killed renamable $at, $zero, %bb.2, implicit-def $at
827
828  bb.1.iftrue:
829    successors: %bb.2(0x80000000)
830
831    INLINEASM &".space 131068", 1
832
833  bb.2.tail:
834    PseudoReturn undef $ra
835
836...
837---
838
839name:            expand_BLTUC
840alignment:       2
841exposesReturnsTwice: false
842legalized:       false
843regBankSelected: false
844selected:        false
845failedISel:      false
846tracksRegLiveness: true
847registers:
848liveins:
849  - { reg: '$a0', virtual-reg: '' }
850frameInfo:
851  isFrameAddressTaken: false
852  isReturnAddressTaken: false
853  hasStackMap:     false
854  hasPatchPoint:   false
855  stackSize:       0
856  offsetAdjustment: 0
857  maxAlignment:    1
858  adjustsStack:    false
859  hasCalls:        false
860  stackProtector:  ''
861  maxCallFrameSize: 0
862  hasOpaqueSPAdjustment: false
863  hasVAStart:      false
864  hasMustTailInVarArgFunc: false
865  localFrameSize:  0
866  savePoint:       ''
867  restorePoint:    ''
868fixedStack:
869stack:
870constants:
871body:             |
872  ; R6-LABEL: name: expand_BLTUC
873  ; R6: bb.0 (%ir-block.0):
874  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
875  ; R6:   renamable $at = ANDi killed renamable $a0, 1
876  ; R6:   BGEUC $at, $zero, %bb.2, implicit-def $at
877  ; R6: bb.1 (%ir-block.0):
878  ; R6:   successors: %bb.3(0x80000000)
879  ; R6:   BC %bb.3
880  ; R6: bb.2.iftrue:
881  ; R6:   successors: %bb.3(0x80000000)
882  ; R6:   INLINEASM &".space 131068", 1
883  ; R6: bb.3.tail:
884  ; R6:   JIC undef $ra, 0, implicit-def $at
885  ; PIC-LABEL: name: expand_BLTUC
886  ; PIC: bb.0 (%ir-block.0):
887  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
888  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
889  ; PIC:   BGEUC $at, $zero, %bb.3, implicit-def $at
890  ; PIC: bb.1 (%ir-block.0):
891  ; PIC:   successors: %bb.2(0x80000000)
892  ; PIC:   $sp = ADDiu $sp, -8
893  ; PIC:   SW $ra, $sp, 0
894  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
895  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
896  ; PIC:   BALC %bb.2, implicit-def $ra
897  ; PIC: bb.2 (%ir-block.0):
898  ; PIC:   successors: %bb.4(0x80000000)
899  ; PIC:   $at = ADDu $ra, $at
900  ; PIC:   $ra = LW $sp, 0
901  ; PIC:   $sp = ADDiu $sp, 8
902  ; PIC:   JIC $at, 0, implicit-def $at
903  ; PIC: bb.3.iftrue:
904  ; PIC:   successors: %bb.4(0x80000000)
905  ; PIC:   INLINEASM &".space 131068", 1
906  ; PIC: bb.4.tail:
907  ; PIC:   JIC undef $ra, 0, implicit-def $at
908  bb.0 (%ir-block.0):
909    successors: %bb.1(0x40000000), %bb.2(0x40000000)
910    liveins: $a0
911
912    renamable $at = ANDi killed renamable $a0, 1
913    BLTUC killed renamable $at, $zero, %bb.2, implicit-def $at
914
915  bb.1.iftrue:
916    successors: %bb.2(0x80000000)
917
918    INLINEASM &".space 131068", 1
919
920  bb.2.tail:
921    PseudoReturn undef $ra
922
923...
924---
925
926name:            expand_BLTZC
927alignment:       2
928exposesReturnsTwice: false
929legalized:       false
930regBankSelected: false
931selected:        false
932failedISel:      false
933tracksRegLiveness: true
934registers:
935liveins:
936  - { reg: '$a0', virtual-reg: '' }
937frameInfo:
938  isFrameAddressTaken: false
939  isReturnAddressTaken: false
940  hasStackMap:     false
941  hasPatchPoint:   false
942  stackSize:       0
943  offsetAdjustment: 0
944  maxAlignment:    1
945  adjustsStack:    false
946  hasCalls:        false
947  stackProtector:  ''
948  maxCallFrameSize: 0
949  hasOpaqueSPAdjustment: false
950  hasVAStart:      false
951  hasMustTailInVarArgFunc: false
952  localFrameSize:  0
953  savePoint:       ''
954  restorePoint:    ''
955fixedStack:
956stack:
957constants:
958body:             |
959  ; R6-LABEL: name: expand_BLTZC
960  ; R6: bb.0 (%ir-block.0):
961  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
962  ; R6:   renamable $at = ANDi killed renamable $a0, 1
963  ; R6:   BGEZC $at, %bb.2, implicit-def $at
964  ; R6: bb.1 (%ir-block.0):
965  ; R6:   successors: %bb.3(0x80000000)
966  ; R6:   BC %bb.3
967  ; R6: bb.2.iftrue:
968  ; R6:   successors: %bb.3(0x80000000)
969  ; R6:   INLINEASM &".space 131068", 1
970  ; R6: bb.3.tail:
971  ; R6:   JIC undef $ra, 0, implicit-def $at
972  ; PIC-LABEL: name: expand_BLTZC
973  ; PIC: bb.0 (%ir-block.0):
974  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
975  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
976  ; PIC:   BGEZC $at, %bb.3, implicit-def $at
977  ; PIC: bb.1 (%ir-block.0):
978  ; PIC:   successors: %bb.2(0x80000000)
979  ; PIC:   $sp = ADDiu $sp, -8
980  ; PIC:   SW $ra, $sp, 0
981  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
982  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
983  ; PIC:   BALC %bb.2, implicit-def $ra
984  ; PIC: bb.2 (%ir-block.0):
985  ; PIC:   successors: %bb.4(0x80000000)
986  ; PIC:   $at = ADDu $ra, $at
987  ; PIC:   $ra = LW $sp, 0
988  ; PIC:   $sp = ADDiu $sp, 8
989  ; PIC:   JIC $at, 0, implicit-def $at
990  ; PIC: bb.3.iftrue:
991  ; PIC:   successors: %bb.4(0x80000000)
992  ; PIC:   INLINEASM &".space 131068", 1
993  ; PIC: bb.4.tail:
994  ; PIC:   JIC undef $ra, 0, implicit-def $at
995  bb.0 (%ir-block.0):
996    successors: %bb.1(0x40000000), %bb.2(0x40000000)
997    liveins: $a0
998
999    renamable $at = ANDi killed renamable $a0, 1
1000    BLTZC killed renamable $at, %bb.2, implicit-def $at
1001
1002  bb.1.iftrue:
1003    successors: %bb.2(0x80000000)
1004
1005    INLINEASM &".space 131068", 1
1006
1007  bb.2.tail:
1008    PseudoReturn undef $ra
1009
1010...
1011---
1012
1013name:            expand_BEQZC
1014alignment:       2
1015exposesReturnsTwice: false
1016legalized:       false
1017regBankSelected: false
1018selected:        false
1019failedISel:      false
1020tracksRegLiveness: true
1021registers:
1022liveins:
1023  - { reg: '$a0', virtual-reg: '' }
1024frameInfo:
1025  isFrameAddressTaken: false
1026  isReturnAddressTaken: false
1027  hasStackMap:     false
1028  hasPatchPoint:   false
1029  stackSize:       0
1030  offsetAdjustment: 0
1031  maxAlignment:    1
1032  adjustsStack:    false
1033  hasCalls:        false
1034  stackProtector:  ''
1035  maxCallFrameSize: 0
1036  hasOpaqueSPAdjustment: false
1037  hasVAStart:      false
1038  hasMustTailInVarArgFunc: false
1039  localFrameSize:  0
1040  savePoint:       ''
1041  restorePoint:    ''
1042fixedStack:
1043stack:
1044constants:
1045body:             |
1046  ; R6-LABEL: name: expand_BEQZC
1047  ; R6: bb.0 (%ir-block.0):
1048  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
1049  ; R6:   renamable $at = ANDi killed renamable $a0, 1
1050  ; R6:   BNEZC $at, %bb.2, implicit-def $at
1051  ; R6: bb.1 (%ir-block.0):
1052  ; R6:   successors: %bb.3(0x80000000)
1053  ; R6:   BC %bb.3
1054  ; R6: bb.2.iftrue:
1055  ; R6:   successors: %bb.3(0x80000000)
1056  ; R6:   INLINEASM &".space 8388608", 1
1057  ; R6: bb.3.tail:
1058  ; R6:   JIC undef $ra, 0, implicit-def $at
1059  ; PIC-LABEL: name: expand_BEQZC
1060  ; PIC: bb.0 (%ir-block.0):
1061  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
1062  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
1063  ; PIC:   BNEZC $at, %bb.3, implicit-def $at
1064  ; PIC: bb.1 (%ir-block.0):
1065  ; PIC:   successors: %bb.2(0x80000000)
1066  ; PIC:   $sp = ADDiu $sp, -8
1067  ; PIC:   SW $ra, $sp, 0
1068  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
1069  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
1070  ; PIC:   BALC %bb.2, implicit-def $ra
1071  ; PIC: bb.2 (%ir-block.0):
1072  ; PIC:   successors: %bb.4(0x80000000)
1073  ; PIC:   $at = ADDu $ra, $at
1074  ; PIC:   $ra = LW $sp, 0
1075  ; PIC:   $sp = ADDiu $sp, 8
1076  ; PIC:   JIC $at, 0, implicit-def $at
1077  ; PIC: bb.3.iftrue:
1078  ; PIC:   successors: %bb.4(0x80000000)
1079  ; PIC:   INLINEASM &".space 8388608", 1
1080  ; PIC: bb.4.tail:
1081  ; PIC:   JIC undef $ra, 0, implicit-def $at
1082  bb.0 (%ir-block.0):
1083    successors: %bb.1(0x40000000), %bb.2(0x40000000)
1084    liveins: $a0
1085
1086    renamable $at = ANDi killed renamable $a0, 1
1087    BEQZC killed renamable $at, %bb.2, implicit-def $at
1088
1089  bb.1.iftrue:
1090    successors: %bb.2(0x80000000)
1091
1092    INLINEASM &".space 8388608", 1
1093
1094  bb.2.tail:
1095    PseudoReturn undef $ra
1096
1097...
1098---
1099
1100name:            expand_BNEZC
1101alignment:       2
1102exposesReturnsTwice: false
1103legalized:       false
1104regBankSelected: false
1105selected:        false
1106failedISel:      false
1107tracksRegLiveness: true
1108registers:
1109liveins:
1110  - { reg: '$a0', virtual-reg: '' }
1111frameInfo:
1112  isFrameAddressTaken: false
1113  isReturnAddressTaken: false
1114  hasStackMap:     false
1115  hasPatchPoint:   false
1116  stackSize:       0
1117  offsetAdjustment: 0
1118  maxAlignment:    1
1119  adjustsStack:    false
1120  hasCalls:        false
1121  stackProtector:  ''
1122  maxCallFrameSize: 0
1123  hasOpaqueSPAdjustment: false
1124  hasVAStart:      false
1125  hasMustTailInVarArgFunc: false
1126  localFrameSize:  0
1127  savePoint:       ''
1128  restorePoint:    ''
1129fixedStack:
1130stack:
1131constants:
1132body:             |
1133  ; R6-LABEL: name: expand_BNEZC
1134  ; R6: bb.0 (%ir-block.0):
1135  ; R6:   successors: %bb.2(0x40000000), %bb.1(0x40000000)
1136  ; R6:   renamable $at = ANDi killed renamable $a0, 1
1137  ; R6:   BEQZC $at, %bb.2, implicit-def $at
1138  ; R6: bb.1 (%ir-block.0):
1139  ; R6:   successors: %bb.3(0x80000000)
1140  ; R6:   BC %bb.3
1141  ; R6: bb.2.iftrue:
1142  ; R6:   successors: %bb.3(0x80000000)
1143  ; R6:   INLINEASM &".space 8388608", 1
1144  ; R6: bb.3.tail:
1145  ; R6:   JIC undef $ra, 0, implicit-def $at
1146  ; PIC-LABEL: name: expand_BNEZC
1147  ; PIC: bb.0 (%ir-block.0):
1148  ; PIC:   successors: %bb.3(0x40000000), %bb.1(0x40000000)
1149  ; PIC:   renamable $at = ANDi killed renamable $a0, 1
1150  ; PIC:   BEQZC $at, %bb.3, implicit-def $at
1151  ; PIC: bb.1 (%ir-block.0):
1152  ; PIC:   successors: %bb.2(0x80000000)
1153  ; PIC:   $sp = ADDiu $sp, -8
1154  ; PIC:   SW $ra, $sp, 0
1155  ; PIC:   $at = LONG_BRANCH_LUi target-flags(mips-abs-hi) %bb.4, %bb.2
1156  ; PIC:   $at = LONG_BRANCH_ADDiu $at, target-flags(mips-abs-lo) %bb.4, %bb.2
1157  ; PIC:   BALC %bb.2, implicit-def $ra
1158  ; PIC: bb.2 (%ir-block.0):
1159  ; PIC:   successors: %bb.4(0x80000000)
1160  ; PIC:   $at = ADDu $ra, $at
1161  ; PIC:   $ra = LW $sp, 0
1162  ; PIC:   $sp = ADDiu $sp, 8
1163  ; PIC:   JIC $at, 0, implicit-def $at
1164  ; PIC: bb.3.iftrue:
1165  ; PIC:   successors: %bb.4(0x80000000)
1166  ; PIC:   INLINEASM &".space 8388608", 1
1167  ; PIC: bb.4.tail:
1168  ; PIC:   JIC undef $ra, 0, implicit-def $at
1169  bb.0 (%ir-block.0):
1170    successors: %bb.1(0x40000000), %bb.2(0x40000000)
1171    liveins: $a0
1172
1173    renamable $at = ANDi killed renamable $a0, 1
1174    BNEZC killed renamable $at, %bb.2, implicit-def $at
1175
1176  bb.1.iftrue:
1177    successors: %bb.2(0x80000000)
1178
1179    INLINEASM &".space 8388608", 1
1180
1181  bb.2.tail:
1182    PseudoReturn undef $ra
1183
1184...
1185