]> git.ipfire.org Git - thirdparty/glibc.git/log
thirdparty/glibc.git
7 months agomath: Use asinf from CORE-MATH
Adhemerval Zanella [Wed, 13 Nov 2024 16:48:14 +0000 (13:48 -0300)] 
math: Use asinf from CORE-MATH

The CORE-MATH implementation is correctly rounded (for any rounding mode)
and shows slight better performance to the generic asinf.

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                      42.8237        35.2460        17.70%
x86_64v2                    43.3711        35.9406        17.13%
x86_64v3                    35.0335        30.5744        12.73%
i686                       213.8780        104.4710       51.15%
aarch64 (Neoverse)          17.2937        13.6025        21.34%
power10                     12.0227        7.4241         38.25%

reciprocal-throughput        master        patched   improvement
x86_64                      13.6770        15.5231       -13.50%
x86_64v2                    13.8722        16.0446       -15.66%
x86_64v3                    13.6211        13.2753         2.54%
i686                       186.7670        45.4388        75.67%
aarch64 (Neoverse)          9.96089        9.39285         5.70%
power10                      4.9862        3.7819         24.15%

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>
7 months agomath: Use acoshf from CORE-MATH
Adhemerval Zanella [Mon, 21 Oct 2024 13:51:09 +0000 (10:51 -0300)] 
math: Use acoshf from CORE-MATH

The CORE-MATH implementation is correctly rounded (for any rounding mode)
and shows slight better performance to the generic acoshf.

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                      61.2471        58.7742         4.04%
x86_64-v2                   62.6519        59.0523         5.75%
x86_64-v3                   58.7408        50.1393        14.64%
aarch64                     24.8580        21.3317        14.19%
power10                     17.0469        13.1345        22.95%

reciprocal-throughput        master        patched   improvement
x86_64                      16.1618        15.1864         6.04%
x86_64-v2                   15.7729        14.7563         6.45%
x86_64-v3                   14.1669        11.9568        15.60%
aarch64                      10.911        9.5486         12.49%
power10                     6.38196        5.06734        20.60%

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>
7 months agomath: Use acosf from CORE-MATH
Adhemerval Zanella [Fri, 18 Oct 2024 19:04:30 +0000 (16:04 -0300)] 
math: Use acosf from CORE-MATH

The CORE-MATH implementation is correctly rounded (for any rounding mode)
and shows slight better performance to the generic acosf.

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                      52.5098        36.6312        30.24%
x86_64v2                    53.0217        37.3091        29.63%
x86_64v3                    42.8501        32.3977        24.39%
i686                       207.3960       109.4000        47.25%
aarch64                     21.3694        13.7871        35.48%
power10                     14.5542         7.2891        49.92%

reciprocal-throughput        master        patched   improvement
x86_64                      14.1487        15.9508       -12.74%
x86_64v2                    14.3293        16.1899       -12.98%
x86_64v3                    13.6563        12.6161         7.62%
i686                       158.4060        45.7354        71.13%
aarch64                     12.5515        9.19233        26.76%
power10                      5.7868         3.3487        42.13%

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>
7 months agomath: Fix the expected carg (inf) results
Adhemerval Zanella [Wed, 4 Dec 2024 15:55:42 +0000 (12:55 -0300)] 
math: Fix the expected carg (inf) results

The pi defined constants are not the expected value for carg
on non-default rounding modes (similar to atan).  Instead use
autogenerated value.

7 months agomath: Fix the expected atan2f (inf) results
Adhemerval Zanella [Wed, 20 Nov 2024 18:50:22 +0000 (15:50 -0300)] 
math: Fix the expected atan2f (inf) results

The pi defined constants are not the expected value for atan2
on non-default rounding modes.  Instead use the autogenerated value.

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agomath: Fix the expected atanf (inf) results
Adhemerval Zanella [Wed, 20 Nov 2024 17:21:56 +0000 (14:21 -0300)] 
math: Fix the expected atanf (inf) results

The M_PI_2 (lit_pi_2_d) constant is not the expected value for atanf
on non-default rounding modes.  Instead use the autogenerated value.

7 months agomath: Add inf support on gen-auto-libm-tests.c
Adhemerval Zanella [Wed, 20 Nov 2024 18:44:58 +0000 (15:44 -0300)] 
math: Add inf support on gen-auto-libm-tests.c

For some correctly rounded inputs where infinity might generate
a number (like atanf), comparing to a pre-defined constant does not
yield the expected result in all rounding modes.

The most straightforward way to handle it would be to get the expected
result from mpfr, where it handles all the rounding modes.

7 months agomath: Fix spurious-divbyzero flag name
Adhemerval Zanella [Wed, 4 Dec 2024 13:05:05 +0000 (10:05 -0300)] 
math: Fix spurious-divbyzero flag name

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add tanhf benchmark
Adhemerval Zanella [Tue, 19 Nov 2024 19:09:11 +0000 (16:09 -0300)] 
benchtests: Add tanhf benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add sinhf benchmark
Adhemerval Zanella [Tue, 19 Nov 2024 16:47:15 +0000 (13:47 -0300)] 
benchtests: Add sinhf benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add coshf benchmark
Adhemerval Zanella [Tue, 19 Nov 2024 12:46:22 +0000 (09:46 -0300)] 
benchtests: Add coshf benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add atanhf benchmark
Adhemerval Zanella [Tue, 19 Nov 2024 14:11:05 +0000 (11:11 -0300)] 
benchtests: Add atanhf benchmark

The input is based on acosf one (random inputs in [-1,1]).

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add atan2f benchmark
Adhemerval Zanella [Mon, 18 Nov 2024 13:12:06 +0000 (10:12 -0300)] 
benchtests: Add atan2f benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add atanf benchmark
Adhemerval Zanella [Thu, 14 Nov 2024 17:56:20 +0000 (14:56 -0300)] 
benchtests: Add atanf benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add asinhf benchmark
Adhemerval Zanella [Thu, 14 Nov 2024 12:55:35 +0000 (09:55 -0300)] 
benchtests: Add asinhf benchmark

Random inputs in the range [-10,10].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add asinf benchmark
Adhemerval Zanella [Wed, 13 Nov 2024 16:29:41 +0000 (13:29 -0300)] 
benchtests: Add asinf benchmark

The input is based on acosf one (random inputs in [-1,1]).

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add acoshf benchmark
Adhemerval Zanella [Mon, 21 Oct 2024 12:08:01 +0000 (09:08 -0300)] 
benchtests: Add acoshf benchmark

Random inputs in the range [1,21].

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add acosf benchmark
Adhemerval Zanella [Fri, 18 Oct 2024 18:27:25 +0000 (15:27 -0300)] 
benchtests: Add acosf benchmark

