This reverts commit a415b4dfcc.
Modify the instruction in place to transform it into a REG_SEQUENCE,
which is what other implementations of foldImmediate do. Also start
erasing the def instruction if there are no other uses.
Fixes #91110.
207 lines
6.5 KiB
YAML
207 lines
6.5 KiB
YAML
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 4
|
|
# RUN: llc -mtriple=s390x-linux-gnu -mcpu=z13 -run-pass=peephole-opt -o - %s | FileCheck %s
|
|
|
|
---
|
|
name: fold_vgbm_0_copyvr128_to_gr128_virtreg
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_0_copyvr128_to_gr128_virtreg
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[LGHI:%[0-9]+]]:gr64bit = LGHI 0
|
|
; CHECK-NEXT: [[REG_SEQUENCE:%[0-9]+]]:gr128bit = REG_SEQUENCE [[LGHI]], %subreg.subreg_h64, [[LGHI]], %subreg.subreg_l64
|
|
; CHECK-NEXT: $r0q = COPY [[REG_SEQUENCE]]
|
|
; CHECK-NEXT: Return implicit $r0q
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
%3:gr128bit = COPY %2
|
|
$r0q = COPY %3
|
|
Return implicit $r0q
|
|
...
|
|
|
|
---
|
|
name: fold_vgbm_0_copyvr128_to_gr128_virtreg_dbg_use
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_0_copyvr128_to_gr128_virtreg_dbg_use
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[LGHI:%[0-9]+]]:gr64bit = LGHI 0
|
|
; CHECK-NEXT: [[REG_SEQUENCE:%[0-9]+]]:gr128bit = REG_SEQUENCE [[LGHI]], %subreg.subreg_h64, [[LGHI]], %subreg.subreg_l64
|
|
; CHECK-NEXT: DBG_VALUE %2:vr128bit
|
|
; CHECK-NEXT: $r0q = COPY [[REG_SEQUENCE]]
|
|
; CHECK-NEXT: Return implicit $r0q
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
%3:gr128bit = COPY %2
|
|
DBG_VALUE %2
|
|
$r0q = COPY %3
|
|
Return implicit $r0q
|
|
...
|
|
|
|
---
|
|
name: fold_vgbm_0_copyvr128_to_gr128_virtreg_multi_use
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_0_copyvr128_to_gr128_virtreg_multi_use
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: [[COPY2:%[0-9]+]]:gr128bit = COPY [[VGBM]]
|
|
; CHECK-NEXT: $r0q = COPY [[COPY2]]
|
|
; CHECK-NEXT: $r2q = COPY [[COPY2]]
|
|
; CHECK-NEXT: Return implicit $r0q, implicit $r2q
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
%3:gr128bit = COPY %2
|
|
%4:gr128bit = COPY %2
|
|
$r0q = COPY %3
|
|
$r2q = COPY %4
|
|
Return implicit $r0q, implicit $r2q
|
|
...
|
|
|
|
---
|
|
name: fold_vgbm_0_copyvr128_to_gr128_physreg
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_0_copyvr128_to_gr128_physreg
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: $r0q = COPY [[VGBM]]
|
|
; CHECK-NEXT: Return implicit $r0q
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
$r0q = COPY %2
|
|
Return implicit $r0q
|
|
...
|
|
|
|
---
|
|
name: no_fold_vgbm_0_copyvr128_to_vr128_virtreg
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: no_fold_vgbm_0_copyvr128_to_vr128_virtreg
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: [[COPY2:%[0-9]+]]:vr128bit = COPY [[VGBM]]
|
|
; CHECK-NEXT: $v0 = COPY [[COPY2]]
|
|
; CHECK-NEXT: Return implicit $v0
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
%3:vr128bit = COPY %2
|
|
$v0 = COPY %3
|
|
Return implicit $v0
|
|
...
|
|
|
|
---
|
|
name: no_fold_vgbm_0_copyvr128_to_vr128_physreg
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: no_fold_vgbm_0_copyvr128_to_vr128_physreg
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: $v0 = COPY [[VGBM]]
|
|
; CHECK-NEXT: Return implicit $v0
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
$v0 = COPY %2
|
|
Return implicit $v0
|
|
...
|
|
|
|
---
|
|
name: fold_vgbm_1_copyvr128_to_gr128_virtreg
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_1_copyvr128_to_gr128_virtreg
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 1
|
|
; CHECK-NEXT: [[COPY2:%[0-9]+]]:gr128bit = COPY [[VGBM]]
|
|
; CHECK-NEXT: $r0q = COPY [[COPY2]]
|
|
; CHECK-NEXT: Return implicit $r0q
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 1
|
|
%3:gr128bit = COPY %2
|
|
$r0q = COPY %3
|
|
Return implicit $r0q
|
|
...
|
|
|
|
---
|
|
name: no_fold_vgbm_0_noncopy_use
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: no_fold_vgbm_0_noncopy_use
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: Return implicit [[VGBM]]
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
Return implicit %2
|
|
...
|
|
|
|
---
|
|
name: fold_vgbm_0_copyvr128_to_gr64_subreg_h64
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $r2d
|
|
; CHECK-LABEL: name: fold_vgbm_0_copyvr128_to_gr64_subreg_h64
|
|
; CHECK: liveins: $r2d
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:gr64bit = COPY $r2d
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:addr64bit = COPY [[COPY]]
|
|
; CHECK-NEXT: [[VGBM:%[0-9]+]]:vr128bit = VGBM 0
|
|
; CHECK-NEXT: [[COPY2:%[0-9]+]]:gr64bit = COPY [[VGBM]].subreg_h64
|
|
; CHECK-NEXT: $r0d = COPY [[COPY2]]
|
|
; CHECK-NEXT: Return implicit $r0d
|
|
%0:gr64bit = COPY $r2d
|
|
%1:addr64bit = COPY %0
|
|
%2:vr128bit = VGBM 0
|
|
%3:gr64bit = COPY %2.subreg_h64
|
|
$r0d = COPY %3
|
|
Return implicit $r0d
|
|
...
|