Strip undefined symbols from .symtab
authorAlan Modra <amodra@gmail.com>
Wed, 18 Feb 2015 06:32:39 +0000 (17:02 +1030)
committerAlan Modra <amodra@gmail.com>
Thu, 19 Feb 2015 03:06:34 +0000 (13:36 +1030)
bfd/
PR ld/4317
* elflink.c (elf_link_input_bfd): Drop undefined local syms.
(elf_link_output_extsym): Drop local and global undefined syms.
Tidy.  Expand comment.
ld/testsuite/
PR ld/4317
* ld-aarch64/gc-tls-relocs.d, * ld-cris/locref2.d,
* ld-elf/ehdr_start-weak.d, * ld-elf/group1.d,
* ld-i386/compressed1.d, * ld-ia64/error1.d, * ld-ia64/error2.d,
* ld-ia64/error3.d, * ld-mips-elf/pic-and-nonpic-1.nd,
* ld-mmix/undef-3.d, * ld-powerpc/tlsexe.r, * ld-powerpc/tlsexetoc.r,
* ld-powerpc/tlsso.r, * ld-powerpc/tlstocso.r,
* ld-x86-64/compressed1.d, * ld-x86-64/pie1.d: Update.

19 files changed:
bfd/ChangeLog
bfd/elflink.c
ld/testsuite/ChangeLog
ld/testsuite/ld-aarch64/gc-tls-relocs.d
ld/testsuite/ld-cris/locref2.d
ld/testsuite/ld-elf/ehdr_start-weak.d
ld/testsuite/ld-elf/group1.d
ld/testsuite/ld-i386/compressed1.d
ld/testsuite/ld-ia64/error1.d
ld/testsuite/ld-ia64/error2.d
ld/testsuite/ld-ia64/error3.d
ld/testsuite/ld-mips-elf/pic-and-nonpic-1.nd
ld/testsuite/ld-mmix/undef-3.d
ld/testsuite/ld-powerpc/tlsexe.r
ld/testsuite/ld-powerpc/tlsexetoc.r
ld/testsuite/ld-powerpc/tlsso.r
ld/testsuite/ld-powerpc/tlstocso.r
ld/testsuite/ld-x86-64/compressed1.d
ld/testsuite/ld-x86-64/pie1.d

index 44fc2bb83eded8e0dab41edfd7f3f7a130a3c79c..71f258f916d7218aea7b332fd8083a5c2b5bd7a4 100644 (file)
@@ -1,3 +1,10 @@
+2015-02-19  Alan Modra  <amodra@gmail.com>
+
+       PR ld/4317
+       * elflink.c (elf_link_input_bfd): Drop undefined local syms.
+       (elf_link_output_extsym): Drop local and global undefined syms.
+       Tidy.  Expand comment.
+
 2015-02-17  Alan Modra  <amodra@gmail.com>
 
        PR ld/17975
index 038e43d3834d6dd825d111f386db16d317b2fdb7..0cd85f1d94c28db63dea3e16ed98452d0763ae35 100644 (file)
@@ -8902,8 +8902,9 @@ elf_link_output_extsym (struct bfd_hash_entry *bh, void *data)
      a regular file, or that we have been told to strip.  However, if
      h->indx is set to -2, the symbol is used by a reloc and we must
      output it.  */
+  strip = FALSE;
   if (h->indx == -2)
-    strip = FALSE;
+    ;
   else if ((h->def_dynamic
            || h->ref_dynamic
            || h->root.type == bfd_link_hash_new)
@@ -8929,12 +8930,11 @@ elf_link_output_extsym (struct bfd_hash_entry *bh, void *data)
           && h->root.u.undef.abfd != NULL
           && (h->root.u.undef.abfd->flags & BFD_PLUGIN) != 0)
     strip = TRUE;
-  else
-    strip = FALSE;
 
   /* If we're stripping it, and it's not a dynamic symbol, there's
-     nothing else to do unless it is a forced local symbol or a
-     STT_GNU_IFUNC symbol.  */
+     nothing else to do.   However, if it is a forced local symbol or
+     an ifunc symbol we need to give the backend finish_dynamic_symbol
+     function a chance to make it dynamic.  */
   if (strip
       && h->dynindx == -1
       && h->type != STT_GNU_IFUNC
@@ -9205,9 +9205,18 @@ elf_link_output_extsym (struct bfd_hash_entry *bh, void *data)
        }
     }
 
