Blame SOURCES/gdb-rhbz1182151-ibm-z13-02of22.patch

2c2fa1
commit fb798c50b2c896195fb94af229dfbcc52babdfea
2c2fa1
Author: Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
2c2fa1
Date:   Fri Jul 5 09:45:44 2013 +0000
2c2fa1
2c2fa1
    2013-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2c2fa1
    opcodes/
2c2fa1
    	    * s390-opc.c (J12_12, J24_24): New macros.
2c2fa1
    	    (INSTR_MII_UPI): Rename to INSTR_MII_UPP.
2c2fa1
    	    (MASK_MII_UPI): Rename to MASK_MII_UPP.
2c2fa1
    	    * s390-opc.txt: Rename MII_UPI to MII_UPP for bprp instruction.
2c2fa1
    
2c2fa1
    include/elf/
2c2fa1
    	    * s390.h: Add new relocs R_390_PC12DBL, R_390_PLT12DBL,
2c2fa1
    	    R_390_PC24DBL, and R_390_PLT24DBL.
2c2fa1
    
2c2fa1
    gas/testsuite/
2c2fa1
    	    * gas/s390/zarch-zEC12.s: Change bprp second operand and add
2c2fa1
    	    variants requiring relocations.
2c2fa1
    	    * gas/s390/zarch-zEC12.d: Likewise.
2c2fa1
    
2c2fa1
    gas/
2c2fa1
    	    * config/tc-s390.c (md_gather_operands, md_apply_fix): Support new
2c2fa1
    	    relocs.
2c2fa1
    bfd/
2c2fa1
    	    * elf32-s390.c: Add new relocation definitions R_390_PC12DBL,
2c2fa1
    	    R_390_PLT12DBL, R_390_PC24DBL, and R_390_PLT24DBL.
2c2fa1
    	    (elf_s390_reloc_type_lookup, elf_s390_check_relocs)
2c2fa1
    	    (elf_s390_gc_sweep_hook, elf_s390_relocate_section): Support new
2c2fa1
    	    relocations.
2c2fa1
    	    * elf64-s390.c: See elf32-s390.c
2c2fa1
    	    * bfd-in2.h: Add new relocs to enum bfd_reloc_code_real.
2c2fa1
    	    * libbfd.h: Add new reloc strings.
2c2fa1
2c2fa1
### a/bfd/ChangeLog
2c2fa1
### b/bfd/ChangeLog
2c2fa1
## -1,3 +1,14 @@
2c2fa1
+2013-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2c2fa1
+
2c2fa1
+	* elf32-s390.c: Add new relocation definitions R_390_PC12DBL,
2c2fa1
+	R_390_PLT12DBL, R_390_PC24DBL, and R_390_PLT24DBL.
2c2fa1
+	(elf_s390_reloc_type_lookup, elf_s390_check_relocs)
2c2fa1
+	(elf_s390_gc_sweep_hook, elf_s390_relocate_section): Support new
2c2fa1
+	relocations.
2c2fa1
+	* elf64-s390.c: See elf32-s390.c
2c2fa1
+	* bfd-in2.h: Add new relocs to enum bfd_reloc_code_real.
2c2fa1
+	* libbfd.h: Add new reloc strings.
2c2fa1
+
2c2fa1
 2013-07-03  Marcus Shawcroft  <marcus.shawcroft@arm.com>
2c2fa1
 
2c2fa1
 	* elfnn-aarch64.c (elfNN_aarch64_final_link_relocate): Reorder case
2c2fa1
--- a/bfd/bfd-in2.h
2c2fa1
+++ b/bfd/bfd-in2.h
2c2fa1
@@ -4332,12 +4332,24 @@ in .byte hlo8(symbol)  */
2c2fa1
 /* 16 bit GOT offset.  */
2c2fa1
   BFD_RELOC_390_GOT16,
2c2fa1
 
2c2fa1
+/* PC relative 12 bit shifted by 1.  */
2c2fa1
+  BFD_RELOC_390_PC12DBL,
2c2fa1
+
2c2fa1
+/* 12 bit PC rel. PLT shifted by 1.  */
2c2fa1
+  BFD_RELOC_390_PLT12DBL,
2c2fa1
+
2c2fa1
 /* PC relative 16 bit shifted by 1.  */
2c2fa1
   BFD_RELOC_390_PC16DBL,
2c2fa1
 
