PR ld/12942

bfd/
	* elflink.c (elf_link_add_object_symbols): Use elf_discarded_section
	rather than kept_section to determine whether a symbol is from
	a discarded section.
	* cofflink.c (coff_link_add_symbols): Make symbols from discarded
	sections appear undefined.

	* elf-bfd.h (_bfd_elf_section_already_linked): Replace
	"asection *" with "struct already_linked *".
	* libbfd-in.h (_bfd_nolink_section_already_linked): Likewise.
	(_bfd_generic_section_already_linked): Likewise.
	(bfd_section_already_linked_table_insert): Likewise.
	(struct already_linked): New.
	(struct bfd_section_already_linked): Use it.
	* elflink.c (_bfd_elf_section_already_linked): Replace.
	"asection *" with "struct already_linked *".  Replace the plugin
	dummy with the LTO output.
	* linker.c (_bfd_generic_section_already_linked): Likewise.
	* targets.c (struct already_linked): Add forward declaration.
	(bfd_target): Replace "struct bfd_section *" with
	"struct already_linked *" in _section_already_linked.
	* bfd-in2.h: Regenerate.
	* libbfd.h: Regenerate.

include/
	* bfdlink.h (bfd_link_info): Add loading_lto_outputs.

ld/
	* ldlang.c (section_already_linked): Pass "struct already_linked *"
	to bfd_section_already_linked.
	(lang_process): Set link_info.loading_lto_outputs before
	loading LTO outputs.
	* plugin.c: Include "libbfd.h".
	(add_symbols): Call bfd_section_already_linked with comdat_key.
This commit is contained in:
Alan Modra 2011-07-09 06:20:51 +00:00
parent da2cf96189
commit f6835aecb3
2 changed files with 8 additions and 0 deletions

View File

@ -1,3 +1,8 @@
2011-07-09 H.J. Lu <hongjiu.lu@intel.com>
PR ld/12942
* bfdlink.h (bfd_link_info): Add loading_lto_outputs.
2011-07-01 Joel Brobecker <brobecker@adacore.com> 2011-07-01 Joel Brobecker <brobecker@adacore.com>
* filenames.h (HAVE_CASE_INSENSITIVE_FILE_SYSTEM): Define * filenames.h (HAVE_CASE_INSENSITIVE_FILE_SYSTEM): Define

View File

@ -357,6 +357,9 @@ struct bfd_link_info
linker created sections, TRUE if it should be omitted. */ linker created sections, TRUE if it should be omitted. */
unsigned int no_ld_generated_unwind_info: 1; unsigned int no_ld_generated_unwind_info: 1;
/* TRUE if we are loading LTO outputs. */
unsigned int loading_lto_outputs: 1;
/* Non-NULL if .note.gnu.build-id section should be created. */ /* Non-NULL if .note.gnu.build-id section should be created. */
char *emit_note_gnu_build_id; char *emit_note_gnu_build_id;