diff options
author | Yann E. MORIN" <yann.morin.1998@anciens.enib.fr> | 2011-09-11 16:18:53 (GMT) |
---|---|---|
committer | Yann E. MORIN" <yann.morin.1998@anciens.enib.fr> | 2011-09-11 16:18:53 (GMT) |
commit | 389a779657ceac86c399d7eda8027102ae9e754c (patch) | |
tree | 5019b11a21a25449b8d3d2872b524fa3e8fa2b74 /patches/binutils/2.20.1a/290-ld-stub-crash.patch | |
parent | 639b71de0fb3ded474b79ec917b9d3eb0fa8548e (diff) |
binutils/binutils: fixup version strings
Recently, all binutils versions have been renamed after a GPL compliance
issue was found and fixed in binutils;
http://sourceware.org/ml/binutils/2011-08/msg00198.html
Although legacy symlinks have been put in place, we should now use
the new, real version strings.
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 346263a0711510a7ac953b1523b6607a1ca53caf)
Diffstat (limited to 'patches/binutils/2.20.1a/290-ld-stub-crash.patch')
-rw-r--r-- | patches/binutils/2.20.1a/290-ld-stub-crash.patch | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/patches/binutils/2.20.1a/290-ld-stub-crash.patch b/patches/binutils/2.20.1a/290-ld-stub-crash.patch new file mode 100644 index 0000000..640231c --- /dev/null +++ b/patches/binutils/2.20.1a/290-ld-stub-crash.patch @@ -0,0 +1,24 @@ +diff -p -c -u -r1.196 elf32-arm.c + +diff -durN binutils-2.20.1.orig/bfd/elf32-arm.c binutils-2.20.1/bfd/elf32-arm.c +--- binutils-2.20.1.orig/bfd/elf32-arm.c 2010-02-22 09:06:48.000000000 +0100 ++++ binutils-2.20.1/bfd/elf32-arm.c 2010-08-17 19:32:25.000000000 +0200 +@@ -3194,11 +3194,15 @@ + + /* We have an extra 2-bytes reach because of + the mode change (bit 24 (H) of BLX encoding). */ ++ /* A stub is needed only if this call is not throught a PLT ++ entry, because PLT stubs handle mode switching ++ already. */ + if (branch_offset > (ARM_MAX_FWD_BRANCH_OFFSET + 2) + || (branch_offset < ARM_MAX_BWD_BRANCH_OFFSET) +- || ((r_type == R_ARM_CALL) && !globals->use_blx) +- || (r_type == R_ARM_JUMP24) +- || (r_type == R_ARM_PLT32)) ++ || ( (((r_type == R_ARM_CALL) && !globals->use_blx) ++ || (r_type == R_ARM_JUMP24) ++ || (r_type == R_ARM_PLT32)) ++ && !use_plt)) + { + stub_type = (info->shared | globals->pic_veneer) + /* PIC stubs. */ |