Properly adjust h->plt.refcount
authorH.J. Lu <hjl.tools@gmail.com>
Fri, 21 Dec 2012 18:15:22 +0000 (18:15 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Fri, 21 Dec 2012 18:15:22 +0000 (18:15 +0000)
bfd/

PR ld/14980
* elf32-i386.c (elf_i386_adjust_dynamic_symbol): Properly
adjust h->plt.refcount.
* elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise.

ld/testsuite/

PR ld/14980
* ld-ifunc/ifunc-14c.s: New file.
* ld-ifunc/ifunc-14e-i386.d: Likewise.
* ld-ifunc/ifunc-14e-x86-64.d: Likewise.
* ld-ifunc/ifunc-14f-i386.d: Likewise.
* ld-ifunc/ifunc-14f-x86-64.d: Likewise.

bfd/ChangeLog
bfd/elf32-i386.c
bfd/elf64-x86-64.c
ld/testsuite/ChangeLog
ld/testsuite/ld-ifunc/ifunc-14c.s [new file with mode: 0644]
ld/testsuite/ld-ifunc/ifunc-14e-i386.d [new file with mode: 0644]
ld/testsuite/ld-ifunc/ifunc-14e-x86-64.d [new file with mode: 0644]
ld/testsuite/ld-ifunc/ifunc-14f-i386.d [new file with mode: 0644]
ld/testsuite/ld-ifunc/ifunc-14f-x86-64.d [new file with mode: 0644]

index 2ceee8dc1e45f7046c12587129825d24e66f27b9..48f94dad2228187e96a0600183511724e79f50be 100644 (file)
@@ -1,3 +1,10 @@
+2012-12-21  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/14980
+       * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Properly
+       adjust h->plt.refcount.
+       * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise.
+
 2012-12-19  H.J. Lu  <hongjiu.lu@intel.com>
 
        * elf32-i386.c (elf_i386_relocate_section): Replace
index fce70b95cfaa80e557a19bf272567840fe741b7a..f76c7a7f404e80bb5ed7b83cdd2a8fc035d53ffe 100644 (file)
@@ -2031,8 +2031,11 @@ elf_i386_adjust_dynamic_symbol (struct bfd_link_info *info,
          if (pc_count || count)
            {
              h->needs_plt = 1;
-             h->plt.refcount += 1;
              h->non_got_ref = 1;
+             if (h->plt.refcount <= 0)
+               h->plt.refcount = 1;
+             else
+               h->plt.refcount += 1;
            }
        }
 
index a37f793e232ee1b0adb1bb24953c704c62b89a4e..11ec917e696baf61ee9db4fa0ebcb2010bd14049 100644 (file)
@@ -2090,8 +2090,11 @@ elf_x86_64_adjust_dynamic_symbol (struct bfd_link_info *info,
          if (pc_count || count)
            {
              h->needs_plt = 1;
-             h->plt.refcount += 1;
              h->non_got_ref = 1;
+             if (h->plt.refcount <= 0)
+               h->plt.refcount = 1;
+             else
+               h->plt.refcount += 1;
            }
        }
 
index a97bd4214a8f5c5236d442817cb7c2bb8cc660fa..16bffd89368dc636f62e0a5726018109ceefc747 100644 (file)
@@ -1,3 +1,12 @@
+2012-12-21  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/14980
+       * ld-ifunc/ifunc-14c.s: New file.
+       * ld-ifunc/ifunc-14e-i386.d: Likewise.
+       * ld-ifunc/ifunc-14e-x86-64.d: Likewise.
+       * ld-ifunc/ifunc-14f-i386.d: Likewise.
+       * ld-ifunc/ifunc-14f-x86-64.d: Likewise.
+
 2012-12-19  Alan Modra  <amodra@gmail.com>
 
        PR ld/14962
diff --git a/ld/testsuite/ld-ifunc/ifunc-14c.s b/ld/testsuite/ld-ifunc/ifunc-14c.s
new file mode 100644 (file)
index 0000000..3cde56e
--- /dev/null
@@ -0,0 +1,7 @@
+       .text
+       .globl xxx
+       .type   xxx, @function
+xxx:
+       jmp     foo
+       .size   xxx, .-xxx
+       .hidden foo
diff --git a/ld/testsuite/ld-ifunc/ifunc-14e-i386.d b/ld/testsuite/ld-ifunc/ifunc-14e-i386.d
new file mode 100644 (file)
index 0000000..5380987
--- /dev/null
@@ -0,0 +1,12 @@
+#source: ifunc-14a.s
+#source: ifunc-14c.s
+#source: ifunc-14b.s
+#ld: -shared -m elf_i386 -z nocombreloc
+#as: --32
+#readelf: -r --wide
+#target: x86_64-*-* i?86-*-*
+
+#failif
+#...
+.* +R_386_NONE +.*
+#...
diff --git a/ld/testsuite/ld-ifunc/ifunc-14e-x86-64.d b/ld/testsuite/ld-ifunc/ifunc-14e-x86-64.d
new file mode 100644 (file)
index 0000000..0955c92
--- /dev/null
@@ -0,0 +1,12 @@
+#source: ifunc-14a.s
+#source: ifunc-14c.s
+#source: ifunc-14b.s
+#ld: -shared -m elf_x86_64 -z nocombreloc
+#as: --64
+#readelf: -r --wide
+#target: x86_64-*-*
+
+#failif
+#...
+.* +R_X86_64_NONE +.*
+#...
diff --git a/ld/testsuite/ld-ifunc/ifunc-14f-i386.d b/ld/testsuite/ld-ifunc/ifunc-14f-i386.d
new file mode 100644 (file)
index 0000000..ed3dc53
--- /dev/null
@@ -0,0 +1,12 @@
+#source: ifunc-14a.s
+#source: ifunc-14b.s
+#source: ifunc-14c.s
+#ld: -shared -m elf_i386 -z nocombreloc
+#as: --32
+#readelf: -r --wide
+#target: x86_64-*-* i?86-*-*
+
+#failif
+#...
+.* +R_386_NONE +.*
+#...
diff --git a/ld/testsuite/ld-ifunc/ifunc-14f-x86-64.d b/ld/testsuite/ld-ifunc/ifunc-14f-x86-64.d
new file mode 100644 (file)
index 0000000..12fb225
--- /dev/null
@@ -0,0 +1,12 @@
+#source: ifunc-14a.s
+#source: ifunc-14b.s
+#source: ifunc-14c.s
+#ld: -shared -m elf_x86_64 -z nocombreloc
+#as: --64
+#readelf: -r --wide
+#target: x86_64-*-*
+
+#failif
+#...
+.* +R_X86_64_NONE +.*
+#...