blob: 88c31325b64b764430e41c35c9bb601366b26add [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=arm < %s | FileCheck %s -check-prefix=SOFT-FLOAT
; RUN: llc -mtriple=arm -mattr=+vfp4d16sp < %s | FileCheck %s -check-prefix=SOFT-FLOAT-VFP32
; RUN: llc -mtriple=arm -mattr=+vfp4d16sp,+fp64 < %s | FileCheck %s -check-prefix=SOFT-FLOAT-VFP64
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: push {r4, lr}
; SOFT-FLOAT-NEXT: mov r4, r2
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: mov r1, r4
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: pop {r4, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_intrinsic_f32:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r4, lr}
; SOFT-FLOAT-VFP32-NEXT: mov r4, r2
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: mov r1, r4
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: pop {r4, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_intrinsic_f32:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r4, lr}
; SOFT-FLOAT-VFP64-NEXT: mov r4, r2
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: mov r1, r4
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: pop {r4, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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: push {r11, lr}
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: pop {r11, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_intrinsic_f64:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r11, lr}
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: pop {r11, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_intrinsic_f64:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r11, lr}
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: pop {r11, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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: push {r4, lr}
; SOFT-FLOAT-NEXT: mov r4, r2
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: mov r1, r4
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: pop {r4, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_contract_f32:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r4, lr}
; SOFT-FLOAT-VFP32-NEXT: mov r4, r2
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: mov r1, r4
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: pop {r4, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_contract_f32:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r4, lr}
; SOFT-FLOAT-VFP64-NEXT: mov r4, r2
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: mov r1, r4
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: pop {r4, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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: push {r11, lr}
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: pop {r11, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_contract_f64:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r11, lr}
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: pop {r11, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_contract_f64:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r11, lr}
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #8]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #12]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: pop {r11, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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: push {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-NEXT: mov r7, r1
; SOFT-FLOAT-NEXT: ldr r1, [sp, #24]
; SOFT-FLOAT-NEXT: mov r4, r3
; SOFT-FLOAT-NEXT: mov r6, r2
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #40]
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-NEXT: mov r5, r0
; SOFT-FLOAT-NEXT: mov r0, r7
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #44]
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #32]
; SOFT-FLOAT-NEXT: mov r7, r0
; SOFT-FLOAT-NEXT: mov r0, r6
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #48]
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-NEXT: mov r6, r0
; SOFT-FLOAT-NEXT: mov r0, r4
; SOFT-FLOAT-NEXT: bl __mulsf3
; SOFT-FLOAT-NEXT: ldr r1, [sp, #52]
; SOFT-FLOAT-NEXT: bl __addsf3
; SOFT-FLOAT-NEXT: mov r3, r0
; SOFT-FLOAT-NEXT: mov r0, r5
; SOFT-FLOAT-NEXT: mov r1, r7
; SOFT-FLOAT-NEXT: mov r2, r6
; SOFT-FLOAT-NEXT: pop {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_contract_v4f32:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-VFP32-NEXT: mov r7, r1
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #24]
; SOFT-FLOAT-VFP32-NEXT: mov r4, r3
; SOFT-FLOAT-VFP32-NEXT: mov r6, r2
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #40]
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-VFP32-NEXT: mov r5, r0
; SOFT-FLOAT-VFP32-NEXT: mov r0, r7
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #44]
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #32]
; SOFT-FLOAT-VFP32-NEXT: mov r7, r0
; SOFT-FLOAT-VFP32-NEXT: mov r0, r6
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #48]
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-VFP32-NEXT: mov r6, r0
; SOFT-FLOAT-VFP32-NEXT: mov r0, r4
; SOFT-FLOAT-VFP32-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #52]
; SOFT-FLOAT-VFP32-NEXT: bl __addsf3
; SOFT-FLOAT-VFP32-NEXT: mov r3, r0
; SOFT-FLOAT-VFP32-NEXT: mov r0, r5
; SOFT-FLOAT-VFP32-NEXT: mov r1, r7
; SOFT-FLOAT-VFP32-NEXT: mov r2, r6
; SOFT-FLOAT-VFP32-NEXT: pop {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_contract_v4f32:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-VFP64-NEXT: mov r7, r1
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #24]
; SOFT-FLOAT-VFP64-NEXT: mov r4, r3
; SOFT-FLOAT-VFP64-NEXT: mov r6, r2
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #40]
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-VFP64-NEXT: mov r5, r0
; SOFT-FLOAT-VFP64-NEXT: mov r0, r7
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #44]
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #32]
; SOFT-FLOAT-VFP64-NEXT: mov r7, r0
; SOFT-FLOAT-VFP64-NEXT: mov r0, r6
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #48]
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-VFP64-NEXT: mov r6, r0
; SOFT-FLOAT-VFP64-NEXT: mov r0, r4
; SOFT-FLOAT-VFP64-NEXT: bl __mulsf3
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #52]
; SOFT-FLOAT-VFP64-NEXT: bl __addsf3
; SOFT-FLOAT-VFP64-NEXT: mov r3, r0
; SOFT-FLOAT-VFP64-NEXT: mov r0, r5
; SOFT-FLOAT-VFP64-NEXT: mov r1, r7
; SOFT-FLOAT-VFP64-NEXT: mov r2, r6
; SOFT-FLOAT-VFP64-NEXT: pop {r4, r5, r6, r7, r11, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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: push {r4, r5, r6, lr}
; SOFT-FLOAT-NEXT: mov r5, r3
; SOFT-FLOAT-NEXT: mov r6, r2
; SOFT-FLOAT-NEXT: mov r4, r0
; SOFT-FLOAT-NEXT: ldr r0, [sp, #32]
; SOFT-FLOAT-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-NEXT: ldr r2, [sp, #64]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #68]
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #96]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #100]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: str r0, [r4, #24]
; SOFT-FLOAT-NEXT: str r1, [r4, #28]
; SOFT-FLOAT-NEXT: ldr r0, [sp, #24]
; SOFT-FLOAT-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-NEXT: ldr r2, [sp, #56]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #60]
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #88]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #92]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: str r0, [r4, #16]
; SOFT-FLOAT-NEXT: str r1, [r4, #20]
; SOFT-FLOAT-NEXT: ldr r0, [sp, #16]
; SOFT-FLOAT-NEXT: ldr r1, [sp, #20]
; SOFT-FLOAT-NEXT: ldr r2, [sp, #48]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #52]
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #80]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #84]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #40]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #44]
; SOFT-FLOAT-NEXT: str r0, [r4, #8]
; SOFT-FLOAT-NEXT: mov r0, r6
; SOFT-FLOAT-NEXT: str r1, [r4, #12]
; SOFT-FLOAT-NEXT: mov r1, r5
; SOFT-FLOAT-NEXT: bl __muldf3
; SOFT-FLOAT-NEXT: ldr r2, [sp, #72]
; SOFT-FLOAT-NEXT: ldr r3, [sp, #76]
; SOFT-FLOAT-NEXT: bl __adddf3
; SOFT-FLOAT-NEXT: stm r4, {r0, r1}
; SOFT-FLOAT-NEXT: pop {r4, r5, r6, lr}
; SOFT-FLOAT-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP32-LABEL: fmuladd_contract_v4f64:
; SOFT-FLOAT-VFP32: @ %bb.0:
; SOFT-FLOAT-VFP32-NEXT: push {r4, r5, r6, lr}
; SOFT-FLOAT-VFP32-NEXT: mov r5, r3
; SOFT-FLOAT-VFP32-NEXT: mov r6, r2
; SOFT-FLOAT-VFP32-NEXT: mov r4, r0
; SOFT-FLOAT-VFP32-NEXT: ldr r0, [sp, #32]
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #64]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #68]
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #96]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #100]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: str r0, [r4, #24]
; SOFT-FLOAT-VFP32-NEXT: str r1, [r4, #28]
; SOFT-FLOAT-VFP32-NEXT: ldr r0, [sp, #24]
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #56]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #60]
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #88]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #92]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: str r0, [r4, #16]
; SOFT-FLOAT-VFP32-NEXT: str r1, [r4, #20]
; SOFT-FLOAT-VFP32-NEXT: ldr r0, [sp, #16]
; SOFT-FLOAT-VFP32-NEXT: ldr r1, [sp, #20]
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #48]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #52]
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #80]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #84]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #40]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #44]
; SOFT-FLOAT-VFP32-NEXT: str r0, [r4, #8]
; SOFT-FLOAT-VFP32-NEXT: mov r0, r6
; SOFT-FLOAT-VFP32-NEXT: str r1, [r4, #12]
; SOFT-FLOAT-VFP32-NEXT: mov r1, r5
; SOFT-FLOAT-VFP32-NEXT: bl __muldf3
; SOFT-FLOAT-VFP32-NEXT: ldr r2, [sp, #72]
; SOFT-FLOAT-VFP32-NEXT: ldr r3, [sp, #76]
; SOFT-FLOAT-VFP32-NEXT: bl __adddf3
; SOFT-FLOAT-VFP32-NEXT: stm r4, {r0, r1}
; SOFT-FLOAT-VFP32-NEXT: pop {r4, r5, r6, lr}
; SOFT-FLOAT-VFP32-NEXT: mov pc, lr
;
; SOFT-FLOAT-VFP64-LABEL: fmuladd_contract_v4f64:
; SOFT-FLOAT-VFP64: @ %bb.0:
; SOFT-FLOAT-VFP64-NEXT: push {r4, r5, r6, lr}
; SOFT-FLOAT-VFP64-NEXT: mov r5, r3
; SOFT-FLOAT-VFP64-NEXT: mov r6, r2
; SOFT-FLOAT-VFP64-NEXT: mov r4, r0
; SOFT-FLOAT-VFP64-NEXT: ldr r0, [sp, #32]
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #36]
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #64]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #68]
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #96]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #100]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: str r0, [r4, #24]
; SOFT-FLOAT-VFP64-NEXT: str r1, [r4, #28]
; SOFT-FLOAT-VFP64-NEXT: ldr r0, [sp, #24]
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #28]
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #56]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #60]
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #88]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #92]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: str r0, [r4, #16]
; SOFT-FLOAT-VFP64-NEXT: str r1, [r4, #20]
; SOFT-FLOAT-VFP64-NEXT: ldr r0, [sp, #16]
; SOFT-FLOAT-VFP64-NEXT: ldr r1, [sp, #20]
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #48]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #52]
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #80]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #84]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #40]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #44]
; SOFT-FLOAT-VFP64-NEXT: str r0, [r4, #8]
; SOFT-FLOAT-VFP64-NEXT: mov r0, r6
; SOFT-FLOAT-VFP64-NEXT: str r1, [r4, #12]
; SOFT-FLOAT-VFP64-NEXT: mov r1, r5
; SOFT-FLOAT-VFP64-NEXT: bl __muldf3
; SOFT-FLOAT-VFP64-NEXT: ldr r2, [sp, #72]
; SOFT-FLOAT-VFP64-NEXT: ldr r3, [sp, #76]
; SOFT-FLOAT-VFP64-NEXT: bl __adddf3
; SOFT-FLOAT-VFP64-NEXT: stm r4, {r0, r1}
; SOFT-FLOAT-VFP64-NEXT: pop {r4, r5, r6, lr}
; SOFT-FLOAT-VFP64-NEXT: mov pc, lr
%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)