blob: b447e9119086f7c428e1b8c180190ce1530ba87f [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc -mtriple=s390x-unknown-linux-gnu -mcpu=z14 < %s | FileCheck %s
define half @fminimumnum_f16(half %a, half %b) nounwind {
; CHECK-LABEL: fminimumnum_f16:
; CHECK: # %bb.0:
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: aghi %r15, -176
; CHECK-NEXT: std %f8, 168(%r15) # 8-byte Spill
; CHECK-NEXT: std %f9, 160(%r15) # 8-byte Spill
; CHECK-NEXT: ldr %f8, %f0
; CHECK-NEXT: ldr %f0, %f2
; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT
; CHECK-NEXT: ldr %f9, %f0
; CHECK-NEXT: ldr %f0, %f8
; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT
; CHECK-NEXT: wfminsb %f0, %f0, %f9, 4
; CHECK-NEXT: brasl %r14, __truncsfhf2@PLT
; CHECK-NEXT: ld %f8, 168(%r15) # 8-byte Reload
; CHECK-NEXT: ld %f9, 160(%r15) # 8-byte Reload
; CHECK-NEXT: lmg %r14, %r15, 288(%r15)
; CHECK-NEXT: br %r14
%res = call half @llvm.minimumnum(half %a, half %b)
ret half %res
}
define float @fminimumnum_f32(float %a, float %b) {
; CHECK-LABEL: fminimumnum_f32:
; CHECK: # %bb.0:
; CHECK-NEXT: wfminsb %f0, %f0, %f2, 4
; CHECK-NEXT: br %r14
%res = call float @llvm.minimumnum(float %a, float %b)
ret float %res
}
define double @fminimumnum_f64(double %a, double %b) {
; CHECK-LABEL: fminimumnum_f64:
; CHECK: # %bb.0:
; CHECK-NEXT: wfmindb %f0, %f0, %f2, 4
; CHECK-NEXT: br %r14
%res = call double @llvm.minimumnum(double %a, double %b)
ret double %res
}
define fp128 @fminimumnum_f128(fp128 %a, fp128 %b) {
; CHECK-LABEL: fminimumnum_f128:
; CHECK: # %bb.0:
; CHECK-NEXT: vl %v0, 0(%r4), 3
; CHECK-NEXT: vl %v1, 0(%r3), 3
; CHECK-NEXT: wfminxb %v0, %v1, %v0, 4
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
%res = call fp128 @llvm.minimumnum(fp128 %a, fp128 %b)
ret fp128 %res
}
define <4 x float> @fminimumnum_v4f32(<4 x float> %a, <4 x float> %b) {
; CHECK-LABEL: fminimumnum_v4f32:
; CHECK: # %bb.0:
; CHECK-NEXT: vfminsb %v24, %v24, %v26, 4
; CHECK-NEXT: br %r14
%res = call <4 x float> @llvm.minimumnum(<4 x float> %a, <4 x float> %b)
ret <4 x float> %res
}
define <2 x double> @fminimumnum_v2f64(<2 x double> %a, <2 x double> %b) {
; CHECK-LABEL: fminimumnum_v2f64:
; CHECK: # %bb.0:
; CHECK-NEXT: vfmindb %v24, %v24, %v26, 4
; CHECK-NEXT: br %r14
%res = call <2 x double> @llvm.minimumnum(<2 x double> %a, <2 x double> %b)
ret <2 x double> %res
}
define <4 x double> @fminimumnum_v4f64(<4 x double> %a, <4 x double> %b) {
; CHECK-LABEL: fminimumnum_v4f64:
; CHECK: # %bb.0:
; CHECK-NEXT: vfmindb %v24, %v24, %v28, 4
; CHECK-NEXT: vfmindb %v26, %v26, %v30, 4
; CHECK-NEXT: br %r14
%res = call <4 x double> @llvm.minimumnum(<4 x double> %a, <4 x double> %b)
ret <4 x double> %res
}
define half @fmaximumnum_f16(half %a, half %b) nounwind {
; CHECK-LABEL: fmaximumnum_f16:
; CHECK: # %bb.0:
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: aghi %r15, -176
; CHECK-NEXT: std %f8, 168(%r15) # 8-byte Spill
; CHECK-NEXT: std %f9, 160(%r15) # 8-byte Spill
; CHECK-NEXT: ldr %f8, %f0
; CHECK-NEXT: ldr %f0, %f2
; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT
; CHECK-NEXT: ldr %f9, %f0
; CHECK-NEXT: ldr %f0, %f8
; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT
; CHECK-NEXT: wfmaxsb %f0, %f0, %f9, 4
; CHECK-NEXT: brasl %r14, __truncsfhf2@PLT
; CHECK-NEXT: ld %f8, 168(%r15) # 8-byte Reload
; CHECK-NEXT: ld %f9, 160(%r15) # 8-byte Reload
; CHECK-NEXT: lmg %r14, %r15, 288(%r15)
; CHECK-NEXT: br %r14
%res = call half @llvm.maximumnum(half %a, half %b)
ret half %res
}
define float @fmaximumnum_f32(float %a, float %b) {
; CHECK-LABEL: fmaximumnum_f32:
; CHECK: # %bb.0:
; CHECK-NEXT: wfmaxsb %f0, %f0, %f2, 4
; CHECK-NEXT: br %r14
%res = call float @llvm.maximumnum(float %a, float %b)
ret float %res
}
define double @fmaximumnum_f64(double %a, double %b) {
; CHECK-LABEL: fmaximumnum_f64:
; CHECK: # %bb.0:
; CHECK-NEXT: wfmaxdb %f0, %f0, %f2, 4
; CHECK-NEXT: br %r14
%res = call double @llvm.maximumnum(double %a, double %b)
ret double %res
}
define fp128 @fmaximumnum_f128(fp128 %a, fp128 %b) {
; CHECK-LABEL: fmaximumnum_f128:
; CHECK: # %bb.0:
; CHECK-NEXT: vl %v0, 0(%r4), 3
; CHECK-NEXT: vl %v1, 0(%r3), 3
; CHECK-NEXT: wfmaxxb %v0, %v1, %v0, 4
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
%res = call fp128 @llvm.maximumnum(fp128 %a, fp128 %b)
ret fp128 %res
}
define <4 x float> @fmaximumnum_v4f32(<4 x float> %a, <4 x float> %b) {
; CHECK-LABEL: fmaximumnum_v4f32:
; CHECK: # %bb.0:
; CHECK-NEXT: vfmaxsb %v24, %v24, %v26, 4
; CHECK-NEXT: br %r14
%res = call <4 x float> @llvm.maximumnum(<4 x float> %a, <4 x float> %b)
ret <4 x float> %res
}
define <2 x double> @fmaximumnum_v2f64(<2 x double> %a, <2 x double> %b) {
; CHECK-LABEL: fmaximumnum_v2f64:
; CHECK: # %bb.0:
; CHECK-NEXT: vfmaxdb %v24, %v24, %v26, 4
; CHECK-NEXT: br %r14
%res = call <2 x double> @llvm.maximumnum(<2 x double> %a, <2 x double> %b)
ret <2 x double> %res
}
define <4 x double> @fmaximumnum_v4f64(<4 x double> %a, <4 x double> %b) {
; CHECK-LABEL: fmaximumnum_v4f64:
; CHECK: # %bb.0:
; CHECK-NEXT: vfmaxdb %v24, %v24, %v28, 4
; CHECK-NEXT: vfmaxdb %v26, %v26, %v30, 4
; CHECK-NEXT: br %r14
%res = call <4 x double> @llvm.maximumnum(<4 x double> %a, <4 x double> %b)
ret <4 x double> %res
}