# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple=aarch64 -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s
...
---
name: fcmeq
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmeq
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %rhs:fpr128 = COPY $q1
; CHECK: %fcmp:fpr128 = nofpexcept FCMEQv2f64 %lhs, %rhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%rhs:fpr(<2 x s64>) = COPY $q1
%fcmp:fpr(<2 x s64>) = G_FCMEQ %lhs, %rhs(<2 x s64>)
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmge
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmge
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %rhs:fpr128 = COPY $q1
; CHECK: %fcmp:fpr128 = nofpexcept FCMGEv2f64 %lhs, %rhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%rhs:fpr(<2 x s64>) = COPY $q1
%fcmp:fpr(<2 x s64>) = G_FCMGE %lhs, %rhs(<2 x s64>)
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmgt
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmgt
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %rhs:fpr128 = COPY $q1
; CHECK: %fcmp:fpr128 = nofpexcept FCMGTv2f64 %lhs, %rhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%rhs:fpr(<2 x s64>) = COPY $q1
%fcmp:fpr(<2 x s64>) = G_FCMGT %lhs, %rhs(<2 x s64>)
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmeqz
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmeqz
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %fcmp:fpr128 = nofpexcept FCMEQv2i64rz %lhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%zero:gpr(s64) = G_CONSTANT i64 0
%zero_vec:fpr(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64)
%fcmp:fpr(<2 x s64>) = G_FCMEQZ %lhs
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmgez
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmgez
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %fcmp:fpr128 = nofpexcept FCMGEv2i64rz %lhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%zero:gpr(s64) = G_CONSTANT i64 0
%zero_vec:fpr(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64)
%fcmp:fpr(<2 x s64>) = G_FCMGEZ %lhs
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmgtz
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmgtz
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %fcmp:fpr128 = nofpexcept FCMGTv2i64rz %lhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%zero:gpr(s64) = G_CONSTANT i64 0
%zero_vec:fpr(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64)
%fcmp:fpr(<2 x s64>) = G_FCMGTZ %lhs
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmlez
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmlez
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %fcmp:fpr128 = nofpexcept FCMLEv2i64rz %lhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%zero:gpr(s64) = G_CONSTANT i64 0
%zero_vec:fpr(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64)
%fcmp:fpr(<2 x s64>) = G_FCMLEZ %lhs
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: fcmltz
alignment: 4
legalized: true
regBankSelected: true
body: |
bb.0:
; CHECK-LABEL: name: fcmltz
; CHECK: %lhs:fpr128 = COPY $q0
; CHECK: %fcmp:fpr128 = nofpexcept FCMLTv2i64rz %lhs
; CHECK: $q0 = COPY %fcmp
; CHECK: RET_ReallyLR implicit $q0
%lhs:fpr(<2 x s64>) = COPY $q0
%zero:gpr(s64) = G_CONSTANT i64 0
%zero_vec:fpr(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64)
%fcmp:fpr(<2 x s64>) = G_FCMLTZ %lhs
$q0 = COPY %fcmp(<2 x s64>)
RET_ReallyLR implicit $q0