diff options
author | Will Newton <will.newton@linaro.org> | 2013-08-29 20:10:26 +0100 |
---|---|---|
committer | Will Newton <will.newton@linaro.org> | 2013-08-30 10:50:25 +0100 |
commit | 6b06ac56cdfc9293908724e51e827534e97819aa (patch) | |
tree | 6b826b8afcd2477624425895af76b24da9d1cd10 | |
parent | 2601bc1860c33653f2d402b871f1211d460aa350 (diff) | |
download | glibc-6b06ac56cdfc9293908724e51e827534e97819aa.zip glibc-6b06ac56cdfc9293908724e51e827534e97819aa.tar.gz glibc-6b06ac56cdfc9293908724e51e827534e97819aa.tar.bz2 |
ARM: Fix clone code when built for Thumb.
The mov lr, pc instruction will lose the Thumb bit from the return address
so use blx lr instead.
ports/ChangeLog.arm:
2013-08-30 Will Newton <will.newton@linaro.org>
[BZ #15909]
* sysdeps/unix/sysv/linux/arm/clone.S (__clone): Use blx
instead of mov lr, pc.
-rw-r--r-- | NEWS | 2 | ||||
-rw-r--r-- | ports/ChangeLog.arm | 6 | ||||
-rw-r--r-- | ports/sysdeps/unix/sysv/linux/arm/clone.S | 4 |
3 files changed, 9 insertions, 3 deletions
@@ -10,7 +10,7 @@ Version 2.19 * The following bugs are resolved with this release: 14699, 15522, 15531, 15532, 15736, 15749, 15797, 15867, 15890, 15897, - 15905. + 15905, 15909. * CVE-2013-4237 The readdir_r function could write more than NAME_MAX bytes to the d_name member of struct dirent, or omit the terminating NUL diff --git a/ports/ChangeLog.arm b/ports/ChangeLog.arm index 8236f0f..2a95834 100644 --- a/ports/ChangeLog.arm +++ b/ports/ChangeLog.arm @@ -1,5 +1,11 @@ 2013-08-30 Will Newton <will.newton@linaro.org> + [BZ #15909] + * sysdeps/unix/sysv/linux/arm/clone.S (__clone): Use blx + instead of mov lr, pc. + +2013-08-30 Will Newton <will.newton@linaro.org> + * sysdeps/arm/armv6t2/strlen.S: New file. 2013-08-29 Thomas Schwinge <thomas@codesourcery.com> diff --git a/ports/sysdeps/unix/sysv/linux/arm/clone.S b/ports/sysdeps/unix/sysv/linux/arm/clone.S index ce9c2a5..6e74fa7 100644 --- a/ports/sysdeps/unix/sysv/linux/arm/clone.S +++ b/ports/sysdeps/unix/sysv/linux/arm/clone.S @@ -93,8 +93,8 @@ PSEUDO_END (__clone) mov lr, pc bx ip #else - mov lr, pc - ldr pc, [sp], #8 + ldr lr, [sp], #8 + blx lr #endif @ and we are done, passing the return value through r0 |