]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
mips: align stack in clone [BZ #28223]
authorXi Ruoyao <xry111@mengyan1223.wang>
Thu, 12 Aug 2021 20:31:59 +0000 (20:31 +0000)
committerAurelien Jarno <aurelien@aurel32.net>
Tue, 14 Dec 2021 21:57:39 +0000 (22:57 +0100)
The MIPS O32 ABI requires 4 byte aligned stack, and the MIPS N64 and N32
ABI require 8 byte aligned stack.  Previously if the caller passed an
unaligned stack to clone the the child misbehaved.

Fixes bug 28223.

(cherry picked from commit 1f51cd9a860ee45eee8a56fb2ba925267a2a7bfe)

NEWS
sysdeps/unix/sysv/linux/mips/clone.S

diff --git a/NEWS b/NEWS
index 698964bb9e9b24fd58ae3acae158e720662261ee..693ac78229b6c5a157ea3c49ea73908049b3cf81 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -13,6 +13,7 @@ The following bugs are resolved with this release:
   [19193] nptl: pthread_kill, pthread_cancel should not fail after exit
   [28036] Incorrect types for pthread_mutexattr_set/getrobust_np
   [28182] _TIME_BITS=64 in C++ has issues with fcntl, ioctl, prctl
+  [28223] mips: clone does not align stack
   [28310] Do not use affinity mask for sysconf (_SC_NPROCESSORS_CONF)
   [28340] ld.so crashes while loading a DSO with a read-only dynamic section
   [28357] deadlock between pthread_create and ELF constructors
index 71d9dba8bd9e8f9e8a68e62e1bd2c5c6b358364a..43a5ad3a400d9504976f21c18e7ae4a9ea11a5c5 100644 (file)
@@ -55,6 +55,13 @@ NESTED(__clone,4*SZREG,sp)
        .set            at
 #endif
 
+       /* Align stack to 4/8 bytes per the ABI.  */
+#if _MIPS_SIM == _ABIO32
+       li              t0,-4
+#else
+       li              t0,-8
+#endif
+       and             a1,a1,t0
 
        /* Sanity check arguments.  */
        li              v0,EINVAL