X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=ld%2Ftestsuite%2Fld-srec%2Fsrec.exp;h=3b45a29c19b105b7e41694cc3c5cfd0d77245b8c;hb=ee58dd1ec5cfc8a91c5100c3f90bd81d4e1e10e4;hp=256e7b9616b90f2fa505e76d03924e96e54b0f63;hpb=3c6d5393c4705b748e27aef0e358164da1f8f252;p=binutils-gdb.git diff --git a/ld/testsuite/ld-srec/srec.exp b/ld/testsuite/ld-srec/srec.exp index 256e7b9616b..3b45a29c19b 100644 --- a/ld/testsuite/ld-srec/srec.exp +++ b/ld/testsuite/ld-srec/srec.exp @@ -1,6 +1,21 @@ # Test linking directly to S-records. # By Ian Lance Taylor, Cygnus Support. -# Public domain. +# Copyright 1999, 2000, 2001, 2002, 2003 +# 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 +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# 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., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. # Get the offset from an S-record line to the start of the data. @@ -210,21 +225,8 @@ proc run_srec_test { test objs } { global sizeof_headers global host_triplet - set flags "" - - # g++ sometimes generates references to __get_dynamic_handler_chain. - set flags "$flags --defsym __get_dynamic_handler_chain=0" - set flags "$flags --defsym ___get_dynamic_handler_chain=0" - - # The mn10200 has out of line prologues and epilogues which the - # comiler uses when compiling the testcase. Define them so that - # we don't need to bring in libgcc.a - if [istarget mn10200-*-*] { - set flags "$flags --defsym ___prologue=0" - set flags "$flags --defsym ___epilogue_noreturn=0" - set flags "$flags --defsym ___epilogue_d0=0" - set flags "$flags --defsym ___epilogue_a0=0" - } + # Tell the ELF linker to not do anything clever with .eh_frame. + set flags "--traditional-format" # If the linker script uses SIZEOF_HEADERS, use a -Ttext argument # to force both the normal link and the S-record link to be put in @@ -242,14 +244,65 @@ proc run_srec_test { test objs } { set flags "$flags --defsym V_SPILL=0 --defsym V_FILL=0" } + if [istarget sh64*-*-elf] { + # This is what gcc passes to ld by default. + set flags "-mshelf32" + # SH64 targets cannot convert format in the linker + # using the -oformat command line switch. + setup_xfail "sh64*-*-*" + } + + if {[istarget arm*-*-*] || \ + [istarget strongarm*-*-*] || \ + [istarget xscale*-*-*] || \ + [istarget thumb-*-*] } { + + # ARM targets call __gccmain + set flags "$flags --defsym __gccmain=0" + + # ARM targets cannot convert format in the linker + # using the --oformat command line switch + setup_xfail "*arm*-*-*" + setup_xfail "xscale-*-*" + setup_xfail "thumb-*-*" + } + # PowerPC EABI code calls __eabi. if [istarget powerpc*-*-eabi*] { set flags "$flags --defsym __eabi=0" } + # mn10200 code calls __truncsipsi2_d0_d2. + if {[istarget mn10200*-*-*]} then { + set flags "$flags --defsym __truncsipsi2_d0_d2=0" + } + + # m6811/m6812 code has references to soft registers. + if {[istarget m6811-*-*] || [istarget m6812-*-*]} { + set flags "$flags --defsym _.frame=0 --defsym _.d1=0 --defsym _.d2=0" + set flags "$flags --defsym _.d3=0 --defsym _.d4=0" + set flags "$flags --defsym _.tmp=0 --defsym _.xy=0 --defsym _.z=0" + } + + # V850 targets need libgcc.a + if [istarget v850*-*-elf] { + set objs "$objs -L ../gcc -lgcc" + } + + # Xtensa ELF targets relax by default; S-Record linker does not + if [istarget xtensa*-*-*] { + set flags "$flags -no-relax" + } + + # Some OpenBSD targets have ProPolice and reference __guard and + # __stack_smash_handler. + if [istarget *-*-openbsd*] { + set flags "$flags --defsym __guard=0" + set flags "$flags --defsym __stack_smash_handler=0" + } + if { ![ld_simple_link $ld tmpdir/sr1 "$flags $objs"] \ - || ![ld_simple_link $ld tmpdir/sr2.sr "$flags -oformat srec $objs"] } { - setup_xfail "hppa*-*-*elf*" + || ![ld_simple_link $ld tmpdir/sr2.sr "$flags --oformat srec $objs"] } { fail $test return } @@ -308,12 +361,43 @@ setup_xfail "i*86-*-aout*" # These tests fail on the native MIPS ELF targets because the GP value # in the .reginfo section is not updated when the S-record version is # written out. The mips-elf target itself does not use a .reginfo section. -setup_xfail "mips*-*-irix5*" "mips*-*-irix6*" +setup_xfail "mips*-*-irix5*" "mips*-*-irix6*" "mips*-*-linux*" # The S-record linker doesn't do the magic TOC handling that XCOFF # linkers do. setup_xfail "*-*-aix*" "*-*-xcoff*" + +# The S-record linker doesn't build ARM/Thumb stubs. setup_xfail "arm-*-coff" +setup_xfail "strongarm*-*-coff" +setup_xfail "xscale*-*-coff" +setup_xfail "arm-*-pe*" +# setup_xfail "arm-*elf*" +setup_xfail "thumb-*-coff*" +setup_xfail "thumb-*-pe*" +setup_xfail "thumb-*-elf*" +setup_xfail "arm*-*-linux*" + +# The S-record linker doesn't build special EABI sections. +# setup_xfail "powerpc*-*-eabi*" + +# The S-record linker doesn't include the .{zda} sections. +setup_xfail "v850*-*-elf" + +# The S-record linker doesn't handle Alpha Elf relaxation. +setup_xfail "alpha*-*-elf*" "alpha*-*-linux-*" "alpha*-*-gnu*" +setup_xfail "alpha*-*-netbsd*" + +# The S-record linker hasn't any hope of coping with HPPA relocs. +setup_xfail "hppa*-*-*" + +# The S-record linker doesn't handle IA64 Elf relaxation. +setup_xfail "ia64-*-*" + +# The S-record linker doesn't support the special PE headers - the PE +# emulation tries to write pe-specific information to the PE headers +# in the output bfd, but it's not a PE bfd (it's an srec bfd) +setup_xfail "*-*-cygwin*" "*-*-mingw*" "*-*-pe*" "*-*-winnt*" run_srec_test $test1 "tmpdir/sr1.o tmpdir/sr2.o" @@ -326,15 +410,24 @@ if { [which $CXX] == 0 } { return } -if ![ld_compile "$CXX $CXXFLAGS -fgnu-linker" $srcdir/$subdir/sr3.cc tmpdir/sr3.o] { +if ![ld_compile "$CXX $CXXFLAGS -fno-exceptions" $srcdir/$subdir/sr3.cc tmpdir/sr3.o] { unresolved $test2 return } # See above. setup_xfail "i*86-*-aout*" -setup_xfail "mips*-*-irix5*" "mips*-*-irix6*" +setup_xfail "mips*-*-irix5*" "mips*-*-irix6*" "mips*-*-linux*" setup_xfail "*-*-aix*" "*-*-xcoff*" -setup_xfail "arm-*-coff" +setup_xfail "arm*-*-*" +setup_xfail "strongarm*-*-*" +setup_xfail "thumb-*-*" +setup_xfail "powerpc*-*-eabi*" +setup_xfail "v850*-*-elf" +setup_xfail "alpha*-*-elf*" "alpha*-*-linux-*" "alpha*-*-gnu*" +setup_xfail "alpha*-*-netbsd*" +setup_xfail "hppa*-*-*" +setup_xfail "ia64-*-*" +setup_xfail "*-*-cygwin*" "*-*-mingw*" "*-*-pe*" "*-*-winnt*" run_srec_test $test2 "tmpdir/sr3.o"