The input is based on acos one (random inputs in [-1,1]).

Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agonptl: Add <thread_pointer.h> for sparc
Michael Jeanson [Wed, 31 Jul 2024 21:04:10 +0000 (17:04 -0400)] 
nptl: Add <thread_pointer.h> for sparc

This will be required by the rseq extensible ABI implementation on all
Linux architectures exposing the '__rseq_size' and '__rseq_offset'
symbols to set the initial value of the 'cpu_id' field which can be used
by applications to test if rseq is available and registered. As long as
the symbols are exposed it is valid for an application to perform this
test even if rseq is not yet implemented in libc for this architecture.

Compile tested with build-many-glibcs.py but I don't have access to any
hardware to run the tests.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
7 months agopowerpc: Update libm-test-ulps
Adhemerval Zanella [Wed, 18 Dec 2024 18:43:09 +0000 (15:43 -0300)] 
powerpc: Update libm-test-ulps

Regen to add new functions acospi, asinpi, atan2pi, atanpi, and
tanpi.

7 months agoarm: Update libm-test-ulps
Adhemerval Zanella [Wed, 18 Dec 2024 17:19:36 +0000 (14:19 -0300)] 
arm: Update libm-test-ulps

Regen to add new functions acospi, asinpi, atan2pi, atanpi, cospi,
sinpi, and tanpi.

7 months agoi386: Update libm-test-ulps
Adhemerval Zanella [Wed, 18 Dec 2024 17:16:06 +0000 (14:16 -0300)] 
i386: Update libm-test-ulps

Regen to add new functions acospi, asinpi, atan2pi, atanpi, cospi,
sinpi, and tanpi.

7 months agoUpdate syscall lists for Linux 6.12
Joseph Myers [Wed, 18 Dec 2024 15:12:36 +0000 (15:12 +0000)] 
Update syscall lists for Linux 6.12

Linux 6.12 has no new syscalls.  Update the version number in
syscall-names.list to reflect that it is still current for 6.12.

Tested with build-many-glibcs.py.

7 months agoHide memset/bzero from compiler
H.J. Lu [Tue, 17 Dec 2024 18:38:26 +0000 (02:38 +0800)] 
Hide memset/bzero from compiler

Hide memset/bzero from compiler to silence Clang error:

./tester.c:1345:29: error: 'size' argument to memset is '0'; did you mean to transpose the last two arguments? [-Werror,-Wmemset-transposed-args]
 1345 |   (void) memset(one+2, 'y', 0);
      |                             ^
./tester.c:1345:29: note: parenthesize the third argument to silence
./tester.c:1432:16: error: 'size' argument to bzero is '0' [-Werror,-Wsuspicious-bzero]
 1432 |   bzero(one+2, 0);
      |                ^
./tester.c:1432:16: note: parenthesize the second argument to silence

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoCheck if clang and clang++ are used to test glibc
H.J. Lu [Tue, 17 Dec 2024 19:25:09 +0000 (03:25 +0800)] 
Check if clang and clang++ are used to test glibc

Set have-test-clang to yes if clang is used to test glibc.  Set
have-test-clangxx to yes if clang++ is used to test glibc.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoReplace __strcpy_chk with __builtin___strcpy_chk
H.J. Lu [Tue, 17 Dec 2024 22:55:35 +0000 (06:55 +0800)] 
Replace __strcpy_chk with __builtin___strcpy_chk

Although _chk functions are exported in libc.so.6, their prototypes aren't
provided.  Their built versions are supported by compiler.  Replace
__strcpy_chk with __builtin___strcpy_chk to silence Clang error:

./tst-gnuglob-skeleton.c:225:3: error: call to undeclared function '__strcpy_chk'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
  225 |   __strcpy_chk (dir->d.d_name, filesystem[dir->idx].name, NAME_MAX);
      |   ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
7 months agoungetc: Guarantee single char pushback
Siddhesh Poyarekar [Thu, 7 Nov 2024 16:16:04 +0000 (11:16 -0500)] 
ungetc: Guarantee single char pushback

The C standard requires that ungetc guarantees at least one pushback,
but the malloc call to allocate the pushback buffer could fail, thus
violating that requirement.  Fix this by adding a single byte pushback
buffer in the FILE struct that the pushback can fall back to if malloc
fails.

The side-effect is that if the initial malloc fails and the 1-byte
fallback buffer is used, future resizing (if it succeeds) will be
2-bytes, 4-bytes and so on, which is suboptimal but it's after a malloc
failure, so maybe even desirable.

A future optimization here could be to have the pushback code use the
single byte buffer first and only fall back to malloc for subsequent
calls.

Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
Reviewed-by: Maciej W. Rozycki <macro@redhat.com>
7 months agolibio: Fix last NULL-as-0 issue in libioP.h
Siddhesh Poyarekar [Tue, 17 Dec 2024 22:36:36 +0000 (17:36 -0500)] 
libio: Fix last NULL-as-0 issue in libioP.h

Signed-off-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
Reviewed-by: Maciej W. Rozycki <macro@redhat.com>
7 months agosys/platform/x86.h: Do not depend on _Bool definition in C++ mode
H.J. Lu [Tue, 17 Dec 2024 18:25:03 +0000 (02:25 +0800)] 
sys/platform/x86.h: Do not depend on _Bool definition in C++ mode

Clang does not define _Bool for -std=c++98:

/usr/include/bits/platform/features.h:31:19: error: unknown type name '_Bool'
   31 | static __inline__ _Bool
      |                   ^

Change _Bool to bool to silence clang++ error.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Florian Weimer <fweimer@redhat.com>
7 months agoReplace copysign (0,-1) with -0.0 in initializer
H.J. Lu [Sat, 14 Dec 2024 11:21:15 +0000 (19:21 +0800)] 
Replace copysign (0,-1) with -0.0 in initializer

GCC 4.9 issues an error for copysign in initializer:

