Count size relocation as PC-relative relocation
authorH.J. Lu <hjl.tools@gmail.com>
Thu, 17 Jan 2013 23:36:10 +0000 (23:36 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Thu, 17 Jan 2013 23:36:10 +0000 (23:36 +0000)
bfd/

* elf32-i386.c (elf_i386_check_relocs): Count size relocation as
PC-relative relocation.
* elf64-x86-64.c (elf_x86_64_check_relocs): Count size relocation
as PC-relative relocation.

ld/testsuite/

* ld-size/size32-3-i386.d: New file.
* ld-size/size32-3-x32.d: Likewise.
* ld-size/size32-3-x86-64.d: Likewise.
* ld-size/size32-3.s: Likewise.

bfd/ChangeLog
bfd/elf32-i386.c
bfd/elf64-x86-64.c
ld/testsuite/ChangeLog

index f75e046..30fead2 100644 (file)
@@ -1,3 +1,10 @@
+2013-01-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * elf32-i386.c (elf_i386_check_relocs): Count size relocation as
+       PC-relative relocation.
+       * elf64-x86-64.c (elf_x86_64_check_relocs): Count size relocation
+       as PC-relative relocation.
+
 2013-01-16  H.J. Lu  <hongjiu.lu@intel.com>
 
        * elf32-i386.c (elf_i386_check_relocs): Update R_386_SIZE32
index 9c061ba..f8ad1d1 100644 (file)
@@ -1454,6 +1454,7 @@ elf_i386_check_relocs (bfd *abfd,
       struct elf_link_hash_entry *h;
       Elf_Internal_Sym *isym;
       const char *name;
+      bfd_boolean size_reloc;
 
       r_symndx = ELF32_R_SYM (rel->r_info);
       r_type = ELF32_R_TYPE (rel->r_info);
@@ -1557,6 +1558,7 @@ elf_i386_check_relocs (bfd *abfd,
          break;
 
        case R_386_SIZE32:
+         size_reloc = TRUE;
          goto do_size;
 
        case R_386_TLS_IE_32:
@@ -1706,6 +1708,7 @@ elf_i386_check_relocs (bfd *abfd,
                h->pointer_equality_needed = 1;
            }
 
+         size_reloc = FALSE;
 do_size:
          /* If we are creating a shared library, and this is a reloc
             against a global symbol, or a non PC relative reloc
@@ -1803,7 +1806,8 @@ do_size:
                }
 
              p->count += 1;
-             if (r_type == R_386_PC32)
+             /* Count size relocation as PC-relative relocation.  */
+             if (r_type == R_386_PC32 || size_reloc)
                p->pc_count += 1;
            }
          break;
index c260606..79b6dc6 100644 (file)
@@ -1424,6 +1424,7 @@ elf_x86_64_check_relocs (bfd *abfd, struct bfd_link_info *info,
       struct elf_link_hash_entry *h;
       Elf_Internal_Sym *isym;
       const char *name;
+      bfd_boolean size_reloc;
 
       r_symndx = htab->r_sym (rel->r_info);
       r_type = ELF32_R_TYPE (rel->r_info);
@@ -1708,6 +1709,7 @@ elf_x86_64_check_relocs (bfd *abfd, struct bfd_link_info *info,
 
        case R_X86_64_SIZE32:
        case R_X86_64_SIZE64:
+         size_reloc = TRUE;
          goto do_size;
 
        case R_X86_64_32:
@@ -1759,6 +1761,7 @@ pointer:
                h->pointer_equality_needed = 1;
            }
 
+         size_reloc = FALSE;
 do_size:
          /* If we are creating a shared library, and this is a reloc
             against a global symbol, or a non PC relative reloc
@@ -1860,7 +1863,8 @@ do_size:
                }
 
              p->count += 1;
-             if (IS_X86_64_PCREL_TYPE (r_type))
+             /* Count size relocation as PC-relative relocation.  */
+             if (IS_X86_64_PCREL_TYPE (r_type) || size_reloc)
                p->pc_count += 1;
            }
          break;
index c578fb6..b6d5214 100644 (file)
@@ -1,3 +1,10 @@
+2013-01-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * ld-size/size32-3-i386.d: New file.
+       * ld-size/size32-3-x32.d: Likewise.
+       * ld-size/size32-3-x86-64.d: Likewise.
+       * ld-size/size32-3.s: Likewise.
+
 2013-01-16  H.J. Lu  <hongjiu.lu@intel.com>
 
        * ld-size/size.exp: New file.