2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+ PR ld/15146
+ * elflink.c (elf_link_add_object_symbols): Don't add DT_NEEDED
+ for references from the dummy bfd.
+
+2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+
PR ld/15149
* elflink.c (elf_link_add_object_symbols): Also track weak
references.
break;
}
+ /* Don't add DT_NEEDED for references from the dummy bfd. */
if (!add_needed
&& definition
&& ((dynsym
- && h->ref_regular)
+ && h->ref_regular
+ && (undef_bfd == NULL
+ || (undef_bfd->flags & BFD_PLUGIN) == 0))
|| (h->ref_dynamic
&& (elf_dyn_lib_class (abfd) & DYN_AS_NEEDED) != 0
&& !on_needed_list (elf_dt_name (abfd), htab->needed))))
2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+ PR ld/15146
+ * plugin.c (plugin_notice): Replace the undefined dummy bfd with
+ the real one.
+
+2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+
PR ld/15141
* plugin.c (plugin_notice): Also trace symbol from the IR bfd.
/* If this is a ref, set non_ir_ref. */
else if (bfd_is_und_section (section))
- h->non_ir_ref = TRUE;
+ {
+ /* Replace the undefined dummy bfd with the real one. */
+ if ((h->type == bfd_link_hash_undefined
+ || h->type == bfd_link_hash_undefweak)
+ && (h->u.undef.abfd->flags & BFD_PLUGIN) != 0)
+ h->u.undef.abfd = abfd;
+ h->non_ir_ref = TRUE;
+ }
/* Otherwise, it must be a new def. Ensure any symbol defined
in an IR dummy BFD takes on a new value from a real BFD.
+2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR ld/15146
+ * ld-plugin/pr15146.d: New file.
+ * ld-plugin/pr15146a.c: Likewise.
+ * ld-plugin/pr15146b.c: Likewise.
+ * ld-plugin/pr15146c.c: Likewise.
+ * ld-plugin/pr15146d.c: Likewise.
+
+ * ld-plugin/lto.exp: Add tests for PR ld/15146.
+
2013-02-15 Markos Chandras <markos.chandras@imgtec.com>
* ld-metag/pcrel.d: Fix the expected disassembler
{"PR ld/13244"
"-shared -O2 -fPIC -flto -fuse-linker-plugin -nostdlib" "-O2 -fno-early-inlining -flto"
{pr13244.c} {{"readelf" {-s --wide} "pr13244.d"}} "pr13244.so" "c"}
+ {"Build libpr15146a.a"
+ "" "-flto -O2"
+ {pr15146a.c} {} "lib15146a.a"}
+ {"Build pr15146b.so"
+ "-shared" "-O2 -fpic"
+ {pr15146b.c} {} "pr15146b.so" "c"}
+ {"Build pr15146c.so"
+ "-shared tmpdir/pr15146b.so" "-O2 -fpic"
+ {pr15146c.c} {} "pr15146c.so" "c"}
+ {"PR ld/15146 (1)"
+ "-O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries tmpdir/pr15146a.o tmpdir/pr15146c.so" ""
+ {dummy.c} {{"readelf" {-d} "pr15146.d"}} "pr15146a.exe"}
+ {"Build libpr15146d.a"
+ "" "-flto -O2"
+ {pr15146d.c} {} "lib15146d.a"}
+ {"Build libpr15146d.a"
+ "" "-flto -O2"
+ {pr15146d.c} {} "lib15146d.a"}
}
# Check final symbols in executables.
if { [is_elf_format]
&& [run_host_cmd_yesno $CC "-shared -fPIC $srcdir/$subdir/dummy.c -o tmpdir/t.so"] } {
run_cc_link_tests $lto_link_elf_tests
+ set testname "PR ld/15146 (2)"
+ set exec_output [run_host_cmd "$CC" "$gcc_gas_flag $gcc_ld_flag -O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries tmpdir/pr15146d.o tmpdir/pr15146c.so"]
+ if { [ regexp "ltrans.o: undefined reference to symbol 'xxx'" $exec_output ] } {
+ pass $testname
+ } {
+ fail $testname
+ }
}
set testname "Build liblto-11.a"
--- /dev/null
+#failif
+#...
+ +0x[0-9a-f]+ +\(NEEDED\) +Shared library: +\[.*pr15146b.so\]
+#...
--- /dev/null
+extern int xxx;
+
+int
+bar (void)
+{
+ return xxx;
+}
+
+int
+main ()
+{
+ return 0;
+}
--- /dev/null
+int xxx = 3;
--- /dev/null
+extern int xxx;
+
+int
+main ()
+{
+ return xxx;
+}