1*0b57cec5SDimitry Andric //===-- lib/mulsf3.c - Single-precision multiplication ------------*- C -*-===// 2*0b57cec5SDimitry Andric // 3*0b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*0b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5*0b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*0b57cec5SDimitry Andric // 7*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===// 8*0b57cec5SDimitry Andric // 9*0b57cec5SDimitry Andric // This file implements single-precision soft-float multiplication 10*0b57cec5SDimitry Andric // with the IEEE-754 default rounding (to nearest, ties to even). 11*0b57cec5SDimitry Andric // 12*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===// 13*0b57cec5SDimitry Andric 14*0b57cec5SDimitry Andric #define SINGLE_PRECISION 15*0b57cec5SDimitry Andric #include "fp_mul_impl.inc" 16*0b57cec5SDimitry Andric __mulsf3(fp_t a,fp_t b)17*0b57cec5SDimitry AndricCOMPILER_RT_ABI fp_t __mulsf3(fp_t a, fp_t b) { return __mulXf3__(a, b); } 18*0b57cec5SDimitry Andric 19*0b57cec5SDimitry Andric #if defined(__ARM_EABI__) 20*0b57cec5SDimitry Andric #if defined(COMPILER_RT_ARMHF_TARGET) __aeabi_fmul(fp_t a,fp_t b)21*0b57cec5SDimitry AndricAEABI_RTABI fp_t __aeabi_fmul(fp_t a, fp_t b) { return __mulsf3(a, b); } 22*0b57cec5SDimitry Andric #else 23*0b57cec5SDimitry Andric COMPILER_RT_ALIAS(__mulsf3, __aeabi_fmul) 24*0b57cec5SDimitry Andric #endif 25*0b57cec5SDimitry Andric #endif 26