]> git.ipfire.org Git - thirdparty/glibc.git/log
thirdparty/glibc.git
22 hours agohtl: move __pthread_startup into libc. master
gfleury [Fri, 15 Aug 2025 18:15:00 +0000 (20:15 +0200)] 
htl: move __pthread_startup into libc.

Message-ID: <20250815181500.107433-20-gfleury@disroot.org>

22 hours agohtl: move __pthread_setup into libc.
gfleury [Fri, 15 Aug 2025 18:14:59 +0000 (20:14 +0200)] 
htl: move __pthread_setup into libc.

Message-ID: <20250815181500.107433-19-gfleury@disroot.org>

22 hours agohtl: move pthread_{join, clockjoin_np, timedjoin_np, tryjoin_np} into libc.
gfleury [Fri, 15 Aug 2025 18:14:58 +0000 (20:14 +0200)] 
htl: move pthread_{join, clockjoin_np, timedjoin_np, tryjoin_np} into libc.

Message-ID: <20250815181500.107433-18-gfleury@disroot.org>

22 hours agohtl: move pthread_exit into libc.
gfleury [Fri, 15 Aug 2025 18:14:57 +0000 (20:14 +0200)] 
htl: move pthread_exit into libc.

Message-ID: <20250815181500.107433-17-gfleury@disroot.org>

22 hours agohtl: move pthread_detach into libc.
gfleury [Fri, 15 Aug 2025 18:14:56 +0000 (20:14 +0200)] 
htl: move pthread_detach into libc.

Message-ID: <20250815181500.107433-16-gfleury@disroot.org>

22 hours agohtl: move __pthread_sigstate_init into libc.
gfleury [Fri, 15 Aug 2025 18:14:55 +0000 (20:14 +0200)] 
htl: move __pthread_sigstate_init into libc.

Message-ID: <20250815181500.107433-15-gfleury@disroot.org>

22 hours agohtl: move pthread_mutex_transfer_np into libc.
gfleury [Fri, 15 Aug 2025 18:14:54 +0000 (20:14 +0200)] 
htl: move pthread_mutex_transfer_np into libc.

Message-ID: <20250815181500.107433-14-gfleury@disroot.org>

22 hours agohtl: move pthread_getattr_np into libc.
gfleury [Fri, 15 Aug 2025 18:14:53 +0000 (20:14 +0200)] 
htl: move pthread_getattr_np into libc.

Message-ID: <20250815181500.107433-13-gfleury@disroot.org>

22 hours agohtl: move pthread_testcancel into libc.
gfleury [Fri, 15 Aug 2025 18:14:52 +0000 (20:14 +0200)] 
htl: move pthread_testcancel into libc.

Message-ID: <20250815181500.107433-12-gfleury@disroot.org>

22 hours agohtl: move pthread_kill into libc.
gfleury [Fri, 15 Aug 2025 18:14:51 +0000 (20:14 +0200)] 
htl: move pthread_kill into libc.

Message-ID: <20250815181500.107433-11-gfleury@disroot.org>

22 hours agohtl: move pthread_cancel, __pthread_do_cancel into libc.
gfleury [Fri, 15 Aug 2025 18:14:50 +0000 (20:14 +0200)] 
htl: move pthread_cancel, __pthread_do_cancel into libc.

Message-ID: <20250815181500.107433-10-gfleury@disroot.org>

22 hours agohtl: move __thread_set_pcsptp into libc.
gfleury [Fri, 15 Aug 2025 18:14:49 +0000 (20:14 +0200)] 
htl: move __thread_set_pcsptp into libc.

Message-ID: <20250815181500.107433-9-gfleury@disroot.org>

22 hours agohtl: move pthread_yield into libc.
gfleury [Fri, 15 Aug 2025 18:14:48 +0000 (20:14 +0200)] 
htl: move pthread_yield into libc.

Message-ID: <20250815181500.107433-8-gfleury@disroot.org>

22 hours agohtl: move pthread_getcpuclockid into libc.
gfleury [Fri, 15 Aug 2025 18:14:47 +0000 (20:14 +0200)] 
htl: move pthread_getcpuclockid into libc.

Message-ID: <20250815181500.107433-7-gfleury@disroot.org>

22 hours agohtl: move __pthread_thread_{alloc, start, terminate} into libc.
gfleury [Fri, 15 Aug 2025 18:14:46 +0000 (20:14 +0200)] 
htl: move __pthread_thread_{alloc, start, terminate} into libc.

Message-ID: <20250815181500.107433-6-gfleury@disroot.org>

23 hours agohtl: move __pthread_stack_alloc into libc.
gfleury [Fri, 15 Aug 2025 18:14:45 +0000 (20:14 +0200)] 
htl: move __pthread_stack_alloc into libc.

Message-ID: <20250815181500.107433-5-gfleury@disroot.org>

23 hours agohtl: move __pthread_init_{specific, static_tls}, __pthread_{alloc}, dealloc} into...
gfleury [Fri, 15 Aug 2025 18:14:44 +0000 (20:14 +0200)] 
htl: move __pthread_init_{specific, static_tls}, __pthread_{alloc}, dealloc} into libc.

Message-ID: <20250815181500.107433-4-gfleury@disroot.org>

23 hours agohtl: move pthread_get/setconcurrency into libc.
gfleury [Fri, 15 Aug 2025 18:14:43 +0000 (20:14 +0200)] 
htl: move pthread_get/setconcurrency into libc.

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