-  /* If we're stripping it, then it was just a dynamic symbol, and
-     there's nothing else to do.  */
-  if (strip || (input_sec->flags & SEC_EXCLUDE) != 0)
+  /* If the symbol is undefined, and we didn't output it to .dynsym,
+     strip it from .symtab too.  Obviously we can't do this for
+     relocatable output or when needed for --emit-relocs.  */
+  else if (input_sec == bfd_und_section_ptr
+          && h->indx != -2
+          && !flinfo->info->relocatable)
+    return TRUE;
+  /* Also strip others that we couldn't earlier due to dynamic symbol
+     processing.  */
+  if (strip)
+    return TRUE;
+  if ((input_sec->flags & SEC_EXCLUDE) != 0)
     return TRUE;
 
   /* Output a FILE symbol so that following locals are not associated
@@ -9455,8 +9464,9 @@ elf_link_input_bfd (struct elf_final_link_info *flinfo, bfd *input_bfd)
 
       *ppsection = isec;
 
-      /* Don't output the first, undefined, symbol.  */
-      if (ppsection == flinfo->sections)
+      /* Don't output the first, undefined, symbol.  In fact, don't
+        output any undefined local symbol.  */
+      if (isec == bfd_und_section_ptr)
        continue;
 
       if (ELF_ST_TYPE (isym->st_info) == STT_SECTION)
index 64f08714a2d37db87b6de5d274f4b91b7aaa3fe8..7619bc5d96d45027f93082b72322363816295bb8 100644 (file)
@@ -1,3 +1,14 @@
+2015-02-19  Alan Modra  <amodra@gmail.com>
+
+       PR ld/4317
+       * ld-aarch64/gc-tls-relocs.d, * ld-cris/locref2.d,
+       * ld-elf/ehdr_start-weak.d, * ld-elf/group1.d,
+       * ld-i386/compressed1.d, * ld-ia64/error1.d, * ld-ia64/error2.d,
+       * ld-ia64/error3.d, * ld-mips-elf/pic-and-nonpic-1.nd,
+       * ld-mmix/undef-3.d, * ld-powerpc/tlsexe.r, * ld-powerpc/tlsexetoc.r,
+       * ld-powerpc/tlsso.r, * ld-powerpc/tlstocso.r,
+       * ld-x86-64/compressed1.d, * ld-x86-64/pie1.d: Update.
+
 2015-02-17  Alan Modra  <amodra@gmail.com>
 
        PR ld/17975
index 191647ca3106a0f305c71411f48056a4dee947ab..480d869917ec6061ae466b75981c9afd37bb0cb9 100644 (file)
@@ -17,7 +17,6 @@ SYMBOL TABLE:
 0+9000 l    d  \.got   0+ \.got
 0+0000 l    df \*ABS\* 0+ .*
 0+0000 l    df \*ABS\* 0+ 
-0+0000 l       \*UND\* 0+ __tls_get_addr
 0+9000 l     O \.got   0+ _GLOBAL_OFFSET_TABLE_
 0+8000 g       \.text  0+ _start
 
index 735b10ec4fffd9309f7d5adb4d6be9e67a0dc77c..0cf53946cb569a1ead161d78e0d3c36fd9f5ab3b 100644 (file)
@@ -12,8 +12,6 @@
 SYMBOL TABLE:
 #...
 0+82088 l     O \.got  0+ _GLOBAL_OFFSET_TABLE_
-0+  w      \*UND\*     0+ expfn
-0+  w      \*UND\*     0+ expobj
 #...
 Disassembly of section \.text:
 #...
index 24ae34cda711f24a2c46ef5e8750b10620b609e0..5644d0537dc23410dcc4d51e84a0b814a992d3fa 100644 (file)
@@ -4,6 +4,7 @@
 #target: *-*-linux* *-*-gnu* *-*-nacl*
 #xfail: frv-*-*
 
+#failif
+#...
+.* __ehdr_start
 #...
-\s+[wU] __ehdr_start
-#pass
index ff675352675387fead13c6fcad2503c6be58c822..257be11fac4391ff0713bbcd547d835bedd4dbf2 100644 (file)
@@ -8,5 +8,3 @@
 Symbol table '.symtab' contains .* entries:
 #...
 .*: 0+1000 +0 +(NOTYPE|OBJECT) +WEAK +DEFAULT +. foo
-.*: 0+0000 +0 +(NOTYPE|OBJECT) +GLOBAL +DEFAULT +UND bar
-#...
index 3a57c815a9a7a9fec6f07eafdd1988bfd1890c9f..c17d3c7fce67ef2fcc397858ee90983fa0fcc396 100644 (file)
@@ -2,8 +2,3 @@
 #as: --32
 #ld: -e foo -melf_i386 --noinhibit-exec
 #warning: .*/compressed1.c:13: undefined reference to .bar.
