238 lines
8.7 KiB
YAML
238 lines
8.7 KiB
YAML
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
|
|
# RUN: llc -mtriple=amdgcn -mcpu=gfx1150 -verify-machineinstrs -run-pass=si-fold-operands %s -o - | FileCheck %s
|
|
|
|
---
|
|
name: fmac_fold_inlinable_src0_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src0_to_fmamk
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1056964608, [[COPY1]], implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %inlinable, %0, %1, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_inlinable_src1_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src1_to_fmamk
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1056964608, [[COPY1]], implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %inlinable, %1, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_inlinable_src2_to_fmaak
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src2_to_fmaak
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAAK_F32 [[COPY]], [[COPY1]], 1056964608, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %1, %inlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_noninlinable_src0_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_noninlinable_src0_to_fmamk
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1234567890, [[COPY1]], implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %noninlinable, %0, %1, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_noninlinable_src1_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_noninlinable_src1_to_fmamk
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1234567890, [[COPY1]], implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %noninlinable, %1, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_noninlinable_src2_to_fmaak
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0, $sgpr1
|
|
|
|
; CHECK-LABEL: name: fmac_fold_noninlinable_src2_to_fmaak
|
|
; CHECK: liveins: $sgpr0, $sgpr1
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAAK_F32 [[COPY]], [[COPY1]], 1234567890, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%1:sreg_32 = COPY $sgpr1
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %1, %noninlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
|
|
---
|
|
name: fmac_fold_inlinable_src2_to_fmaak_noninlinable_src0_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src2_to_fmaak_noninlinable_src0_to_fmamk
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1234567890, 1056964608, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %noninlinable, %0, %inlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_inlinable_src2_to_fmaak_noninlinable_src1_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src2_to_fmaak_noninlinable_src1_to_fmamk
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 [[COPY]], 1234567890, 1056964608, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %noninlinable, %inlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_noninlinable_src2_to_fmaak_inlinable_src1
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_noninlinable_src2_to_fmaak_inlinable_src1
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAAK_F32 [[COPY]], 1056964608, 1234567890, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %inlinable, %noninlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_noninlinable_src2_to_fmaak_dont_fold_other_noninlinable
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_noninlinable_src2_to_fmaak_dont_fold_other_noninlinable
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %noninlinable2:sreg_32 = S_MOV_B32 1234567891
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAAK_F32 [[COPY]], %noninlinable2, 1234567890, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%noninlinable2:sreg_32 = S_MOV_B32 1234567891
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %noninlinable2, %noninlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_inlinable_src1_to_fmamk_noninlinable_src2_to_fmaak
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_inlinable_src1_to_fmamk_noninlinable_src2_to_fmaak
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAAK_F32 [[COPY]], 1056964608, 1234567890, implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%inlinable:sreg_32 = S_MOV_B32 1056964608
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %0, %inlinable, %noninlinable, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|
|
---
|
|
name: fmac_fold_same_noninlinable_src0_and_src1_to_fmamk
|
|
tracksRegLiveness: true
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0
|
|
|
|
; CHECK-LABEL: name: fmac_fold_same_noninlinable_src0_and_src1_to_fmamk
|
|
; CHECK: liveins: $sgpr0
|
|
; CHECK-NEXT: {{ $}}
|
|
; CHECK-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
|
|
; CHECK-NEXT: %fma:sreg_32 = nofpexcept S_FMAMK_F32 1234567890, 1234567890, [[COPY]], implicit $mode
|
|
; CHECK-NEXT: $sgpr0 = COPY %fma
|
|
%0:sreg_32 = COPY $sgpr0
|
|
%noninlinable:sreg_32 = S_MOV_B32 1234567890
|
|
%fma:sreg_32 = nofpexcept S_FMAC_F32 %noninlinable, %noninlinable, %0, implicit $mode
|
|
$sgpr0 = COPY %fma
|
|
...
|