patches/binutils/2.20.1a/290-ld-stub-crash.patch
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Sun May 05 00:01:05 2013 +0200 (2013-05-05)
changeset 3218 3709e61ad85b
parent 2088 4f21ba5f8e91
permissions -rw-r--r--
complibs/cloog: add support for the ISL backend

CLooG 0.18+ will use ISL instead of PPL, so we have to configure
adequately depending of which backend is in use.

The Kconfig entries will decide for us which is selected, so we
can rely on either PPL xor ISL to be selected, not both.

Reported-by: "Plotnikov Dmitry" <leitz@ispras.ru>
[Dmitry did a preliminray patch to add ISL support,
which this patch is inspired from]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
     1 diff -p -c -u -r1.196 elf32-arm.c
     2 
     3 diff -durN binutils-2.20.1.orig/bfd/elf32-arm.c binutils-2.20.1/bfd/elf32-arm.c
     4 --- binutils-2.20.1.orig/bfd/elf32-arm.c	2010-02-22 09:06:48.000000000 +0100
     5 +++ binutils-2.20.1/bfd/elf32-arm.c	2010-08-17 19:32:25.000000000 +0200
     6 @@ -3194,11 +3194,15 @@
     7  
     8  	  /* We have an extra 2-bytes reach because of
     9  	     the mode change (bit 24 (H) of BLX encoding).  */
    10 +	  /* A stub is needed only if this call is not throught a PLT
    11 +	     entry, because PLT stubs handle mode switching
    12 +	     already.  */
    13  	  if (branch_offset > (ARM_MAX_FWD_BRANCH_OFFSET + 2)
    14  	      || (branch_offset < ARM_MAX_BWD_BRANCH_OFFSET)
    15 -	      || ((r_type == R_ARM_CALL) && !globals->use_blx)
    16 -	      || (r_type == R_ARM_JUMP24)
    17 -	      || (r_type == R_ARM_PLT32))
    18 +	      || ( (((r_type == R_ARM_CALL) && !globals->use_blx)
    19 +		    || (r_type == R_ARM_JUMP24)
    20 +		    || (r_type == R_ARM_PLT32))
    21 +		   && !use_plt))
    22  	    {
    23  	      stub_type = (info->shared | globals->pic_veneer)
    24  		/* PIC stubs.  */