]> Git Repo - binutils.git/blobdiff - ld/testsuite/ld-pe/pe.exp
Add support for COFF secidx relocations
[binutils.git] / ld / testsuite / ld-pe / pe.exp
index 17991892515dc3a2ded622a44e4a07055431e472..413b316f152ead41457146810404e797d9bf712d 100644 (file)
@@ -1,5 +1,5 @@
 # Expect script for simple PE tests that require the just-built binutils only.
-#   Copyright (C) 2004-2015 Free Software Foundation, Inc.
+#   Copyright (C) 2004-2022 Free Software Foundation, Inc.
 #
 # This file is part of the GNU Binutils.
 #
@@ -33,8 +33,10 @@ if {[istarget i*86-*-cygwin*]
 
     if {[istarget x86_64-*-mingw*] } {
       set pe_tests {
-       {".secrel32" "" "" "" {secrel1.s secrel2.s}
+       {".secrel32" "--disable-reloc-section" "" "" {secrel1.s secrel2.s}
         {{objdump -s secrel_64.d}} "secrel.x"}
+       {".secidx" "--disable-reloc-section" "" "" {secidx1.s secidx2.s}
+        {{objdump -s secidx_64.d}} "secidx.x"}
        {"Empty export table" "" "" "" "exports.s"
         {{objdump -p exports64.d}} "exports.dll"}
        {"TLS directory entry" "" "" "" "tlssec.s"
@@ -42,7 +44,18 @@ if {[istarget i*86-*-cygwin*]
       }
     } elseif {[istarget i*86-*-cygwin*] } {
       set pe_tests {
-       {".secrel32" "--disable-auto-import" "" "" {secrel1.s secrel2.s}
+       {".secrel32" "--disable-auto-import --disable-reloc-section" "" "" {secrel1.s secrel2.s}
+        {{objdump -s secrel.d}} "secrel.x"}
+       {".secidx" "--disable-auto-import --disable-reloc-section" "" "" {secidx1.s secidx2.s}
+        {{objdump -s secidx.d}} "secidx.x"}
+       {"Empty export table" "" "" "" "exports.s"
+        {{objdump -p exports.d}} "exports.dll"}
+       {"TLS directory entry" "" "" "" "tlssec.s"
+        {{objdump -p tlssec32.d}} "tlssec.dll"}
+      }
+    } elseif {[istarget arm-wince-pe] } {
+      set pe_tests {
+       {".secrel32" "--disable-reloc-section" "" "" {secrel1.s secrel2.s}
         {{objdump -s secrel.d}} "secrel.x"}
        {"Empty export table" "" "" "" "exports.s"
         {{objdump -p exports.d}} "exports.dll"}
@@ -51,8 +64,10 @@ if {[istarget i*86-*-cygwin*]
       }
     } else {
       set pe_tests {
-       {".secrel32" "" "" "" {secrel1.s secrel2.s}
+       {".secrel32" "--disable-reloc-section" "" "" {secrel1.s secrel2.s}
         {{objdump -s secrel.d}} "secrel.x"}
+       {".secidx" "--disable-reloc-section" "" "" {secidx1.s secidx2.s}
+        {{objdump -s secidx.d}} "secidx.x"}
        {"Empty export table" "" "" "" "exports.s"
         {{objdump -p exports.d}} "exports.dll"}
        {"TLS directory entry" "" "" "" "tlssec.s"
@@ -76,6 +91,25 @@ run_dump_test "longsecn-5"
 run_dump_test "orphan"
 run_dump_test "orphan_nu"
 
+run_dump_test "reloc"
+
+run_dump_test "weakdef-1"
+
+run_dump_test "pr19803"
+run_dump_test "pr26659-weak-undef-sym"
+set pr19803_dll {
+    {   "PR 19803: not exporting swept symbols"
+       "-shared --out-implib dx.dll --gc-sections"
+       "" "" {pr19803.s}
+       {{objdump "--syms dx.dll" pr19803.e}}
+       "a.exe"}
+}
+# This test is *supposed* to fail.  If the symbol defined in pr19803.e is
+# found then it was not stripped from the export dll, despite the fact that
+# it (should have been) garbage collected from the executable.
+setup_xfail *-*-*
+run_ld_link_tests $pr19803_dll
+
 if {[istarget x86_64-*-mingw*] } {
        run_dump_test "cfi"
 } elseif {[istarget i*86-*-cygwin*] || [istarget i*86-*-mingw*] } {
@@ -87,4 +121,6 @@ set foreign_sym_test {
    {{nm -C non-c-lang-syms.d}} "non-c-lang-syms.x"}
 }
 
+# MCore rearranges symbol order.
+setup_xfail mcore-*-pe
 run_ld_link_tests $foreign_sym_test
This page took 0.027229 seconds and 4 git commands to generate.