2c2fa1
 /* 16 bit PC rel. PLT shifted by 1.  */
2c2fa1
   BFD_RELOC_390_PLT16DBL,
2c2fa1
 
2c2fa1
+/* PC relative 24 bit shifted by 1.  */
2c2fa1
+  BFD_RELOC_390_PC24DBL,
2c2fa1
+
2c2fa1
+/* 24 bit PC rel. PLT shifted by 1.  */
2c2fa1
+  BFD_RELOC_390_PLT24DBL,
2c2fa1
+
2c2fa1
 /* PC relative 32 bit shifted by 1.  */
2c2fa1
   BFD_RELOC_390_PC32DBL,
2c2fa1
 
2c2fa1
--- a/bfd/elf32-s390.c
2c2fa1
+++ b/bfd/elf32-s390.c
2c2fa1
@@ -40,7 +40,7 @@ static reloc_howto_type elf_howto_table[] =
2c2fa1
 {
2c2fa1
   HOWTO (R_390_NONE,		/* type */
2c2fa1
 	 0,			/* rightshift */
2c2fa1
-	 0,			/* size (0 = byte, 1 = short, 2 = long) */
2c2fa1
+	 0,			/* size (0 = byte, 1 = 2 byte, 2 = 4 byte) */
2c2fa1
 	 0,			/* bitsize */
2c2fa1
 	 FALSE,			/* pc_relative */
2c2fa1
 	 0,			/* bitpos */
2c2fa1
@@ -161,6 +161,14 @@ static reloc_howto_type elf_howto_table[] =
2c2fa1
 	s390_elf_ldisp_reloc, "R_390_TLS_GOTIE20", FALSE, 0,0x0fffff00, FALSE),
2c2fa1
   HOWTO(R_390_IRELATIVE, 0, 2, 32, TRUE, 0, complain_overflow_bitfield,
2c2fa1
 	bfd_elf_generic_reloc, "R_390_IRELATIVE", FALSE, 0, 0xffffffff, FALSE),
2c2fa1
+  HOWTO(R_390_PC12DBL,   1, 1, 12,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PC12DBL",  FALSE, 0,0x00000fff, TRUE),
2c2fa1
+  HOWTO(R_390_PLT12DBL,	 1, 1, 12,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PLT12DBL", FALSE, 0,0x00000fff, TRUE),
2c2fa1
+  HOWTO(R_390_PC24DBL,   1, 2, 24,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PC24DBL",  FALSE, 0,0x00ffffff, TRUE),
2c2fa1
+  HOWTO(R_390_PLT24DBL,	 1, 2, 24,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PLT24DBL", FALSE, 0,0x00ffffff, TRUE),
2c2fa1
 };
2c2fa1
 
2c2fa1
 /* GNU extension to record C++ vtable hierarchy.  */
2c2fa1
@@ -211,10 +219,18 @@ elf_s390_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED,
2c2fa1
       return &elf_howto_table[(int) R_390_GOT16];
2c2fa1
     case BFD_RELOC_16_PCREL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC16];
2c2fa1
+    case BFD_RELOC_390_PC12DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PC12DBL];
2c2fa1
+    case BFD_RELOC_390_PLT12DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PLT12DBL];
2c2fa1
     case BFD_RELOC_390_PC16DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC16DBL];
2c2fa1
     case BFD_RELOC_390_PLT16DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PLT16DBL];
2c2fa1
+    case BFD_RELOC_390_PC24DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PC24DBL];
2c2fa1
+    case BFD_RELOC_390_PLT24DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PLT24DBL];
2c2fa1
     case BFD_RELOC_390_PC32DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC32DBL];
2c2fa1
     case BFD_RELOC_390_PLT32DBL:
