Fix implib test failures
[deliverable/binutils-gdb.git] / ld / testsuite / ld-elf / elf.exp
index 4c8ca3ad7083f45b7fb3dbe7c8ad90f092977a05..b67105fa4413aba45bfcb363f3e1464c48d0bb9c 100644 (file)
@@ -1,5 +1,5 @@
 # Expect script for various ELF tests.
-#   Copyright (C) 2002-2014 Free Software Foundation, Inc.
+#   Copyright (C) 2002-2016 Free Software Foundation, Inc.
 #
 # This file is part of the GNU Binutils.
 #
@@ -70,6 +70,10 @@ if { ![istarget hppa64*-hpux*] } {
        run_ld_link_tests {
            {"Build shared library for pr14170"
                "-shared" "" "" "pr14170b.s" {} "pr14170.so" }
+       }
+       # bfin does not currently support copy relocs.
+       setup_xfail "bfin-*-*"
+       run_ld_link_tests {
            {"PR ld/14170"
                "tmpdir/pr14170a.o tmpdir/pr14170.so" "" "" "pr14170c.s"
                { } "pr14170" }
@@ -77,13 +81,12 @@ if { ![istarget hppa64*-hpux*] } {
     }
 }
 
-# Run a test to check linking a shared library with a broken linker
-# script that accidentally marks dynamic sections as notes.  The
-# resulting executable is not expected to work, but the linker
-# should not seg-fault whilst creating the binary.
-#
-# Only run the test on targets thats support creating shared libraries.
+# Only run these tests on targets that support creating shared libraries.
 if { [check_shared_lib_support] } then {
+    # Run a test to check linking a shared library with a broken linker
+    # script that accidentally marks dynamic sections as notes.  The
+    # resulting executable is not expected to work, but the linker
+    # should not seg-fault whilst creating the binary.
     setup_xfail "tic6x-*-*"
     run_ld_link_tests {
        {"Build shared library for next test"
@@ -93,6 +96,37 @@ if { [check_shared_lib_support] } then {
            { { ld "note-3.l" } }
            "a.out" }
     }
+    setup_xfail "tic6x-*-*"
+    run_ld_link_tests {
+       {"Build pr17068.so"
+           "-shared" "" ""
+           {pr17068d.s} {} "pr17068.so"}
+       {"Build pr17068a.a"
+           "" "" ""
+           {pr17068a.s pr17068c.s pr17068ez.s} {} "pr17068a.a"}
+       {"Build pr17068b.a"
+           "" "" ""
+           {pr17068b.s pr17068e.s} {} "pr17068b.a"}
+    }
+    # bfin does not currently support copy relocs.
+    setup_xfail "bfin-*-*"
+    run_ld_link_tests {
+       {"pr17068 link --as-needed lib in group"
+           "--as-needed" "--start-group tmpdir/pr17068a.a tmpdir/pr17068.so tmpdir/pr17068b.a --end-group" ""
+           {start.s pr17068.s} {} "pr17068"}
+    }
+    # xfail on tic6x due to non-PIC/non-PID warnings
+    setup_xfail "tic6x-*-*"
+    # Fails on MIPS because ABI trickery means that a NULL reloc is also emitted.
+    setup_xfail "mips*-*-*"
+    # Fails on bfin because relocations are not created.
+    setup_xfail "bfin-*-*"
+    run_ld_link_tests {
+       {"-Bsymbolic-functions"
+           "-shared -Bsymbolic-functions" "" ""
+           {symbolic-func.s} {{readelf {-r --wide} symbolic-func.r}}
+           "symbolic-func.so"}
+    }
 }
 
 set test_list [lsort [glob -nocomplain $srcdir/$subdir/*.d]]
@@ -102,6 +136,41 @@ foreach t $test_list {
     run_dump_test [file rootname $t]
 }
 
+# Targets using the generic linker backend don't support generating
+# an import library.
+set xfail_implib ""
+if { [istarget "d30v-*-*"]
+     || [istarget "dlx-*-*"]
+     || [istarget "fr30-*-*"]
+     || ([istarget "frv-*-*"] && ![istarget "frv-*-linux*"])
+     || [istarget "ft32-*-*"]
+     || [istarget "i860-*-*"]
+     || [istarget "i960-*-*"]
+     || [istarget "iq2000-*-*"]
+     || [istarget "mn10200-*-*"]
+     || [istarget "moxie-*-*"]
+     || [istarget "msp430-*-*"]
+     || [istarget "mt-*-*"]
+     || [istarget "pj*-*-*"] } {
+    set xfail_implib "*-*-*"
+}
+
+# Check that the --out-implib option work correctly.
+run_ld_link_tests {
+    {"Generate empty import library"
+       "--out-implib=tmpdir/implib.lib" ""
+       "--defsym NO_GLOBAL=1"
+       {implib.s}
+       {{ld empty-implib.out}}
+       "implib"}
+    {"Generate import library"
+       "--out-implib=tmpdir/implib.lib" ""
+       ""
+       {implib.s}
+       {{readelf {-s tmpdir/implib.lib} implib.rd}}
+       "implib"}
+} $xfail_implib
+
 if { [istarget *-*-linux*]
      || [istarget *-*-nacl*]
      || [istarget *-*-gnu*] } {
This page took 0.025023 seconds and 4 git commands to generate.