164 lines
6 KiB
YAML
164 lines
6 KiB
YAML
# 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
|
|
...
|