From 3b6c19668236e6fd60c6299e7d016396d645fa61 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Tue, 19 Mar 2019 15:41:58 +1030 Subject: Fix some dlx fails 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/testsuite/ld-elf/pr22319.d | 2 -- 1 file changed, 2 deletions(-) (limited to 'ld/testsuite/ld-elf') diff --git a/ld/testsuite/ld-elf/pr22319.d b/ld/testsuite/ld-elf/pr22319.d index 8ad2f3e..f5413f0 100644 --- a/ld/testsuite/ld-elf/pr22319.d +++ b/ld/testsuite/ld-elf/pr22319.d @@ -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 -- cgit v1.1