-#nm: -n
-
-#...
-[ \t]+U bar
-#pass
index 82142b6a11e64125411caa2124de4e86672ac867..7b2476f95e5c67a1006cf2f49774e196a1b9ec52 100644 (file)
@@ -2,6 +2,4 @@
 #ld: -unresolved-symbols=ignore-all
 #readelf: -s
 
-#...
-[      ]+[0-9]+:[      ]+[0]+[         ]+0[    ]+NOTYPE[       ]+GLOBAL DEFAULT[       ]+UND[  ]+foo
 #pass
index 764ba66d279dae87ecf8783d00c5be3f04ef0696..ae74eaa464b2767c3048364d75623baa1b2aff18 100644 (file)
@@ -2,6 +2,4 @@
 #ld: -pie -unresolved-symbols=ignore-all
 #readelf: -s
 
-#...
-[      ]+[0-9]+:[      ]+[0]+[         ]+0[    ]+NOTYPE[       ]+GLOBAL DEFAULT[       ]+UND[  ]+foo
 #pass
index e14d451bbaef442214e7ec0fe78ff63555955178..256a6fdc17b783c50431b1f08273d4793df8b1d6 100644 (file)
@@ -2,6 +2,4 @@
 #ld: -pie -shared
 #readelf: -s
 
-#...
-[      ]+[0-9]+:[      ]+[0]+[         ]+0[    ]+NOTYPE[       ]+GLOBAL DEFAULT[       ]+UND[  ]+foo
 #pass
index 78a1c60579732dd69c1a4602ba60e66ba206513b..3c449fbcb7ae17292b35ddb9ff50f3343da16c51 100644 (file)
@@ -2,7 +2,6 @@
 .*: 00068000 +0 +NOTYPE +LOCAL +DEFAULT +ABS _gp
 .*: 00041018 +8 +FUNC +LOCAL +DEFAULT .* .pic.f1
 .*: 00041000 +16 +FUNC +LOCAL +DEFAULT .* .pic.f2
-.*: 00000000 +0 +OBJECT +GLOBAL +DEFAULT +UND _gp_disp
 .*: 00041050 +14 +FUNC +GLOBAL +DEFAULT +\[MIPS16\] .* f3
 .*: 00041060 +24 +FUNC +GLOBAL +DEFAULT .* __start
 .*: 0004103c +20 +FUNC +GLOBAL +DEFAULT .* f2
index 2f551b9f71f1e771d9410545a301f13144ae13e4..8fbf304d40e5bf128e6c2993598d50ea08fbc78d 100644 (file)
@@ -14,19 +14,18 @@ Section Headers:
  +\[ 2\] \.shstrtab +STRTAB +0+ +0+7c
  +0+21 +0+ +0 +0 +1
  +\[ 3\] \.symtab +SYMTAB +0+ .*
- +0+c0 +0+18 +4 +2 +8
+ +0+a8 +0+18 +4 +2 +8
  +\[ 4\] \.strtab +STRTAB +0+ .*
- +0+2f +0+ +0 +0 +1
+ +0+28 +0+ +0 +0 +1
 Key to Flags:
 #...
 
-Symbol table '\.symtab' contains 8 entries:
+Symbol table '\.symtab' contains 7 entries:
  +Num: +Value +Size +Type +Bind +Vis +Ndx +Name
  +0: 0+ +0 +NOTYPE +LOCAL +DEFAULT +UND 
  +1: 0+ +0 +SECTION +LOCAL +DEFAULT +1 
- +2: 0+ +0 +NOTYPE +GLOBAL +DEFAULT +UND undefd
- +3: 0+ +0 +NOTYPE +GLOBAL +DEFAULT +1 _start
- +4: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 __bss_start
- +5: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 _edata
- +6: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 _end
- +7: 0+ +0 +NOTYPE +GLOBAL +DEFAULT +1 _start\.
+ +2: 0+ +0 +NOTYPE +GLOBAL +DEFAULT +1 _start
+ +3: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 __bss_start
+ +4: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 _edata
+ +5: 2000000000000000 +0 +NOTYPE +GLOBAL +DEFAULT +1 _end
+ +6: 0+ +0 +NOTYPE +GLOBAL +DEFAULT +1 _start\.
index 443bae872b6653a86c683beade160719c0367093..94e5272b9ca3c94d050abde93911f1e4f28b8ff0 100644 (file)
@@ -98,9 +98,8 @@ Symbol table '\.symtab' contains [0-9]+ entries:
 .* TLS +LOCAL +DEFAULT +8 le5
 .* FILE +LOCAL +DEFAULT +ABS 
 .* OBJECT +LOCAL +DEFAULT +10 _DYNAMIC
