ARM: Fix clone code when built for Thumb.
authorWill Newton <will.newton@linaro.org>
Thu, 29 Aug 2013 19:10:26 +0000 (20:10 +0100)
committerWill Newton <will.newton@linaro.org>
Fri, 30 Aug 2013 09:50:25 +0000 (10:50 +0100)
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.

NEWS
ports/ChangeLog.arm
ports/sysdeps/unix/sysv/linux/arm/clone.S

diff --git a/NEWS b/NEWS
index d3524ff..4fe4b63 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -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
index 8236f0f..2a95834 100644 (file)
@@ -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>
index ce9c2a5..6e74fa7 100644 (file)
@@ -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