Add undefined weak function tests
authorAlan Modra <amodra@gmail.com>
Fri, 12 Aug 2016 04:37:40 +0000 (14:07 +0930)
committerAlan Modra <amodra@gmail.com>
Fri, 12 Aug 2016 05:04:49 +0000 (14:34 +0930)
* testsuite/ld-undefined/weak-fundef.s: New.
* testsuite/ld-undefined/weak-undef.t: Don't specify filename.
* testsuite/ld-undefined/weak-undef.exp: Run new tests.  Rearrange
much of old code.  Use is_elf_format to select targets.

ld/ChangeLog
ld/testsuite/ld-undefined/weak-fundef.s [new file with mode: 0644]
ld/testsuite/ld-undefined/weak-undef.exp
ld/testsuite/ld-undefined/weak-undef.t

index 35e066e8dfd563bab3713300d481e542577b941a..6c70b54b131b9f7b8b5012cdbe1d251a1b346903 100644 (file)
@@ -1,3 +1,10 @@
+2016-08-12  Alan Modra  <amodra@gmail.com>
+
+       * testsuite/ld-undefined/weak-fundef.s: New.
+       * testsuite/ld-undefined/weak-undef.t: Don't specify filename.
+       * testsuite/ld-undefined/weak-undef.exp: Run new tests.  Rearrange
+       much of old code.  Use is_elf_format to select targets.
+
 2016-08-11  Alan Modra  <amodra@gmail.com>
 
        PR ld/20436
diff --git a/ld/testsuite/ld-undefined/weak-fundef.s b/ld/testsuite/ld-undefined/weak-fundef.s
new file mode 100644 (file)
index 0000000..2c20f79
--- /dev/null
@@ -0,0 +1,14 @@
+       .text
+       .weak undef_weak_fun
+       .type undef_weak_fun %function
+ .ifdef BL
+       bl undef_weak_fun
+       nop
+ .endif
+ .ifdef CALLPLT
+       call undef_weak_fun@plt
+ .endif
+ .ifdef HPPA
+       bl undef_weak_fun,%r2
+       nop
+ .endif
index c53d73e960bfd4cebd314eb0ca40585431a20395..127628ff9af0567baaa1d7ba40a866c09c4927ff 100644 (file)
 # Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
 # MA 02110-1301, USA.
 
-set testname "weak undefined symbols"
-
-# This test only works for ELF targets.  It ought to work for some
-# a.out targets, but it doesn't.
+# The linker should accept references to undefined weaks without error,
+# and resolve them to zero in a static executable.  Ought to work for
+# some a.out targets too.
+set testname "weak undefined data symbols"
 