In file included from tst-printf-format-p-double.c:20:0:
tst-printf-format-skeleton-double.c:29:3: error: initializer element is not a constant expression [-Werror]
   { -HUGE_VAL, -DBL_MAX, -DBL_MIN, copysign (0, -1), -NAN, NAN, 0, DBL_MIN,
   ^

since it can't fold "copysign (0, -1)".  Replace copysign (0,-1) with -0.0.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
7 months agotst-unique3.cc: Add explicit instantiation declaration for S<char>::i
H.J. Lu [Mon, 16 Dec 2024 21:57:49 +0000 (05:57 +0800)] 
tst-unique3.cc: Add explicit instantiation declaration for S<char>::i

Add explicit instantiation declaration of S<char>::i to silence Clang
error:

tst-unique3.cc:6:18: error: instantiation of variable 'S<char>::i' required here, but no definition is available [-Werror,-Wundefined-var-template]
    6 | int t = S<char>::i;
      |                  ^
./tst-unique3.h:5:14: note: forward declaration of template entity is here
    5 |   static int i;
      |              ^
tst-unique3.cc:6:18: note: add an explicit instantiation declaration to suppress this warning if 'S<char>::i' is explicitly instantiated in another translation unit
    6 | int t = S<char>::i;
      |                  ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
7 months agoldbl-96: Set -1 to "int sign_exponent:16"
H.J. Lu [Mon, 16 Dec 2024 21:50:47 +0000 (05:50 +0800)] 
ldbl-96: Set -1 to "int sign_exponent:16"

ieee_long_double_shape_type has

typedef union
{
  long double value;
  struct
  {
    ...
    int sign_exponent:16;
    ...
  } parts;
} ieee_long_double_shape_type;

Clang issues an error:

../sysdeps/ieee754/ldbl-96/test-totalorderl-ldbl-96.c:49:2: error: implicit truncation from 'int' to bit-field changes value from 65535 to -1 [-Werror,-Wbitfield-constant-conversion]
   49 |         SET_LDOUBLE_WORDS (ldnx, 0xffff,
      |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   50 |                            tests[i] >> 32, tests[i] & 0xffffffffULL);
      |

Use -1, instead of 0xffff, to silence Clang.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotst-clone3[-internal].c: Add _Atomic to silence Clang
H.J. Lu [Mon, 16 Dec 2024 21:54:19 +0000 (05:54 +0800)] 
tst-clone3[-internal].c: Add _Atomic to silence Clang

Add _Atomic to futex_wait argument and ctid in tst-clone3[-internal].c to
silence Clang error:

../sysdeps/unix/sysv/linux/tst-clone3-internal.c:93:3: error: address argument to atomic operation must be a pointer to _Atomic type ('pid_t *' (aka 'int *') invalid)
   93 |   wait_tid (&ctid, CTID_INIT_VAL);
      |   ^         ~~~~~
../sysdeps/unix/sysv/linux/tst-clone3-internal.c:51:21: note: expanded from macro 'wait_tid'
   51 |     while ((__tid = atomic_load_explicit (ctid_ptr,                     \
      |                     ^                     ~~~~~~~~
/usr/bin/../lib/clang/19/include/stdatomic.h:145:30: note: expanded from macro 'atomic_load_explicit'
  145 | #define atomic_load_explicit __c11_atomic_load
      |                              ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotst-atexit-common.c: Mark _exit_with_flush as noreturn
H.J. Lu [Mon, 16 Dec 2024 21:51:07 +0000 (05:51 +0800)] 
tst-atexit-common.c: Mark _exit_with_flush as noreturn

Mark _exit_with_flush as noreturn to silence the Clang error on
tst-atexit-common.c:

In file included from tst-atexit.c:22:
../stdlib/tst-atexit-common.c:113:5: error: unannotated fall-through between switch labels [-Werror,-Wimplicit-fallthrough]
  113 |     case 0:  /* Child.  */
      |     ^
../stdlib/tst-atexit-common.c:113:5: note: insert 'break;' to avoid fall-through
  113 |     case 0:  /* Child.  */
      |     ^
      |     break;
1 error generated.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agox86: Avoid integer truncation with large cache sizes (bug 32470)
Florian Weimer [Tue, 17 Dec 2024 17:12:03 +0000 (18:12 +0100)] 
x86: Avoid integer truncation with large cache sizes (bug 32470)

Some hypervisors report 1 TiB L3 cache size.  This results
in some variables incorrectly getting zeroed, causing crashes
in memcpy/memmove because invariants are violated.

7 months agotst-timespec.c: Explicitly cast TIME_T_MAX to double
H.J. Lu [Mon, 16 Dec 2024 21:52:43 +0000 (05:52 +0800)] 
tst-timespec.c: Explicitly cast TIME_T_MAX to double

Explicitly cast TIME_T_MAX to double in tst-timespec.c to silence Clang
error:

tst-timespec.c:290:19: error: implicit conversion from 'time_t' (aka 'long') to 'double' changes value from 9223372036854775807 to 9223372036854775808 [-Werror,-Wimplicit-const-int-float-conversion]
  287 |   {.expected = {.tv_sec = 0, .tv_nsec = 1},
      |   ~
  288 |    .observed = {.tv_sec = TIME_T_MAX / TIMESPEC_HZ,
  289 |                 .tv_nsec = TIMESPEC_HZ - 1},
  290 |    .upper_bound = TIME_T_MAX, .lower_bound = 1, .result = 1,
      |                   ^~~~~~~~~~

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotst-resolv-invalid-cname.c: Explicitly cast 192 and 168 to char
H.J. Lu [Mon, 16 Dec 2024 21:54:52 +0000 (05:54 +0800)] 
tst-resolv-invalid-cname.c: Explicitly cast 192 and 168 to char

Explicitly cast 192 and 168 to char to silence Clang error:

tst-resolv-invalid-cname.c:313:17: error: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Werror,-Wconstant-conversion]
  313 |       addr[0] = 192;
      |               ~ ^~~
tst-resolv-invalid-cname.c:314:17: error: implicit conversion from 'int' to 'char' changes value from 168 to -88 [-Werror,-Wconstant-conversion]
  314 |       addr[1] = 168;
      |               ~ ^~~

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoSilence Clang #include_next error
H.J. Lu [Mon, 16 Dec 2024 21:56:53 +0000 (05:56 +0800)] 
Silence Clang #include_next error

Use "#include <...>" to silence Clang #include_next error:

In file included from ../sysdeps/x86_64/fpu/test-double-vlen4-wrappers.c:19:
../sysdeps/x86_64/fpu/test-double-vlen4.h:19:2: error: #include_next in file found relative to primary source file or found by absolute path; will search from start of include path [-Werror,-Winclude-next-absolute-path]
   19 | #include_next <test-double-vlen4.h>
      |  ^
1 error generated.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agocet: Pass -mshstk to compiler for tst-cet-legacy-10a[-static].c
H.J. Lu [Mon, 16 Dec 2024 22:18:55 +0000 (06:18 +0800)] 
cet: Pass -mshstk to compiler for tst-cet-legacy-10a[-static].c

Pass -mshstk to compiler to silence Clang:

In file included from ../sysdeps/x86_64/tst-cet-legacy-10a.c:2:
../sysdeps/x86_64/tst-cet-legacy-10.c:29:7: error: always_inline function '_get_ssp' requires target feature 'shstk', but would be inlined into function 'do_test' that is compiled without support for 'shstk'
   29 |   if (_get_ssp () != 0)
      |       ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoAArch64: Improve codegen of AdvSIMD expf family
Joana Cruz [Tue, 17 Dec 2024 14:50:33 +0000 (14:50 +0000)] 
AArch64: Improve codegen of AdvSIMD expf family

Load the polynomial evaluation coefficients into 2 vectors and use lanewise MLAs.
Also use intrinsics instead of native operations.
expf: 3% improvement in throughput microbenchmark on Neoverse V1, exp2f: 5%,
exp10f: 13%, coshf: 14%.

Reviewed-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
7 months agoAArch64: Improve codegen of AdvSIMD atan(2)(f)
Joana Cruz [Tue, 17 Dec 2024 14:49:30 +0000 (14:49 +0000)] 
AArch64: Improve codegen of AdvSIMD atan(2)(f)

Load the polynomial evaluation coefficients into 2 vectors and use lanewise MLAs.
8% improvement in throughput microbenchmark on Neoverse V1.

Reviewed-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
7 months agoAArch64: Improve codegen of AdvSIMD logf function family
Joana Cruz [Tue, 17 Dec 2024 14:47:31 +0000 (14:47 +0000)] 
AArch64: Improve codegen of AdvSIMD logf function family

Load the polynomial evaluation coefficients into 2 vectors and use lanewise MLAs.
8% improvement in throughput microbenchmark on Neoverse V1 for log2 and log,
and 2% for log10.

Reviewed-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
7 months agoHide all malloc functions from compiler [BZ #32366]
H.J. Lu [Tue, 17 Dec 2024 10:41:45 +0000 (18:41 +0800)] 
Hide all malloc functions from compiler [BZ #32366]

Since -1 isn't a power of two, compiler may reject it, hide memalign from
Clang 19 which issues an error:

tst-memalign.c:86:31: error: requested alignment is not a power of 2 [-Werror,-Wnon-power-of-two-alignment]
   86 |   p = memalign (-1, pagesize);
      |                 ^~
tst-memalign.c:86:31: error: requested alignment must be 4294967296 bytes or smaller; maximum alignment assumed [-Werror,-Wbuiltin-assume-aligned-alignment]
   86 |   p = memalign (-1, pagesize);
      |                 ^~

Update tst-malloc-aux.h to hide all malloc functions and include it in
all malloc tests to prevent compiler from optimizing out any malloc
functions.

Tested with Clang 19.1.5 and GCC 15 20241206 for BZ #32366.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agolibio: Use NULL instead of 0 as a null pointer constant
Alejandro Colomar [Mon, 16 Dec 2024 23:22:19 +0000 (00:22 +0100)] 
libio: Use NULL instead of 0 as a null pointer constant

This was missed in a recent global change.

Fixes: 53fcdf5f743a (2024-11-25, "Silence most -Wzero-as-null-pointer-constant diagnostics")
Reported-by: "Maciej W. Rozycki" <macro@redhat.com>
Cc: Siddhesh Poyarekar <siddhesh@sourceware.org>
Cc: Bruno Haible <bruno@clisp.org>
Cc: Martin Uecker <uecker@tugraz.at>
Cc: Xi Ruoyao <xry111@xry111.site>
Cc: Florian Weimer <fweimer@redhat.com>
Cc: Joseph Myers <josmyers@redhat.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
Reviewed-by: Maciej W. Rozycki <macro@redhat.com>
7 months agomanual: Document more sigaction flags
DJ Delorie [Tue, 10 Dec 2024 22:07:21 +0000 (17:07 -0500)] 
manual: Document more sigaction flags

Adds documentation for three-argument handler

Adds remainder of the SA_* flags

Reviewed-by: Florian Weimer <fweimer@redhat.com>
7 months agoRemove duplicated BUILD_CC in Makeconfig
H.J. Lu [Thu, 5 Dec 2024 07:47:53 +0000 (15:47 +0800)] 
Remove duplicated BUILD_CC in Makeconfig

Remove the second

ifndef BUILD_CC
BUILD_CC = $(CC)
endif

in Makeconfig.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agoiconv: do not report error exit with transliteration [BZ #32448]
Aurelien Jarno [Sat, 14 Dec 2024 10:44:11 +0000 (11:44 +0100)] 
iconv: do not report error exit with transliteration [BZ #32448]

Commit 6cbf845fcdc7 ("iconv: Preserve iconv -c error exit on invalid
inputs (bug 32046)") changed the error exit code to report an error when
an input character has been transliterated. This looks like a bug as the
moto in the iconv program is to report an error code in the same
condition as the iconv() function.

This happens because the STANDARD_TO_LOOP_ERR_HANDLER macro sets a
default value for result and later updates it if the transliteration
succeed. With the changes, setting the default value also marks the
input as illegal.

Fix that by setting up the default value of result only when the
transliteration is not used. This works because __gconv_transliterate()
calls __gconv_mark_illegal_input() to return an error. At the same time
also fix the typo outself -> ourselves.

Fixes: 6cbf845fcdc7
Resolves: BZ #32448
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
7 months agoFix sysdeps/x86/fpu/Makefile: Split and sort tests
H.J. Lu [Sun, 15 Dec 2024 21:57:28 +0000 (05:57 +0800)] 
Fix sysdeps/x86/fpu/Makefile: Split and sort tests

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
7 months agosysdeps/x86/fpu/Makefile: Split and sort tests
H.J. Lu [Sun, 15 Dec 2024 21:49:43 +0000 (05:49 +0800)] 
sysdeps/x86/fpu/Makefile: Split and sort tests

Split and sort tests in sysdeps/x86/fpu/Makefile.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
7 months agoUse empty initializer to silence GCC 4.9 or older
H.J. Lu [Sun, 15 Dec 2024 14:44:49 +0000 (22:44 +0800)] 
Use empty initializer to silence GCC 4.9 or older

Use empty initializer to silence GCC 4.9 or older:

getaddrinfo.c: In function ‘gaih_inet’:
getaddrinfo.c:1135:24: error: missing braces around initializer [-Werror=missing-braces]
       / sizeof (struct gaih_typeproto)] = {0};
                        ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoLinux: Check for 0 return value from vDSO getrandom probe
Florian Weimer [Sun, 15 Dec 2024 16:05:25 +0000 (17:05 +0100)] 
Linux: Check for 0 return value from vDSO getrandom probe

As of Linux 6.13, there is no code in the vDSO that declines this
initialization request with the special ~0UL state size.  If the vDSO
has the function, the call succeeds and returns 0.  It's expected
that the code would follow the “a negative value indicating an error”
convention, as indicated in the __cvdso_getrandom_data function
comment, so that INTERNAL_SYSCALL_ERROR_P on glibc's side would return
true.  This commit changes the commit to check for zero to indicate
success instead, which covers potential future non-zero success
return values and error returns.

Fixes commit 4f5704ea347e52ac3f272d1341da10aed6e9973e ("powerpc: Use
correct procedure call standard for getrandom vDSO call (bug 32440)").

7 months agohppa: Update libm-test-ulps
John David Anglin [Sun, 15 Dec 2024 14:24:53 +0000 (09:24 -0500)] 
hppa: Update libm-test-ulps

Signed-off-by: John David Anglin <dave.anglin@bell.net>
7 months agoRevert "Add braces in initializers for GCC 4.9 or older"
H.J. Lu [Sun, 15 Dec 2024 10:49:43 +0000 (18:49 +0800)] 
Revert "Add braces in initializers for GCC 4.9 or older"

This reverts commit 8aa2a9e0339215012354f3c4a262edda838134e8.

as not all targets need braces.

7 months agotst-difftime.c: Use "main (void)"
H.J. Lu [Sun, 15 Dec 2024 07:01:57 +0000 (15:01 +0800)] 
tst-difftime.c: Use "main (void)"

Use "main (void)" instead of "main (void)" to avoid GCC 4.9 warning:

tst-difftime.c:62:1: error: function declaration isn’t a prototype [-Werror=strict-prototypes]
 main ()
 ^
tst-difftime.c: In function ‘main’:
tst-difftime.c:62:1: error: old-style function definition [-Werror=old-style-definition]
cc1: all warnings being treated as errors

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
7 months agoor1k: Update libm-test-ulps
Stafford Horne [Fri, 13 Dec 2024 11:24:12 +0000 (11:24 +0000)] 
or1k: Update libm-test-ulps

Regen to add new functions acospi, asinpi, atan2pi and atanpi.

7 months agohtl: move pthread_sigmask into libc.
gfleury [Thu, 12 Dec 2024 22:06:12 +0000 (00:06 +0200)] 
htl: move pthread_sigmask into libc.

Message-ID: <20241212220612.782313-3-gfleury@disroot.org>

7 months agohtl: move __pthread_sigstate into libc.
gfleury [Thu, 12 Dec 2024 22:06:11 +0000 (00:06 +0200)] 
htl: move __pthread_sigstate into libc.

Message-ID: <20241212220612.782313-2-gfleury@disroot.org>

7 months agohtl: move __pthread_sigstate_destroy into libc.
gfleury [Thu, 12 Dec 2024 22:06:10 +0000 (00:06 +0200)] 
htl: move __pthread_sigstate_destroy into libc.

Message-ID: <20241212220612.782313-1-gfleury@disroot.org>

7 months agoReturn EXIT_UNSUPPORTED if __builtin_add_overflow unavailable
H.J. Lu [Sat, 14 Dec 2024 12:12:21 +0000 (20:12 +0800)] 
Return EXIT_UNSUPPORTED if __builtin_add_overflow unavailable

Since GCC 4.9 doesn't have __builtin_add_overflow:

In file included from tst-stringtable.c:180:0:
stringtable.c: In function ‘stringtable_finalize’:
stringtable.c:185:7: error: implicit declaration of function ‘__builtin_add_overflow’ [-Werror=implicit-function-declaration]
       else if (__builtin_add_overflow (previous->offset,
       ^

return EXIT_UNSUPPORTED for GCC 4.9 or older.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoifuncmain9.c: Return EXIT_UNSUPPORTED for GCC 5.4 or older
H.J. Lu [Thu, 12 Dec 2024 21:22:47 +0000 (05:22 +0800)] 
ifuncmain9.c: Return EXIT_UNSUPPORTED for GCC 5.4 or older

Since elf/ifuncmain9.c fails at run-time when compiled with GCC 5.4 or
older (PR ipa/81128), return EXIT_UNSUPPORTED for GCC 5.4 or older.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoinclude/bits/sigstksz.h: Avoid #elif IS_IN (libsupport)
H.J. Lu [Thu, 12 Dec 2024 21:56:05 +0000 (05:56 +0800)] 
include/bits/sigstksz.h: Avoid #elif IS_IN (libsupport)

GCC 4.9 issues an error when generating misc/check-installed-headers-c.out:

In file included from ../signal/signal.h:328:0,
                 from ../include/signal.h:2,
                 from ../misc/sys/param.h:28,
                 from ../include/sys/param.h:1,
                 from /tmp/cih_test_e156ZB.c:10:
../include/bits/sigstksz.h:5:7: error: "IS_IN" is not defined [-Werror=undef]
 #elif IS_IN (libsupport)
       ^

Use "#else" instead.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoregex.h: Avoid #elif __STDC_VERSION__
H.J. Lu [Thu, 12 Dec 2024 23:13:00 +0000 (07:13 +0800)] 
regex.h: Avoid #elif __STDC_VERSION__

GCC 4.9 doesn't define __STDC_VERSION__ and issues an error:

In file included from ../include/regex.h:2:0,
                 from ../posix/re_comp.h:23,
                 from ../include/re_comp.h:1,
                 from /tmp/cih_test_7IKTRI.c:10:
../posix/regex.h:650:19: error: "__STDC_VERSION__" is not defined [-Werror=undef]
 # elif 199901L <= __STDC_VERSION__ || defined restrict
                   ^

Use "#else" instead.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotst-assert-c++.cc: Return EXIT_UNSUPPORTED for GCC 4.9 or older
H.J. Lu [Thu, 12 Dec 2024 21:31:05 +0000 (05:31 +0800)] 
tst-assert-c++.cc: Return EXIT_UNSUPPORTED for GCC 4.9 or older

Since assert/tst-assert-c++.cc fails to compile with GCC 4.9:

./tst-assert-c++.cc: In function ‘constexpr int check_constexpr()’:
./tst-assert-c++.cc:30:1: error: body of constexpr function ‘constexpr int check_constexpr()’ not a return-statement
 }
 ^

return EXIT_UNSUPPORTED for GCC 4.9 or older.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoAdd braces in initializers for GCC 4.9 or older
H.J. Lu [Thu, 12 Dec 2024 21:38:57 +0000 (05:38 +0800)] 
Add braces in initializers for GCC 4.9 or older

Add braces to silence GCC 4.9 or older:

getaddrinfo.c: In function ‘gaih_inet’:
getaddrinfo.c:1135:24: error: missing braces around initializer [-Werror=missing-braces]
       / sizeof (struct gaih_typeproto)] = {0};
                        ^

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoReturn EXIT_UNSUPPORTED if __builtin_mul_overflow unavailable
H.J. Lu [Thu, 12 Dec 2024 21:59:59 +0000 (05:59 +0800)] 
Return EXIT_UNSUPPORTED if __builtin_mul_overflow unavailable

Since GCC 4.9 doesn't support __builtin_mul_overflow:

tst-fd_to_filename.c: In function ‘check_ranges’:
tst-fd_to_filename.c:51:3: error: implicit declaration of function ‘__builtin_mul_overflow’ [-Werror=implicit-function-declaration]
   while (!__builtin_mul_overflow (power, base, &power));
   ^
cc1: all warnings being treated as errors

return EXIT_UNSUPPORTED for GCC 4.9 or older.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotst-minsigstksz-1.c: Return EXIT_UNSUPPORTED for GCC 4.9 or older
H.J. Lu [Thu, 12 Dec 2024 22:28:45 +0000 (06:28 +0800)] 
tst-minsigstksz-1.c: Return EXIT_UNSUPPORTED for GCC 4.9 or older

Since ATOMIC_INT_LOCK_FREE in GCC 4.9 is defined as

 #define ATOMIC_INT_LOCK_FREE                    \
  __atomic_type_lock_free (atomic_int)

GCC 4.9 fails to compile tst-minsigstksz-1.c:

tst-minsigstksz-1.c:45:6: error: missing binary operator before token "("
 # if ATOMIC_INT_LOCK_FREE != 2
      ^

Change tst-minsigstksz-1.c to define TEST_ATOMIC_OPS to 0 for GCC 4.9 or
older.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agotester.c: Use -Wmemset-transposed-args for GCC 5 or newer
H.J. Lu [Thu, 12 Dec 2024 22:51:22 +0000 (06:51 +0800)] 
tester.c: Use -Wmemset-transposed-args for GCC 5 or newer

Since GCC 4.9 issues an error:

In file included from inl-tester.c:6:0:
tester.c:58:1: error: unknown option after ‘#pragma GCC diagnostic’ kind [-Werror=pragmas]
 DIAG_IGNORE_NEEDS_COMMENT (5.0, "-Wmemset-transposed-args");
 ^

use it for GCC 5 or newer.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoMakefile.in: Add test to check xcheck rule
H.J. Lu [Sat, 14 Dec 2024 00:43:29 +0000 (08:43 +0800)] 
Makefile.in: Add test to check xcheck rule

Add test to check xcheck rule so that TEST_CC and TEST_CXX are used for
"make test".

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoDon't use TEST_CXX as CXX for build
H.J. Lu [Sat, 14 Dec 2024 00:43:01 +0000 (08:43 +0800)] 
Don't use TEST_CXX as CXX for build

Since the C++ compiler is also used to compile links-dso-program.cc in
libsupport, use TEST_CXX to get C++ headers for testing, but don't use
TEST_CXX as CXX for build.

Tested for m68k-linux-gnu-coldfire build and native build on x86-64.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoAArch64: Update libm-test-ulps
Wilco Dijkstra [Fri, 13 Dec 2024 16:50:25 +0000 (16:50 +0000)] 
AArch64: Update libm-test-ulps

Update ulps for acospi, asinpi, atanpi, atan2pi.

7 months agos390: Simplify elf_machine_{load_address, dynamic} [BZ #31799]
Stefan Liebler [Fri, 6 Dec 2024 11:50:09 +0000 (12:50 +0100)] 
s390: Simplify elf_machine_{load_address, dynamic} [BZ #31799]

If an executable is static PIE and has a non-zero load address
(compare to elf/tst-pie-address-static), it segfaults as
elf_machine_load_address() returns 0x0 and elf_machine_dynamic()
returns the run-time instead of link-time address of _DYNAMIC.

Now rely on __ehdr_start and _DYNAMIC as also done on other
architectures.

Checked back to old arch-levels that this approach works fine:
- 31bit: -march=g5
- 64bit: -march=z900

Note, that there is no static-PIE support on 31bit, but this
approach cleans it also up.

Furthermore this cleanup in glibc does not change anything
regarding the first GOT-element as the s390 ABI
(https://github.com/IBM/s390x-abi) explicitely defines:
The doubleword at _GLOBAL_OFFSET_TABLE_[0] is set by the linkage
editor to hold the address of the dynamic structure, referenced
with the symbol _DYNAMIC. This allows a program, such as the dynamic
linker, to find its own dynamic structure without having yet processed
its relocation entries. This is especially important for the dynamic
linker, because it must initialize itself without relying on other
programs to relocate its memory image.

7 months agoor1k: Update libm-test-ulps
Stafford Horne [Thu, 12 Dec 2024 21:04:50 +0000 (21:04 +0000)] 
or1k: Update libm-test-ulps

Pick up new functions cospi, "Imaginary part of csin", exp10m1, exp2m1,
log10p1, log2p1, sinpi and tanpi.

7 months agonptl: Add <thread_pointer.h> for or1k
Michael Jeanson [Fri, 1 Nov 2024 19:23:24 +0000 (15:23 -0400)] 
nptl: Add <thread_pointer.h> for or1k

This will be required by the rseq extensible ABI implementation on all
Linux architectures exposing the '__rseq_size' and '__rseq_offset'
symbols to set the initial value of the 'cpu_id' field which can be used
by applications to test if rseq is available and registered. As long as
the symbols are exposed it is valid for an application to perform this
test even if rseq is not yet implemented in libc for this architecture.

Compile tested with build-many-glibcs.py but I don't have access to any
hardware to run the tests.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Signed-off-by: Stafford Horne <shorne@gmail.com>
7 months agoImplement C23 atan2pi
Joseph Myers [Thu, 12 Dec 2024 20:57:44 +0000 (20:57 +0000)] 
Implement C23 atan2pi

C23 adds various <math.h> function families originally defined in TS
18661-4.  Add the atan2pi functions (atan2(y,x)/pi).

Tested for x86_64 and x86, and with build-many-glibcs.py.

7 months agoClear CXX and TEST_CXX if C++ link test fails
H.J. Lu [Thu, 12 Dec 2024 11:13:52 +0000 (19:13 +0800)] 
Clear CXX and TEST_CXX if C++ link test fails

Since the C++ compiler is used only for testing, use TEST_CXX as the C++
compiler if available.  If C++ link test fails, clear both CXX and
TEST_CXX so that the C++ compiler isn't used for glibc build nor test.

Tested for m68k-linux-gnu-coldfire build and native build on x86-64.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agomath: Remove __XXX math functions from installed math.h [BZ #32418]
H.J. Lu [Thu, 5 Dec 2024 00:05:04 +0000 (08:05 +0800)] 
math: Remove __XXX math functions from installed math.h [BZ #32418]

Since libm doesn't export __XXX math functions, don't declare them in
the installed math.h by adding <bits/mathcalls-macros.h> to declare
__XXX math functions internally for glibc build.  This fixes BZ #32418.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agoOptimize bsearch() implementation for performance
Kuan-Wei Chiu [Mon, 9 Sep 2024 16:23:27 +0000 (00:23 +0800)] 
Optimize bsearch() implementation for performance

Optimize the bsearch() function to improve binary search performance.
Although the code size grew by 8 bytes, the new implementation achieves
a 15% reduction in execution time on my x86 machine, according to the
bench-bsearch benchmark results.

Signed-off-by: Kuan-Wei Chiu <visitorckw@gmail.com>
Reviewed-by: Noah Goldstein <goldstein.w.n@gmail.com>
Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agobenchtests: Add benchmark test for bsearch
Kuan-Wei Chiu [Mon, 9 Sep 2024 16:23:26 +0000 (00:23 +0800)] 
benchtests: Add benchmark test for bsearch

Introduce a benchmark test for the bsearch function to evaluate its
performance.

Signed-off-by: Kuan-Wei Chiu <visitorckw@gmail.com>
Reviewed-by: Noah Goldstein <goldstein.w.n@gmail.com>
Reviewed-by: DJ Delorie <dj@redhat.com>
7 months agoImplement C23 atanpi
Joseph Myers [Wed, 11 Dec 2024 21:51:49 +0000 (21:51 +0000)] 
Implement C23 atanpi

C23 adds various <math.h> function families originally defined in TS
18661-4.  Add the atanpi functions (atan(x)/pi).

Tested for x86_64 and x86, and with build-many-glibcs.py.

7 months agopowerpc64: Fix dl-trampoline.S big-endian / non-ROP build failure
Peter Bergner [Wed, 11 Dec 2024 20:15:13 +0000 (23:15 +0300)] 
powerpc64: Fix dl-trampoline.S big-endian / non-ROP build failure

Fix a big-endian / non-ROP build failure caused by commit 4d9a4c02 when
building dl-trampoline.S.

Reported-by: Joseph Myers <josmyers@redhat.com>
7 months agopowerpc: Use correct procedure call standard for getrandom vDSO call (bug 32440)
Florian Weimer [Tue, 10 Dec 2024 15:17:06 +0000 (16:17 +0100)] 
powerpc: Use correct procedure call standard for getrandom vDSO call (bug 32440)

A plain indirect function call does not work on POWER because
success and failure are signaled through a flag register, and
not via the usual Linux negative return value convention.

This has potential security impact, in two ways: the return value
could be out of bounds (EAGAIN is 11 on powerpc6le), and no
random bytes have been written despite the non-error return value.

Fixes commit 461cab1de747f3842f27a5d24977d78d561d45f9 ("linux: Add
support for getrandom vDSO").

Reported-by: Ján Stanček <jstancek@redhat.com>
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
7 months agoAdd TEST_CC and TEST_CXX support
H.J. Lu [Thu, 5 Dec 2024 20:44:05 +0000 (04:44 +0800)] 
Add TEST_CC and TEST_CXX support

Support testing glibc build with a different C compiler or a different
C++ compiler with

$ ../glibc-VERSION/configure TEST_CC="gcc-6.4.1" TEST_CXX="g++-6.4.1"

1. Add LIBC_TRY_CC_AND_TEST_CC_OPTION, LIBC_TRY_CC_AND_TEST_CC_COMMAND
and LIBC_TRY_CC_AND_TEST_LINK to test both CC and TEST_CC.
2. Add check and xcheck targets to Makefile.in and override build compiler
options with ones from TEST_CC and TEST_CXX.

Tested on Fedora 41/x86-64:

1. Building with GCC 14.2.1 and testing with GCC 6.4.1 and GCC 11.2.1.
2. Building with GCC 15 and testing with GCC 6.4.1.

Support for GCC versions older than GCC 6.2 may need to change the test
sources.  Other targets may need to update configure.ac under sysdeps and
modify Makefile.in to override target build compiler options.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
7 months agopowerpc64le: ROP changes for the dl-trampoline functions
Peter Bergner [Tue, 10 Dec 2024 03:41:08 +0000 (22:41 -0500)] 
powerpc64le: ROP changes for the dl-trampoline functions

Add ROP protection for the _dl_runtime_resolve and _dl_profile_resolve
functions.

7 months agomalloc: Add tcache path for calloc
Wangyang Guo [Wed, 4 Dec 2024 11:16:22 +0000 (19:16 +0800)] 
malloc: Add tcache path for calloc

This commit add tcache support in calloc() which can largely improve
the performance of small size allocation, especially in multi-thread
scenario. tcache_available() and tcache_try_malloc() are split out as
a helper function for better reusing the code.

Also fix tst-safe-linking failure after enabling tcache. In previous,
calloc() is used as a way to by-pass tcache in memory allocation and
trigger safe-linking check in fastbins path. With tcache enabled, it
needs extra workarounds to bypass tcache.

Result of bench-calloc-thread benchmark

Test Platform: Xeon-8380
Ratio: New / Original time_per_iteration (Lower is Better)

Threads#   | Ratio
-----------|------
1 thread   | 0.656
4 threads  | 0.470
Reviewed-by: H.J. Lu <hjl.tools@gmail.com>
7 months agoImplement C23 asinpi
Joseph Myers [Tue, 10 Dec 2024 20:42:20 +0000 (20:42 +0000)] 
Implement C23 asinpi

C23 adds various <math.h> function families originally defined in TS
18661-4.  Add the asinpi functions (asin(x)/pi).

Tested for x86_64 and x86, and with build-many-glibcs.py.

7 months agomalloc: add indirection for malloc(-like) functions in tests [BZ #32366]
Sam James [Mon, 9 Dec 2024 23:11:25 +0000 (23:11 +0000)] 
malloc: add indirection for malloc(-like) functions in tests [BZ #32366]

GCC 15 introduces allocation dead code removal (DCE) for PR117370 in
r15-5255-g7828dc070510f8. This breaks various glibc tests which want
to assert various properties of the allocator without doing anything
obviously useful with the allocated memory.

Alexander Monakov rightly pointed out that we can and should do better
than passing -fno-malloc-dce to paper over the problem. Not least because
GCC 14 already does such DCE where there's no testing of malloc's return
value against NULL, and LLVM has such optimisations too.

Handle this by providing malloc (and friends) wrappers with a volatile
function pointer to obscure that we're calling malloc (et. al) from the
compiler.

Reviewed-by: Paul Eggert <eggert@cs.ucla.edu>
7 months agoImplement C23 acospi
Joseph Myers [Mon, 9 Dec 2024 23:01:29 +0000 (23:01 +0000)] 
Implement C23 acospi

C23 adds various <math.h> function families originally defined in TS
18661-4.  Add the acospi functions (acos(x)/pi).

Tested for x86_64 and x86, and with build-many-glibcs.py.

7 months agopowerpc64le: ROP changes for the *context and setjmp functions
Sachin Monga [Mon, 9 Dec 2024 21:47:40 +0000 (16:47 -0500)] 
powerpc64le: ROP changes for the *context and setjmp functions

Add ROP protection for the getcontext, setcontext, makecontext, swapcontext
and __sigsetjmp_symbol functions.

Reviewed-by: Peter Bergner <bergner@linux.ibm.com>
7 months agonptl: Add <thread_pointer.h> for m68k
Michael Jeanson [Mon, 9 Dec 2024 20:24:26 +0000 (20:24 +0000)] 
nptl: Add <thread_pointer.h> for m68k

This will be required by the rseq extensible ABI implementation on all
Linux architectures exposing the '__rseq_size' and '__rseq_offset'
symbols to set the initial value of the 'cpu_id' field which can be used
by applications to test if rseq is available and registered. As long as
the symbols are exposed it is valid for an application to perform this
test even if rseq is not yet implemented in libc for this architecture.

Compile tested with build-many-glibcs.py but I don't have access to any
hardware to run the tests.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Arjun Shankar <arjun@redhat.com>
7 months agonptl: Add <thread_pointer.h> for RISC-V
Michael Jeanson [Wed, 31 Jul 2024 15:20:36 +0000 (11:20 -0400)] 
nptl: Add <thread_pointer.h> for RISC-V

This will be required by the rseq extensible ABI implementation on all
Linux architectures exposing the '__rseq_size' and '__rseq_offset'
symbols to set the initial value of the 'cpu_id' field which can be used
by applications to test if rseq is available and registered. As long as
the symbols are exposed it is valid for an application to perform this
test even if rseq is not yet implemented in libc for this architecture.

Both code paths tested on a Visionfive 2 with Debian sid.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Palmer Dabbelt <palmer@rivosinc.com>
Acked-by: Palmer Dabbelt <palmer@rivosinc.com>
7 months agonptl: add RSEQ_SIG for RISC-V
Michael Jeanson [Wed, 31 Jul 2024 17:18:18 +0000 (13:18 -0400)] 
nptl: add RSEQ_SIG for RISC-V

Enable RSEQ for RISC-V, support was added in Linux 5.18.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Palmer Dabbelt <palmer@rivosinc.com>
Acked-by: Palmer Dabbelt <palmer@rivosinc.com>
7 months agoAArch64: Improve codegen in users of ADVSIMD expm1 helper
Pierre Blanchard [Mon, 9 Dec 2024 15:58:47 +0000 (15:58 +0000)] 
AArch64: Improve codegen in users of ADVSIMD expm1 helper

Add inline helper for expm1 and rearrange operations so MOV
is not necessary in reduction or around the special-case handler.
Reduce memory access by using more indexed MLAs in polynomial.
Speedup on Neoverse V1 for expm1 (19%), sinh (8.5%), and tanh (7.5%).

7 months agoAArch64: Improve codegen in users of ADVSIMD log1p helper
Pierre Blanchard [Mon, 9 Dec 2024 15:55:39 +0000 (15:55 +0000)] 
AArch64: Improve codegen in users of ADVSIMD log1p helper

Add inline helper for log1p and rearrange operations so MOV
is not necessary in reduction or around the special-case handler.
Reduce memory access by using more indexed MLAs in polynomial.
Speedup on Neoverse V1 for log1p (3.5%), acosh (7.5%) and atanh (10%).

7 months agoAArch64: Improve codegen in AdvSIMD logs
Pierre Blanchard [Mon, 9 Dec 2024 15:54:34 +0000 (15:54 +0000)] 
AArch64: Improve codegen in AdvSIMD logs

Remove spurious ADRP and a few MOVs.
Reduce memory access by using more indexed MLAs in polynomial.
Align notation so that algorithms are easier to compare.
Speedup on Neoverse V1 for log10 (8%), log (8.5%), and log2 (10%).
Update error threshold in AdvSIMD log (now matches SVE log).

7 months agoAArch64: Improve codegen in AdvSIMD pow
Pierre Blanchard [Mon, 9 Dec 2024 15:53:04 +0000 (15:53 +0000)] 
AArch64: Improve codegen in AdvSIMD pow

Remove spurious ADRP. Improve memory access by shuffling constants and
using more indexed MLAs.

A few more optimisation with no impact on accuracy
- force fmas contraction
- switch from shift-aided rint to rint instruction

Between 1 and 5% throughput improvement on Neoverse
V1 depending on benchmark.

7 months agos390x: Regenerated ULPs.
Stefan Liebler [Mon, 9 Dec 2024 09:25:24 +0000 (10:25 +0100)] 
s390x: Regenerated ULPs.

Needed after:
"Implement C23 cospi"
commit 0ae0af68d8fa3bf6cbe1e4f1de5929ff71de67b3
and
"Implement C23 sinpi"
commit 776938e8b8dcf2b59998979e91cc0f9db7d771a8
and
"Implement C23 tanpi"

7 months agohtl: move pthread_condattr_setpshared into libc.
gfleury [Tue, 26 Nov 2024 20:53:29 +0000 (22:53 +0200)] 
htl: move pthread_condattr_setpshared into libc.

Signed-off-by: gfleury <gfleury@disroot.org>
Message-ID: <20241126205329.2215295-8-gfleury@disroot.org>

7 months agohtl: move pthread_condattr_setclock into libc.
gfleury [Tue, 26 Nov 2024 20:53:28 +0000 (22:53 +0200)] 
htl: move pthread_condattr_setclock into libc.

Signed-off-by: gfleury <gfleury@disroot.org>
Message-ID: <20241126205329.2215295-7-gfleury@disroot.org>

7 months agohtl: move pthread_condattr_init into libc.
gfleury [Tue, 26 Nov 2024 20:53:27 +0000 (22:53 +0200)] 
htl: move pthread_condattr_init into libc.

Signed-off-by: gfleury <gfleury@disroot.org>
Message-ID: <20241126205329.2215295-6-gfleury@disroot.org>

7 months agohtl: move pthread_condattr_getpshared into libc.
gfleury [Tue, 26 Nov 2024 20:53:26 +0000 (22:53 +0200)] 
htl: move pthread_condattr_getpshared into libc.

Signed-off-by: gfleury <gfleury@disroot.org>
Message-ID: <20241126205329.2215295-5-gfleury@disroot.org>