-.* (NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve|(FUNC|NOTYPE) +LOCAL +DEFAULT +UND \.__tls_get_addr(|_opt))
-.* (NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt)|NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve)
-.* ((FUNC|NOTYPE) +LOCAL +DEFAULT +UND \.__tls_get_addr(|_opt)|NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt))
+.* NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve
+.* NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt)
 .* GLOBAL +DEFAULT +UND gd
 .* GLOBAL +DEFAULT +9 le0
 .* GLOBAL +DEFAULT +9 ld0
index bb6462f6b34f20adc113596b43617eb5bf73fd0b..7b55281a7a5cc3e3c4597ed906dcd4907a057740 100644 (file)
@@ -98,9 +98,8 @@ Symbol table '\.symtab' contains [0-9]+ entries:
 .* NOTYPE +LOCAL +DEFAULT +12 \.Lie0
 .* FILE +LOCAL +DEFAULT +ABS 
 .* OBJECT +LOCAL +DEFAULT +10 _DYNAMIC
-.* (NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve|(FUNC|NOTYPE) +LOCAL +DEFAULT +UND \.__tls_get_addr(|_opt))
-.* (NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt)|NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve)
-.* ((FUNC|NOTYPE) +LOCAL +DEFAULT +UND \.__tls_get_addr(|_opt)|NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt))
+.* NOTYPE +LOCAL +DEFAULT +7 __glink_PLTresolve
+.* NOTYPE +LOCAL +DEFAULT +7 .*\.plt_call\.__tls_get_addr(|_opt)
 .* TLS +GLOBAL +DEFAULT +UND gd
 .* TLS +GLOBAL +DEFAULT +9 le0
 .* TLS +GLOBAL +DEFAULT +9 ld0
index 3a5b8089233f4ea51451110f62594b725aff6006..e0a3a7549930b2d89fb61442d7dac3d2e979507a 100644 (file)
@@ -116,7 +116,6 @@ Symbol table '\.symtab' contains [0-9]+ entries:
 .* OBJECT +LOCAL +DEFAULT +9 _DYNAMIC
 .* NOTYPE +LOCAL +DEFAULT +6 .*\.plt_call\.__tls_get_addr
 .* NOTYPE +LOCAL +DEFAULT +6 __glink_PLTresolve
-.* NOTYPE +LOCAL +DEFAULT +UND \.__tls_get_addr
 .* TLS +GLOBAL +DEFAULT +UND gd
 .* TLS +GLOBAL +DEFAULT +8 le0
 .* NOTYPE +GLOBAL +DEFAULT +UND __tls_get_addr
index 075e30375857fbacaa9b83134d7838657b846d13..0006db9a36498044c569e48abdd5f76c97689f09 100644 (file)
@@ -112,7 +112,6 @@ Symbol table '\.symtab' contains [0-9]+ entries:
 .* OBJECT +LOCAL +DEFAULT +9 _DYNAMIC
 .* NOTYPE +LOCAL +DEFAULT +6 .*\.plt_call\.__tls_get_addr
 .* NOTYPE +LOCAL +DEFAULT +6 __glink_PLTresolve
-.* NOTYPE +LOCAL +DEFAULT +UND \.__tls_get_addr
 .* TLS +GLOBAL +DEFAULT +UND gd
 .* TLS +GLOBAL +DEFAULT +8 le0
 .* NOTYPE +GLOBAL +DEFAULT +UND __tls_get_addr
index 1dd0f4cf6c7f845f084de74059405bd81bf5f554..9e9d92cea2c0e8fd465e11f0de6a3dd00dc1a264 100644 (file)
@@ -2,8 +2,3 @@
 #as: --64
 #ld: -e foo -melf_x86_64 --noinhibit-exec
 #warning: .*/compressed1.c:13: undefined reference to .bar.
-#nm: -n
-
-#...
-[ \t]+U bar
-#pass
index 06d2562b8043bee9faa0efe1dd97d43eba905969..368d1538f411a4e788501173012ba92c6d8f82bb 100644 (file)
@@ -1,9 +1,4 @@
 #name: PIE with undefined symbol
 #as: --64
 #ld: -pie -melf_x86_64 --noinhibit-exec
-#readelf: -s --wide
 #warning: \A[^\n]*\.o[^\n]*In function `_start':\n[^\n]*: undefined reference to `foo'\Z
-
-#...
- +[0-9]+: +[0-9a-f]+ +0 +NOTYPE +GLOBAL +DEFAULT +UND foo
-#pass