Fix some dlx fails
authorAlan Modra <amodra@gmail.com>
Tue, 19 Mar 2019 05:11:58 +0000 (15:41 +1030)
committerAlan Modra <amodra@gmail.com>
Wed, 20 Mar 2019 22:15:28 +0000 (08:45 +1030)
Generic linker ELF targets using CREATE_OBJECT_SYMBOLS in their
scripts run into a problem.  The file symbols are created by
_bfd_generic_link_output_symbols in each object file, in the section
corresponding to the CREATE_OBJECT_SYMBOLS section, typically .text.
If it so happens that the output .text section is stripped due to
being empty, then elf.c:assign_section_numbers won't assign an ELF
section number and swap_out_syms will report "unable to find
equivalent output section" for the object symbols.  Fix this by
always keeping an output section with CREATE_OBJECT_SYMBOLS.

* ldlang.c (lang_size_sections_1): Set SEC_KEEP on
create_object_symbols_section.
* testsuite/ld-elf/pr22319.d: Don't xfail dlx.

ld/ChangeLog
ld/ldlang.c
ld/testsuite/ld-elf/pr22319.d

index 9000cab..4fe6889 100644 (file)
@@ -1,3 +1,9 @@
+2019-03-21  Alan Modra  <amodra@gmail.com>
+
+       * ldlang.c (lang_size_sections_1): Set SEC_KEEP on
+       create_object_symbols_section.
+       * testsuite/ld-elf/pr22319.d: Don't xfail dlx.
+
 2019-03-18  Alan Modra  <amodra@gmail.com>
 
        * testsuite/ld-elf/merge.d: Remove csky from xfails, add moxie.
index 33f6bda..77d890e 100644 (file)
@@ -5619,8 +5619,9 @@ lang_size_sections_1
          break;
 
        case lang_object_symbols_statement_enum:
-         link_info.create_object_symbols_section =
-           output_section_statement->bfd_section;
+         link_info.create_object_symbols_section
+           = output_section_statement->bfd_section;
+         output_section_statement->bfd_section->flags |= SEC_KEEP;
          break;
 
        case lang_output_statement_enum:
index 8ad2f3e..f5413f0 100644 (file)
@@ -1,8 +1,6 @@
 #name: PR 22319 - required undefined symbols in output
 #ld: -u undefined_symbol -e 0
 #nm: -u
-#xfail: dlx-*-* 
-# The DLX target fails because it needs a special linker script to handle file symbols.
 
 [      ]+U+[   ]+undefined_symbol
 #pass