forked from rpms/glibc
c2879fd933
* Thu Jan 13 2022 Florian Weimer <fweimer@redhat.com> - 2.34-18 - Backport optimized ELF dependency sorting algorithm (#2032647) * Thu Jan 13 2022 Florian Weimer <fweimer@redhat.com> - 2.34-17 - Sync with upstream branch release/2.34/master, commit 2fe2af88abd13ae5636881da2e26f461ecb7dfb5 - i386: Remove broken CAN_USE_REGISTER_ASM_EBP (bug 28771) - Update syscall lists for Linux 5.15 - powerpc: Fix unrecognized instruction errors with recent GCC - timezone: test-case for BZ #28707 - timezone: handle truncated timezones from tzcode-2021d and later (BZ #28707) - Fix subscript error with odd TZif file [BZ #28338] - AArch64: Check for SVE in ifuncs [BZ #28744] - intl/plural.y: Avoid conflicting declarations of yyerror and yylex - Linux: Fix 32-bit vDSO for clock_gettime on powerpc32 - linux: Add sparck brk implementation - Update sparc libm-test-ulps - Update hppa libm-test-ulps - riscv: align stack before calling _dl_init [BZ #28703] - riscv: align stack in clone [BZ #28702] - powerpc64[le]: Allocate extra stack frame on syscall.S - elf: Fix tst-cpu-features-cpuinfo for KVM guests on some AMD systems [BZ #28704] - nss: Use "files dns" as the default for the hosts database (bug 28700) - arm: Guard ucontext _rtld_global_ro access by SHARED, not PIC macro - mips: increase stack alignment in clone to match the ABI - mips: align stack in clone [BZ #28223] Resolves: #2032647 Resolves: #2033649
33 lines
1.1 KiB
Diff
33 lines
1.1 KiB
Diff
commit 9de8011c328021f10588a8acb418daf5121d5f3d
|
|
Author: Aurelien Jarno <aurelien@aurel32.net>
|
|
Date: Tue Dec 14 22:44:35 2021 +0100
|
|
|
|
riscv: align stack in clone [BZ #28702]
|
|
|
|
The RISC-V ABI [1] mandates that "the stack pointer shall be aligned to
|
|
a 128-bit boundary upon procedure entry". This as not the case in clone.
|
|
|
|
This fixes the misc/tst-misalign-clone-internal and
|
|
misc/tst-misalign-clone tests.
|
|
|
|
Fixes bug 28702.
|
|
|
|
[1] https://github.com/riscv-non-isa/riscv-elf-psabi-doc
|
|
|
|
(cherry picked from commit d2e594d71509faf36cf851a69370db34a4f5fa65)
|
|
|
|
diff --git a/sysdeps/unix/sysv/linux/riscv/clone.S b/sysdeps/unix/sysv/linux/riscv/clone.S
|
|
index 12f91a20d3bb34f5..161e83c7e3786b8d 100644
|
|
--- a/sysdeps/unix/sysv/linux/riscv/clone.S
|
|
+++ b/sysdeps/unix/sysv/linux/riscv/clone.S
|
|
@@ -32,6 +32,9 @@
|
|
.text
|
|
LEAF (__clone)
|
|
|
|
+ /* Align stack to a 128-bit boundary as per RISC-V ABI. */
|
|
+ andi a1,a1,ALMASK
|
|
+
|
|
/* Sanity check arguments. */
|
|
beqz a0,L (invalid) /* No NULL function pointers. */
|
|
beqz a1,L (invalid) /* No NULL stack pointers. */
|