|  | # RUN: llc -ppc-asm-full-reg-names -mtriple=powerpc64le-unknown-linux-gnu \ | 
|  | # RUN:   -run-pass=ppc-ctrloops %s -o - -verify-machineinstrs | FileCheck %s | 
|  | # RUN: llc -ppc-asm-full-reg-names -mtriple=powerpc64-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:g8rc = LI8 2048 | 
|  | ; CHECK: MTCTR8loop | 
|  | ; CHECK: BDNZ8 | 
|  | ; CHECK-NOT: ADDI8 | 
|  | ; CHECK-NOT: CMPLDI | 
|  | ; CHECK-NOT: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_clobber | 
|  | # CHECK: test_fail_clobber | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr8 | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_use_in_loop | 
|  | # CHECK: test_fail_use_in_loop | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:g8rc = MFCTR8 implicit $ctr8 | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, 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:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8 | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  | BL8 @test_fail_use_in_loop, csr_ppc64, implicit-def dead $lr8, implicit $rm | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, 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:g8rc = LI8 2048 | 
|  | BL8 @test_fail_use_in_loop, csr_ppc64, implicit-def dead $lr8, implicit $rm | 
|  | ; CHECK: MTCTR8 | 
|  | ; CHECK: BDNZ8 | 
|  | ; CHECK-NOT: ADDI8 | 
|  | ; CHECK-NOT: CMPLDI | 
|  | ; CHECK-NOT: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_call_in_loop | 
|  | # CHECK: test_fail_call_in_loop | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8 | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | BL8 @test_fail_use_in_loop, csr_ppc64, implicit-def dead $lr8, implicit $rm | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_indirect_call_in_loop | 
|  | # CHECK: test_fail_indirect_call_in_loop | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  | liveins: $x3, $x4 | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8 | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | renamable %1:crrc = CMPLD killed renamable $x3, killed renamable $x4 | 
|  | renamable %2:crbitrc = COPY %1.sub_gt | 
|  | MTLR8 %0:g8rc, implicit-def $lr8 | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | BCLRL renamable %2, implicit $lr, implicit $rm | 
|  | %3:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %3:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_livein_preheader | 
|  | # CHECK: test_fail_livein_preheader | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  | liveins: $ctr8 | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, 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 $ctr8 | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %1:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %1:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_success_only_use_preheader | 
|  | # CHECK: test_success_only_use_preheader | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = MFCTR8 implicit $ctr8 | 
|  | %1:g8rc = LI8 2048 | 
|  | ; CHECK: MTCTR8loop | 
|  | ; CHECK: BDNZ8 | 
|  | ; CHECK-NOT: ADDI8 | 
|  | ; CHECK-NOT: CMPLDI | 
|  | ; CHECK-NOT: BC | 
|  | MTCTR8loop killed %1:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_use_after_mtctr | 
|  | # CHECK: test_fail_use_after_mtctr | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  | %1:g8rc = MFCTR8 implicit $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_def_after_mtctr | 
|  | # CHECK: test_fail_def_after_mtctr | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  | INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_success_def_after_loop | 
|  | # CHECK: test_success_def_after_loop | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | ; CHECK: MTCTR8loop | 
|  | ; CHECK: BDNZ8 | 
|  | ; CHECK-NOT: ADDI8 | 
|  | ; CHECK-NOT: CMPLDI | 
|  | ; CHECK-NOT: BC | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  | INLINEASM &"", 1 /* sideeffect attdialect */, 12 /* clobber */, implicit-def early-clobber $ctr8 | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... | 
|  | --- | 
|  | name:            test_fail_dead_def_in_preheader | 
|  | # CHECK: test_fail_dead_def_in_preheader | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0.entry: | 
|  |  | 
|  | %0:g8rc = LI8 2048 | 
|  | %1:g8rc = LI8 1024 | 
|  | MTCTR8loop killed %0:g8rc, implicit-def dead $ctr8 | 
|  | MTCTR8 killed %1:g8rc, implicit-def dead $ctr8 | 
|  | ; CHECK-NOT: MTCTR8loop | 
|  | ; CHECK-NOT: BDNZ8 | 
|  | ; CHECK: ADDI8 | 
|  | ; CHECK: CMPLDI | 
|  | ; CHECK: BC | 
|  |  | 
|  | bb.1: | 
|  |  | 
|  | %2:crbitrc = DecreaseCTR8loop 1, implicit-def dead $ctr8, implicit $ctr8 | 
|  | BC killed %2:crbitrc, %bb.1 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  |  | 
|  | BLR8 implicit $lr8, implicit $rm | 
|  | ... |