Use better test for usable compiler in ld testsuite.
[deliverable/binutils-gdb.git] / ld / testsuite / ld-mn10300 / mn10300.exp
index 14ba85b20ab3e5efbaa69e650bd0599fb065e425..b78ef55965d2d7f842bcf5075b91a7967069c5b8 100644 (file)
@@ -1,5 +1,5 @@
 # Expect script for ld-mn10300 tests
-#   Copyright (C) 2007 Free Software Foundation
+#   Copyright (C) 2007-2019 Free Software Foundation, Inc.
 #
 # This file is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -13,7 +13,8 @@
 #
 # You should have received a copy of the GNU General Public License
 # along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
+# MA 02110-1301, USA.
 #
 
 if {!([istarget "am3*-*-*"]) && !([istarget "mn10300*-*-*"]) } {
@@ -22,38 +23,103 @@ if {!([istarget "am3*-*-*"]) && !([istarget "mn10300*-*-*"]) } {
 
 # Set up a list as described in ld-lib.exp
 
-set am33_tests {
+set mn10300_tests {
     {
        "am33 string merging"
-       "--relax -Ttext 0x8000000"
+       "-relax -Ttext 0x8000074" ""
        ""
        { "i36434.s" "i36434-2.s" }
        { {objdump -dz i36434.d} }
        "i36434.x"
     }
     {
-       "difference of two symbols"
-       "-Ttext 0"
+       "difference of two same-section symbols"
+       "-Ttext 0" ""
        ""
        { "i112045-1.s" }
        { {objdump -d i112045-1.d} }
        "i112045-1.x"
     }
     {
-       "(shared) difference of two symbols"
-       "-shared"
+       "difference of two same-section symbols where the difference is held in another section"
+       "-relax -Ttext 100" ""
        ""
-       { "i112045-2.s" }
-       { {objdump -R i112045-2.d} }
-       "i112045-2.x"
+       { "i112045-3.s" }
+       { {objdump -D i112045-3.d} }
+       "i112045-3.x"
+    }
+    {
+       "relaxation and alignment directives"
+       "-relax -Ttext 100 -Tbss 300" ""
+       ""
+       { "i127740.s" }
+       { {objdump -d i127740.d} }
+       "i127740.x"
     }
     {
        "adjustment of symbols due to relaxation"
-       "-Tdata 1f -relax"
+       "-Tdata 1f -Ttext 0 -relax" ""
+       ""
+       { "i135409-1.s" }
+       { {readelf --syms i135409-1.d} }
+       "i135409-1.x"
+    }
+    {
+       "adjustment of symbols due to relaxation (with alignment directives)"
+       "-Tdata 1f -Ttext 0 -relax" ""
+       ""
+       { "i135409-2.s" }
+       { {readelf --syms i135409-2.d} }
+       "i135409-2.x"
+    }
+    {
+       "adjustment of symbols due to relaxation (with a symbol in the deleted region)"
+       "-Tdata 1f -Ttext 0 -relax" ""
+       ""
+       { "i135409-3.s" }
+       { {objdump -d i135409-3.d} }
+       "i135409-3.x"
+    }
+    {
+       "adjusting a 16-bit forward branch"
+       "-Ti135409-4.t -relax" ""
+       ""
+       { "i135409-4.s" }
+       { {objdump -d i135409-4.d} }
+       "i135409-4.x"
+    }
+    {
+       "adjusting a 16-bit backward branch"
+       "-Ti135409-5.t -relax" ""
        ""
-       { "i135409.s" }
-       { {readelf --syms i135409.d } }
-       "i135409.x"
+       { "i135409-5.s" }
+       { {objdump -d i135409-5.d} }
+       "i135409-5.x"
+    }
+    {
+       "relaxing offsets into a merged string section"
+       "-Ti143317.t -shared -relax" ""
+       ""
+       { "i143317.s" }
+       { {objdump -d i143317.d} }
+       "i143317.x"
+    }
+}
+
+run_ld_link_tests $mn10300_tests
+
+if {!([istarget "am3*-*-*"])} {
+    return
+}
+
+set am33_tests {
+    {
+       "difference of two same-section symbols (in a shared library)"
+       "-shared" ""
+       ""
+       { "i112045-2.s" }
+       { {objdump -R i112045-2.d} }
+       "i112045-2.x"
     }
 }
 
@@ -66,7 +132,11 @@ proc i126256-test { } {
     global subdir
 
     set tmpdir tmpdir
-    set testname "Issue 126256 - seg fault whilst linking one shared library into another when relaxation is enabled."
+    set testname "Seg fault whilst linking one shared library into another when relaxation is enabled."
+
+    if { ![check_compiler_available] } then {
+       return
+    }
 
     if { ![ld_compile "$CC -mrelax -fPIC" $srcdir/$subdir/i126256-1.c $tmpdir/i126256-1.o] } {
        unresolved $testname
@@ -78,12 +148,12 @@ proc i126256-test { } {
        return
     }
     
-    if { ![ld_simple_link $ld $tmpdir/i126256-1.so "-shared $tmpdir/i126256-1.o -e 0"]} {
+    if { ![ld_link $ld $tmpdir/i126256-1.so "-shared $tmpdir/i126256-1.o -e 0"]} {
         unresolved $testname
        return
     }
 
-    if { ![ld_simple_link $ld $tmpdir/i126256-2.so "--relax -shared $tmpdir/i126256-2.o $tmpdir/i126256-1.so -e 0"]} {
+    if { ![ld_link $ld $tmpdir/i126256-2.so "--relax -shared $tmpdir/i126256-2.o $tmpdir/i126256-1.so -e 0"]} {
         fail $testname
        return
     }
This page took 0.025668 seconds and 4 git commands to generate.