-if { ![istarget *-*-sysv4*] \
-     && ![istarget *-*-unixware*] \
-     && ![istarget *-*-elf*] \
-     && ![istarget *-*-eabi*] \
-     && ![istarget hppa*64*-*-hpux*] \
-     && ![istarget *-*-linux*] \
-     && ![istarget *-*-gnu*] \
-     && ![istarget *-*-nacl*] \
-     && ![istarget *-*-irix5*] \
-     && ![istarget *-*-irix6*] \
-     && ![is_pecoff_format] \
-     && ![istarget *-*-solaris2*] } then {
+if { ![is_elf_format] && ![is_pecoff_format] } then {
     unsupported $testname
-    return
-}
+} elseif {![ld_assemble $as $srcdir/$subdir/weak-undef.s \
+           tmpdir/weak-undef.o]} then {
+    # It's OK if .weak doesn't work on this target.
+    unresolved $testname
+} elseif {![ld_simple_link $ld tmpdir/weak-undef \
+               "tmpdir/weak-undef.o -T $srcdir/$subdir/weak-undef.t"]} then {
+    # Weak symbols are broken for non-i386 PE targets.
+    if {! [istarget i?86-*-*]} {
+       setup_xfail *-*-pe*
+    }
+    setup_xfail pj-*-*
+    fail $testname
+} elseif {![is_remote host] && [which $objdump] == 0} then {
+    unresolved $testname
+} else {
+    set exec_output [run_host_cmd "$objdump" "-s tmpdir/weak-undef"]
+    set exec_output [prune_warnings $exec_output]
+    verbose -log $exec_output
 
-if { [istarget *-*-linux*aout*] \
-     || [istarget *-*-linux*oldld*] } {
-    unsupported $testname
-    return
-}
+    set output_regexp ".*Contents of section .data:.*0000 00000000 11111111.*"
 
-# Weak symbols are broken for non-i386 PE targets.
-if {! [istarget i?86-*-*]} {
-    setup_xfail *-*-pe*
+    if {[regexp $output_regexp $exec_output]} then {
+       pass $testname
+    } else {
+       fail $testname
+    }
 }
 
-setup_xfail pj-*-*
+# When linking a shared lib, weak undefined symbols should become dynamic.
+set testname "weak undefined function symbols in shared lib"
 
-if {! [ld_assemble $as $srcdir/$subdir/weak-undef.s tmpdir/weak-undef.o]} then {
-    # It's OK if .weak doesn't work on this target.
-    unresolved $testname
-    return
+set asflags ""
+switch -glob $target_triplet {
+    aarch64* -
+    arm* -
+    powerpc* { set asflags "--defsym BL=1" }
+    hppa* { set asflags "--defsym HPPA=1" }
+    i\[3-7\]86* -
+    x86_64* { set asflags "--defsym CALLPLT=1" }
 }
 
-# The linker should accept references to undefined weaks without error,
-# and resolve them to zero.
-
-set output_regexp \
-".*Contents of section .data:.*0000 00000000 11111111.*"
-
-if {! [ld_simple_link $ld tmpdir/weak-undef "$flags tmpdir/weak-undef.o -T $srcdir/$subdir/weak-undef.t"] } then {
+if { $asflags == "" || ![is_elf_format] || ![check_shared_lib_support]} then {
+    unresolved $testname
+} elseif {![ld_assemble $as "$asflags $srcdir/$subdir/weak-fundef.s" \
+               tmpdir/weak-fundef.o]} then {
+    fail $testname
+} elseif {![ld_simple_link $ld tmpdir/weak-fundef.so \
+           "--shared tmpdir/weak-fundef.o"]} then {
     fail $testname
+} elseif {![is_remote host] && [which $nm] == 0} then {
+    unresolved $testname
 } else {
-    if {![is_remote host] && [which $objdump] == 0} then {
-       unresolved $testname
-       return
-    }
-
-    set exec_output [run_host_cmd "$objdump" "-s tmpdir/weak-undef"]
+    set exec_output [run_host_cmd "$nm" "-D tmpdir/weak-fundef.so"]
     set exec_output [prune_warnings $exec_output]
     verbose -log $exec_output
 
+    set output_regexp ".*w undef_weak_fun.*"
+
     if {[regexp $output_regexp $exec_output]} then {
        pass $testname
     } else {
        fail $testname
     }
+
+    # When linking a dynamic executable, weak undefined symbols become dynamic.
+    set testname "weak undefined function symbols in dynamic exe"
+
+    if {![ld_simple_link $ld tmpdir/weak-fundef \
+         "--no-as-needed tmpdir/weak-fundef.o tmpdir/weak-fundef.so"]} then {
+       fail $testname
+    } else {
+       set exec_output [run_host_cmd "$nm" "-D tmpdir/weak-fundef"]
+       set exec_output [prune_warnings $exec_output]
+       verbose -log $exec_output
+
+       if {[regexp $output_regexp $exec_output]} then {
+           pass $testname
+       } else {
+           fail $testname
+       }
+    }
 }
index a95bbcf1e3a279f692a8d8752ecf3eb540e7ff30..c0e840926991b27f7797348f4487064d672e2235 100644 (file)
@@ -1,7 +1,7 @@
 SECTIONS
 {
   .data : {
-    tmpdir/weak-undef.o(.data)
+    *(.data)
   }
   /DISCARD/ : {
     *(*)