blob: 1447c576f48ae805a0a290066f8147f044124104 [file] [log] [blame]
; 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 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)