2c2fa1
@@ -1107,7 +1123,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	     are done.  */
2c2fa1
 	  break;
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	case R_390_PLTOFF16:
2c2fa1
@@ -1242,7 +1260,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	case R_390_16:
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_PC16:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	  if (h != NULL)
2c2fa1
@@ -1287,7 +1307,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	  if ((info->shared
2c2fa1
 	       && (sec->flags & SEC_ALLOC) != 0
2c2fa1
 	       && ((ELF32_R_TYPE (rel->r_info) != R_390_PC16
2c2fa1
+		    && ELF32_R_TYPE (rel->r_info) != R_390_PC12DBL
2c2fa1
 		    && ELF32_R_TYPE (rel->r_info) != R_390_PC16DBL
2c2fa1
+		    && ELF32_R_TYPE (rel->r_info) != R_390_PC24DBL
2c2fa1
 		    && ELF32_R_TYPE (rel->r_info) != R_390_PC32DBL
2c2fa1
 		    && ELF32_R_TYPE (rel->r_info) != R_390_PC32)
2c2fa1
 		   || (h != NULL
2c2fa1
@@ -1364,7 +1386,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 
2c2fa1
 	      p->count += 1;
2c2fa1
 	      if (ELF32_R_TYPE (rel->r_info) == R_390_PC16
2c2fa1
+		  || ELF32_R_TYPE (rel->r_info) == R_390_PC12DBL
2c2fa1
 		  || ELF32_R_TYPE (rel->r_info) == R_390_PC16DBL
2c2fa1
+		  || ELF32_R_TYPE (rel->r_info) == R_390_PC24DBL
2c2fa1
 		  || ELF32_R_TYPE (rel->r_info) == R_390_PC32DBL
2c2fa1
 		  || ELF32_R_TYPE (rel->r_info) == R_390_PC32)
2c2fa1
 		p->pc_count += 1;
2c2fa1
@@ -1531,14 +1555,18 @@ elf_s390_gc_sweep_hook (bfd *abfd,
2c2fa1
 	case R_390_20:
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_PC16:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	  if (info->shared)
2c2fa1
 	    break;
2c2fa1
 	  /* Fall through.  */
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	case R_390_PLTOFF16:
2c2fa1
@@ -2588,7 +2616,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	  unresolved_reloc = FALSE;
2c2fa1
 	  break;
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	  /* Relocation is to the entry for this symbol in the
2c2fa1
@@ -2651,7 +2681,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	case R_390_16:
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_PC16:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	  if (h != NULL
2c2fa1
@@ -2723,7 +2755,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 		   || ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
2c2fa1
 		   || h->root.type != bfd_link_hash_undefweak)
2c2fa1
 	       && ((r_type != R_390_PC16
2c2fa1
+		    && r_type != R_390_PC12DBL
2c2fa1
 		    && r_type != R_390_PC16DBL
2c2fa1
+		    && r_type != R_390_PC24DBL
2c2fa1
 		    && r_type != R_390_PC32DBL
2c2fa1
 		    && r_type != R_390_PC32)
2c2fa1
 		   || !SYMBOL_CALLS_LOCAL (info, h)))
2c2fa1
@@ -2764,7 +2798,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	      else if (h != NULL
2c2fa1
 		       && h->dynindx != -1
2c2fa1
 		       && (r_type == R_390_PC16
2c2fa1
+			   || r_type == R_390_PC12DBL
2c2fa1
 			   || r_type == R_390_PC16DBL
2c2fa1
+			   || r_type == R_390_PC24DBL
2c2fa1
 			   || r_type == R_390_PC32DBL
2c2fa1
 			   || r_type == R_390_PC32
2c2fa1
 			   || !info->shared
2c2fa1
@@ -3242,6 +3278,13 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 
2c2fa1
     do_relocation:
2c2fa1
 
2c2fa1
+      /* When applying a 24 bit reloc we need to start one byte
2c2fa1
+	 earlier.  Otherwise the 32 bit get/put bfd operations might
2c2fa1
+	 access a byte after the actual section.  */
2c2fa1
+      if (r_type == R_390_PC24DBL
2c2fa1
+	  || r_type == R_390_PLT24DBL)
2c2fa1
+	rel->r_offset--;
2c2fa1
+
2c2fa1
       if (r_type == R_390_20
2c2fa1
 	  || r_type == R_390_GOT20
2c2fa1
 	  || r_type == R_390_GOTPLT20
2c2fa1
--- a/bfd/elf64-s390.c
2c2fa1
+++ b/bfd/elf64-s390.c
2c2fa1
@@ -43,7 +43,7 @@ static reloc_howto_type elf_howto_table[] =
2c2fa1
 {
2c2fa1
   HOWTO (R_390_NONE,		/* type */
2c2fa1
 	 0,			/* rightshift */
2c2fa1
-	 0,			/* size (0 = byte, 1 = short, 2 = long) */
2c2fa1
+	 0,			/* size (0 = byte, 1 = 2 byte, 2 = 4 byte) */
2c2fa1
 	 0,			/* bitsize */
2c2fa1
 	 FALSE,			/* pc_relative */
2c2fa1
 	 0,			/* bitpos */
2c2fa1
@@ -171,7 +171,14 @@ static reloc_howto_type elf_howto_table[] =
2c2fa1
 	s390_elf_ldisp_reloc, "R_390_TLS_GOTIE20", FALSE, 0,0x0fffff00, FALSE),
2c2fa1
   HOWTO(R_390_IRELATIVE, 0, 4, 64, FALSE, 0, complain_overflow_bitfield,
2c2fa1
 	bfd_elf_generic_reloc, "R_390_IRELATIVE", FALSE, 0, MINUS_ONE, FALSE),
2c2fa1
-
2c2fa1
+  HOWTO(R_390_PC12DBL,   1, 1, 12,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PC12DBL",  FALSE, 0,0x00000fff, TRUE),
2c2fa1
+  HOWTO(R_390_PLT12DBL,  1, 1, 12,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PLT12DBL", FALSE, 0,0x00000fff, TRUE),
2c2fa1
+  HOWTO(R_390_PC24DBL,   1, 2, 24,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PC24DBL",  FALSE, 0,0x00ffffff, TRUE),
2c2fa1
+  HOWTO(R_390_PLT24DBL,  1, 2, 24,  TRUE, 0, complain_overflow_bitfield,
2c2fa1
+	bfd_elf_generic_reloc, "R_390_PLT24DBL", FALSE, 0,0x00ffffff, TRUE),
2c2fa1
 };
2c2fa1
 
2c2fa1
 /* GNU extension to record C++ vtable hierarchy.  */
2c2fa1
@@ -222,10 +229,18 @@ elf_s390_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED,
2c2fa1
       return &elf_howto_table[(int) R_390_GOT16];
2c2fa1
     case BFD_RELOC_16_PCREL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC16];
2c2fa1
+    case BFD_RELOC_390_PC12DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PC12DBL];
2c2fa1
+    case BFD_RELOC_390_PLT12DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PLT12DBL];
2c2fa1
     case BFD_RELOC_390_PC16DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC16DBL];
2c2fa1
     case BFD_RELOC_390_PLT16DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PLT16DBL];
2c2fa1
+    case BFD_RELOC_390_PC24DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PC24DBL];
2c2fa1
+    case BFD_RELOC_390_PLT24DBL:
2c2fa1
+      return &elf_howto_table[(int) R_390_PLT24DBL];
2c2fa1
     case BFD_RELOC_390_PC32DBL:
2c2fa1
       return &elf_howto_table[(int) R_390_PC32DBL];
2c2fa1
     case BFD_RELOC_390_PLT32DBL:
2c2fa1
@@ -1037,7 +1052,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	     are done.  */
2c2fa1
 	  break;
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT64:
2c2fa1
@@ -1176,8 +1193,10 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	case R_390_16:
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_64:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC64:
2c2fa1
@@ -1223,7 +1242,9 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 	  if ((info->shared
2c2fa1
 	       && (sec->flags & SEC_ALLOC) != 0
2c2fa1
 	       && ((ELF64_R_TYPE (rel->r_info) != R_390_PC16
2c2fa1
+		    && ELF64_R_TYPE (rel->r_info) != R_390_PC12DBL
2c2fa1
 		    && ELF64_R_TYPE (rel->r_info) != R_390_PC16DBL
2c2fa1
+		    && ELF64_R_TYPE (rel->r_info) != R_390_PC24DBL
2c2fa1
 		    && ELF64_R_TYPE (rel->r_info) != R_390_PC32
2c2fa1
 		    && ELF64_R_TYPE (rel->r_info) != R_390_PC32DBL
2c2fa1
 		    && ELF64_R_TYPE (rel->r_info) != R_390_PC64)
2c2fa1
@@ -1300,6 +1321,8 @@ elf_s390_check_relocs (bfd *abfd,
2c2fa1
 
2c2fa1
 	      p->count += 1;
2c2fa1
 	      if (ELF64_R_TYPE (rel->r_info) == R_390_PC16
2c2fa1
+		  || ELF64_R_TYPE (rel->r_info) == R_390_PC12DBL
2c2fa1
+		  || ELF64_R_TYPE (rel->r_info) == R_390_PC16DBL
2c2fa1
 		  || ELF64_R_TYPE (rel->r_info) == R_390_PC16DBL
2c2fa1
 		  || ELF64_R_TYPE (rel->r_info) == R_390_PC32
2c2fa1
 		  || ELF64_R_TYPE (rel->r_info) == R_390_PC32DBL
2c2fa1
@@ -1471,7 +1494,9 @@ elf_s390_gc_sweep_hook (bfd *abfd,
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_64:
2c2fa1
 	case R_390_PC16:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC64:
2c2fa1
@@ -1479,7 +1504,9 @@ elf_s390_gc_sweep_hook (bfd *abfd,
2c2fa1
 	    break;
2c2fa1
 	  /* Fall through */
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT64:
2c2fa1
@@ -2550,7 +2577,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	  unresolved_reloc = FALSE;
2c2fa1
 	  break;
2c2fa1
 
2c2fa1
+	case R_390_PLT12DBL:
2c2fa1
 	case R_390_PLT16DBL:
2c2fa1
+	case R_390_PLT24DBL:
2c2fa1
 	case R_390_PLT32:
2c2fa1
 	case R_390_PLT32DBL:
2c2fa1
 	case R_390_PLT64:
2c2fa1
@@ -2615,7 +2644,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	case R_390_32:
2c2fa1
 	case R_390_64:
2c2fa1
 	case R_390_PC16:
2c2fa1
+	case R_390_PC12DBL:
2c2fa1
 	case R_390_PC16DBL:
2c2fa1
+	case R_390_PC24DBL:
2c2fa1
 	case R_390_PC32:
2c2fa1
 	case R_390_PC32DBL:
2c2fa1
 	case R_390_PC64:
2c2fa1
@@ -2689,7 +2720,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 		   || ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
2c2fa1
 		   || h->root.type != bfd_link_hash_undefweak)
2c2fa1
 	       && ((r_type != R_390_PC16
2c2fa1
+		    && r_type != R_390_PC12DBL
2c2fa1
 		    && r_type != R_390_PC16DBL
2c2fa1
+		    && r_type != R_390_PC24DBL
2c2fa1
 		    && r_type != R_390_PC32
2c2fa1
 		    && r_type != R_390_PC32DBL
2c2fa1
 		    && r_type != R_390_PC64)
2c2fa1
@@ -2731,7 +2764,9 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 	      else if (h != NULL
2c2fa1
 		       && h->dynindx != -1
2c2fa1
 		       && (r_type == R_390_PC16
2c2fa1
+			   || r_type == R_390_PC12DBL
2c2fa1
 			   || r_type == R_390_PC16DBL
2c2fa1
+			   || r_type == R_390_PC24DBL
2c2fa1
 			   || r_type == R_390_PC32
2c2fa1
 			   || r_type == R_390_PC32DBL
2c2fa1
 			   || r_type == R_390_PC64
2c2fa1
@@ -3168,6 +3203,13 @@ elf_s390_relocate_section (bfd *output_bfd,
2c2fa1
 
2c2fa1
     do_relocation:
2c2fa1
 
2c2fa1
+      /* When applying a 24 bit reloc we need to start one byte
2c2fa1
+	 earlier.  Otherwise the 32 bit get/put bfd operations might
2c2fa1
+	 access a byte after the actual section.  */
2c2fa1
+      if (r_type == R_390_PC24DBL
2c2fa1
+	  || r_type == R_390_PLT24DBL)
2c2fa1
+	rel->r_offset--;
2c2fa1
+
2c2fa1
       if (r_type == R_390_20
2c2fa1
 	  || r_type == R_390_GOT20
2c2fa1
 	  || r_type == R_390_GOTPLT20
2c2fa1
--- a/bfd/libbfd.h
2c2fa1
+++ b/bfd/libbfd.h
2c2fa1
@@ -2008,8 +2008,12 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@",
2c2fa1
   "BFD_RELOC_390_RELATIVE",
2c2fa1
   "BFD_RELOC_390_GOTPC",
2c2fa1
   "BFD_RELOC_390_GOT16",
2c2fa1
+  "BFD_RELOC_390_PC12DBL",
2c2fa1
+  "BFD_RELOC_390_PLT12DBL",
2c2fa1
   "BFD_RELOC_390_PC16DBL",
2c2fa1
   "BFD_RELOC_390_PLT16DBL",
2c2fa1
+  "BFD_RELOC_390_PC24DBL",
2c2fa1
+  "BFD_RELOC_390_PLT24DBL",
2c2fa1
   "BFD_RELOC_390_PC32DBL",
2c2fa1
   "BFD_RELOC_390_PLT32DBL",
2c2fa1
   "BFD_RELOC_390_GOTPCDBL",
2c2fa1
### a/include/elf/ChangeLog
2c2fa1
### b/include/elf/ChangeLog
2c2fa1
## -1,3 +1,8 @@
2c2fa1
+2013-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2c2fa1
+
2c2fa1
+	* s390.h: Add new relocs R_390_PC12DBL, R_390_PLT12DBL,
2c2fa1
+	R_390_PC24DBL, and R_390_PLT24DBL.
2c2fa1
+
2c2fa1
 2013-06-26  Yufeng Zhang  <yufeng.zhang@arm.com>
2c2fa1
 
2c2fa1
 	* aarch64.h: Add ELF32 reloc codes and remove fake ELF64 ones.
2c2fa1
--- a/include/elf/s390.h
2c2fa1
+++ b/include/elf/s390.h
2c2fa1
@@ -57,8 +57,12 @@ START_RELOC_NUMBERS (elf_s390_reloc_type)
2c2fa1
     RELOC_NUMBER (R_390_GOTPC, 14)	/* 32 bit PC relative offset to GOT.  */
2c2fa1
     RELOC_NUMBER (R_390_GOT16, 15)	/* 16 bit GOT offset.  */
2c2fa1
     RELOC_NUMBER (R_390_PC16, 16)	/* PC relative 16 bit.  */
2c2fa1
+    RELOC_NUMBER (R_390_PC12DBL, 62)	/* PC relative 12 bit shifted by 1.  */
2c2fa1
+    RELOC_NUMBER (R_390_PLT12DBL, 63)	/* 12 bit PC rel. PLT shifted by 1.  */
2c2fa1
     RELOC_NUMBER (R_390_PC16DBL, 17)	/* PC relative 16 bit shifted by 1.  */
2c2fa1
     RELOC_NUMBER (R_390_PLT16DBL, 18)	/* 16 bit PC rel. PLT shifted by 1.  */
2c2fa1
+    RELOC_NUMBER (R_390_PC24DBL, 64)	/* PC relative 24 bit shifted by 1.  */
2c2fa1
+    RELOC_NUMBER (R_390_PLT24DBL, 65)	/* 24 bit PC rel. PLT shifted by 1.  */
2c2fa1
     RELOC_NUMBER (R_390_PC32DBL, 19)	/* PC relative 32 bit shifted by 1.  */
2c2fa1
     RELOC_NUMBER (R_390_PLT32DBL, 20)	/* 32 bit PC rel. PLT shifted by 1.  */
2c2fa1
     RELOC_NUMBER (R_390_GOTPCDBL, 21)	/* 32 bit PC rel. GOT shifted by 1.  */
2c2fa1
### a/opcodes/ChangeLog
2c2fa1
### b/opcodes/ChangeLog
2c2fa1
## -1,3 +1,10 @@
2c2fa1
+2013-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2c2fa1
+
2c2fa1
+	* s390-opc.c (J12_12, J24_24): New macros.
2c2fa1
+	(INSTR_MII_UPI): Rename to INSTR_MII_UPP.
2c2fa1
+	(MASK_MII_UPI): Rename to MASK_MII_UPP.
2c2fa1
+	* s390-opc.txt: Rename MII_UPI to MII_UPP for bprp instruction.
2c2fa1
+
2c2fa1
 2013-07-04  Alan Modra  <amodra@gmail.com>
2c2fa1
 
2c2fa1
 	* ppc-opc.c (powerpc_opcodes): Add tdui, twui, tdu, twu, tui, tu.
2c2fa1
--- a/opcodes/s390-opc.c
2c2fa1
+++ b/opcodes/s390-opc.c
2c2fa1
@@ -217,20 +217,23 @@ const struct s390_operand s390_operands[] =
2c2fa1
 
2c2fa1
 /* PC-relative address operands.  */
2c2fa1
 
2c2fa1
-#define J12_12 69                 /* PC relative offset at 12 */
2c2fa1
+#define J12_12 69                 /* 12 bit PC relative offset at 12 */
2c2fa1
   { 12, 12, S390_OPERAND_PCREL },
2c2fa1
-#define J16_16 70                 /* PC relative offset at 16 */
2c2fa1
+#define J16_16 70                 /* 16 bit PC relative offset at 16 */
2c2fa1
   { 16, 16, S390_OPERAND_PCREL },
2c2fa1
-#define J16_32 71                 /* PC relative offset at 16 */
2c2fa1
+#define J16_32 71                 /* 16 bit PC relative offset at 32 */
2c2fa1
   { 16, 32, S390_OPERAND_PCREL },
2c2fa1
-#define J32_16 72                 /* PC relative offset at 16 */
2c2fa1
+#define J24_24 72                 /* 24 bit PC relative offset at 24 */
2c2fa1
+  { 24, 24, S390_OPERAND_PCREL },
2c2fa1
+#define J32_16 73                 /* 32 bit PC relative offset at 16 */
2c2fa1
   { 32, 16, S390_OPERAND_PCREL },
2c2fa1
 
2c2fa1
+
2c2fa1
 /* Conditional mask operands.  */
2c2fa1
 
2c2fa1
-#define M_16OPT   73              /* 4 bit optional mask starting at 16 */
2c2fa1
+#define M_16OPT   74              /* 4 bit optional mask starting at 16 */
2c2fa1
   { 4, 16, S390_OPERAND_OPTIONAL },
2c2fa1
-#define M_20OPT   74              /* 4 bit optional mask starting at 20 */
2c2fa1
+#define M_20OPT   75              /* 4 bit optional mask starting at 20 */
2c2fa1
   { 4, 20, S390_OPERAND_OPTIONAL },
2c2fa1
 
2c2fa1
 };
2c2fa1
@@ -284,7 +287,7 @@ const struct s390_operand s390_operands[] =
2c2fa1
 
2c2fa1
 #define INSTR_E          2, { 0,0,0,0,0,0 }                    /* e.g. pr    */
2c2fa1
 #define INSTR_IE_UU      4, { U4_24,U4_28,0,0,0,0 }            /* e.g. niai  */
2c2fa1
-#define INSTR_MII_UPI    6, { U4_8,J12_12,I24_24 }             /* e.g. bprp  */
2c2fa1
+#define INSTR_MII_UPP    6, { U4_8,J12_12,J24_24 }             /* e.g. bprp  */
2c2fa1
 #define INSTR_RIE_RRP    6, { R_8,R_12,J16_16,0,0,0 }          /* e.g. brxhg */
2c2fa1
 #define INSTR_RIE_RRPU   6, { R_8,R_12,U4_32,J16_16,0,0 }      /* e.g. crj   */
2c2fa1
 #define INSTR_RIE_RRP0   6, { R_8,R_12,J16_16,0,0,0 }          /* e.g. crjne */
2c2fa1
@@ -446,7 +449,7 @@ const struct s390_operand s390_operands[] =
2c2fa1
 
2c2fa1
 #define MASK_E           { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }
2c2fa1
 #define MASK_IE_UU       { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }
2c2fa1
-#define MASK_MII_UPI     { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }
2c2fa1
+#define MASK_MII_UPP     { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }
2c2fa1
 #define MASK_RIE_RRP     { 0xff, 0x00, 0x00, 0x00, 0x00, 0xff }
2c2fa1
 #define MASK_RIE_RRPU    { 0xff, 0x00, 0x00, 0x00, 0x00, 0xff }
2c2fa1
 #define MASK_RIE_RRP0    { 0xff, 0x00, 0x00, 0x00, 0xf0, 0xff }
2c2fa1
--- a/opcodes/s390-opc.txt
2c2fa1
+++ b/opcodes/s390-opc.txt
2c2fa1
@@ -1126,7 +1126,7 @@ e560 tbegin SIL_RDU "transaction begin" zEC12 zarch
2c2fa1
 e561 tbeginc SIL_RDU "constrained transaction begin" zEC12 zarch
2c2fa1
 b2f8 tend S_00 "transaction end" zEC12 zarch
2c2fa1
 c7 bpp SMI_U0RDP "branch prediction preload" zEC12 zarch
2c2fa1
-c5 bprp MII_UPI "branch prediction relative preload" zEC12 zarch
2c2fa1
+c5 bprp MII_UPP "branch prediction relative preload" zEC12 zarch
2c2fa1
 b2e8 ppa RRF_U0RR "perform processor assist" zEC12 zarch
2c2fa1
 b2fa niai IE_UU "next instruction access intent" zEC12 zarch
2c2fa1
 b98f crdte RRF_RMRR "compare and replace DAT table entry" zEC12 zarch