# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple powerpc64le-unknown-linux-gnu -mcpu=pwr8 -x mir \
# RUN: -verify-machineinstrs -run-pass ppc-mi-peepholes < %s | FileCheck %s
---
name: fold_RLDICL_ANDI
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICL_ANDI
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICL:%[0-9]+]]:g8rc = RLDICL [[COPY]], 0, 32
; CHECK-NEXT: [[ANDI8_rec:%[0-9]+]]:g8rc = ANDI8_rec killed [[COPY]], 1, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDI8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICL %1:g8rc, 0, 32
%3:g8rc = ANDI8_rec killed %2:g8rc, 1, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICL_ANDI2
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICL_ANDI2
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICL:%[0-9]+]]:g8rc = RLDICL [[COPY]], 10, 60
; CHECK-NEXT: [[ANDI8_rec:%[0-9]+]]:g8rc = ANDI8_rec killed [[COPY]], 0, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDI8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICL %1:g8rc, 10, 60
%3:g8rc = ANDI8_rec killed %2:g8rc, 32, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICR_ANDI
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICR_ANDI
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICR:%[0-9]+]]:g8rc = RLDICR [[COPY]], 0, 60
; CHECK-NEXT: [[ANDI8_rec:%[0-9]+]]:g8rc = ANDI8_rec killed [[COPY]], 16, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDI8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICR %1:g8rc, 0, 60
%3:g8rc = ANDI8_rec killed %2:g8rc, 16, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICR_ANDI2
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICR_ANDI2
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICR:%[0-9]+]]:g8rc = RLDICR [[COPY]], 10, 60
; CHECK-NEXT: [[ANDI8_rec:%[0-9]+]]:g8rc = ANDI8_rec killed [[COPY]], 0, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDI8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICR %1:g8rc, 10, 60
%3:g8rc = ANDI8_rec killed %2:g8rc, 1, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICL_ANDIS
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICL_ANDIS
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICL:%[0-9]+]]:g8rc = RLDICL [[COPY]], 0, 32
; CHECK-NEXT: [[ANDIS8_rec:%[0-9]+]]:g8rc = ANDIS8_rec killed [[COPY]], 1, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDIS8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICL %1:g8rc, 0, 32
%3:g8rc = ANDIS8_rec killed %2:g8rc, 1, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICL_ANDIS2
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICL_ANDIS2
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICL:%[0-9]+]]:g8rc = RLDICL [[COPY]], 10, 60
; CHECK-NEXT: [[ANDIS8_rec:%[0-9]+]]:g8rc = ANDIS8_rec killed [[COPY]], 0, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDIS8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICL %1:g8rc, 10, 60
%3:g8rc = ANDIS8_rec killed %2:g8rc, 16, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICR_ANDIS
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICR_ANDIS
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICR:%[0-9]+]]:g8rc = RLDICR [[COPY]], 0, 60
; CHECK-NEXT: [[ANDIS8_rec:%[0-9]+]]:g8rc = ANDIS8_rec killed [[COPY]], 16, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDIS8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICR %1:g8rc, 0, 60
%3:g8rc = ANDIS8_rec killed %2:g8rc, 16, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...
---
name: fold_RLDICR_ANDIS2
tracksRegLiveness: true
body: |
bb.0.entry:
liveins: $x3
; CHECK-LABEL: name: fold_RLDICR_ANDIS2
; CHECK: liveins: $x3
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:g8rc = COPY killed $x3
; CHECK-NEXT: dead [[RLDICR:%[0-9]+]]:g8rc = RLDICR [[COPY]], 10, 32
; CHECK-NEXT: [[ANDIS8_rec:%[0-9]+]]:g8rc = ANDIS8_rec killed [[COPY]], 0, implicit-def dead $cr0
; CHECK-NEXT: $x3 = COPY killed [[ANDIS8_rec]]
; CHECK-NEXT: BLR8 implicit $lr8, implicit $rm, implicit killed $x3
%1:g8rc = COPY $x3
%2:g8rc = RLDICR %1:g8rc, 10, 32
%3:g8rc = ANDIS8_rec killed %2:g8rc, 1, implicit-def dead $cr0
$x3 = COPY %3:g8rc
BLR8 implicit $lr8, implicit $rm, implicit $x3
...