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

The code was adapted to glibc style and to use the definition of
math_config.h (to handle errno, overflow, and underflow).

Benchtest on x64_64 (Ryzen 9 5900X, gcc 14.2.1), aarch64 (Neoverse-N1,
gcc 13.3.1), and powerpc (POWER10, gcc 13.2.1):

latency                     master        patched   improvement
x86_64                     66.3296        52.7558        20.46%
x86_64v2                   66.0429        51.4007        22.17%
x86_64v3                   60.6294        48.7876        19.53%
aarch64 (Neoverse)         24.3163        20.9110        14.00%
power8                     16.5766        13.3620        19.39%
power10                    16.5115        13.4072        18.80%

reciprocal-throughput       master        patched   improvement
x86_64                     30.8599        16.0866        47.87%
x86_64v2                   29.2286        15.4688        47.08%
x86_64v3                   23.0960        12.8510        44.36%
aarch64 (Neoverse)         15.4619        10.6752        30.96%
power8                      7.9200         5.2483        33.73%
power10                     6.8539         4.6262        32.50%

Reviewed-by: DJ Delorie <dj@redhat.com>
2025-02-12 16:31:57 -03:00
..
aarch64 math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
alpha math: update alpha ulps 2025-01-05 20:02:53 +01:00
arc math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
arm math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
csky Move <thread_pointer.h> to kernel-independent sysdeps directories 2025-01-09 19:30:16 +01:00
generic elf: Add l_soname accessor function for DT_SONAME values 2025-02-02 20:10:09 +01:00
gnu Update copyright dates with scripts/update-copyrights 2025-01-01 11:22:09 -08:00
hppa math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
htl htl: stop exporting __pthread_default_barrierattr. 2025-02-10 01:39:17 +01:00
hurd Update copyright dates with scripts/update-copyrights 2025-01-01 11:22:09 -08:00
i386 math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
ieee754 math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
loongarch math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
m68k Add missing include guards to <dl-tls.h> 2025-01-10 19:02:47 +01:00
mach hurd: Replace char foo[1024] with string_t 2025-02-10 20:10:59 +01:00
microblaze Move <thread_pointer.h> to kernel-independent sysdeps directories 2025-01-09 19:30:16 +01:00
mips math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
nptl nptl: Add support for setup guard pages with MADV_GUARD_INSTALL 2025-01-30 10:16:37 -03:00
or1k math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
posix Fix underallocation of abort_msg_s struct (CVE-2025-0395) 2025-01-22 08:17:17 -05:00
powerpc math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
pthread htl: move pthread_setcancelstate into libc. 2025-02-01 11:24:14 +01:00
riscv math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
s390 math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
sh sh: Fix tst-guard1 build 2025-01-31 09:34:36 -03:00
sparc math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00
unix ld.so: Decorate BSS mappings 2025-01-30 10:16:37 -03:00
wordsize-32 Update copyright dates with scripts/update-copyrights 2025-01-01 11:22:09 -08:00
wordsize-64 Update copyright dates with scripts/update-copyrights 2025-01-01 11:22:09 -08:00
x86 x86: Add missing #include <features.h> to <thread_pointer.h> 2025-01-09 19:30:41 +01:00
x86_64 math: Use atanpif from CORE-MATH 2025-02-12 16:31:57 -03:00