blob: e02f931c4d31e0674bada470146443b712ce89b5 [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --default-march s390x-unknown-linux-gnu --version 5
; RUN: llc -mtriple=s390x-linux-gnu -mcpu=z16 < %s | FileCheck %s -check-prefixes=Z16
define half @canonicalize_fp16(half %a) nounwind {
; Z16-LABEL: canonicalize_fp16:
; Z16: # %bb.0:
; Z16-NEXT: stmg %r14, %r15, 112(%r15)
; Z16-NEXT: aghi %r15, -160
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: lmg %r14, %r15, 272(%r15)
; Z16-NEXT: br %r14
%canonicalized = call half @llvm.canonicalize.f16(half %a)
ret half %canonicalized
}
define float @canonicalize_fp32(float %a) {
; Z16-LABEL: canonicalize_fp32:
; Z16: # %bb.0:
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: br %r14
%canonicalized = call float @llvm.canonicalize.f32(float %a)
ret float %canonicalized
}
define double @canonicalize_fp64(double %a) {
; Z16-LABEL: canonicalize_fp64:
; Z16: # %bb.0:
; Z16-NEXT: vgmg %v1, 2, 11
; Z16-NEXT: mdbr %f0, %f1
; Z16-NEXT: br %r14
%canonicalized = call double @llvm.canonicalize.f64(double %a)
ret double %canonicalized
}
define fp128 @canonicalize_fp128(fp128 %a) {
; Z16-LABEL: canonicalize_fp128:
; Z16: # %bb.0:
; Z16-NEXT: larl %r1, .LCPI3_0
; Z16-NEXT: vl %v0, 0(%r3), 3
; Z16-NEXT: vl %v1, 0(%r1), 3
; Z16-NEXT: wfmxb %v0, %v0, %v1
; Z16-NEXT: vst %v0, 0(%r2), 3
; Z16-NEXT: br %r14
%canonicalized = call fp128 @llvm.canonicalize.f128(fp128 %a)
ret fp128 %canonicalized
}
define void @canonicalize_ptr_f16(ptr %out) nounwind {
; Z16-LABEL: canonicalize_ptr_f16:
; Z16: # %bb.0:
; Z16-NEXT: stmg %r13, %r15, 104(%r15)
; Z16-NEXT: aghi %r15, -160
; Z16-NEXT: vlreph %v0, 0(%r2)
; Z16-NEXT: lgr %r13, %r2
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: vsteh %v0, 0(%r13), 0
; Z16-NEXT: lmg %r13, %r15, 264(%r15)
; Z16-NEXT: br %r14
%val = load half, ptr %out
%canonicalized = call half @llvm.canonicalize.f16(half %val)
store half %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_f32(ptr %out) {
; Z16-LABEL: canonicalize_ptr_f32:
; Z16: # %bb.0:
; Z16-NEXT: vgmf %v0, 2, 8
; Z16-NEXT: meeb %f0, 0(%r2)
; Z16-NEXT: ste %f0, 0(%r2)
; Z16-NEXT: br %r14
%val = load float, ptr %out
%canonicalized = call float @llvm.canonicalize.f32(float %val)
store float %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_f64(ptr %out) {
; Z16-LABEL: canonicalize_ptr_f64:
; Z16: # %bb.0:
; Z16-NEXT: vgmg %v0, 2, 11
; Z16-NEXT: mdb %f0, 0(%r2)
; Z16-NEXT: std %f0, 0(%r2)
; Z16-NEXT: br %r14
%val = load double, ptr %out
%canonicalized = call double @llvm.canonicalize.f64(double %val)
store double %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_f128(ptr %out) {
; Z16-LABEL: canonicalize_ptr_f128:
; Z16: # %bb.0:
; Z16-NEXT: larl %r1, .LCPI7_0
; Z16-NEXT: vl %v0, 0(%r2), 3
; Z16-NEXT: vl %v1, 0(%r1), 3
; Z16-NEXT: wfmxb %v0, %v0, %v1
; Z16-NEXT: vst %v0, 0(%r2), 3
; Z16-NEXT: br %r14
%val = load fp128, ptr %out
%canonicalized = call fp128 @llvm.canonicalize.f128(fp128 %val)
store fp128 %canonicalized, ptr %out
ret void
}
define <8 x half> @canonicalize_v8f16(<8 x half> %a) nounwind {
; Z16-LABEL: canonicalize_v8f16:
; Z16: # %bb.0:
; Z16-NEXT: stmg %r13, %r15, 104(%r15)
; Z16-NEXT: aghi %r15, -224
; Z16-NEXT: std %f8, 216(%r15) # 8-byte Spill
; Z16-NEXT: std %f9, 208(%r15) # 8-byte Spill
; Z16-NEXT: std %f10, 200(%r15) # 8-byte Spill
; Z16-NEXT: std %f11, 192(%r15) # 8-byte Spill
; Z16-NEXT: std %f12, 184(%r15) # 8-byte Spill
; Z16-NEXT: std %f13, 176(%r15) # 8-byte Spill
; Z16-NEXT: std %f14, 168(%r15) # 8-byte Spill
; Z16-NEXT: std %f15, 160(%r15) # 8-byte Spill
; Z16-NEXT: vlreph %v11, 414(%r15)
; Z16-NEXT: vlreph %v12, 406(%r15)
; Z16-NEXT: vlreph %v13, 398(%r15)
; Z16-NEXT: vlreph %v14, 390(%r15)
; Z16-NEXT: ldr %f8, %f6
; Z16-NEXT: ldr %f9, %f4
; Z16-NEXT: ldr %f10, %f2
; Z16-NEXT: lgr %r13, %r2
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f15, %f0
; Z16-NEXT: ldr %f0, %f10
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f10, %f0
; Z16-NEXT: ldr %f0, %f9
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f9, %f0
; Z16-NEXT: ldr %f0, %f8
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f8, %f0
; Z16-NEXT: ldr %f0, %f14
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f14, %f0
; Z16-NEXT: ldr %f0, %f13
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f13, %f0
; Z16-NEXT: ldr %f0, %f12
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f12, %f0
; Z16-NEXT: ldr %f0, %f11
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: vsteh %v0, 14(%r13), 0
; Z16-NEXT: vsteh %v12, 12(%r13), 0
; Z16-NEXT: vsteh %v13, 10(%r13), 0
; Z16-NEXT: vsteh %v14, 8(%r13), 0
; Z16-NEXT: vsteh %v8, 6(%r13), 0
; Z16-NEXT: vsteh %v9, 4(%r13), 0
; Z16-NEXT: vsteh %v10, 2(%r13), 0
; Z16-NEXT: vsteh %v15, 0(%r13), 0
; Z16-NEXT: ld %f8, 216(%r15) # 8-byte Reload
; Z16-NEXT: ld %f9, 208(%r15) # 8-byte Reload
; Z16-NEXT: ld %f10, 200(%r15) # 8-byte Reload
; Z16-NEXT: ld %f11, 192(%r15) # 8-byte Reload
; Z16-NEXT: ld %f12, 184(%r15) # 8-byte Reload
; Z16-NEXT: ld %f13, 176(%r15) # 8-byte Reload
; Z16-NEXT: ld %f14, 168(%r15) # 8-byte Reload
; Z16-NEXT: ld %f15, 160(%r15) # 8-byte Reload
; Z16-NEXT: lmg %r13, %r15, 328(%r15)
; Z16-NEXT: br %r14
%canonicalized = call <8 x half> @llvm.canonicalize.v8f16(<8 x half> %a)
ret <8 x half> %canonicalized
}
define <4 x float> @canonicalize_v4f32(<4 x float> %a) {
; Z16-LABEL: canonicalize_v4f32:
; Z16: # %bb.0:
; Z16-NEXT: vrepf %v0, %v24, 3
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: vrepf %v2, %v24, 2
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: meebr %f2, %f1
; Z16-NEXT: vrepf %v3, %v24, 1
; Z16-NEXT: vmrhf %v0, %v2, %v0
; Z16-NEXT: wfmsb %f2, %v24, %f1
; Z16-NEXT: wfmsb %f1, %f3, %f1
; Z16-NEXT: vmrhf %v1, %v2, %v1
; Z16-NEXT: vmrhg %v24, %v1, %v0
; Z16-NEXT: br %r14
%canonicalized = call <4 x float> @llvm.canonicalize.v4f32(<4 x float> %a)
ret <4 x float> %canonicalized
}
define <4 x double> @canonicalize_v4f64(<4 x double> %a) {
; Z16-LABEL: canonicalize_v4f64:
; Z16: # %bb.0:
; Z16-NEXT: vgmg %v0, 2, 11
; Z16-NEXT: vrepg %v2, %v24, 1
; Z16-NEXT: wfmdb %f1, %v24, %f0
; Z16-NEXT: mdbr %f2, %f0
; Z16-NEXT: vmrhg %v24, %v1, %v2
; Z16-NEXT: vrepg %v2, %v26, 1
; Z16-NEXT: wfmdb %f1, %v26, %f0
; Z16-NEXT: wfmdb %f0, %f2, %f0
; Z16-NEXT: vmrhg %v26, %v1, %v0
; Z16-NEXT: br %r14
%canonicalized = call <4 x double> @llvm.canonicalize.v4f64(<4 x double> %a)
ret <4 x double> %canonicalized
}
define <2 x fp128> @canonicalize_v2f128(<2 x fp128> %a) {
; Z16-LABEL: canonicalize_v2f128:
; Z16: # %bb.0:
; Z16-NEXT: larl %r1, .LCPI11_0
; Z16-NEXT: vl %v0, 16(%r3), 3
; Z16-NEXT: vl %v1, 0(%r3), 3
; Z16-NEXT: vl %v2, 0(%r1), 3
; Z16-NEXT: wfmxb %v1, %v1, %v2
; Z16-NEXT: wfmxb %v0, %v0, %v2
; Z16-NEXT: vst %v0, 16(%r2), 4
; Z16-NEXT: vst %v1, 0(%r2), 4
; Z16-NEXT: br %r14
%canonicalized = call <2 x fp128> @llvm.canonicalize.v2f128(<2 x fp128> %a)
ret <2 x fp128> %canonicalized
}
define void @canonicalize_ptr_v8f16(ptr %out) nounwind {
; Z16-LABEL: canonicalize_ptr_v8f16:
; Z16: # %bb.0:
; Z16-NEXT: stmg %r13, %r15, 104(%r15)
; Z16-NEXT: aghi %r15, -224
; Z16-NEXT: std %f8, 216(%r15) # 8-byte Spill
; Z16-NEXT: std %f9, 208(%r15) # 8-byte Spill
; Z16-NEXT: std %f10, 200(%r15) # 8-byte Spill
; Z16-NEXT: std %f11, 192(%r15) # 8-byte Spill
; Z16-NEXT: std %f12, 184(%r15) # 8-byte Spill
; Z16-NEXT: std %f13, 176(%r15) # 8-byte Spill
; Z16-NEXT: std %f14, 168(%r15) # 8-byte Spill
; Z16-NEXT: std %f15, 160(%r15) # 8-byte Spill
; Z16-NEXT: vlreph %v0, 0(%r2)
; Z16-NEXT: vlreph %v8, 14(%r2)
; Z16-NEXT: vlreph %v9, 12(%r2)
; Z16-NEXT: vlreph %v10, 10(%r2)
; Z16-NEXT: lgr %r13, %r2
; Z16-NEXT: vlreph %v11, 8(%r2)
; Z16-NEXT: vlreph %v12, 6(%r2)
; Z16-NEXT: vlreph %v13, 4(%r2)
; Z16-NEXT: vlreph %v14, 2(%r2)
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f15, %f0
; Z16-NEXT: ldr %f0, %f14
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f14, %f0
; Z16-NEXT: ldr %f0, %f13
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f13, %f0
; Z16-NEXT: ldr %f0, %f12
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f12, %f0
; Z16-NEXT: ldr %f0, %f11
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f11, %f0
; Z16-NEXT: ldr %f0, %f10
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f10, %f0
; Z16-NEXT: ldr %f0, %f9
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: ldr %f9, %f0
; Z16-NEXT: ldr %f0, %f8
; Z16-NEXT: brasl %r14, __extendhfsf2@PLT
; Z16-NEXT: vgmf %v1, 2, 8
; Z16-NEXT: meebr %f0, %f1
; Z16-NEXT: brasl %r14, __truncsfhf2@PLT
; Z16-NEXT: vsteh %v9, 12(%r13), 0
; Z16-NEXT: vsteh %v10, 10(%r13), 0
; Z16-NEXT: vsteh %v11, 8(%r13), 0
; Z16-NEXT: vsteh %v12, 6(%r13), 0
; Z16-NEXT: vsteh %v13, 4(%r13), 0
; Z16-NEXT: vsteh %v14, 2(%r13), 0
; Z16-NEXT: vsteh %v15, 0(%r13), 0
; Z16-NEXT: ld %f8, 216(%r15) # 8-byte Reload
; Z16-NEXT: ld %f9, 208(%r15) # 8-byte Reload
; Z16-NEXT: ld %f10, 200(%r15) # 8-byte Reload
; Z16-NEXT: ld %f11, 192(%r15) # 8-byte Reload
; Z16-NEXT: ld %f12, 184(%r15) # 8-byte Reload
; Z16-NEXT: ld %f13, 176(%r15) # 8-byte Reload
; Z16-NEXT: ld %f14, 168(%r15) # 8-byte Reload
; Z16-NEXT: ld %f15, 160(%r15) # 8-byte Reload
; Z16-NEXT: vsteh %v0, 14(%r13), 0
; Z16-NEXT: lmg %r13, %r15, 328(%r15)
; Z16-NEXT: br %r14
%val = load <8 x half>, ptr %out
%canonicalized = call <8 x half> @llvm.canonicalize.v8f16(<8 x half> %val)
store <8 x half> %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_v4f32(ptr %out) {
; Z16-LABEL: canonicalize_ptr_v4f32:
; Z16: # %bb.0:
; Z16-NEXT: vl %v0, 0(%r2), 3
; Z16-NEXT: vrepf %v1, %v0, 3
; Z16-NEXT: vgmf %v2, 2, 8
; Z16-NEXT: vrepf %v3, %v0, 2
; Z16-NEXT: meebr %f1, %f2
; Z16-NEXT: meebr %f3, %f2
; Z16-NEXT: vmrhf %v1, %v3, %v1
; Z16-NEXT: wfmsb %f3, %f0, %f2
; Z16-NEXT: vrepf %v0, %v0, 1
; Z16-NEXT: meebr %f0, %f2
; Z16-NEXT: vmrhf %v0, %v3, %v0
; Z16-NEXT: vmrhg %v0, %v0, %v1
; Z16-NEXT: vst %v0, 0(%r2), 3
; Z16-NEXT: br %r14
%val = load <4 x float>, ptr %out
%canonicalized = call <4 x float> @llvm.canonicalize.v4f32(<4 x float> %val)
store <4 x float> %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_v4f64(ptr %out) {
; Z16-LABEL: canonicalize_ptr_v4f64:
; Z16: # %bb.0:
; Z16-NEXT: vl %v1, 16(%r2), 4
; Z16-NEXT: vgmg %v2, 2, 11
; Z16-NEXT: wfmdb %f3, %f1, %f2
; Z16-NEXT: vrepg %v1, %v1, 1
; Z16-NEXT: mdbr %f1, %f2
; Z16-NEXT: vl %v0, 0(%r2), 4
; Z16-NEXT: vmrhg %v1, %v3, %v1
; Z16-NEXT: wfmdb %f3, %f0, %f2
; Z16-NEXT: vrepg %v0, %v0, 1
; Z16-NEXT: mdbr %f0, %f2
; Z16-NEXT: vmrhg %v0, %v3, %v0
; Z16-NEXT: vst %v0, 0(%r2), 4
; Z16-NEXT: vst %v1, 16(%r2), 4
; Z16-NEXT: br %r14
%val = load <4 x double>, ptr %out
%canonicalized = call <4 x double> @llvm.canonicalize.v4f64(<4 x double> %val)
store <4 x double> %canonicalized, ptr %out
ret void
}
define void @canonicalize_ptr_v2f128(ptr %out) {
; Z16-LABEL: canonicalize_ptr_v2f128:
; Z16: # %bb.0:
; Z16-NEXT: larl %r1, .LCPI15_0
; Z16-NEXT: vl %v0, 16(%r2), 4
; Z16-NEXT: vl %v1, 0(%r2), 4
; Z16-NEXT: vl %v2, 0(%r1), 3
; Z16-NEXT: wfmxb %v1, %v1, %v2
; Z16-NEXT: wfmxb %v0, %v0, %v2
; Z16-NEXT: vst %v0, 16(%r2), 4
; Z16-NEXT: vst %v1, 0(%r2), 4
; Z16-NEXT: br %r14
%val = load <2 x fp128>, ptr %out
%canonicalized = call <2 x fp128> @llvm.canonicalize.v2f128(<2 x fp128> %val)
store <2 x fp128> %canonicalized, ptr %out
ret void
}