forked from rpms/glibc
2118accf25
Resolves: RHEL-45522
Fedora 40 commit: 9404e14f4d
Upstream commit: 4bdcc1963bc2b5ba5f8e319e402d9eb2cb6096c1
Fedora 40 changes:
- Backport /etc/resolv.conf enhancements to thelp with RHEL-18039 testing
Related: RHEL-50663
- Support --without testsuite builds without perl installed (#2292195)
- Use release instead of baserelease for glibc32 conflict
- Add Conflicts:/Obsoletes: for glibc32 to glibc.i686
- ppc64le: Build early startup code with -mcpu=power8
Resolves: RHEL-43456
- Move ANSI_X3.110-1983 support from main package to glibc-gconv-extra.
Resolves: RHEL-41206
Upstream changes:
- manual: make setrlimit() description less ambiguous
- manual/stdio: Clarify putc and putwc
- malloc: add multi-threaded tests for aligned_alloc/calloc/malloc
- malloc: avoid global locks in tst-aligned_alloc-lib.c
- resolv: Track single-request fallback via _res._flags (bug 31476)
- resolv: Do not wait for non-existing second DNS response after error (bug 30081)
- resolv: Allow short error responses to match any query (bug 31890)
Resolves: RHEL-50663
- elf: Fix localplt.awk for DT_RELR-enabled builds (BZ 31978)
- Fix usage of _STACK_GROWS_DOWN and _STACK_GROWS_UP defines [BZ 31989]
- Linux: Make __rseq_size useful for feature detection (bug 31965)
- elf: Make dl-rseq-symbols Linux only
- nptl: fix potential merge of __rseq_* relro symbols
- s390x: Fix segfault in wcsncmp [BZ #31934]
Resolves: RHEL-49488
- stdlib: fix arc4random fallback to /dev/urandom (BZ 31612)
- math: Provide missing math symbols on libc.a (BZ 31781)
- math: Fix isnanf128 static build (BZ 31774)
- math: Fix i386 and m68k exp10 on static build (BZ 31775)
- math: Fix i386 and m68k fmod/fmodf on static build (BZ 31488)
- posix: Fix pidfd_spawn/pidfd_spawnp leak if execve fails (BZ 31695)
33 lines
1.2 KiB
Diff
33 lines
1.2 KiB
Diff
commit a03631124602f2dcef40d46660b96d2e51c44bfd
|
|
Author: Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
|
Date: Fri Apr 5 10:27:29 2024 -0300
|
|
|
|
stdlib: fix arc4random fallback to /dev/urandom (BZ 31612)
|
|
|
|
The __getrandom_nocancel used by __arc4random_buf uses
|
|
INLINE_SYSCALL_CALL (which returns -1/errno) and the loop checks for
|
|
the return value instead of errno to fallback to /dev/urandom.
|
|
|
|
The malloc code now uses __getrandom_nocancel_nostatus, which uses
|
|
INTERNAL_SYSCALL_CALL, so there is no need to use the variant that does
|
|
not set errno (BZ#29624).
|
|
|
|
Checked on x86_64-linux-gnu.
|
|
|
|
Reviewed-by: Xi Ruoyao <xry111@xry111.site>
|
|
(cherry picked from commit 184b9e530e6326e668709826903b6d30dc6cac3f)
|
|
|
|
diff --git a/stdlib/arc4random.c b/stdlib/arc4random.c
|
|
index 3ae8fc130234b04d..7818cb9cf66e0f3b 100644
|
|
--- a/stdlib/arc4random.c
|
|
+++ b/stdlib/arc4random.c
|
|
@@ -51,7 +51,7 @@ __arc4random_buf (void *p, size_t n)
|
|
n -= l;
|
|
continue; /* Interrupted by a signal; keep going. */
|
|
}
|
|
- else if (l == -ENOSYS)
|
|
+ else if (l < 0 && errno == ENOSYS)
|
|
break; /* No syscall, so fallback to /dev/urandom. */
|
|
arc4random_getrandom_failure ();
|
|
}
|