X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=ld%2Ftestsuite%2Fld-srec%2Fsrec.exp;h=0a3dc4440810dffe5c70c7e2611833a01c5fae91;hb=1b66220522691049e2a4c477d32fd8bc0f6f63c1;hp=f0ef1ae1ef9119b18408e5d6bf54d68eec2899bf;hpb=aa820537ead0135a7c38c619039dce8a6fc74ed1;p=deliverable%2Fbinutils-gdb.git diff --git a/ld/testsuite/ld-srec/srec.exp b/ld/testsuite/ld-srec/srec.exp index f0ef1ae1ef..0a3dc44408 100644 --- a/ld/testsuite/ld-srec/srec.exp +++ b/ld/testsuite/ld-srec/srec.exp @@ -229,9 +229,9 @@ proc run_srec_test { test objs } { global host_triplet # Tell the ELF linker to not do anything clever with .eh_frame, - # not to put anything in small data, and define a symbol referenced - # by gcc -fstack-protector code. - set flags "--traditional-format -G 0 --defsym __stack_chk_fail=0" + # not to put anything in small data, and define various symbols. + set flags "--traditional-format -G 0 " + append flags [ld_simple_link_defsyms] # 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 @@ -244,7 +244,7 @@ proc run_srec_test { test objs } { if [istarget sh64*-*-elf] { # This is what gcc passes to ld by default. - set flags "-mshelf32" + set flags "$flags -mshelf32" # SH64 targets cannot convert format in the linker # using the -oformat command line switch. setup_xfail "sh64*-*-*" @@ -254,10 +254,6 @@ proc run_srec_test { test objs } { [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*-*-*" @@ -265,23 +261,6 @@ proc run_srec_test { test objs } { 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" @@ -292,13 +271,6 @@ proc run_srec_test { test objs } { 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"] } { fail $test @@ -395,6 +367,9 @@ setup_xfail "ia64-*-*" setup_xfail "*-*-cygwin*" "*-*-mingw*" "*-*-pe*" "*-*-winnt*" setup_xfail "score-*-*" +# The S-record linker doesn't support Blackfin ELF FDPIC ABI. +setup_xfail "bfin-*-linux-uclibc" + run_srec_test $test1 "tmpdir/sr1.o tmpdir/sr2.o" # Now try linking a C++ program with global constructors and @@ -425,5 +400,6 @@ setup_xfail "hppa*-*-*" "mep-*-*" setup_xfail "ia64-*-*" setup_xfail "*-*-cygwin*" "*-*-mingw*" "*-*-pe*" "*-*-winnt*" setup_xfail "score-*-*" +setup_xfail "bfin-*-linux-uclibc" run_srec_test $test2 "tmpdir/sr3.o"