[builtins] Define fmax and scalbn inline
authorRyan Prichard <rprichard@google.com>
Wed, 24 Feb 2021 06:09:24 +0000 (22:09 -0800)
committerRyan Prichard <rprichard@google.com>
Wed, 24 Feb 2021 22:27:37 +0000 (14:27 -0800)
commit341889ee9e03e73b313263c516b3d1fd33d4c4ba
tree2e1dcecdb5f9849011ccd98ebad9f1cb0ad779a3
parenta921aaf789912d981cbb2036bdc91ad7289e1523
[builtins] Define fmax and scalbn inline

Define inline versions of __compiler_rt_fmax* and __compiler_rt_scalbn*
rather than depend on the versions in libm. As with
__compiler_rt_logbn*, these functions are only defined for single,
double, and quad precision (binary128).

Fixes PR32279 for targets using only these FP formats (e.g. Android
on arm/arm64/x86/x86_64).

For single and double precision, on AArch64, use __builtin_fmax[f]
instead of the new inline function, because the builtin expands to the
AArch64 fmaxnm instruction.

Reviewed By: MaskRay

Differential Revision: https://reviews.llvm.org/D91841
13 files changed:
compiler-rt/lib/builtins/divdc3.c
compiler-rt/lib/builtins/divsc3.c
compiler-rt/lib/builtins/divtc3.c
compiler-rt/lib/builtins/fp_lib.h
compiler-rt/lib/builtins/int_lib.h
compiler-rt/lib/builtins/int_math.h
compiler-rt/lib/builtins/ppc/divtc3.c
compiler-rt/test/builtins/Unit/compiler_rt_fmax_test.c [new file with mode: 0644]
compiler-rt/test/builtins/Unit/compiler_rt_fmaxf_test.c [new file with mode: 0644]
compiler-rt/test/builtins/Unit/compiler_rt_fmaxl_test.c [new file with mode: 0644]
compiler-rt/test/builtins/Unit/compiler_rt_scalbn_test.c [new file with mode: 0644]
compiler-rt/test/builtins/Unit/compiler_rt_scalbnf_test.c [new file with mode: 0644]
compiler-rt/test/builtins/Unit/compiler_rt_scalbnl_test.c [new file with mode: 0644]