# RUN: llc -ppc-asm-full-reg-names -mtriple=powerpc-ibm-aix-xcoff \
# RUN: -run-pass=ppc-ctrloops %s -o - -verify-machineinstrs | FileCheck %s
---
name: test_success1
# CHECK: test_success1
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK: MTCTRloop
; CHECK: BDNZ
; CHECK-NOT: ADDI
; CHECK-NOT: CMPLWI
; CHECK-NOT: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_clobber
# CHECK: test_fail_clobber
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_use_in_loop
# CHECK: test_fail_use_in_loop
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%1:gprc = MFCTR implicit $ctr
%2:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %2:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_call_in_preheader_after_mtctr
# CHECK: test_fail_call_in_preheader_after_mtctr
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTR
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
BL @test_fail_use_in_loop, csr_aix32, implicit-def dead $lr, implicit $rm
bb.1:
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_succ_call_in_preheader_before_mtctr
# CHECK: test_succ_call_in_preheader_before_mtctr
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
BL @test_fail_use_in_loop, csr_aix32, implicit-def dead $lr, implicit $rm
; CHECK: MTCTR
; CHECK: BDNZ
; CHECK-NOT: ADDI
; CHECK-NOT: CMPLWI
; CHECK-NOT: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_call_in_loop
# CHECK: test_fail_call_in_loop
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTR
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
BL @test_fail_use_in_loop, csr_aix32, implicit-def dead $lr, implicit $rm
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_indirect_call_in_loop
# CHECK: test_fail_indirect_call_in_loop
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $r3, $r4
%0:gprc = LI 2048
; CHECK-NOT: MTCTR
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
renamable %1:crrc = CMPLW killed renamable $r3, killed renamable $r4
renamable %2:crbitrc = COPY %1.sub_gt
MTLR %0:gprc, implicit-def $lr
MTCTRloop %0:gprc, implicit-def dead $ctr
bb.1:
BCLRL renamable %2, implicit $lr, implicit $rm
%3:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %3:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_livein_preheader
# CHECK: test_fail_livein_preheader
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $ctr
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_def_preheader
# CHECK: test_fail_def_preheader
tracksRegLiveness: true
body: |
bb.0.entry:
INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%1:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %1:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_success_only_use_preheader
# CHECK: test_success_only_use_preheader
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = MFCTR implicit $ctr
%1:gprc = LI 2048
; CHECK: MTCTRloop
; CHECK: BDNZ
; CHECK-NOT: ADDI
; CHECK-NOT: CMPLWI
; CHECK-NOT: BC
MTCTRloop killed %1:gprc, implicit-def dead $ctr
bb.1:
%2:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %2:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_use_after_mtctr
# CHECK: test_fail_use_after_mtctr
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
%1:gprc = MFCTR implicit $ctr
bb.1:
%2:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %2:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_fail_def_after_mtctr
# CHECK: test_fail_def_after_mtctr
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK-NOT: MTCTRloop
; CHECK-NOT: BDNZ
; CHECK: ADDI
; CHECK: CMPLWI
; CHECK: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr
bb.1:
%2:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %2:crbitrc, %bb.1
B %bb.2
bb.2:
BLR implicit $lr, implicit $rm
...
---
name: test_success_def_after_loop
# CHECK: test_success_def_after_loop
tracksRegLiveness: true
body: |
bb.0.entry:
%0:gprc = LI 2048
; CHECK: MTCTRloop
; CHECK: BDNZ
; CHECK-NOT: ADDI
; CHECK-NOT: CMPLWI
; CHECK-NOT: BC
MTCTRloop killed %0:gprc, implicit-def dead $ctr
bb.1:
%2:crbitrc = DecreaseCTRloop 1, implicit-def dead $ctr, implicit $ctr
BC killed %2:crbitrc, %bb.1
B %bb.2
bb.2:
INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr
BLR implicit $lr, implicit $rm
...