summaryrefslogtreecommitdiff
path: root/meta/packages/binutils/binutils-2.20/ld-stub-crash.patch
diff options
context:
space:
mode:
authorRichard Purdie <rpurdie@linux.intel.com>2010-02-23 17:30:19 +0000
committerRichard Purdie <rpurdie@linux.intel.com>2010-02-23 17:30:19 +0000
commit8d382809b3e06a3fc9f22156d988a5b539001eac (patch)
treeba06d0d0476484437e663ac9de4cf7116b3ef4a4 /meta/packages/binutils/binutils-2.20/ld-stub-crash.patch
parent2baf8bbf8b48a10853030e0d560ddd48b2b5efea (diff)
downloadopenembedded-core-8d382809b3e06a3fc9f22156d988a5b539001eac.tar.gz
openembedded-core-8d382809b3e06a3fc9f22156d988a5b539001eac.tar.bz2
openembedded-core-8d382809b3e06a3fc9f22156d988a5b539001eac.tar.xz
openembedded-core-8d382809b3e06a3fc9f22156d988a5b539001eac.zip
binutils: Add 2.20 (patchset from OE.dev)
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'meta/packages/binutils/binutils-2.20/ld-stub-crash.patch')
-rw-r--r--meta/packages/binutils/binutils-2.20/ld-stub-crash.patch26
1 files changed, 26 insertions, 0 deletions
diff --git a/meta/packages/binutils/binutils-2.20/ld-stub-crash.patch b/meta/packages/binutils/binutils-2.20/ld-stub-crash.patch
new file mode 100644
index 000000000..1952649eb
--- /dev/null
+++ b/meta/packages/binutils/binutils-2.20/ld-stub-crash.patch
@@ -0,0 +1,26 @@
+Index: bfd/elf32-arm.c
+===================================================================
+RCS file: /cvs/src/src/bfd/elf32-arm.c,v
+retrieving revision 1.196
+diff -p -c -u -r1.196 elf32-arm.c
+--- bfd/elf32-arm.c 22 May 2009 11:58:44 -0000 1.196
++++ bfd/elf32-arm.c 12 Jun 2009 13:18:20 -0000
+@@ -3175,11 +3175,15 @@ arm_type_of_stub (struct bfd_link_info *
+
+ /* 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. */