
- _Float16 is now accepted by Clang. - The half IR type is fully handled by the backend. - These values are passed in FP registers and converted to/from float around each operation. - Compiler-rt conversion functions are now built for s390x including the missing extendhfdf2 which was added. Fixes #50374
268 lines
11 KiB
LLVM
268 lines
11 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: llc -mtriple=s390x-linux < %s | FileCheck %s -check-prefix=SOFT-FLOAT
|
|
|
|
define half @fmuladd_intrinsic_f16(half %a, half %b, half %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_intrinsic_f16:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r12, %r15, 96(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r12, -64
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -160
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 320
|
|
; SOFT-FLOAT-NEXT: # kill: def $r4l killed $r4l def $r4d
|
|
; SOFT-FLOAT-NEXT: llghr %r0, %r4
|
|
; SOFT-FLOAT-NEXT: lr %r13, %r3
|
|
; SOFT-FLOAT-NEXT: lr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __extendhfsf2@PLT
|
|
; SOFT-FLOAT-NEXT: llghr %r0, %r12
|
|
; SOFT-FLOAT-NEXT: lgr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __extendhfsf2@PLT
|
|
; SOFT-FLOAT-NEXT: llghr %r0, %r13
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __extendhfsf2@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r13
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r12
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __truncsfhf2@PLT
|
|
; SOFT-FLOAT-NEXT: # kill: def $r2l killed $r2l killed $r2d
|
|
; SOFT-FLOAT-NEXT: lmg %r12, %r15, 256(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%result = call half @llvm.fmuladd.f16(half %a, half %b, half %c)
|
|
ret half %result
|
|
}
|
|
|
|
define float @fmuladd_intrinsic_f32(float %a, float %b, float %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_intrinsic_f32:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r13, %r15, 104(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -160
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 320
|
|
; SOFT-FLOAT-NEXT: llgfr %r2, %r2
|
|
; SOFT-FLOAT-NEXT: llgfr %r3, %r3
|
|
; SOFT-FLOAT-NEXT: lr %r13, %r4
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: llgfr %r3, %r13
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: # kill: def $r2l killed $r2l killed $r2d
|
|
; SOFT-FLOAT-NEXT: lmg %r13, %r15, 264(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%result = call float @llvm.fmuladd.f32(float %a, float %b, float %c)
|
|
ret float %result
|
|
}
|
|
|
|
define double @fmuladd_intrinsic_f64(double %a, double %b, double %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_intrinsic_f64:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r13, %r15, 104(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -160
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 320
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r4
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r13
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lmg %r13, %r15, 264(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%result = call double @llvm.fmuladd.f64(double %a, double %b, double %c)
|
|
ret double %result
|
|
}
|
|
|
|
define float @fmuladd_contract_f32(float %a, float %b, float %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_contract_f32:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r13, %r15, 104(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -160
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 320
|
|
; SOFT-FLOAT-NEXT: llgfr %r2, %r2
|
|
; SOFT-FLOAT-NEXT: llgfr %r3, %r3
|
|
; SOFT-FLOAT-NEXT: lr %r13, %r4
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: llgfr %r3, %r13
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: # kill: def $r2l killed $r2l killed $r2d
|
|
; SOFT-FLOAT-NEXT: lmg %r13, %r15, 264(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%product = fmul contract float %a, %b
|
|
%result = fadd contract float %product, %c
|
|
ret float %result
|
|
}
|
|
|
|
define double @fmuladd_contract_f64(double %a, double %b, double %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_contract_f64:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r13, %r15, 104(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -160
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 320
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r4
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r13
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lmg %r13, %r15, 264(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%product = fmul contract double %a, %b
|
|
%result = fadd contract double %product, %c
|
|
ret double %result
|
|
}
|
|
|
|
define <4 x float> @fmuladd_contract_v4f32(<4 x float> %a, <4 x float> %b, <4 x float> %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_contract_v4f32:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r7, %r15, 56(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r7, -104
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r8, -96
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r9, -88
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r10, -80
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r11, -72
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r12, -64
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -176
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 336
|
|
; SOFT-FLOAT-NEXT: llgf %r0, 388(%r15)
|
|
; SOFT-FLOAT-NEXT: stg %r0, 168(%r15) # 8-byte Spill
|
|
; SOFT-FLOAT-NEXT: llgf %r0, 380(%r15)
|
|
; SOFT-FLOAT-NEXT: stg %r0, 160(%r15) # 8-byte Spill
|
|
; SOFT-FLOAT-NEXT: llgf %r11, 372(%r15)
|
|
; SOFT-FLOAT-NEXT: llgf %r10, 364(%r15)
|
|
; SOFT-FLOAT-NEXT: llgf %r8, 340(%r15)
|
|
; SOFT-FLOAT-NEXT: llgf %r0, 356(%r15)
|
|
; SOFT-FLOAT-NEXT: llgf %r7, 348(%r15)
|
|
; SOFT-FLOAT-NEXT: llgfr %r1, %r5
|
|
; SOFT-FLOAT-NEXT: lr %r9, %r4
|
|
; SOFT-FLOAT-NEXT: lr %r13, %r3
|
|
; SOFT-FLOAT-NEXT: lr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r1
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: llgfr %r0, %r9
|
|
; SOFT-FLOAT-NEXT: lgr %r9, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r7
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: llgfr %r0, %r13
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r8
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: llgfr %r0, %r12
|
|
; SOFT-FLOAT-NEXT: llgfr %r3, %r6
|
|
; SOFT-FLOAT-NEXT: lgr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __mulsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r10
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r10, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r12
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r11
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r13
|
|
; SOFT-FLOAT-NEXT: lg %r3, 160(%r15) # 8-byte Reload
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r9
|
|
; SOFT-FLOAT-NEXT: lg %r3, 168(%r15) # 8-byte Reload
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __addsf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r5, %r2
|
|
; SOFT-FLOAT-NEXT: lr %r2, %r10
|
|
; SOFT-FLOAT-NEXT: lr %r3, %r12
|
|
; SOFT-FLOAT-NEXT: lr %r4, %r13
|
|
; SOFT-FLOAT-NEXT: # kill: def $r5l killed $r5l killed $r5d
|
|
; SOFT-FLOAT-NEXT: lmg %r7, %r15, 232(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%product = fmul contract <4 x float> %a, %b
|
|
%result = fadd contract <4 x float> %product, %c
|
|
ret <4 x float> %result
|
|
}
|
|
|
|
define <4 x double> @fmuladd_contract_v4f64(<4 x double> %a, <4 x double> %b, <4 x double> %c) #0 {
|
|
; SOFT-FLOAT-LABEL: fmuladd_contract_v4f64:
|
|
; SOFT-FLOAT: # %bb.0:
|
|
; SOFT-FLOAT-NEXT: stmg %r6, %r15, 48(%r15)
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r6, -112
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r7, -104
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r8, -96
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r9, -88
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r10, -80
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r11, -72
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r12, -64
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r13, -56
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r14, -48
|
|
; SOFT-FLOAT-NEXT: .cfi_offset %r15, -40
|
|
; SOFT-FLOAT-NEXT: aghi %r15, -184
|
|
; SOFT-FLOAT-NEXT: .cfi_def_cfa_offset 344
|
|
; SOFT-FLOAT-NEXT: mvc 176(8,%r15), 24(%r4) # 8-byte Folded Spill
|
|
; SOFT-FLOAT-NEXT: mvc 168(8,%r15), 16(%r4) # 8-byte Folded Spill
|
|
; SOFT-FLOAT-NEXT: mvc 160(8,%r15), 8(%r4) # 8-byte Folded Spill
|
|
; SOFT-FLOAT-NEXT: lg %r10, 0(%r4)
|
|
; SOFT-FLOAT-NEXT: lg %r9, 0(%r2)
|
|
; SOFT-FLOAT-NEXT: lg %r8, 0(%r3)
|
|
; SOFT-FLOAT-NEXT: lg %r7, 8(%r2)
|
|
; SOFT-FLOAT-NEXT: lg %r6, 8(%r3)
|
|
; SOFT-FLOAT-NEXT: lg %r13, 16(%r2)
|
|
; SOFT-FLOAT-NEXT: lg %r2, 24(%r2)
|
|
; SOFT-FLOAT-NEXT: lg %r0, 24(%r3)
|
|
; SOFT-FLOAT-NEXT: lg %r12, 16(%r3)
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r0
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r11, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r13
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r12
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r7
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r6
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r9
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r8
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __muldf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r10
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r10, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r12
|
|
; SOFT-FLOAT-NEXT: lg %r3, 160(%r15) # 8-byte Reload
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r12, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r13
|
|
; SOFT-FLOAT-NEXT: lg %r3, 168(%r15) # 8-byte Reload
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r13, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r11
|
|
; SOFT-FLOAT-NEXT: lg %r3, 176(%r15) # 8-byte Reload
|
|
; SOFT-FLOAT-NEXT: brasl %r14, __adddf3@PLT
|
|
; SOFT-FLOAT-NEXT: lgr %r5, %r2
|
|
; SOFT-FLOAT-NEXT: lgr %r2, %r10
|
|
; SOFT-FLOAT-NEXT: lgr %r3, %r12
|
|
; SOFT-FLOAT-NEXT: lgr %r4, %r13
|
|
; SOFT-FLOAT-NEXT: lmg %r6, %r15, 232(%r15)
|
|
; SOFT-FLOAT-NEXT: br %r14
|
|
%product = fmul contract <4 x double> %a, %b
|
|
%result = fadd contract <4 x double> %product, %c
|
|
ret <4 x double> %result
|
|
}
|
|
|
|
attributes #0 = { "use-soft-float"="true" }
|
|
|
|
declare float @llvm.fmuladd.f32(float %a, float %b, float %c)
|
|
declare double @llvm.fmuladd.f64(double %a, double %b, double %c)
|