Remove ref_dynamic_nonweak added by accident
authorH.J. Lu <hjl.tools@gmail.com>
Tue, 20 Nov 2012 22:17:27 +0000 (22:17 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Tue, 20 Nov 2012 22:17:27 +0000 (22:17 +0000)
bfd/

2012-11-20  H.J. Lu  <hongjiu.lu@intel.com>

PR ld/14862
* elf-bfd.h (elf_link_hash_entry): Remove ref_dynamic_nonweak
added by accident.
(elf_link_add_object_symbols): Don't set nor check
ref_dynamic_nonweak.

ld/testsuite/

2012-11-20  H.J. Lu  <hongjiu.lu@intel.com>

PR ld/14862
* ld-elf/shared.exp (build_tests): Build libpr14862-1.o and
libpr14862.so.
(run_tests): Test pr14862.

* ld-elf/pr14862-1.c: New file.
* ld-elf/pr14862-2.c: Likewise.
* ld-elf/pr14862.map: Likewise.
* ld-elf/pr14862.out: Likewise.

bfd/ChangeLog
bfd/elf-bfd.h
bfd/elflink.c
ld/testsuite/ChangeLog
ld/testsuite/ld-elf/pr14862-1.c [new file with mode: 0644]
ld/testsuite/ld-elf/pr14862-2.c [new file with mode: 0644]
ld/testsuite/ld-elf/pr14862.map [new file with mode: 0644]
ld/testsuite/ld-elf/pr14862.out [new file with mode: 0644]
ld/testsuite/ld-elf/shared.exp

index 95f9aef..755e747 100644 (file)
@@ -1,3 +1,11 @@
+2012-11-20  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR ld/14862
+       * elf-bfd.h (elf_link_hash_entry): Remove ref_dynamic_nonweak
+       added by accident.
+       (elf_link_add_object_symbols): Don't set nor check
+       ref_dynamic_nonweak.
+
 2012-11-20  Alan Modra  <amodra@gmail.com>
 
        * elf32-rx.c (rx_elf_print_private_bfd_data): Warning fix.
index aa78ecd..b8d82b1 100644 (file)
@@ -168,8 +168,6 @@ struct elf_link_hash_entry
   /* Symbol has a non-weak reference from a non-shared object (other than
      the object in which it is defined).  */
   unsigned int ref_regular_nonweak : 1;
-  /* Symbol has a non-weak reference from a shared object.  */
-  unsigned int ref_dynamic_nonweak : 1;  
   /* Dynamic symbol has been adjustd.  */
   unsigned int dynamic_adjusted : 1;
   /* Symbol needs a copy reloc.  */
index 2fcbac3..f22e023 100644 (file)
@@ -4394,8 +4394,6 @@ error_free_dyn:
                    {
                      h->def_dynamic = 0;
                      h->ref_dynamic = 1;
-                     /* PR 12549: Note if the dynamic reference is weak.  */
-                     h->ref_dynamic_nonweak = (bind != STB_WEAK);
                    }
                }
 
@@ -4413,9 +4411,6 @@ error_free_dyn:
                {
                  h->ref_dynamic = 1;
                  hi->ref_dynamic = 1;
-                 /* PR 12549: Note if the dynamic reference is weak.  */
-                 hi->ref_dynamic_nonweak =
-                   h->ref_dynamic_nonweak = (bind != STB_WEAK);
                }
              else
                {
@@ -4503,8 +4498,8 @@ error_free_dyn:
          if (!add_needed
              && definition
              && ((dynsym
-                  && h->ref_regular_nonweak)
-                 || (h->ref_dynamic_nonweak
+                  && h->ref_regular)
+                 || (h->ref_dynamic
                      && (elf_dyn_lib_class (abfd) & DYN_AS_NEEDED) != 0
                      && !on_needed_list (elf_dt_name (abfd), htab->needed))))
            {
index 81ec67c..30a4d99 100644 (file)
@@ -1,5 +1,17 @@
 2012-11-20  H.J. Lu  <hongjiu.lu@intel.com>
 
+       PR ld/14862
+       * ld-elf/shared.exp (build_tests): Build libpr14862-1.o and
+       libpr14862.so.
+       (run_tests): Test pr14862.
+
+       * ld-elf/pr14862-1.c: New file.
+       * ld-elf/pr14862-2.c: Likewise.
+       * ld-elf/pr14862.map: Likewise.
+       * ld-elf/pr14862.out: Likewise.
+
+2012-11-20  H.J. Lu  <hongjiu.lu@intel.com>
+
        * ld-elf/global1.d: New file.
 
 2012-11-07  James Murray   <jsm@jsm-net.demon.co.uk>
diff --git a/ld/testsuite/ld-elf/pr14862-1.c b/ld/testsuite/ld-elf/pr14862-1.c
new file mode 100644 (file)
index 0000000..258a834
--- /dev/null
@@ -0,0 +1,9 @@
+extern void bar () __attribute__((weak));
+
+int
+main (void)
+{
+  if (bar)
+    bar ();
+  return 0;
+}
diff --git a/ld/testsuite/ld-elf/pr14862-2.c b/ld/testsuite/ld-elf/pr14862-2.c
new file mode 100644 (file)
index 0000000..1b9b393
--- /dev/null
@@ -0,0 +1,7 @@
+#include <stdio.h>
+
+void
+bar (void)
+{
+  printf ("OK\n");
+}
diff --git a/ld/testsuite/ld-elf/pr14862.map b/ld/testsuite/ld-elf/pr14862.map
new file mode 100644 (file)
index 0000000..2947640
--- /dev/null
@@ -0,0 +1,4 @@
+VERS_1 {
+  global: bar;
+  local: *;
+};
diff --git a/ld/testsuite/ld-elf/pr14862.out b/ld/testsuite/ld-elf/pr14862.out
new file mode 100644 (file)
index 0000000..d86bac9
--- /dev/null
@@ -0,0 +1 @@
+OK
index c9f2056..9b35d53 100644 (file)
@@ -173,6 +173,12 @@ set build_tests {
   {"Build libpr14323-2.so"
    "-shared" "-fPIC"
    {pr14323-2.c} {} "libpr14323-2.so"}
+  {"Build pr14862-1.o"
+   "-r -nostdlib" ""
+   {pr14862-1.c} {} "libpr14862-1.o"}
+  {"Build libpr14862.so"
+   "-shared -Wl,--version-script=pr11138-1.map" "-fPIC"
+   {pr14862-2.c} {} "libpr14862.so"}
 }
 
 run_cc_link_tests $build_tests
@@ -308,6 +314,9 @@ set run_tests {
     {"Run with pr14323-1.c pr14323-2.so"
      "tmpdir/libpr14323-2.so" ""
      {pr14323-1.c} "pr14323" "pass.out"}
+    {"Run with pr14862-1.c libpr14862.so"
+     "--as-needed tmpdir/libpr14862-1.o tmpdir/libpr14862.so" ""
+     {dummy.c} "pr14862" "pr14862.out"}
 }
 
 # NetBSD ELF systems do not currently support the .*_array sections.