glibc/sysdeps
Adhemerval Zanella d846f4c12d math: Use lgammaf from CORE-MATH
The CORE-MATH implementation is correctly rounded (for any rounding mode)
and shows better performance to the generic lgammaf.

The code was adapted to glibc style, to use the definition of
math_config.h, to remove errno handling, to use math_narrow_eval
on overflow usage, and to adapt to make it reentrant.

Benchtest on x64_64 (Ryzen 9 5900X, gcc 14.2.1), aarch64 (M1,
gcc 13.2.1), and powerpc (POWER10, gcc 13.2.1):

latency                       master       patched  improvement
x86_64                       86.5609       70.3278       18.75%
x86_64v2                     78.3030       69.9709       10.64%
x86_64v3                     74.7470       59.8457       19.94%
i686                         387.355       229.761       40.68%
aarch64                      40.8341       33.7563       17.33%
power10                      26.5520       16.1672       39.11%
powerpc                      28.3145       17.0625       39.74%

reciprocal-throughput         master       patched  improvement
x86_64                       68.0461       48.3098       29.00%
x86_64v2                     55.3256       47.2476       14.60%
x86_64v3                     52.3015       38.9028       25.62%
i686                         340.848       195.707       42.58%
aarch64                      36.8000       30.5234       17.06%
power10                      20.4043       12.6268       38.12%
powerpc                      22.6588       13.8866       38.71%

Signed-off-by: Alexei Sibidanov <sibid@uvic.ca>
Signed-off-by: Paul Zimmermann <Paul.Zimmermann@inria.fr>
Signed-off-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Reviewed-by: DJ Delorie <dj@redhat.com>
2024-11-22 10:52:27 -03:00
..
aarch64 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
alpha math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
arc math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
arm math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
csky math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
generic linux: Add support for getrandom vDSO 2024-11-12 14:42:12 -03:00
gnu sysdeps: Re-flow and sort multiline gnu/Makefile definitions 2024-08-07 11:02:03 -03:00
hppa math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
htl htl: move pthread_attr_init into libc. 2024-11-19 01:37:35 +01:00
hurd hurd: Move internal functions to internal header 2024-03-23 22:43:07 +01:00
i386 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
ieee754 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
loongarch math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
m68k math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
mach htl: move pthread_attr_init into libc. 2024-11-19 01:37:35 +01:00
microblaze math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
mips math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
nios2 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
nptl linux: Add support for getrandom vDSO 2024-11-12 14:42:12 -03:00
or1k math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
posix stdlib: Make abort/_Exit AS-safe (BZ 26275) 2024-10-08 14:40:12 -03:00
powerpc math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
pthread Rename new tst-sem17 test to tst-sem18 2024-11-08 17:08:09 +00:00
riscv math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
s390 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
sh math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
sparc math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00
unix AArch64: Add support for memory protection keys 2024-11-20 11:30:58 +00:00
wordsize-32 Update copyright dates with scripts/update-copyrights 2024-01-01 10:53:40 -08:00
wordsize-64 Update copyright dates with scripts/update-copyrights 2024-01-01 10:53:40 -08:00
x86 x86: Enable non-temporal memset for Hygon processors 2024-08-26 10:01:58 -07:00
x86_64 math: Use lgammaf from CORE-MATH 2024-11-22 10:52:27 -03:00