# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 2
# RUN: llc -mtriple aarch64 -run-pass=aarch64-prelegalizer-combiner -verify-machineinstrs %s -o - | FileCheck %s
---
name: fadd
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fadd
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 1.000000e+00
; CHECK-NEXT: %add:_(s32) = G_FADD [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %add(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 1.000000e+00
%add:_(s32) = G_FADD %cst, %0
$s0 = COPY %add
RET_ReallyLR
...
---
name: fmul
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmul
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %mul:_(s32) = G_FMUL [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %mul(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%mul:_(s32) = G_FMUL %cst, %0
$s0 = COPY %mul
RET_ReallyLR
...
---
name: fmul_vector
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmul_vector
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(<4 x s32>) = COPY $q0
; CHECK-NEXT: %cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %cst:_(<4 x s32>) = G_BUILD_VECTOR %cst_scalar(s32), %cst_scalar(s32), %cst_scalar(s32), %cst_scalar(s32)
; CHECK-NEXT: %mul:_(<4 x s32>) = G_FMUL [[COPY]], %cst
; CHECK-NEXT: $q0 = COPY %mul(<4 x s32>)
; CHECK-NEXT: RET_ReallyLR
%0:_(<4 x s32>) = COPY $q0
%cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
%cst:_(<4 x s32>) = G_BUILD_VECTOR %cst_scalar, %cst_scalar, %cst_scalar, %cst_scalar
%mul:_(<4 x s32>) = G_FMUL %cst, %0
$q0 = COPY %mul
RET_ReallyLR
...
---
name: fmul_splat_with_undef
tracksRegLiveness: true
body: |
bb.1:
liveins: $q0
; CHECK-LABEL: name: fmul_splat_with_undef
; CHECK: liveins: $q0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(<4 x s32>) = COPY $q0
; CHECK-NEXT: %undef:_(s32) = G_IMPLICIT_DEF
; CHECK-NEXT: %cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %cst:_(<4 x s32>) = G_BUILD_VECTOR %undef(s32), %undef(s32), %cst_scalar(s32), %cst_scalar(s32)
; CHECK-NEXT: %mul:_(<4 x s32>) = G_FMUL [[COPY]], %cst
; CHECK-NEXT: $q0 = COPY %mul(<4 x s32>)
; CHECK-NEXT: RET_ReallyLR
%0:_(<4 x s32>) = COPY $q0
%undef:_(s32) = G_IMPLICIT_DEF
%cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
%cst:_(<4 x s32>) = G_BUILD_VECTOR %undef, %undef, %cst_scalar, %cst_scalar
%mul:_(<4 x s32>) = G_FMUL %cst, %0
$q0 = COPY %mul
RET_ReallyLR
...
---
name: fmul_vector_nonsplat
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmul_vector_nonsplat
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(<4 x s32>) = COPY $q0
; CHECK-NEXT: %scalar:_(s32) = COPY $s0
; CHECK-NEXT: %cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %cst:_(<4 x s32>) = G_BUILD_VECTOR %cst_scalar(s32), %cst_scalar(s32), %cst_scalar(s32), %scalar(s32)
; CHECK-NEXT: %mul:_(<4 x s32>) = G_FMUL %cst, [[COPY]]
; CHECK-NEXT: $q0 = COPY %mul(<4 x s32>)
; CHECK-NEXT: RET_ReallyLR
%0:_(<4 x s32>) = COPY $q0
%scalar:_(s32) = COPY $s0
%cst_scalar:_(s32) = G_FCONSTANT float 2.000000e+00
%cst:_(<4 x s32>) = G_BUILD_VECTOR %cst_scalar, %cst_scalar, %cst_scalar, %scalar
%mul:_(<4 x s32>) = G_FMUL %cst, %0
$q0 = COPY %mul
RET_ReallyLR
...
---
name: fminnum
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fminnum
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %min:_(s32) = G_FMINNUM [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %min(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%min:_(s32) = G_FMINNUM %cst, %0
$s0 = COPY %min
RET_ReallyLR
...
---
name: fmaxnum
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmaxnum
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %max:_(s32) = G_FMAXNUM [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %max(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%max:_(s32) = G_FMAXNUM %cst, %0
$s0 = COPY %max
RET_ReallyLR
...
---
name: fminnum_ieee
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fminnum_ieee
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %min:_(s32) = G_FMINNUM_IEEE [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %min(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%min:_(s32) = G_FMINNUM_IEEE %cst, %0
$s0 = COPY %min
RET_ReallyLR
...
---
name: fmaxnum_ieee
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmaxnum_ieee
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %max:_(s32) = G_FMAXNUM_IEEE [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %max(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%max:_(s32) = G_FMAXNUM_IEEE %cst, %0
$s0 = COPY %max
RET_ReallyLR
...
---
name: fminimum
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fminimum
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %min:_(s32) = G_FMINIMUM [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %min(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%min:_(s32) = G_FMINIMUM %cst, %0
$s0 = COPY %min
RET_ReallyLR
...
---
name: fmaximum
tracksRegLiveness: true
body: |
bb.1:
liveins: $s0
; CHECK-LABEL: name: fmaximum
; CHECK: liveins: $s0
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
; CHECK-NEXT: %cst:_(s32) = G_FCONSTANT float 2.000000e+00
; CHECK-NEXT: %max:_(s32) = G_FMAXIMUM [[COPY]], %cst
; CHECK-NEXT: $s0 = COPY %max(s32)
; CHECK-NEXT: RET_ReallyLR
%0:_(s32) = COPY $s0
%cst:_(s32) = G_FCONSTANT float 2.000000e+00
%max:_(s32) = G_FMAXIMUM %cst, %0
$s0 = COPY %max
RET_ReallyLR
...