23 hours agohtl: move pthread_setschedprio into libc.
gfleury [Fri, 15 Aug 2025 18:14:42 +0000 (20:14 +0200)] 
htl: move pthread_setschedprio into libc.

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

2 days agox86-64: Add GLIBC_ABI_DT_X86_64_PLT [BZ #33212]
H.J. Lu [Thu, 14 Aug 2025 14:03:20 +0000 (07:03 -0700)] 
x86-64: Add GLIBC_ABI_DT_X86_64_PLT [BZ #33212]

When the linker -z mark-plt option is used to add DT_X86_64_PLT,
DT_X86_64_PLTSZ and DT_X86_64_PLTENT, the r_addend field of the
R_X86_64_JUMP_SLOT relocation stores the offset of the indirect
branch instruction.  However, glibc versions without the commit:

commit f8587a61892cbafd98ce599131bf4f103466f084
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Fri May 20 19:21:48 2022 -0700

    x86-64: Ignore r_addend for R_X86_64_GLOB_DAT/R_X86_64_JUMP_SLOT

    According to x86-64 psABI, r_addend should be ignored for R_X86_64_GLOB_DAT
    and R_X86_64_JUMP_SLOT.  Since linkers always set their r_addends to 0, we
    can ignore their r_addends.

Reviewed-by: Fangrui Song <maskray@google.com>
won't ignore the r_addend value in the R_X86_64_JUMP_SLOT relocation.
Such programs and shared libraries will fail at run-time randomly.

Add GLIBC_ABI_DT_X86_64_PLT version to indicate that glibc is compatible
with DT_X86_64_PLT.

The linker can add the glibc GLIBC_ABI_DT_X86_64_PLT version dependency
whenever -z mark-plt is passed to the linker.  The resulting programs and
shared libraries will fail to load at run-time against libc.so without the
GLIBC_ABI_DT_X86_64_PLT version, instead of fail randomly.

This fixes BZ #33212.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
2 days agoi386: Add GLIBC_ABI_GNU_TLS version [BZ #33221]
H.J. Lu [Mon, 28 Jul 2025 19:16:11 +0000 (12:16 -0700)] 
i386: Add GLIBC_ABI_GNU_TLS version [BZ #33221]

On i386, programs and shared libraries with __thread usage may fail
silently at run-time against glibc without the TLS run-time fix for:

https://sourceware.org/bugzilla/show_bug.cgi?id=32996

Add GLIBC_ABI_GNU_TLS version to indicate that glibc has the working
GNU TLS run-time.  Linker can add the GLIBC_ABI_GNU_TLS version to
binaries which depend on the working TLS run-time so that such programs
and shared libraries will fail to load and run at run-time against
libc.so without the GLIBC_ABI_GNU_TLS version, instead of fail silently
at random.

This fixes BZ #33221.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
2 days agox86-64: Add GLIBC_ABI_GNU2_TLS version [BZ #33129]
H.J. Lu [Mon, 28 Jul 2025 19:18:22 +0000 (12:18 -0700)] 
x86-64: Add GLIBC_ABI_GNU2_TLS version [BZ #33129]

Programs and shared libraries compiled with -mtls-dialect=gnu2 may fail
silently at run-time against glibc without the GNU2 TLS run-time fix
for:

https://sourceware.org/bugzilla/show_bug.cgi?id=31372

Add GLIBC_ABI_GNU2_TLS version to indicate that glibc has the working
GNU2 TLS run-time.  Linker can add the GLIBC_ABI_GNU2_TLS version to
binaries which depend on the working GNU2 TLS run-time:

https://sourceware.org/bugzilla/show_bug.cgi?id=33130

so that such programs and shared libraries will fail to load and run at
run-time against libc.so without the GLIBC_ABI_GNU2_TLS version, instead
of fail silently at random.

This fixes BZ #33129.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
3 days agoLoongArch: Fix build failure for loongarch64-linux-gnusf toolchain. [BZ #32776]
caiyinyu [Wed, 13 Aug 2025 07:08:09 +0000 (15:08 +0800)] 
LoongArch: Fix build failure for loongarch64-linux-gnusf toolchain. [BZ #32776]

GCC parts:

A GCC bug caused the loss of the search path: /usr/lib64/sf, and this
bug has now been fixed in GCC.

See:
https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=9467435253948b83fcb5f7430f6cd571236960d8

4 days agobenchtests: Avoid truncation in random memcpy/memset benchmarks
Wilco Dijkstra [Tue, 12 Aug 2025 11:14:24 +0000 (11:14 +0000)] 
benchtests: Avoid truncation in random memcpy/memset benchmarks

Use uint16_t rather than uint8_t for the size arrays.

Reviewed-by: Carlos O'Donell <carlos@redhat.com>
5 days agostdio-common: Fix macro parameter shadowing in scanf input specifier tests
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Fix macro parameter shadowing in scanf input specifier tests

The use of the same name for a local variable combined with passing a
pointer to it to a nested macro call causes the wrong 'err' variable to
be updated in 'read_real', because '&err' is only expanded at '*errp'
evaluation.  Consequently the variable defined in 'read_real' is set
rather than one in its 'verify_input' caller as it would be the case
should 'read_real' be a function, leading to invalid input such as:

%a:nan:1:3:nan(:

to be accepted.

Address the issue by renaming the 'err' variable in 'verify_input' to
'errx', causing such input to be correctly rejected:

error: ./tst-scanf-format-skeleton.c:242: input line 1: input data format error

No test case added as it's a test case issue in the first place.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
5 days agostdio-common: Add 'f' conversion tests for . scanf input [BZ #12701]
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Add 'f' conversion tests for . scanf input [BZ #12701]

Verify that . input is rejected by 'f' conversion (and its uppercase
counterpart).  Replace 0 input with .0 rather than adding new one,
because the integral part of 0 is already covered by 0.0 data, so
there's no need to keep this duplication.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
5 days agostdio-common: Add 'e' conversion tests for . scanf input [BZ #12701]
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Add 'e' conversion tests for . scanf input [BZ #12701]

Verify that . input is rejected by 'e' conversion (and its uppercase
counterpart).  Replace 0e0 input with .0e0 rather than adding new one,
because 0 significand is already covered by 0e+0 data, so there's no
need to keep this duplication.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
5 days agostdio-common: Add 'a', 'g' conversion tests for 0x. scanf input [BZ #12701]
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Add 'a', 'g' conversion tests for 0x. scanf input [BZ #12701]

Verify that 0x. input is rejected by 'a' and 'g' conversions (and their
uppercase counterparts).  Replace 0x0p0 input with 0x.0p0 rather than
adding new one, because 0x0 significand is already covered by 0x0p+0
data, so there's no need to keep this duplication.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
5 days agostdio-common: Reject significands w/o digits in scanf [BZ #12701]
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Reject significands w/o digits in scanf [BZ #12701]

Reject invalid formatted scanf real input data the significand part of
which is comprised of a hexadecimal prefix followed by a decimal point
only, optionally preceded by a sign.  Such data is a prefix of, but not
a matching input sequence and it is required by ISO C to cause a
matching failure.

Currently a matching success is instead incorrectly produced along with
the conversion result of zero, with data up to and including the decimal
point consumed from input.

Technically this change also causes lone . to be rejected early, though
it doesn't change semantics, because unlike 0x. it's not valid input to
'strtod', etc. so it gets rejected at actual conversion time later on
anyway.

Test cases follow as separate changes.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
5 days agostdio-common: Don't read real input beyond the field width in scanf
Maciej W. Rozycki [Mon, 11 Aug 2025 16:42:12 +0000 (17:42 +0100)] 
stdio-common: Don't read real input beyond the field width in scanf

Fix a code pattern that repeats across '__vfscanf_internal' where the
remaining field width of 0 is incorrectly interpreted as no width limit,
which in turn results in reading input beyond the limit requested.  The
lack of width limit is indicated by the field width of -1 rather than 0,
set earlier on in the function.

The problematic code pattern is used for both integer and floating-point
conversions, but in the former case a corresponding conditional earlier
on prevents the field width from being 0 when executing the pattern.  It
does trigger in the latter case, where the decimal point is a multibyte
character or for multibyte digit characters.

Fix the code pattern by using 'width > 0' comparison, and apply the fix
throughout even to code handling integer conversions so as to interpret
the field width consistently and avoid people's confusion even if width
cannot be 0 at those places.

For multibyte digit characters there is an additional issue that causes
code to push back a partially fetched multibyte character multiple times
as execution proceeds through matching data retrieved against individual
digits that have to be rejected due to the field width limit preventing
the rest of the multibyte character from being retrieved.  It is because
code relies on 'ungetc' ignoring a request to push back EOF, however in
the out-of-limit field width condition the data held is not EOF but the
previously retrieved character byte instead.

Fix this issue by artificially assigning EOF to the character byte
storage variable where the out-of-limit field width condition prevents
further processing, and also apply the fix throughout except for the
decimal point/thousands separator case, which uses different code.

Add test cases accordingly.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
6 days agomalloc: Fix checking for small negative values of tcache_key
Samuel Thibault [Sun, 10 Aug 2025 21:43:37 +0000 (23:43 +0200)] 
malloc: Fix checking for small negative values of tcache_key

tcache_key is unsigned so we should turn it explicitly to signed before
taking its absolute value.

6 days agomalloc: Make sure tcache_key is odd enough
Samuel Thibault [Tue, 29 Jul 2025 23:55:22 +0000 (01:55 +0200)] 
malloc: Make sure tcache_key is odd enough

We want tcache_key not to be a commonly-occurring value in memory, so ensure
a minimum amount of one and zero bits.

And we need it non-zero, otherwise even if tcache_double_free_verify sets
e->key to 0 before calling __libc_free, it gets called again by __libc_free,
thus looping indefinitely.

Fixes: c968fe50628db74b52124d863cd828225a1d305c ("malloc: Use tailcalls in __libc_free")
8 days agolocaledata: Add en_SE for ISO8601 dates
Andreas Schneider [Mon, 21 Jul 2025 08:00:27 +0000 (10:00 +0200)] 
localedata: Add en_SE for ISO8601 dates

On a Linux system you have two sources for locales: glibc and ICU.

ICU offeres a lot more languages than glibc. Especially when it comes to
en_*.

If you have an English system and want to use ISO8601 for date and time
format there is only one locale which can be used for that: en_SE

However ICU offers en_SE and glibc doesn't. If you set LC_TIME=en_SE a
lot of application wont start, because the locale is not known to glibc.

https://sourceware.org/bugzilla/show_bug.cgi?id=33190

Signed-off-by: Andreas Schneider <asn@cryptomilk.org>
Reviewed-by: Mike FABIAN <mfabian@redhat.com>
8 days agomalloc: Fix MALLOC_DEBUG
Wilco Dijkstra [Fri, 8 Aug 2025 14:00:43 +0000 (14:00 +0000)] 
malloc: Fix MALLOC_DEBUG

MALLOC_DEBUG only works on locked arenas, so move the call to
check_inuse_chunk from __libc_free() to _int_free_chunk().
Regress now passes if MALLOC_DEBUG is enabled.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
8 days agomalloc: Support THP in arenas
Wilco Dijkstra [Fri, 8 Aug 2025 14:00:11 +0000 (14:00 +0000)] 
malloc: Support THP in arenas

Arenas support huge pages but not transparent huge pages.  Add this by
also checking mp_.thp_pagesize when creating a new arena, and use madvise.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
8 days agomalloc: Remove use of __curbrk
Wilco Dijkstra [Fri, 8 Aug 2025 13:59:31 +0000 (13:59 +0000)] 
malloc: Remove use of __curbrk

Remove an odd use of __curbrk and use MORECORE (0) instead.
This fixes Hurd build since it doesn't define this symbol.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
9 days agoFilter machine compiler flags into Assembler Flags
Sachin Monga [Fri, 1 Aug 2025 09:35:11 +0000 (04:35 -0500)] 
Filter machine compiler flags into Assembler Flags

Assembler files may want or need to test for predefined macros which are
set via -m* compiler options, so ensure all -m* options in CFLAGS are passed
to ASFLAGS.

Reviewed-by: Florian Weimer <fweimer@redhat.com>
10 days agotst-freopen4: Remove temporary directory from warning message
H.J. Lu [Tue, 5 Aug 2025 23:17:42 +0000 (16:17 -0700)] 
tst-freopen4: Remove temporary directory from warning message

tst-freopen4-main.c issues a warning message:

warning: could not remove temporary file: /tmp/tst-freopen4potgti: No such file or directory

since chroot makes generated temporary directories inaccessible.  Add
special rules for tst-freopen4.out and tst-freopen64-4.out to remove
the temporary directory in warning message from tst-freopen4 and
tst-freopen64-4.

This partially fixes BZ #33182.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
11 days agoRevert "tst-freopen4-main.c: Call support_capture_subprocess with chroot"
H.J. Lu [Tue, 5 Aug 2025 16:16:14 +0000 (09:16 -0700)] 
Revert "tst-freopen4-main.c: Call support_capture_subprocess with chroot"

Revert commit 6463d4a7b28e5ee3891c34a8a1f0a59c24dfa9de to fix

FAIL: stdio-common/tst-freopen4-mem
FAIL: stdio-common/tst-freopen64-4-mem

This fixes BZ #33254.

Reviewed-by: Sam James <sam@gentoo.org>
11 days agoiconv: Fix iconv functions not following symlinks [BZ #32339]
Avinal Kumar [Mon, 14 Jul 2025 16:04:27 +0000 (21:34 +0530)] 
iconv: Fix iconv functions not following symlinks [BZ #32339]

On some file systems iconv do not follow symlinks.  This happens because
read_conf_file() function's directory traversal loop reject symbolic
links and then lstat64() call do not follow symlinks.

This commit fixes the directory traversal loop to accept symbolic links
and then follow the link using stat64().

The test works by creating a temporary directory and placing a symbolic
link inside it that points to a configuration file.  It then runs
iconvconfig on this directory.

The test passes if iconvconfig successfully follows the symlink and
generates the cache correctly, confirming that the directory traversal
logic now properly handles symbolic links.

Signed-off-by: Avinal Kumar <avinal.xlvii@gmail.com>
Co-authored-by: Adhemerval Zanella Netto <adhemerval.zanella@linaro.org>
Reviewed-by: Adhemerval Zanella Netto <adhemerval.zanella@linaro.org>
11 days agoLinux: Add test case for bug 33245
Florian Weimer [Sat, 2 Aug 2025 10:44:51 +0000 (12:44 +0200)] 
Linux: Add test case for bug 33245

The copy_file_range system call seems to be the only one that can
return an off64_t value.  Use FUSE to exercise this, without actually
creating such large files or copying any data.  Due to FUSE protocol
limitations, only sizes up to UINT_MAX can be tested, but this is
sufficient to check for the presence of bug 33245.

The FUSE protocol limitations are raised here:

  copy_file_range return value on FUSE
  <https://lore.kernel.org/all/lhuh5ynl8z5.fsf@oldenburg.str.redhat.com/>

Reviewed-by: Sam James <sam@gentoo.org>
Reviewed-by: Collin Funk <collin.funk1@gmail.com>
11 days agoUse TLS initial-exec model for __libc_tsd_CTYPE_* thread variables [BZ #33234]
Jens Remus [Fri, 25 Jul 2025 13:40:03 +0000 (15:40 +0200)] 
Use TLS initial-exec model for __libc_tsd_CTYPE_* thread variables [BZ #33234]

Commit 10a66a8e421b ("Remove <libc-tsd.h>") removed the TLS initial-exec
(IE) model attribute from the __libc_tsd_CTYPE_* thread variable declarations
and definitions.  Commit a894f04d8776 ("Optimize __libc_tsd_* thread
variable access") restored it on declarations.

Restore the TLS initial-exec model attribute on __libc_tsd_CTYPE_* thread
variable definitions.

This resolves test tst-locale1 failure on s390 32-bit, when using a
GNU linker without the fix from GNU binutils commit aefebe82dc89
("IBM zSystems: Fix offset relative to static TLS").

Reviewed-by: Florian Weimer <fweimer@redhat.com>
11 days agoiconv: use bswap_32 instead of __builtin_bswap32
Collin Funk [Tue, 5 Aug 2025 08:07:18 +0000 (10:07 +0200)] 
iconv: use bswap_32 instead of __builtin_bswap32

This file uses a mix of both functions, prefer the non-builtin version.

Reviewed-by: Florian Weimer <fweimer@redhat.com>
12 days agotst-env-setuid: Delete LD_DEBUG_OUTPUT output
H.J. Lu [Sat, 19 Jul 2025 14:43:29 +0000 (07:43 -0700)] 
tst-env-setuid: Delete LD_DEBUG_OUTPUT output

Update tst-env-setuid.c to delete LD_DEBUG_OUTPUT output, instead of
leaving it behind.

This partially fixes BZ #33182.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agotst-freopen4-main.c: Call support_capture_subprocess with chroot
H.J. Lu [Sat, 19 Jul 2025 14:43:28 +0000 (07:43 -0700)] 
tst-freopen4-main.c: Call support_capture_subprocess with chroot

Update tst-freopen4-main.c to call support_capture_subprocess with chroot,
which makes temporary files inaccessible, so that temporary files can be
deleted.

This partially fixes BZ #33182.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agotst-fopen-threaded.c: Delete temporary file
H.J. Lu [Sat, 19 Jul 2025 14:43:27 +0000 (07:43 -0700)] 
tst-fopen-threaded.c: Delete temporary file

Update tst-fopen-threaded.c to call support_create_temp_directory to
create a temporary directory and open "file" in the temporary directory,
instead of using /tmp/openclosetest and leaving it behind.

This partially fixes BZ #33182.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agoDelete temporary files in support_subprocess
H.J. Lu [Sat, 19 Jul 2025 14:43:26 +0000 (07:43 -0700)] 
Delete temporary files in support_subprocess

Call support_delete_temp_files to delete temporary files before exit in
support_subprocess.

This partially fixes BZ #33182.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agoRevert "Remove use of __curbrk."
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:56 +0000 (17:31 +0000)] 
Revert "Remove use of __curbrk."

This reverts commit 1ee0b771a9c0cd2b882fe7acd38deddb7d4fbef2.

12 days agoRevert "Improve MALLOC_DEBUG"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:54 +0000 (17:31 +0000)] 
Revert "Improve MALLOC_DEBUG"

This reverts commit 4b3e65682d1895a651653d82f05c66ead8dfcf3b.

12 days agoRevert "Enable THP on arenas"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:52 +0000 (17:31 +0000)] 
Revert "Enable THP on arenas"

This reverts commit 77d3e739360ebb49bae6ecfd4181e4e1692f6362.

12 days agoRevert "benchtests: Avoid overflow in random memcpy/memset benchmarks"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:51 +0000 (17:31 +0000)] 
Revert "benchtests: Avoid overflow in random memcpy/memset benchmarks"

This reverts commit 09604542d31abf1e35cd00c1db8d9bee9568bdd0.

12 days agoRevert "Use _int_free_chunk in tcache_thread_shutdown"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:49 +0000 (17:31 +0000)] 
Revert "Use _int_free_chunk in tcache_thread_shutdown"

This reverts commit 05ef6a49746faedb4262db1476449c1c2c822e95.

12 days agoRevert "Remove dumped heap support"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:47 +0000 (17:31 +0000)] 
Revert "Remove dumped heap support"

This reverts commit 8f57caa7fdcb7ab3016897a056ccf386061e7734.

12 days agoRevert "malloc: Cleanup libc_realloc"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:45 +0000 (17:31 +0000)] 
Revert "malloc: Cleanup libc_realloc"

This reverts commit dea1e52af38c20eae37ec09727f17ab8fde87f55.

12 days agoRevert "Change mmap representation"
Wilco Dijkstra [Mon, 4 Aug 2025 17:31:40 +0000 (17:31 +0000)] 
Revert "Change mmap representation"

This reverts commit 4b74591022e88639dcaefb8c4a2e405d301a59e2.

12 days agoRemove use of __curbrk.
Wilco Dijkstra [Mon, 4 Aug 2025 12:45:56 +0000 (12:45 +0000)] 
Remove use of __curbrk.

12 days agoImprove MALLOC_DEBUG
Wilco Dijkstra [Sat, 2 Aug 2025 17:18:57 +0000 (17:18 +0000)] 
Improve MALLOC_DEBUG

12 days agoEnable THP on arenas
Wilco Dijkstra [Wed, 30 Jul 2025 15:04:35 +0000 (15:04 +0000)] 
Enable THP on arenas

12 days agobenchtests: Avoid overflow in random memcpy/memset benchmarks
Wilco Dijkstra [Tue, 20 May 2025 15:56:14 +0000 (15:56 +0000)] 
benchtests: Avoid overflow in random memcpy/memset benchmarks

Use uint16_t rather than uint8_t for the size arrays.

12 days agoUse _int_free_chunk in tcache_thread_shutdown
Wilco Dijkstra [Thu, 3 Apr 2025 14:24:22 +0000 (14:24 +0000)] 
Use _int_free_chunk in tcache_thread_shutdown

12 days agoRemove dumped heap support
Wilco Dijkstra [Fri, 25 Jul 2025 12:16:40 +0000 (12:16 +0000)] 
Remove dumped heap support

12 days agomalloc: Cleanup libc_realloc
Wilco Dijkstra [Wed, 28 May 2025 15:17:43 +0000 (15:17 +0000)] 
malloc: Cleanup libc_realloc

Minor cleanup of libc_realloc: remove unnecessary special cases for mmap, move
ar_ptr initialization, first check for oldmem == NULL.

12 days agoChange mmap representation
Wilco Dijkstra [Thu, 10 Jul 2025 15:59:37 +0000 (15:59 +0000)] 
Change mmap representation

12 days agomanual: Adjust documentation to standardization of select
Collin Funk [Sat, 26 Jul 2025 04:15:12 +0000 (21:15 -0700)] 
manual: Adjust documentation to standardization of select

The select function, fd_set, and FD_* macros were standardized by POSIX
in the sys/select.h header. They are still defined in sys/types.h if
__USE_MISC is defined, but we should recommend the more portable and
standardized sys/select.h.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agomanual: Use sys/select.h instead of sys/time.h for select example.
Collin Funk [Fri, 25 Jul 2025 00:44:10 +0000 (17:44 -0700)] 
manual: Use sys/select.h instead of sys/time.h for select example.

The original example works on glibc since sys/time.h includes
sys/select.h. However, since POSIX requires that select is defined in
sys/select.h this change makes the example more portable.

Reported by Gavin Smith <gavinsmith0123@gmail.com> in:
<https://lists.gnu.org/archive/html/bug-texinfo/2025-07/msg00091.html>.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agomanual: document getsubopt standardization.
Collin Funk [Sat, 28 Jun 2025 06:13:48 +0000 (23:13 -0700)] 
manual: document getsubopt standardization.

The getsubopt function was an XSI extension since POSIX issue 4 until it
was added to Base in POSIX Issue 7.  This also adds the 'restrict'
qualifier to the arguments as done in POSIX.1-2024, and has been the
case in glibc.
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
12 days agoerrlist: add missing entries for MIPS/SPARC
Luca Boccassi [Tue, 29 Jul 2025 12:07:58 +0000 (13:07 +0100)] 
errlist: add missing entries for MIPS/SPARC

These are defined in the kernel headers but missing from the list
of names, so strerrorname_np() returns NULL.

https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/mips/include/uapi/asm/errno.h#n95
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/sparc/include/uapi/asm/errno.h#n55

Signed-off-by: Luca Boccassi <luca.boccassi@gmail.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
13 days agohurd: support: Fix running SGID tests
Samuel Thibault [Fri, 18 Jul 2025 21:14:40 +0000 (23:14 +0200)] 
hurd: support: Fix running SGID tests

Secure mode is enabled only if SGID actually provides a new privilege,
so we have to drop it before gaining it again.

Fixes commit 3a3fb2ed83f79100c116c824454095ecfb335ad7
("Fix error reporting (false negatives) in SGID tests")

13 days agosupport: Handle COPY_FILE_RANGE events with FUSE
Florian Weimer [Sat, 2 Aug 2025 10:35:34 +0000 (12:35 +0200)] 
support: Handle COPY_FILE_RANGE events with FUSE

2 weeks agomalloc: Cleanup sysmalloc_mmap
Wilco Dijkstra [Sat, 2 Aug 2025 15:11:28 +0000 (15:11 +0000)] 
malloc: Cleanup sysmalloc_mmap

Cleanup sysmalloc_mmap - simplify padding since it is always a constant.
Remove av parameter which is only used in do_check_chunk, but since it may be
NULL for mmap, it will cause a crash in checking mode.  Remove the odd check
on mmap in do_check_chunk.

Reviewed-by: DJ Delorie <dj@redhat.com>
2 weeks agomalloc: Improve checked_request2size
Wilco Dijkstra [Fri, 6 Jun 2025 17:11:36 +0000 (17:11 +0000)] 
malloc: Improve checked_request2size

Change checked_request2size to return SIZE_MAX for huge inputs.  This
ensures large allocation requests stay large and can't be confused with a
small allocation.  As a result several existing checks against PTRDIFF_MAX
become redundant.

Reviewed-by: DJ Delorie <dj@redhat.com>
2 weeks agomalloc: Cleanup madvise defines
Wilco Dijkstra [Thu, 10 Jul 2025 16:04:24 +0000 (16:04 +0000)] 
malloc: Cleanup madvise defines

Remove redundant ifdefs for madvise/THP.

Reviewed-by: DJ Delorie <dj@redhat.com>
2 weeks agobenchtests: Cleanup bench-malloc-thread
Wilco Dijkstra [Fri, 9 May 2025 14:24:42 +0000 (14:24 +0000)] 
benchtests: Cleanup bench-malloc-thread

Change duration to 3 seconds.  Add spaces before '('.

Reviewed-by: DJ Delorie <dj@redhat.com>
2 weeks agomalloc: Fix MAX_TCACHE_SMALL_SIZE
Wilco Dijkstra [Thu, 17 Jul 2025 14:31:06 +0000 (14:31 +0000)] 
malloc: Fix MAX_TCACHE_SMALL_SIZE

MAX_TCACHE_SMALL_SIZE should use chunk size since it is used after
checked_request2size.  Increase limit of tcache_max_bytes by 1 since all
comparisons use '<'.  As a result, the last tcache entry is now used as
expected.

Reviewed-by: DJ Delorie <dj@redhat.com>
2 weeks agonptl: Fix SYSCALL_CANCEL for return values larger than INT_MAX (BZ 33245)
Adhemerval Zanella [Fri, 1 Aug 2025 18:00:25 +0000 (15:00 -0300)] 
nptl: Fix SYSCALL_CANCEL for return values larger than INT_MAX (BZ 33245)

The SYSCALL_CANCEL calls __syscall_cancel, which in turn
calls __internal_syscall_cancel with an 'int' return instead of the
expected 'long int'.  This causes issues with syscalls that return
values larger than INT_MAX, such as copy_file_range [1].

Checked on x86_64-linux-gnu.

[1] https://debbugs.gnu.org/cgi/bugreport.cgi?bug=79139

Reviewed-by: Andreas K. Huettel <dilfridge@gentoo.org>
2 weeks agoi386: Consolidate subdirectory check on elf and csu
H.J. Lu [Mon, 28 Jul 2025 19:15:30 +0000 (12:15 -0700)] 
i386: Consolidate subdirectory check on elf and csu

Consolidate subdirectory check on elf and csu to avoid checking them
more than once.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
2 weeks agox86-64: Consolidate subdirectory check on elf and csu
H.J. Lu [Mon, 28 Jul 2025 19:15:11 +0000 (12:15 -0700)] 
x86-64: Consolidate subdirectory check on elf and csu

Consolidate subdirectory check on elf and csu to avoid checking them
more than once.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
2 weeks agoelf: Handle ld.so with LOAD segment gaps in _dl_find_object (bug 31943)
Florian Weimer [Fri, 1 Aug 2025 08:20:23 +0000 (10:20 +0200)] 
elf: Handle ld.so with LOAD segment gaps in _dl_find_object (bug 31943)

Detect if ld.so not contiguous and handle that case in _dl_find_object.
Set l_find_object_processed even for initially loaded link maps,
otherwise dlopen of an initially loaded object adds it to
_dlfo_loaded_mappings (where maps are expected to be contiguous),
in addition to _dlfo_nodelete_mappings.

Test elf/tst-link-map-contiguous-ldso iterates over the loader
image, reading every word to make sure memory is actually mapped.
It only does that if the l_contiguous flag is set for the link map.
Otherwise, it finds gaps with mmap and checks that _dl_find_object
does not return the ld.so mapping for them.

The test elf/tst-link-map-contiguous-main does the same thing for
the libc.so shared object.  This only works if the kernel loaded
the main program because the glibc dynamic loader may fill
the gaps with PROT_NONE mappings in some cases, making it contiguous,
but accesses to individual words may still fault.

Test elf/tst-link-map-contiguous-libc is again slightly different
because the dynamic loader always fills the gaps with PROT_NONE
mappings, so a different form of probing has to be used.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
2 weeks agoelf: Extract rtld_setup_phdr function from dl_main
Florian Weimer [Fri, 1 Aug 2025 08:20:23 +0000 (10:20 +0200)] 
elf: Extract rtld_setup_phdr function from dl_main

Remove historic binutils reference from comment and update
how this data is used by applications.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
2 weeks agostdlib: resolve a double lock init issue after fork [BZ #32994]
Davide Cavalca [Thu, 31 Jul 2025 15:32:58 +0000 (17:32 +0200)] 
stdlib: resolve a double lock init issue after fork [BZ #32994]

The __abort_fork_reset_child (introduced in
d40ac01cbbc66e6d9dbd8e3485605c63b2178251) call resets the lock after the
fork. This causes a DRD regression in valgrind
(https://bugs.kde.org/show_bug.cgi?id=503668), as it's effectively a
double initialization, despite it being actually ok in this case. As
suggested in https://sourceware.org/bugzilla/show_bug.cgi?id=32994#c2
we replace it here with a memcpy of another initialized lock instead,
which makes valgrind happy.

Reviewed-by: Florian Weimer <fweimer@redhat.com>
2 weeks agoUse Linux 6.16, GCC 15, binutils 2.45 in build-many-glibcs.py
Joseph Myers [Tue, 29 Jul 2025 15:08:09 +0000 (15:08 +0000)] 
Use Linux 6.16, GCC 15, binutils 2.45 in build-many-glibcs.py

Tested with build-many-glibcs.py (host-libraries, compilers and glibcs
builds).

2 weeks agomalloc: Enable THP always support on hugetlb tunable
William Hunt [Tue, 29 Jul 2025 15:04:58 +0000 (15:04 +0000)] 
malloc: Enable THP always support on hugetlb tunable

Enable support for THP always when glibc.malloc.hugetlb=1, as the tunable
currently only gives explicit support in malloc for the THP madvise mode
by aligning to a huge page size. Add a thp_mode parameter to mp_ and check
in madvise_thp whether the system is using madvise mode, otherwise the
`__madvise` call is useless. Set the thp_mode to be unsupported by default,
but if the hugetlb tunable is set this updates thp_mode. Performance of
xalancbmk improves by 4.9% on Neoverse V2 when THP always mode is set on the
system and glibc.malloc.hugetlb=1.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
2 weeks agomalloc: Remove redundant NULL check
Wilco Dijkstra [Thu, 10 Jul 2025 15:49:14 +0000 (15:49 +0000)] 
malloc: Remove redundant NULL check

Remove a redundant NULL check from tcache_get_n.

Reviewed-by: Cupertino Miranda <cupertino.miranda@oracle.com>
2 weeks agoreplace atan2-inputs with more meaningful inputs
Paul Zimmermann [Wed, 9 Jul 2025 08:11:23 +0000 (10:11 +0200)] 
replace atan2-inputs with more meaningful inputs

Commit 934d88d used inputs with exponent generated at random in the
whole binary64 exponent range, which yields essentially very large
or very small values of |y/x|. Instead, this commit generates x, y at
random in [-10,10], which should better corresponds to real applications.
Reviewed-by: Florian Weimer <fweimer@redhat.com>
2 weeks agoinet-fortified: fix namespace violation (bug 33227)
Sam James [Mon, 28 Jul 2025 20:55:30 +0000 (21:55 +0100)] 
inet-fortified: fix namespace violation (bug 33227)

We need to use __sz, not sz, as we do elsewhere.

Reviewed-by: Florian Weimer <fweimer@redhat.com>
2 weeks agotst-cond23: return EXIT_UNSUPPORTED on missing clock selection
Samuel Thibault [Tue, 29 Jul 2025 09:56:06 +0000 (11:56 +0200)] 
tst-cond23: return EXIT_UNSUPPORTED on missing clock selection

2 weeks agoNEWS: Add 2.43 section
Andreas K. Hüttel [Mon, 28 Jul 2025 18:33:18 +0000 (20:33 +0200)] 
NEWS: Add 2.43 section

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agoBump version to 2.42.9000 glibc-2.42.9000
Andreas K. Hüttel [Mon, 28 Jul 2025 18:31:31 +0000 (20:31 +0200)] 
Bump version to 2.42.9000

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agoCreate ChangeLog.old/ChangeLog.31 glibc-2.42
Andreas K. Hüttel [Mon, 28 Jul 2025 18:22:55 +0000 (20:22 +0200)] 
Create ChangeLog.old/ChangeLog.31

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agoBump version number to 2.42
Andreas K. Hüttel [Mon, 28 Jul 2025 18:19:17 +0000 (20:19 +0200)] 
Bump version number to 2.42

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agoNEWS: update with last-minute fix bug 33224
Andreas K. Hüttel [Mon, 28 Jul 2025 18:12:05 +0000 (20:12 +0200)] 
NEWS: update with last-minute fix bug 33224

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agomath: Update auto-libm-tests-in with ldbl-128ibm compoundn/pown failures
Adhemerval Zanella [Mon, 28 Jul 2025 13:59:07 +0000 (10:59 -0300)] 
math: Update auto-libm-tests-in with ldbl-128ibm compoundn/pown failures

It fixes ce488f7c1615bc2f6fe96ff4d51456e470aa5805 which updated
the out files without using gen-auto-libm-tests.c instructions.

Checked on powerpc64le-linux-gnu.

Tested-by: Andreas K. Huettel <dilfridge@gentoo.org>
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
2 weeks agoINSTALL: Update newest tested binutils version
Andreas K. Hüttel [Mon, 28 Jul 2025 14:49:01 +0000 (16:49 +0200)] 
INSTALL: Update newest tested binutils version

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
2 weeks agoelf: Compile _dl_debug_state separately (bug 33224)
Florian Weimer [Mon, 28 Jul 2025 12:16:52 +0000 (14:16 +0200)] 
elf: Compile _dl_debug_state separately (bug 33224)

This ensures that the compiler will not inline it, so that
debuggers which do not use the Systemtap probes can reliably
set a breakpoint on it.

Reviewed-by: Andreas K. Huettel <dilfridge@gentoo.org>
Tested-by: Andreas K. Huettel <dilfridge@gentoo.org>
2 weeks agoconfigure.ac: fix bashisms in SFrame checks
Sam James [Mon, 28 Jul 2025 13:00:52 +0000 (14:00 +0100)] 
configure.ac: fix bashisms in SFrame checks

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
3 weeks agoINSTALL: regenerate
Andreas K. Hüttel [Sat, 26 Jul 2025 15:07:14 +0000 (17:07 +0200)] 
INSTALL: regenerate

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
3 weeks agoinstall.texi: Update tested build tool versions
Andreas K. Hüttel [Sat, 26 Jul 2025 15:05:21 +0000 (17:05 +0200)] 
install.texi: Update tested build tool versions

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
3 weeks agocontrib.texi: Update
Andreas K. Hüttel [Sat, 26 Jul 2025 14:53:43 +0000 (16:53 +0200)] 
contrib.texi: Update

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
3 weeks agoNEWS: insert list of CVEs
Andreas K. Hüttel [Sat, 26 Jul 2025 13:23:49 +0000 (15:23 +0200)] 
NEWS: insert list of CVEs

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>
3 weeks agoadvisories: s/CVE-id/CVE-Id/ (the lowercase i breaks our tooling)
Andreas K. Hüttel [Sat, 26 Jul 2025 13:21:27 +0000 (15:21 +0200)] 
advisories: s/CVE-id/CVE-Id/ (the lowercase i breaks our tooling)

Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>