2016-01-01 11:25:12 +00:00
|
|
|
# Copyright (C) 1994-2016 Free Software Foundation, Inc.
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
2007-07-05 16:54:46 +00:00
|
|
|
# the Free Software Foundation; either version 3 of the License, or
|
1999-05-03 07:29:11 +00:00
|
|
|
# (at your option) any later version.
|
2015-10-15 11:07:13 +00:00
|
|
|
#
|
1999-05-03 07:29:11 +00:00
|
|
|
# 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.
|
2015-10-15 11:07:13 +00:00
|
|
|
#
|
1999-05-03 07:29:11 +00:00
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
2005-05-08 14:17:41 +00:00
|
|
|
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
# Please email any bugs, comments, and/or additions to this file to:
|
|
|
|
# bug-dejagnu@prep.ai.mit.edu
|
|
|
|
|
|
|
|
# Written by Ian Lance Taylor <ian@cygnus.com>
|
|
|
|
|
|
|
|
if ![is_remote host] {
|
|
|
|
if {[which $OBJCOPY] == 0} then {
|
|
|
|
perror "$OBJCOPY does not exist"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
send_user "Version [binutil_version $OBJCOPY]"
|
|
|
|
|
|
|
|
if ![is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set tempfile tmpdir/bintest.o
|
|
|
|
set copyfile tmpdir/copy
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
|
|
|
set tempfile [remote_download host tmpdir/bintest.o]
|
|
|
|
set copyfile copy
|
|
|
|
}
|
|
|
|
|
|
|
|
# Test that objcopy does not modify a file when copying it.
|
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
proc objcopy_test {testname srcfile} {
|
|
|
|
global OBJCOPY
|
|
|
|
global OBJCOPYFLAGS
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
global tempfile
|
|
|
|
global copyfile
|
1999-05-03 07:29:11 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
if {![binutils_assemble $srcdir/$subdir/${srcfile} $tempfile]} then {
|
2005-10-19 20:49:03 +00:00
|
|
|
perror "unresolved $testname"
|
|
|
|
unresolved "objcopy ($testname)"
|
2016-06-22 13:42:26 +00:00
|
|
|
remote_file host delete $tempfile
|
2005-10-19 20:49:03 +00:00
|
|
|
return
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS $tempfile ${copyfile}.o"]
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
2005-10-19 20:49:03 +00:00
|
|
|
fail "objcopy ($testname)"
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
2005-10-19 20:49:03 +00:00
|
|
|
send_log "cmp $tempfile ${copyfile}.o\n"
|
|
|
|
verbose "cmp $tempfile ${copyfile}.o"
|
|
|
|
if [is_remote host] {
|
|
|
|
set src1 tmpdir/bintest.o
|
|
|
|
set src2 tmpdir/copy.o
|
|
|
|
remote_upload host $tempfile $src1
|
|
|
|
remote_upload host ${copyfile}.o $src2
|
|
|
|
} else {
|
|
|
|
set src1 ${tempfile}
|
|
|
|
set src2 ${copyfile}.o
|
|
|
|
}
|
|
|
|
set status [remote_exec build cmp "${src1} ${src2}"]
|
|
|
|
set exec_output [lindex $status 1]
|
|
|
|
set exec_output [prune_warnings $exec_output]
|
|
|
|
|
|
|
|
# On some systems the result of objcopy will not be identical.
|
|
|
|
# Usually this is just because gas isn't using bfd to write the
|
|
|
|
# files in the first place, and may order things a little
|
|
|
|
# differently. Those systems should use setup_xfail here.
|
|
|
|
|
2010-09-23 12:04:37 +00:00
|
|
|
setup_xfail "h8300-*-coff"
|
2005-10-19 20:49:03 +00:00
|
|
|
setup_xfail "h8500-*-rtems*" "h8500-*-coff"
|
|
|
|
setup_xfail "hppa*-*-*"
|
|
|
|
setup_xfail "i960-*"
|
|
|
|
setup_xfail "m68*-*-*coff" "m68*-*-hpux*" "m68*-*-lynxos*"
|
|
|
|
setup_xfail "m68*-*-sysv*" "m68*-apple-aux*"
|
|
|
|
setup_xfail "m8*-*"
|
2011-05-13 04:14:51 +00:00
|
|
|
setup_xfail "sh-*-coff*"
|
|
|
|
setup_xfail "tic80-*-*" "w65-*"
|
2005-10-19 20:49:03 +00:00
|
|
|
|
|
|
|
clear_xfail "hppa*64*-*-hpux*" "hppa*-*-linux*" "hppa*-*-lites*"
|
|
|
|
clear_xfail "hppa*-*-*n*bsd*" "hppa*-*-rtems*" "*-*-*elf*"
|
|
|
|
clear_xfail "m68*-*-sysv4*"
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if [string equal "" $exec_output] then {
|
2005-10-19 20:49:03 +00:00
|
|
|
pass "objcopy ($testname)"
|
|
|
|
} else {
|
|
|
|
send_log "$exec_output\n"
|
|
|
|
verbose "$exec_output" 1
|
1999-05-03 07:29:11 +00:00
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
# On OSF/1, this succeeds with gas and fails with /bin/as.
|
|
|
|
setup_xfail "alpha*-*-osf*"
|
1999-05-03 07:29:11 +00:00
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
fail "objcopy ($testname)"
|
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
objcopy_test "simple copy" bintest.s
|
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
if { [file exists $tempfile] } {
|
|
|
|
# Test reversing bytes in a section.
|
2007-04-23 10:59:07 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
set reversed ${tempfile}-reversed
|
|
|
|
set sect_names [get_standard_section_names]
|
|
|
|
if { $sect_names != "" } {
|
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -j [lindex $sect_names 1] --reverse-bytes=4 $tempfile $reversed"]
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -j .data --reverse-bytes=4 $tempfile $reversed"]
|
2007-04-23 10:59:07 +00:00
|
|
|
}
|
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
if ![string equal "" $got] then {
|
|
|
|
fail "objcopy --reverse-bytes"
|
|
|
|
} else {
|
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host ${reversed} tmpdir/copy-reversed.o
|
|
|
|
set reversed tmpdir/copy-reversed.o
|
|
|
|
}
|
2007-04-23 10:59:07 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
set origdata [binutils_run $OBJDUMP "$OBJDUMPFLAGS -s -j .data $tempfile"]
|
|
|
|
set revdata [binutils_run $OBJDUMP "$OBJDUMPFLAGS -s -j .data $reversed"]
|
2007-04-23 10:59:07 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
set want "^ \[0-9\]+ (\[0-9\]+)"
|
|
|
|
set found_orig [regexp -lineanchor $want $origdata -> origdata]
|
|
|
|
set found_rev [regexp -lineanchor $want $revdata -> revdata]
|
2011-01-01 01:56:59 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
if {$found_orig == 0 || $found_rev == 0} then {
|
|
|
|
# som doesn't have a .data section
|
|
|
|
setup_xfail "hppa*-*-hpux*"
|
|
|
|
clear_xfail "hppa*64*-*-hpux*"
|
2007-04-23 10:59:07 +00:00
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
fail "objcopy --reverse-bytes"
|
|
|
|
} else {
|
|
|
|
scan $origdata "%2x%2x%2x%2x" b1 b2 b3 b4
|
|
|
|
scan $revdata "%2x%2x%2x%2x" c4 c3 c2 c1
|
|
|
|
|
|
|
|
if {$b1 == $c1 && $b2 == $c2 && $b3 == $c3 && $b4 == $c4} then {
|
|
|
|
pass "objcopy --reverse-bytes"
|
|
|
|
} else {
|
|
|
|
fail "objcopy --reverse-bytes"
|
|
|
|
}
|
|
|
|
}
|
2007-04-23 10:59:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-09-10 12:11:28 +00:00
|
|
|
# Test interleaved copy of multiple byte width
|
|
|
|
|
|
|
|
set sequence_file sequence_file
|
|
|
|
set file [open ${sequence_file} w]
|
|
|
|
puts ${file} "12345678"
|
|
|
|
close ${file}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host ${sequence_file} tmpdir/sequence_file
|
|
|
|
set sequence_file tmpdir/sequence_file
|
|
|
|
}
|
|
|
|
|
|
|
|
set got [binutils_run $OBJCOPY "-I binary -i 4 -b 0 --interleave-width 2 ${sequence_file} ${copyfile}"]
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
2010-09-10 12:11:28 +00:00
|
|
|
fail "objcopy -i --interleave-width"
|
|
|
|
} else {
|
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host ${copyfile} tmpdir/interleave_output
|
|
|
|
set interleave_output tmpdir/interleave_output
|
|
|
|
} else {
|
|
|
|
set interleave_output ${copyfile}
|
|
|
|
}
|
|
|
|
|
|
|
|
set file [open ${interleave_output} r]
|
|
|
|
gets $file line
|
|
|
|
send_log "$line\n"
|
|
|
|
verbose $line
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "1256" $line] then {
|
2010-09-10 12:11:28 +00:00
|
|
|
fail "objcopy -i --interleave-width"
|
|
|
|
}
|
|
|
|
pass "objcopy -i --interleave-width"
|
|
|
|
|
|
|
|
close $file
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
# Test generating S records.
|
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
if { [file exists $tempfile] } {
|
|
|
|
# We make the srec filename 8.3 compatible. Note that the header string
|
|
|
|
# matched against depends on the name of the file. Ugh.
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
if [is_remote host] {
|
2016-06-22 13:42:26 +00:00
|
|
|
set srecfile copy.sre
|
|
|
|
set header_string S00B0000636F70792E737265C1
|
|
|
|
} else {
|
|
|
|
set srecfile ${copyfile}.srec
|
|
|
|
set header_string S0130000746D706469722F636F70792E7372656397
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec $tempfile ${srecfile}"]
|
|
|
|
|
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy -O srec"
|
|
|
|
} else {
|
2016-06-22 13:42:26 +00:00
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host ${srecfile} tmpdir/copy.srec
|
|
|
|
set srecfile tmpdir/copy.srec
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
2016-06-22 13:42:26 +00:00
|
|
|
set file [open ${srecfile} r]
|
|
|
|
|
|
|
|
# The first S record is fixed by the file name we are using.
|
|
|
|
gets $file line
|
1999-05-03 07:29:11 +00:00
|
|
|
send_log "$line\n"
|
|
|
|
verbose $line
|
2016-06-22 13:42:26 +00:00
|
|
|
if ![regexp "$header_string.*" $line] {
|
|
|
|
send_log "bad header\n"
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy -O srec"
|
|
|
|
} else {
|
2016-06-22 13:42:26 +00:00
|
|
|
while {[gets $file line] != -1 \
|
|
|
|
&& [regexp "^S\[123\]\[0-9a-fA-F\]+\[\r\n\]*$" $line]} {
|
1999-05-03 07:29:11 +00:00
|
|
|
send_log "$line\n"
|
|
|
|
verbose $line
|
2016-06-22 13:42:26 +00:00
|
|
|
set line "**EOF**"
|
|
|
|
}
|
|
|
|
send_log "$line\n"
|
|
|
|
verbose $line
|
|
|
|
if ![regexp "^S\[789\]\[0-9a-fA-F\]+\[\r\n\]*$" $line] then {
|
|
|
|
send_log "bad trailer\n"
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy -O srec"
|
|
|
|
} else {
|
2016-06-22 13:42:26 +00:00
|
|
|
if {[gets $file line] != -1} then {
|
|
|
|
send_log "garbage at end\n"
|
|
|
|
send_log "$line\n"
|
|
|
|
verbose $line
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy -O srec"
|
|
|
|
} else {
|
2016-06-22 13:42:26 +00:00
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -f ${srecfile}"]
|
|
|
|
if ![regexp "file format srec" $got] then {
|
|
|
|
send_log "objdump failed\n"
|
|
|
|
fail "objcopy -O srec"
|
|
|
|
} else {
|
|
|
|
pass "objcopy -O srec"
|
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-22 13:42:26 +00:00
|
|
|
close $file
|
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Test setting and adjusting the start address. We only test this
|
|
|
|
# while generating S records, because we may not be able to set the
|
|
|
|
# start address for other object file formats, and the S record case
|
|
|
|
# is the only useful one anyhow.
|
|
|
|
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -f $tempfile"]
|
|
|
|
if ![regexp "start address (\[0-9a-fA-FxX\]+)" $got all origstart] then {
|
|
|
|
perror "objdump can not recognize bintest.o"
|
|
|
|
set origstart ""
|
|
|
|
} else {
|
2004-02-20 15:21:54 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec --set-start 0x7654 $tempfile ${copyfile}.srec"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy --set-start"
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -f ${copyfile}.srec"]
|
|
|
|
if ![regexp "file format srec.*start address (\[0-9a-fA-FxX\]+)" $got all srecstart] then {
|
|
|
|
fail "objcopy --set-start"
|
|
|
|
} else {
|
|
|
|
if {$srecstart != 0x7654} then {
|
|
|
|
send_log "$srecstart != 0x7654\n"
|
|
|
|
fail "objcopy --set-start"
|
|
|
|
} else {
|
|
|
|
pass "objcopy --set-start"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-02-20 15:21:54 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec --adjust-start 0x123 $tempfile ${copyfile}.srec"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy --adjust-start"
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -f ${copyfile}.srec"]
|
|
|
|
if ![regexp "file format srec.*start address (\[0-9a-fA-FxX\]+)" $got all srecstart] then {
|
|
|
|
fail "objcopy --adjust-start"
|
|
|
|
} else {
|
|
|
|
if {$srecstart != $origstart + 0x123} then {
|
|
|
|
send_log "$srecstart != $origstart + 0x123\n"
|
|
|
|
fail "objcopy --adjust-start"
|
|
|
|
} else {
|
|
|
|
pass "objcopy --adjust-start"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Test adjusting the overall VMA, and adjusting the VMA of a
|
|
|
|
# particular section. We again only test this when generating S
|
|
|
|
# records.
|
|
|
|
|
|
|
|
set low ""
|
|
|
|
set lowname ""
|
|
|
|
|
|
|
|
set headers [binutils_run $OBJDUMP "$OBJDUMPFLAGS -h $tempfile"]
|
|
|
|
|
|
|
|
set headers_regexp "\[ 0-9\]+(\[^ \]+)\[ \]*(\[0-9a-fA-F\]+)\[ \]+\[0-9a-fA-F\]+\[ \]+(\[0-9a-fA-F\]+)\[ \]+\[0-9a-fA-F\]+\[ \]+2\[*\]\[*\]\[0-9\]+(.*)"
|
|
|
|
|
|
|
|
set got $headers
|
|
|
|
while {[regexp $headers_regexp $got all name size vma rest]} {
|
|
|
|
set vma 0x$vma
|
|
|
|
set size 0x$size
|
|
|
|
if {$size != 0} {
|
|
|
|
if {$low == "" || $vma < $low} {
|
|
|
|
set low $vma
|
|
|
|
set lowname $name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
set got $rest
|
|
|
|
}
|
|
|
|
|
|
|
|
if {$low == "" || $origstart == ""} then {
|
|
|
|
perror "objdump can not recognize bintest.o"
|
|
|
|
} else {
|
2004-02-20 15:21:54 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec --adjust-vma 0x123 $tempfile ${copyfile}.srec"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy --adjust-vma"
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -fh ${copyfile}.srec"]
|
|
|
|
set want "file format srec.*start address\[ \]*(\[0-9a-fA-FxX\]+).*sec1\[ \]+\[0-9a-fA-F\]+\[ \]+(\[0-9a-fA-F\]+)"
|
|
|
|
if ![regexp $want $got all start vma] then {
|
|
|
|
fail "objcopy --adjust-vma"
|
|
|
|
} else {
|
|
|
|
set vma 0x$vma
|
|
|
|
if {$vma != $low + 0x123} then {
|
|
|
|
send_log "$vma != $low + 0x123\n"
|
|
|
|
fail "objcopy --adjust-vma"
|
|
|
|
} else {
|
|
|
|
if {$start != $origstart + 0x123} then {
|
|
|
|
send_log "$start != $origstart + 0x123\n"
|
|
|
|
fail "objcopy --adjust-vma"
|
|
|
|
} else {
|
|
|
|
pass "objcopy --adjust-vma"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
set arg ""
|
|
|
|
set got $headers
|
|
|
|
while {[regexp $headers_regexp $got all name size vma rest]} {
|
|
|
|
set vma 0x$vma
|
|
|
|
if {$vma == $low} then {
|
|
|
|
set arg "$arg --adjust-section-vma $name+4"
|
|
|
|
}
|
|
|
|
set got $rest
|
|
|
|
}
|
|
|
|
|
2004-02-20 15:21:54 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec $arg $tempfile ${copyfile}.srec"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy --adjust-section-vma +"
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -h ${copyfile}.srec"]
|
|
|
|
set want "file format srec.*sec1\[ \]+\[0-9a-fA-F\]+\[ \]+(\[0-9a-fA-F\]+)"
|
|
|
|
if ![regexp $want $got all vma] then {
|
|
|
|
fail "objcopy --adjust-section-vma +"
|
|
|
|
} else {
|
|
|
|
set vma 0x$vma
|
|
|
|
if {$vma != $low + 4} then {
|
|
|
|
send_log "$vma != $low + 4\n"
|
|
|
|
fail "objcopy --adjust-section-vma +"
|
|
|
|
} else {
|
|
|
|
pass "objcopy --adjust-section-vma +"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
regsub -all "\\+4" $arg "=[expr $low + 4]" argeq
|
2004-02-20 15:21:54 +00:00
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS -O srec $argeq $tempfile ${copyfile}.srec"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $got] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail "objcopy --adjust-section-vma ="
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -h ${copyfile}.srec"]
|
|
|
|
set want "file format srec.*sec1\[ \]+\[0-9a-fA-F\]+\[ \]+(\[0-9a-fA-F\]+)"
|
|
|
|
if ![regexp $want $got all vma] then {
|
|
|
|
fail "objcopy --adjust-section-vma ="
|
|
|
|
} else {
|
|
|
|
set vma 0x$vma
|
|
|
|
if {$vma != $low + 4} then {
|
|
|
|
send_log "$vma != $low + 4\n"
|
|
|
|
fail "objcopy --adjust-section-vma ="
|
|
|
|
} else {
|
|
|
|
pass "objcopy --adjust-section-vma ="
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Test stripping an object.
|
|
|
|
|
|
|
|
proc strip_test { } {
|
2001-11-29 17:34:07 +00:00
|
|
|
global AR
|
1999-05-03 07:29:11 +00:00
|
|
|
global CC
|
|
|
|
global STRIP
|
|
|
|
global STRIPFLAGS
|
|
|
|
global NM
|
|
|
|
global NMFLAGS
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
2011-06-30 21:41:05 +00:00
|
|
|
global READELF
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
set test "strip"
|
|
|
|
|
|
|
|
if { [target_compile $srcdir/$subdir/testprog.c tmpdir/testprog.o object debug] != "" } {
|
|
|
|
untested $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2011-06-30 21:41:05 +00:00
|
|
|
set osabi_fail "false"
|
|
|
|
if [is_elf_format] {
|
|
|
|
verbose -log "$READELF -a tmpdir/testprog.o > tmpdir/osabi.in"
|
|
|
|
set exec_output [remote_exec host "$READELF -h tmpdir/testprog.o" "" "/dev/null" "tmpdir/osabi.in"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
set osabi_fail "true"
|
|
|
|
} else {
|
|
|
|
verbose -log "grep OS/ABI tmpdir/osabi.in"
|
|
|
|
catch "exec grep OS/ABI tmpdir/osabi.in" osabi_in
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
if [is_remote host] {
|
2001-11-29 17:34:07 +00:00
|
|
|
set archive libstrip.a
|
2004-05-12 03:28:46 +00:00
|
|
|
set objfile [remote_download host tmpdir/testprog.o]
|
2001-11-29 17:34:07 +00:00
|
|
|
remote_file host delete $archive
|
|
|
|
} else {
|
|
|
|
set archive tmpdir/libstrip.a
|
|
|
|
set objfile tmpdir/testprog.o
|
|
|
|
}
|
|
|
|
|
|
|
|
remote_file build delete tmpdir/libstrip.a
|
|
|
|
|
|
|
|
set exec_output [binutils_run $AR "rc $archive ${objfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2001-11-29 17:34:07 +00:00
|
|
|
fail $test
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test preserving OS/ABI"
|
2001-11-29 17:34:07 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2006-04-25 14:06:10 +00:00
|
|
|
set exec_output [binutils_run $STRIP "-g $archive"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2006-04-25 14:06:10 +00:00
|
|
|
fail $test
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test preserving OS/ABI"
|
2006-04-25 14:06:10 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2001-11-29 17:34:07 +00:00
|
|
|
set exec_output [binutils_run $STRIP "$STRIPFLAGS $archive"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2001-11-29 17:34:07 +00:00
|
|
|
fail $test
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test preserving OS/ABI"
|
2001-11-29 17:34:07 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2011-06-30 21:41:05 +00:00
|
|
|
if { $osabi_fail != "true" && [is_elf_format] } {
|
|
|
|
verbose -log "$READELF -a tmpdir/testprog.o > tmpdir/osabi.out"
|
|
|
|
set exec_output [remote_exec host "$READELF -h tmpdir/testprog.o" "" "/dev/null" "tmpdir/osabi.out"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
} else {
|
|
|
|
verbose -log "grep OS/ABI tmpdir/osabi.out"
|
|
|
|
catch "exec grep OS/ABI tmpdir/osabi.out" osabi_out
|
|
|
|
if { "$osabi_in" == "$osabi_out" } {
|
|
|
|
pass "$test preserving OS/ABI"
|
|
|
|
} else {
|
|
|
|
fail "$test preserving OS/ABI"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-11-29 17:34:07 +00:00
|
|
|
if { [target_compile $srcdir/$subdir/testprog.c tmpdir/testprog.o object debug] != "" } {
|
|
|
|
untested $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set objfile [remote_download host tmpdir/testprog.o]
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
|
|
|
set objfile tmpdir/testprog.o
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $STRIP "$STRIPFLAGS $objfile"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $NM "-a $NMFLAGS $objfile"]
|
2002-08-26 23:15:48 +00:00
|
|
|
if ![string match "*: no symbols*" $exec_output] {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
pass $test
|
|
|
|
}
|
|
|
|
|
|
|
|
strip_test
|
|
|
|
|
|
|
|
# Test stripping an object file with saving a symbol
|
|
|
|
|
|
|
|
proc strip_test_with_saving_a_symbol { } {
|
|
|
|
global CC
|
|
|
|
global STRIP
|
|
|
|
global STRIPFLAGS
|
|
|
|
global NM
|
|
|
|
global NMFLAGS
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
|
|
|
|
set test "strip with saving a symbol"
|
|
|
|
|
|
|
|
if { [target_compile $srcdir/$subdir/testprog.c tmpdir/testprog.o object debug] != "" } {
|
|
|
|
untested $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set objfile [remote_download host tmpdir/testprog.o]
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
|
|
|
set objfile tmpdir/testprog.o
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $STRIP "$STRIPFLAGS -K main -K _main $objfile"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $NM "$NMFLAGS $objfile"]
|
2002-05-29 05:00:33 +00:00
|
|
|
if {![regexp {^([0-9a-fA-F]+)?[ ]+[TD] main} $exec_output] \
|
1999-05-03 07:29:11 +00:00
|
|
|
&& ![regexp {^([0-9a-fA-F]+)?[ ]+T _main} $exec_output]} {
|
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
pass $test
|
|
|
|
}
|
|
|
|
|
|
|
|
strip_test_with_saving_a_symbol
|
|
|
|
|
|
|
|
# Build a final executable.
|
|
|
|
|
2006-09-20 11:35:11 +00:00
|
|
|
if { [istarget *-*-cygwin] || [istarget *-*-mingw*] } {
|
2003-06-19 07:45:50 +00:00
|
|
|
set test_prog "testprog.exe"
|
|
|
|
} else {
|
|
|
|
set test_prog "testprog"
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
proc copy_setup { } {
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
2001-02-12 00:21:59 +00:00
|
|
|
global gcc_gas_flag
|
2003-06-19 07:45:50 +00:00
|
|
|
global test_prog
|
2008-07-08 08:15:09 +00:00
|
|
|
global host_triplet
|
2015-10-15 11:07:13 +00:00
|
|
|
|
2004-05-12 03:28:46 +00:00
|
|
|
set res [build_wrapper testglue.o]
|
|
|
|
set flags { debug }
|
2015-10-15 11:07:13 +00:00
|
|
|
|
2011-06-30 21:41:05 +00:00
|
|
|
if { [istarget *-*-uclinux*] && ![istarget tic6x-*-*] } {
|
2007-02-27 12:19:16 +00:00
|
|
|
return 1
|
|
|
|
}
|
2015-10-15 11:07:13 +00:00
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
if { $res != "" } {
|
2004-05-12 03:28:46 +00:00
|
|
|
lappend flags "additional_flags=[lindex $res 1]"
|
|
|
|
set add_libs "testglue.o"
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
2004-05-12 03:28:46 +00:00
|
|
|
set add_libs ""
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2010-11-08 06:43:40 +00:00
|
|
|
if { [istarget *-*-linux*]
|
|
|
|
|| [istarget *-*-gnu*] } {
|
2001-02-12 00:21:59 +00:00
|
|
|
foreach i $gcc_gas_flag {
|
|
|
|
set flags "additional_flags=$i $flags"
|
|
|
|
}
|
|
|
|
}
|
2003-06-19 07:45:50 +00:00
|
|
|
if { [target_compile "$srcdir/$subdir/testprog.c $add_libs" tmpdir/$test_prog executable $flags] != "" } {
|
1999-05-03 07:29:11 +00:00
|
|
|
return 2
|
|
|
|
}
|
|
|
|
|
2004-05-12 03:28:46 +00:00
|
|
|
set result [remote_load target tmpdir/$test_prog]
|
|
|
|
set status [lindex $result 0]
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
if { $status != "pass" } {
|
2008-07-08 08:15:09 +00:00
|
|
|
send_log "cannot run executable, status = ${status} on ${host_triplet}\n"
|
2015-10-15 11:07:13 +00:00
|
|
|
return 3
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
# Test copying an executable.
|
|
|
|
|
|
|
|
proc copy_executable { prog flags test1 test2 } {
|
2003-06-19 07:45:50 +00:00
|
|
|
global test_prog
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set testfile [remote_download host tmpdir/$test_prog]
|
1999-05-03 07:29:11 +00:00
|
|
|
set testcopy copyprog
|
|
|
|
} else {
|
2003-06-19 07:45:50 +00:00
|
|
|
set testfile tmpdir/$test_prog
|
1999-05-03 07:29:11 +00:00
|
|
|
set testcopy tmpdir/copyprog
|
|
|
|
}
|
2004-05-12 03:28:46 +00:00
|
|
|
remote_file host delete $testcopy
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
set exec_output [binutils_run $prog "$flags $testfile $testcopy"]
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test1
|
2015-10-15 11:07:13 +00:00
|
|
|
if [string equal "" $test2] {
|
2007-05-02 10:38:00 +00:00
|
|
|
return
|
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test2
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host $testcopy tmpdir/copyprog
|
|
|
|
}
|
|
|
|
|
2003-06-19 07:45:50 +00:00
|
|
|
set status [remote_exec build "cmp" "tmpdir/$test_prog tmpdir/copyprog"]
|
2004-05-12 03:28:46 +00:00
|
|
|
set exec_output [lindex $status 1]
|
1999-05-03 07:29:11 +00:00
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if [string equal "" $exec_output] then {
|
1999-05-03 07:29:11 +00:00
|
|
|
pass $test1
|
|
|
|
} else {
|
|
|
|
send_log "$exec_output\n"
|
|
|
|
verbose "$exec_output"
|
|
|
|
|
|
|
|
# This will fail for many reasons. For example, it will most
|
|
|
|
# likely fail if a non-GNU linker is used. Therefore, we do
|
|
|
|
# not insist that it pass. If you are using an assembler and
|
|
|
|
# linker based on the same BFD as objcopy, it is worth
|
|
|
|
# investigating to see why this failure occurs. If we are
|
|
|
|
# cross compiling, we assume that a GNU linker is being used,
|
|
|
|
# and expect it to succeed.
|
|
|
|
if {[isnative]} then {
|
|
|
|
setup_xfail "*-*-*"
|
|
|
|
}
|
|
|
|
|
2016-06-23 12:41:57 +00:00
|
|
|
# This also fails for some mips targets. See elf32-mips.c
|
1999-05-03 07:29:11 +00:00
|
|
|
# mips_elf_sym_is_global.
|
2016-06-23 12:41:57 +00:00
|
|
|
if { [is_bad_symtab] } then {
|
|
|
|
setup_xfail "*-*-*"
|
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
|
bfd:
* config.bfd (thumb-*-oabi): Don't handle in list of obsolete
targets.
(strongarm*, thumb*, xscale*): Remove architectures.
(strongarm-*-kaos*, thumb-*-coff, thumb-*-elf, thumb-epoc-pe*,
thumb-*-pe*, strongarm-*-elf, strongarm-*-coff, xscale-*-elf,
xscale-*-coff): Remove targets.
binutils:
* configure.in (thumb-*-pe*): Remove.
* configure: Regenerate.
binutils/testsuite:
* binutils-all/objcopy.exp (*arm*-*-coff): Change to arm*-*-coff.
(xscale-*-coff, thumb*-*-coff, thumb*-*-pe): Don't handle.
gas:
* configure.tgt (strongarm*be, strongarm*b, strongarm*,
xscale*be|xscale*b, xscale*): Remove architectures.
(thumb-*-coff, thumb-*-rtems*, thumb-*-elf, thumb-epoc-pe,
thumb-*-pe, xscale-*-coff, xscale-*-elf): Remove targets.
gas/testsuite:
* gas/all/gas.exp (*arm*-*-coff): Change to arm*-*-coff.
(thumb*-*-coff, thumb*-*-pe*): Don;t handle.
* gas/arm/arm.exp (*arm*-*-*): Change to arm*-*-*.
(*xscale*-*-*): Don't handle.
* gas/cfi/cfi.exp (xscale*-*): Don't handle.
* gas/elf/elf.exp (*arm*-*-*): Change to arm*-*-*.
(xscale*-*-*): Don't handle.
ld:
* configure.tgt (thumb-*-linux-* | thumb-*-uclinux*,
strongarm-*-coff, strongarm-*-elf, strongarm-*-kaos*,
thumb-*-coff, thumb-*-elf, thumb-epoc-pe, thumb-*-pe,
xscale-*-coff, xscale-*-elf): Remove targets.
ld/testsuite:
* ld-selective/selective.exp (xscale-*-*): Don't handle.
* ld-srec/srec.exp (strongarm*-*-*, xscale*-*-*, thumb-*-*): Don't
handle.
(*arm*-*-*): Change to arm*-*-*.
(strongarm*-*-coff, xscale*-*-coff, thumb-*-coff*, thumb-*-pe*,
thumb-*-elf*, strongarm*-*-*, thumb-*-*): Remove xfails.
* ld-undefined/undefined.exp (thumb*-*-pe*, thumb*-*-pe*): Remove
commented-out xfails.
(thumb-elf): Remove reference in comment.
* lib/ld-lib.exp (strongarm*-*-*, xscale*-*-*, thumb-*-*): Don't
handle.
2011-04-06 17:09:56 +00:00
|
|
|
setup_xfail "arm*-*-coff"
|
1999-11-01 16:48:05 +00:00
|
|
|
setup_xfail "arm*-*-pe"
|
2010-03-30 17:45:19 +00:00
|
|
|
setup_xfail "*-*-mingw*"
|
2009-06-26 01:26:28 +00:00
|
|
|
setup_xfail "*-*-cygwin*"
|
2015-10-15 11:07:13 +00:00
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
fail $test1
|
|
|
|
}
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if [string equal "" $test2] {
|
2007-05-02 10:38:00 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
set output [remote_load target tmpdir/copyprog]
|
2004-05-12 03:28:46 +00:00
|
|
|
set status [lindex $output 0]
|
1999-05-03 07:29:11 +00:00
|
|
|
if { $status != "pass" } {
|
|
|
|
fail $test2
|
|
|
|
} else {
|
|
|
|
pass $test2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Test stripping an executable
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
proc strip_executable { prog flags test1 test2 } {
|
1999-05-03 07:29:11 +00:00
|
|
|
global NM
|
|
|
|
global NMFLAGS
|
2011-06-30 21:41:05 +00:00
|
|
|
global READELF
|
1999-05-03 07:29:11 +00:00
|
|
|
|
2009-04-02 13:47:44 +00:00
|
|
|
remote_file build delete tmpdir/striprog
|
1999-05-03 07:29:11 +00:00
|
|
|
remote_download build tmpdir/copyprog tmpdir/striprog
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set copyfile [remote_download host tmpdir/striprog]
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
|
|
|
set copyfile tmpdir/striprog
|
|
|
|
}
|
|
|
|
|
2011-06-30 21:41:05 +00:00
|
|
|
set osabi_fail "false"
|
|
|
|
if [is_elf_format] {
|
|
|
|
verbose -log "$READELF -a ${copyfile} > tmpdir/osabi.in"
|
|
|
|
set exec_output [remote_exec host "$READELF -h ${copyfile}" "" "/dev/null" "tmpdir/osabi.in"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test1 preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
set osabi_fail "true"
|
|
|
|
} else {
|
|
|
|
verbose -log "grep OS/ABI tmpdir/osabi.in"
|
|
|
|
catch "exec grep OS/ABI tmpdir/osabi.in" osabi_in
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
set exec_output [binutils_run $prog "$flags ${copyfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
|
|
|
fail $test1
|
|
|
|
if [string equal "" $test2] {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fail $test2
|
1999-05-03 07:29:11 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
remote_upload host ${copyfile} tmpdir/striprog
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2011-06-30 21:41:05 +00:00
|
|
|
if { $osabi_fail != "true" && [is_elf_format] } {
|
|
|
|
verbose -log "$READELF -a ${copyfile} > tmpdir/osabi.out"
|
|
|
|
set exec_output [remote_exec host "$READELF -h ${copyfile}" "" "/dev/null" "tmpdir/osabi.out"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
2015-10-15 11:07:13 +00:00
|
|
|
unresolved "$test1 preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
} else {
|
|
|
|
verbose -log "grep OS/ABI tmpdir/osabi.out"
|
|
|
|
catch "exec grep OS/ABI tmpdir/osabi.out" osabi_out
|
|
|
|
if { "$osabi_in" == "$osabi_out" } {
|
2015-10-15 11:07:13 +00:00
|
|
|
pass "$test1 preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
} else {
|
2015-10-15 11:07:13 +00:00
|
|
|
fail "$test1 preserving OS/ABI"
|
2011-06-30 21:41:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
set exec_output [binutils_run $NM "$NMFLAGS ${copyfile}"]
|
2002-08-26 23:15:48 +00:00
|
|
|
if ![string match "*: no symbols*" $exec_output] {
|
2015-10-15 11:07:13 +00:00
|
|
|
fail $test1
|
1999-05-03 07:29:11 +00:00
|
|
|
return
|
|
|
|
}
|
2015-10-15 11:07:13 +00:00
|
|
|
|
|
|
|
if [string equal "" $test2] {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set result [remote_load target tmpdir/striprog]
|
|
|
|
set status [lindex $result 0]
|
|
|
|
if { $status != "pass" } {
|
|
|
|
fail $test2
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
pass $test2
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Test stripping an executable with saving a symbol
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
proc strip_executable_with_saving_a_symbol { prog flags test1 test2 } {
|
1999-05-03 07:29:11 +00:00
|
|
|
global NM
|
|
|
|
global NMFLAGS
|
|
|
|
|
2009-04-02 13:47:44 +00:00
|
|
|
remote_file build delete tmpdir/striprog
|
1999-05-03 07:29:11 +00:00
|
|
|
remote_download build tmpdir/copyprog tmpdir/striprog
|
|
|
|
if [is_remote host] {
|
2004-05-12 03:28:46 +00:00
|
|
|
set copyfile [remote_download host tmpdir/striprog]
|
1999-05-03 07:29:11 +00:00
|
|
|
} else {
|
|
|
|
set copyfile tmpdir/striprog
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $prog "$flags ${copyfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
|
|
|
fail $test1
|
|
|
|
if [string equal "" $test2] {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fail $test2
|
1999-05-03 07:29:11 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $NM "$NMFLAGS ${copyfile}"]
|
2002-02-18 09:13:48 +00:00
|
|
|
if { [istarget mmix-knuth-mmixware] } {
|
|
|
|
# Whenever there's a symbol in the mmo format, there's the symbol
|
|
|
|
# Main, so remove it manually from the expected output for sake of
|
|
|
|
# this test.
|
|
|
|
|
|
|
|
# Using "" not {} to get the \n and \r translated.
|
|
|
|
regsub "^\[0-9a-fA-F\]+\[ \]+T Main\[\n\r\]+" $exec_output "" exec_output
|
|
|
|
}
|
|
|
|
|
2004-03-30 09:54:15 +00:00
|
|
|
if {![regexp {^([0-9a-fA-F]+)?[ ]+[TD] main} $exec_output] \
|
|
|
|
&& ![regexp {^([0-9a-fA-F]+)?[ ]+[TD] _main} $exec_output]} {
|
2015-10-15 11:07:13 +00:00
|
|
|
fail $test1
|
1999-05-03 07:29:11 +00:00
|
|
|
return
|
|
|
|
}
|
2015-10-15 11:07:13 +00:00
|
|
|
|
|
|
|
if [string equal "" $test2] {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
|
|
|
remote_upload host ${copyfile} tmpdir/striprog
|
|
|
|
}
|
|
|
|
|
|
|
|
set result [remote_load target tmpdir/striprog]
|
|
|
|
set status [lindex $result 0]
|
|
|
|
if { $status != "pass" } {
|
|
|
|
fail $test2
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
pass $test2
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2008-05-29 07:07:21 +00:00
|
|
|
# Test keeping only debug symbols of an executable
|
|
|
|
|
|
|
|
proc keep_debug_symbols_and_test_copy { prog1 flags1 test1 prog2 flags2 test2 } {
|
2009-04-02 13:47:44 +00:00
|
|
|
remote_file build delete tmpdir/striprog
|
2008-05-29 07:07:21 +00:00
|
|
|
remote_download build tmpdir/copyprog tmpdir/striprog
|
|
|
|
if [is_remote host] {
|
|
|
|
set copyfile [remote_download host tmpdir/striprog]
|
|
|
|
} else {
|
|
|
|
set copyfile tmpdir/striprog
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $prog1 "$flags1 ${copyfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2008-05-29 07:07:21 +00:00
|
|
|
fail $test1
|
|
|
|
return
|
|
|
|
}
|
|
|
|
pass $test1
|
|
|
|
|
|
|
|
set exec_output [binutils_run $prog2 "$flags2 ${copyfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2008-05-29 07:07:21 +00:00
|
|
|
fail $test2
|
|
|
|
return
|
|
|
|
}
|
|
|
|
pass $test2
|
|
|
|
}
|
|
|
|
|
2015-08-05 15:16:39 +00:00
|
|
|
# Tests that in a debug only copy of a file the sections
|
|
|
|
# headers whoes types have been changed to NOBITS still
|
|
|
|
# retain their sh_link fields.
|
|
|
|
|
|
|
|
proc keep_debug_symbols_and_check_links { prog flags test } {
|
|
|
|
global READELF
|
|
|
|
|
|
|
|
remote_file build delete tmpdir/striprog
|
|
|
|
remote_download build tmpdir/copyprog tmpdir/striprog
|
|
|
|
if [is_remote host] {
|
|
|
|
set copyfile [remote_download host tmpdir/striprog]
|
|
|
|
} else {
|
|
|
|
set copyfile tmpdir/striprog
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $prog "$flags ${copyfile}"]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] {
|
2015-08-05 15:16:39 +00:00
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set got [binutils_run $READELF "-S --wide ${copyfile}"]
|
|
|
|
|
|
|
|
set fails 0
|
|
|
|
# Regexp to match a section with NOBITS type and extract its name and sh_link fields
|
|
|
|
while {[regexp \
|
|
|
|
{[^a-zA-Z]+([a-zA-Z0-9_\.]+)[ ]+NOBITS[ ]+[0-9a-fA-F]+ [0-9a-fA-F]+ [0-9a-fA-F]+ [0-9]+[ A]+([0-9]+)(.*)} \
|
|
|
|
$got all name link rest]} {
|
|
|
|
set sh_link 0x$link
|
|
|
|
if {$sh_link == 0} {
|
|
|
|
# Only some NOBITS sections should have a non-zero sh_link field.
|
|
|
|
# Look for them by name.
|
|
|
|
verbose "NOBITS section .$name has a 0 sh_link field\n"
|
|
|
|
switch $name {
|
|
|
|
"rela.*" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"rel.*" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"hash" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"gnu_version" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"dynsym" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"gnu.version_r" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"dynamic" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
"symtab" { set fails 1 ; send_log "Expected non-zero sh_link for .$name\n" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
set got $rest
|
|
|
|
}
|
|
|
|
|
|
|
|
if {$fails == 0} {
|
|
|
|
pass $test
|
|
|
|
} else {
|
|
|
|
fail $test
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-05-03 07:29:11 +00:00
|
|
|
set test1 "simple objcopy of executable"
|
2015-10-15 11:07:13 +00:00
|
|
|
set test1r "run objcopy of executable"
|
|
|
|
set test2 "strip executable"
|
|
|
|
set test2r "run stripped executable"
|
|
|
|
set test3 "strip executable with saving a symbol"
|
|
|
|
set test3r "run stripped executable with saving a symbol"
|
|
|
|
set test4 "keep only debug data"
|
|
|
|
set test5 "simple objcopy of debug data"
|
2015-08-05 15:16:39 +00:00
|
|
|
if [is_elf_format] {
|
2015-10-15 11:07:13 +00:00
|
|
|
set test6 "NOBITS sections retain sh_link field"
|
2015-08-05 15:16:39 +00:00
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
switch [copy_setup] {
|
|
|
|
"1" {
|
|
|
|
# do nothing
|
|
|
|
}
|
|
|
|
"2" {
|
|
|
|
untested $test1
|
2015-10-15 11:07:13 +00:00
|
|
|
untested $test1r
|
1999-05-03 07:29:11 +00:00
|
|
|
untested $test2
|
2015-10-15 11:07:13 +00:00
|
|
|
untested $test2r
|
1999-05-03 07:29:11 +00:00
|
|
|
untested $test3
|
2015-10-15 11:07:13 +00:00
|
|
|
untested $test3r
|
1999-05-03 07:29:11 +00:00
|
|
|
untested $test4
|
2008-05-29 07:07:21 +00:00
|
|
|
untested $test5
|
2015-08-05 15:16:39 +00:00
|
|
|
if [is_elf_format] {
|
2015-10-15 11:07:13 +00:00
|
|
|
untested $test6
|
2015-08-05 15:16:39 +00:00
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
"3" {
|
2007-05-02 10:38:00 +00:00
|
|
|
copy_executable "$OBJCOPY" "$OBJCOPYFLAGS" "$test1" ""
|
2015-10-15 11:07:13 +00:00
|
|
|
unsupported $test1r
|
|
|
|
strip_executable "$STRIP" "$STRIPFLAGS" "$test2" ""
|
|
|
|
unsupported $test2r
|
|
|
|
strip_executable_with_saving_a_symbol "$STRIP" "-K main -K _main $STRIPFLAGS" "$test3" ""
|
|
|
|
unsupported $test3r
|
|
|
|
keep_debug_symbols_and_test_copy "$STRIP" "--only-keep-debug $STRIPFLAGS" "$test4" \
|
|
|
|
"$OBJCOPY" "$OBJCOPYFLAGS" "$test5"
|
2015-08-05 15:16:39 +00:00
|
|
|
if [is_elf_format] {
|
2015-10-15 11:07:13 +00:00
|
|
|
keep_debug_symbols_and_check_links "$STRIP" "--only-keep-debug $STRIPFLAGS" "$test6"
|
2015-08-05 15:16:39 +00:00
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
"0" {
|
2015-10-15 11:07:13 +00:00
|
|
|
copy_executable "$OBJCOPY" "$OBJCOPYFLAGS" "$test1" "$test1r"
|
|
|
|
strip_executable "$STRIP" "$STRIPFLAGS" "$test2" "$test2r"
|
|
|
|
strip_executable_with_saving_a_symbol "$STRIP" "-K main -K _main $STRIPFLAGS" "$test3" "$test3r"
|
|
|
|
keep_debug_symbols_and_test_copy "$STRIP" "--only-keep-debug $STRIPFLAGS" "$test4" \
|
|
|
|
"$OBJCOPY" "$OBJCOPYFLAGS" "$test5"
|
2015-08-05 15:16:39 +00:00
|
|
|
if [is_elf_format] {
|
2015-10-15 11:07:13 +00:00
|
|
|
keep_debug_symbols_and_check_links "$STRIP" "--only-keep-debug $STRIPFLAGS" "$test6"
|
2015-08-05 15:16:39 +00:00
|
|
|
}
|
1999-05-03 07:29:11 +00:00
|
|
|
}
|
|
|
|
}
|
2005-10-19 17:39:43 +00:00
|
|
|
|
2005-10-20 17:06:41 +00:00
|
|
|
proc objcopy_test_readelf {testname srcfile} {
|
|
|
|
global OBJCOPY
|
|
|
|
global OBJCOPYFLAGS
|
|
|
|
global READELF
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
|
|
|
|
if {![binutils_assemble $srcdir/$subdir/${srcfile} tmpdir/bintest.o]} then {
|
|
|
|
unresolved "objcopy ($testname)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
verbose -log "$OBJCOPY $OBJCOPYFLAGS tmpdir/bintest.o tmpdir/copy.o"
|
2007-08-28 13:21:58 +00:00
|
|
|
set exec_output [remote_exec host "$OBJCOPY $OBJCOPYFLAGS tmpdir/bintest.o tmpdir/copy.o"]
|
|
|
|
if { [lindex $exec_output 0] != 0
|
2015-10-15 11:07:13 +00:00
|
|
|
|| ![string equal "" [lindex $exec_output 1]] } then {
|
2005-10-20 17:06:41 +00:00
|
|
|
fail "objcopy ($testname)"
|
2006-05-01 04:01:25 +00:00
|
|
|
return
|
2005-10-20 17:06:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
verbose -log "$READELF -a tmpdir/bintest.o > tmpdir/bintest.o.out"
|
2007-08-28 13:21:58 +00:00
|
|
|
set exec_output [remote_exec host "$READELF -a tmpdir/bintest.o" "" "/dev/null" "tmpdir/bintest.o.out"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
|
|
|
unresolved "objcopy ($testname)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
set exec_output [prune_warnings [lindex $exec_output 1]]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] then {
|
2005-10-20 17:06:41 +00:00
|
|
|
unresolved "objcopy ($testname)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
verbose -log "$READELF -a tmpdir/copy.o > tmpdir/copy.o.out"
|
2007-08-28 13:21:58 +00:00
|
|
|
set exec_output [remote_exec host "$READELF -a tmpdir/copy.o" "" "/dev/null" "tmpdir/copy.o.out"]
|
|
|
|
if { [lindex $exec_output 0] != 0 } then {
|
|
|
|
unresolved "objcopy ($testname)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
set exec_output [prune_warnings [lindex $exec_output 1]]
|
2015-10-15 11:07:13 +00:00
|
|
|
if ![string equal "" $exec_output] then {
|
2005-10-20 17:06:41 +00:00
|
|
|
unresolved "objcopy ($testname)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
verbose -log "diff tmpdir/bintest.o.out tmpdir/copy.o.out"
|
|
|
|
catch "exec diff tmpdir/bintest.o.out tmpdir/copy.o.out" exec_output
|
|
|
|
set exec_output [prune_warnings $exec_output]
|
|
|
|
|
2015-10-15 11:07:13 +00:00
|
|
|
if [string equal "" $exec_output] then {
|
2005-10-20 17:06:41 +00:00
|
|
|
pass "objcopy ($testname)"
|
|
|
|
} else {
|
|
|
|
fail "objcopy ($testname)"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
objcopy: Improve wildcard matching for symbols with '!' prefix.
When using options such as --localize-symbol, --globalize-symbol, etc,
along with the --wildcard option, prefixing a symbol name with '!'
should provide non-matching behaviour, as example the following example
is given in the manual:
--wildcard --weaken-symbol !foo --weaken-symbol fo*
which should weaken all symbols matching the pattern 'fo*', but not the
symbol 'foo'.
However, this currently does not work, the current logic will waken all
symbols matching the pattern 'fo*' AND all symbols that are not 'foo'.
The symbol 'foo' is covered by the first condition, and so is weakened,
while, other symbols, for example 'bar' will match the second condition,
and so be weakened.
This patch adjusts the logic so that a pattern prefixed with '!'
specifically DOES NOT apply the relevant change to any matching symbols,
instead of applying the change to all non-matching symbols. So this:
--weaken-symbol !foo
will ensure that the symbol 'foo' is not weakened, but says nothing
about symbols that are not 'foo'. As a result, a pattern prefixed with
'!' now only makes sense when used alongside a more wide ranging
wildcard pattern.
This change should make the wildcard matching feature more useful, with
no overall loss of functionality. The example given in the manual,
weaken all symbols matching 'fo*' except 'foo' can now be achieved, but
so too can more complex examples, such as weaken all symbols matching
'fo*' except 'foo', 'foa', and 'fob', like this:
--wildcard --weaken-symbol !foo \
--weaken-symbol !foa \
--weaken-symbol !fob \
--weaken-symbol fo*
Under the previous scheme, something as symbols as, weaken all symbols
except 'foo' could have been achieved with this:
--weaken-symbol !foo
however, this will no longer work. To achieve the same result under the
new scheme this is now required:
--weaken-symbol !foo --weaken-symbol *
binutils/ChangeLog:
* objcopy.c (is_specified_symbol_predicate): Don't stop at first
match. Non-match rules set found to FALSE.
binutils/testsuite/ChangeLog:
* binutils-all/objcopy.exp: Run new symbol tests.
(objcopy_test_symbol_manipulation): New function.
* binutils-all/symbols-1.d: New file.
* binutils-all/symbols-2.d: New file.
* binutils-all/symbols-3.d: New file.
* binutils-all/symbols-4.d: New file.
* binutils-all/symbols.s: New file.
2015-07-31 12:48:22 +00:00
|
|
|
proc objcopy_test_symbol_manipulation {} {
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
|
|
|
|
set test_list [lsort [glob -nocomplain $srcdir/$subdir/symbols-*.d]]
|
|
|
|
foreach t $test_list {
|
|
|
|
# We need to strip the ".d", but can leave the dirname.
|
|
|
|
verbose [file rootname $t]
|
|
|
|
run_dump_test [file rootname $t]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Properly implement STT_COMMON
The BFD configure option, --enable-elf-stt-common, can't be to used to
verify STT_COMMON implementation with the normal binutils build. Instead,
this patch removes it from BFD. It adds --elf-stt-common=[no|yes] to ELF
assembler/objcopy and adds -z common/-z nocommon to ld.
A configure option, --enable-elf-stt-common, is added to gas to specify
whether ELF assembler should generate common symbols with the STT_COMMON
type by default.
Since BSF_KEEP_G is never used, it is renamed to BSF_ELF_COMMON for ELF
common symbols.
bfd/
PR ld/19645
* bfd.c (bfd): Change flags to 20 bits.
(BFD_CONVERT_ELF_COMMON): New.
(BFD_USE_ELF_STT_COMMON): Likewise.
(BFD_FLAGS_SAVED): Add BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON.
(BFD_FLAGS_FOR_BFD_USE_MASK): Likewise.
* configure.ac: Remove --enable-elf-stt-common.
* elf.c (swap_out_syms): Choose STT_COMMON or STT_OBJECT for
common symbol depending on BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON.
* elfcode.h (elf_slurp_symbol_table): Set BSF_ELF_COMMON for
STT_COMMON.
* elflink.c (bfd_elf_link_mark_dynamic_symbol): Also check
STT_COMMON.
(elf_link_convert_common_type): New function.
(elf_link_output_extsym): Choose STT_COMMON or STT_OBJECT for
common symbol depending on BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON. Set sym.st_info after sym.st_shndx.
* elfxx-target.h (TARGET_BIG_SYM): Add BFD_CONVERT_ELF_COMMON
and BFD_USE_ELF_STT_COMMON to object_flags.
(TARGET_LITTLE_SYM): Likewise.
* syms.c (BSF_KEEP_G): Renamed to ...
(BSF_ELF_COMMON): This.
* bfd-in2.h: Regenerated.
* config.in: Likewise.
* configure: Likewise.
binutils/
PR ld/19645
* NEWS: Mention --elf-stt-common= for objcopy.
* doc/binutils.texi: Document --elf-stt-common= for objcopy.
* objcopy.c (do_elf_stt_common): New.
(command_line_switch): Add OPTION_ELF_STT_COMMON.
(copy_options): Add --elf-stt-common=.
(copy_usage): Add --elf-stt-common=.
(copy_object): Also check do_elf_stt_common for ELF targets.
(copy_file): Handle do_elf_stt_common.
(copy_main): Handle OPTION_ELF_STT_COMMON.
* readelf.c (apply_relocations): Support STT_COMMON.
* testsuite/binutils-all/common-1.s: New file.
* testsuite/binutils-all/common-1a.d: Likewise.
* testsuite/binutils-all/common-1b.d: Likewise.
* testsuite/binutils-all/common-1c.d: Likewise.
* testsuite/binutils-all/common-1d.d: Likewise.
* testsuite/binutils-all/common-1e.d: Likewise.
* testsuite/binutils-all/common-1f.d: Likewise.
* testsuite/binutils-all/common-2.s: Likewise.
* testsuite/binutils-all/common-2a.d: Likewise.
* testsuite/binutils-all/common-2b.d: Likewise.
* testsuite/binutils-all/common-2c.d: Likewise.
* testsuite/binutils-all/common-2d.d: Likewise.
* testsuite/binutils-all/common-2e.d: Likewise.
* testsuite/binutils-all/common-2f.d: Likewise.
* testsuite/binutils-all/objcopy.exp
(objcopy_test_elf_common_symbols): New proc.
Run objcopy_test_elf_common_symbols for ELF targets
gas/
PR ld/19645
* NEWS: Mention --enable-elf-stt-common and --elf-stt-common=
for ELF assemblers.
* as.c (flag_use_elf_stt_common): New.
(show_usage): Add --elf-stt-common=.
(option_values): Add OPTION_ELF_STT_COMMON.
(std_longopts): Add --elf-stt-common=.
(parse_args): Handle --elf-stt-common=.
* as.h (flag_use_elf_stt_common): New.
* config.in: Regenerated.
* configure: Likewise.
* configure.ac: Add --enable-elf-stt-common and define
DEFAULT_GENERATE_ELF_STT_COMMON.
* gas/write.c (write_object_file): Set BFD_CONVERT_ELF_COMMON
and BFD_USE_ELF_STT_COMMON if flag_use_elf_stt_common is set.
* doc/as.texinfo: Document --elf-stt-common=.
* testsuite/gas/elf/common3.s: New file.
* testsuite/gas/elf/common3a.d: Likewise.
* testsuite/gas/elf/common3b.d: Likewise.
* testsuite/gas/elf/common4.s: Likewise.
* testsuite/gas/elf/common4a.d: Likewise.
* testsuite/gas/elf/common4b.d: Likewise.
* testsuite/gas/i386/dw2-compress-3b.d: Likewise.
* testsuite/gas/i386/dw2-compressed-3b.d: Likewise.
* testsuite/gas/elf/elf.exp: Run common3a, common3b, common4a
and common4b.
* testsuite/gas/i386/dw2-compress-3.d: Renamed to ...
* testsuite/gas/i386/dw2-compress-3a.d: This. Pass
--elf-stt-common=no to as.
* testsuite/gas/i386/dw2-compressed-3.d: Renamed to ...
* testsuite/gas/i386/dw2-compressed-3a.d: This. Pass
--elf-stt-common=no to as.
* testsuite/gas/i386/i386.exp: Run dw2-compress-3a,
dw2-compress-3b, dw2-compressed-3a and dw2-compressed-3b instead
of dw2-compress-3 and dw2-compressed-3.
include/
PR ld/19645
* bfdlink.h (bfd_link_elf_stt_common): New enum.
(bfd_link_info): Add elf_stt_common.
ld/
PR ld/19645
* NEWS: Mention -z common/-z nocommon for ELF targets.
* emultempl/elf32.em (gld${EMULATION_NAME}_handle_option): Handle
-z common and -z nocommon.
* ld.texinfo: Document -z common/-z nocommon.
* lexsup.c (elf_shlib_list_options): Add -z common/-z nocommon.
* testsuite/ld-elf/tls_common.exp: Test --elf-stt-common=no and
--elf-stt-common=yes with assembler.
* testsuite/ld-elfcomm/common-1.s: New file.
* testsuite/ld-elfcomm/common-1a.d: Likewise.
* testsuite/ld-elfcomm/common-1b.d: Likewise.
* testsuite/ld-elfcomm/common-1c.d: Likewise.
* testsuite/ld-elfcomm/common-1d.d: Likewise.
* testsuite/ld-elfcomm/common-1e.d: Likewise.
* testsuite/ld-elfcomm/common-1f.d: Likewise.
* testsuite/ld-elfcomm/common-2.s: Likewise.
* testsuite/ld-elfcomm/common-2a.d: Likewise.
* testsuite/ld-elfcomm/common-2b.d: Likewise.
* testsuite/ld-elfcomm/common-2c.d: Likewise.
* testsuite/ld-elfcomm/common-2d.d: Likewise.
* testsuite/ld-elfcomm/common-2e.d: Likewise.
* testsuite/ld-elfcomm/common-2f.d: Likewise.
* testsuite/ld-elfcomm/common-3a.rd: Likewise.
* testsuite/ld-elfcomm/common-3b.rd: Likewise.
* testsuite/ld-i386/pr19645.d: Likewise.
* testsuite/ld-i386/pr19645.s: Likewise.
* testsuite/ld-x86-64/largecomm-1.s: Likewise.
* testsuite/ld-x86-64/largecomm-1a.d: Likewise.
* testsuite/ld-x86-64/largecomm-1b.d: Likewise.
* testsuite/ld-x86-64/largecomm-1c.d: Likewise.
* testsuite/ld-x86-64/largecomm-1d.d: Likewise.
* testsuite/ld-x86-64/largecomm-1e.d: Likewise.
* testsuite/ld-x86-64/largecomm-1f.d: Likewise.
* testsuite/ld-x86-64/pr19645.d: Likewise.
* testsuite/ld-x86-64/pr19645.s: Likewise.
* testsuite/ld-elfcomm/elfcomm.exp: Test --elf-stt-common=yes
with assembler.
(assembler_generates_commons): Removed.
Run -z common/-z nocommon tests. Run *.d tests.
* testsuite/ld-i386/i386.exp: Run pr19645.
* testsuite/ld-x86-64/x86-64.exp: Likewise.
* testsuite/ld-x86-64/dwarfreloc.exp: Test --elf-stt-common with
assembler. Test STT_COMMON with readelf.
2016-02-22 17:18:52 +00:00
|
|
|
proc objcopy_test_elf_common_symbols {} {
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
|
|
|
|
# hpux has a non-standard common directive.
|
|
|
|
if { [istarget "*-*-hpux*"] } then {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set test_list [lsort [glob -nocomplain $srcdir/$subdir/common-*.d]]
|
|
|
|
foreach t $test_list {
|
|
|
|
# We need to strip the ".d", but can leave the dirname.
|
|
|
|
verbose [file rootname $t]
|
|
|
|
run_dump_test [file rootname $t]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-10-19 17:39:43 +00:00
|
|
|
# ia64 specific tests
|
|
|
|
if { ([istarget "ia64-*-elf*"]
|
|
|
|
|| [istarget "ia64-*-linux*"]) } {
|
2005-10-19 20:49:03 +00:00
|
|
|
objcopy_test "ia64 link order" link-order.s
|
|
|
|
}
|
2005-10-19 17:39:43 +00:00
|
|
|
|
2005-10-19 20:49:03 +00:00
|
|
|
# ELF specific tests
|
|
|
|
if [is_elf_format] {
|
objcopy: Improve wildcard matching for symbols with '!' prefix.
When using options such as --localize-symbol, --globalize-symbol, etc,
along with the --wildcard option, prefixing a symbol name with '!'
should provide non-matching behaviour, as example the following example
is given in the manual:
--wildcard --weaken-symbol !foo --weaken-symbol fo*
which should weaken all symbols matching the pattern 'fo*', but not the
symbol 'foo'.
However, this currently does not work, the current logic will waken all
symbols matching the pattern 'fo*' AND all symbols that are not 'foo'.
The symbol 'foo' is covered by the first condition, and so is weakened,
while, other symbols, for example 'bar' will match the second condition,
and so be weakened.
This patch adjusts the logic so that a pattern prefixed with '!'
specifically DOES NOT apply the relevant change to any matching symbols,
instead of applying the change to all non-matching symbols. So this:
--weaken-symbol !foo
will ensure that the symbol 'foo' is not weakened, but says nothing
about symbols that are not 'foo'. As a result, a pattern prefixed with
'!' now only makes sense when used alongside a more wide ranging
wildcard pattern.
This change should make the wildcard matching feature more useful, with
no overall loss of functionality. The example given in the manual,
weaken all symbols matching 'fo*' except 'foo' can now be achieved, but
so too can more complex examples, such as weaken all symbols matching
'fo*' except 'foo', 'foa', and 'fob', like this:
--wildcard --weaken-symbol !foo \
--weaken-symbol !foa \
--weaken-symbol !fob \
--weaken-symbol fo*
Under the previous scheme, something as symbols as, weaken all symbols
except 'foo' could have been achieved with this:
--weaken-symbol !foo
however, this will no longer work. To achieve the same result under the
new scheme this is now required:
--weaken-symbol !foo --weaken-symbol *
binutils/ChangeLog:
* objcopy.c (is_specified_symbol_predicate): Don't stop at first
match. Non-match rules set found to FALSE.
binutils/testsuite/ChangeLog:
* binutils-all/objcopy.exp: Run new symbol tests.
(objcopy_test_symbol_manipulation): New function.
* binutils-all/symbols-1.d: New file.
* binutils-all/symbols-2.d: New file.
* binutils-all/symbols-3.d: New file.
* binutils-all/symbols-4.d: New file.
* binutils-all/symbols.s: New file.
2015-07-31 12:48:22 +00:00
|
|
|
objcopy_test_symbol_manipulation
|
Properly implement STT_COMMON
The BFD configure option, --enable-elf-stt-common, can't be to used to
verify STT_COMMON implementation with the normal binutils build. Instead,
this patch removes it from BFD. It adds --elf-stt-common=[no|yes] to ELF
assembler/objcopy and adds -z common/-z nocommon to ld.
A configure option, --enable-elf-stt-common, is added to gas to specify
whether ELF assembler should generate common symbols with the STT_COMMON
type by default.
Since BSF_KEEP_G is never used, it is renamed to BSF_ELF_COMMON for ELF
common symbols.
bfd/
PR ld/19645
* bfd.c (bfd): Change flags to 20 bits.
(BFD_CONVERT_ELF_COMMON): New.
(BFD_USE_ELF_STT_COMMON): Likewise.
(BFD_FLAGS_SAVED): Add BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON.
(BFD_FLAGS_FOR_BFD_USE_MASK): Likewise.
* configure.ac: Remove --enable-elf-stt-common.
* elf.c (swap_out_syms): Choose STT_COMMON or STT_OBJECT for
common symbol depending on BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON.
* elfcode.h (elf_slurp_symbol_table): Set BSF_ELF_COMMON for
STT_COMMON.
* elflink.c (bfd_elf_link_mark_dynamic_symbol): Also check
STT_COMMON.
(elf_link_convert_common_type): New function.
(elf_link_output_extsym): Choose STT_COMMON or STT_OBJECT for
common symbol depending on BFD_CONVERT_ELF_COMMON and
BFD_USE_ELF_STT_COMMON. Set sym.st_info after sym.st_shndx.
* elfxx-target.h (TARGET_BIG_SYM): Add BFD_CONVERT_ELF_COMMON
and BFD_USE_ELF_STT_COMMON to object_flags.
(TARGET_LITTLE_SYM): Likewise.
* syms.c (BSF_KEEP_G): Renamed to ...
(BSF_ELF_COMMON): This.
* bfd-in2.h: Regenerated.
* config.in: Likewise.
* configure: Likewise.
binutils/
PR ld/19645
* NEWS: Mention --elf-stt-common= for objcopy.
* doc/binutils.texi: Document --elf-stt-common= for objcopy.
* objcopy.c (do_elf_stt_common): New.
(command_line_switch): Add OPTION_ELF_STT_COMMON.
(copy_options): Add --elf-stt-common=.
(copy_usage): Add --elf-stt-common=.
(copy_object): Also check do_elf_stt_common for ELF targets.
(copy_file): Handle do_elf_stt_common.
(copy_main): Handle OPTION_ELF_STT_COMMON.
* readelf.c (apply_relocations): Support STT_COMMON.
* testsuite/binutils-all/common-1.s: New file.
* testsuite/binutils-all/common-1a.d: Likewise.
* testsuite/binutils-all/common-1b.d: Likewise.
* testsuite/binutils-all/common-1c.d: Likewise.
* testsuite/binutils-all/common-1d.d: Likewise.
* testsuite/binutils-all/common-1e.d: Likewise.
* testsuite/binutils-all/common-1f.d: Likewise.
* testsuite/binutils-all/common-2.s: Likewise.
* testsuite/binutils-all/common-2a.d: Likewise.
* testsuite/binutils-all/common-2b.d: Likewise.
* testsuite/binutils-all/common-2c.d: Likewise.
* testsuite/binutils-all/common-2d.d: Likewise.
* testsuite/binutils-all/common-2e.d: Likewise.
* testsuite/binutils-all/common-2f.d: Likewise.
* testsuite/binutils-all/objcopy.exp
(objcopy_test_elf_common_symbols): New proc.
Run objcopy_test_elf_common_symbols for ELF targets
gas/
PR ld/19645
* NEWS: Mention --enable-elf-stt-common and --elf-stt-common=
for ELF assemblers.
* as.c (flag_use_elf_stt_common): New.
(show_usage): Add --elf-stt-common=.
(option_values): Add OPTION_ELF_STT_COMMON.
(std_longopts): Add --elf-stt-common=.
(parse_args): Handle --elf-stt-common=.
* as.h (flag_use_elf_stt_common): New.
* config.in: Regenerated.
* configure: Likewise.
* configure.ac: Add --enable-elf-stt-common and define
DEFAULT_GENERATE_ELF_STT_COMMON.
* gas/write.c (write_object_file): Set BFD_CONVERT_ELF_COMMON
and BFD_USE_ELF_STT_COMMON if flag_use_elf_stt_common is set.
* doc/as.texinfo: Document --elf-stt-common=.
* testsuite/gas/elf/common3.s: New file.
* testsuite/gas/elf/common3a.d: Likewise.
* testsuite/gas/elf/common3b.d: Likewise.
* testsuite/gas/elf/common4.s: Likewise.
* testsuite/gas/elf/common4a.d: Likewise.
* testsuite/gas/elf/common4b.d: Likewise.
* testsuite/gas/i386/dw2-compress-3b.d: Likewise.
* testsuite/gas/i386/dw2-compressed-3b.d: Likewise.
* testsuite/gas/elf/elf.exp: Run common3a, common3b, common4a
and common4b.
* testsuite/gas/i386/dw2-compress-3.d: Renamed to ...
* testsuite/gas/i386/dw2-compress-3a.d: This. Pass
--elf-stt-common=no to as.
* testsuite/gas/i386/dw2-compressed-3.d: Renamed to ...
* testsuite/gas/i386/dw2-compressed-3a.d: This. Pass
--elf-stt-common=no to as.
* testsuite/gas/i386/i386.exp: Run dw2-compress-3a,
dw2-compress-3b, dw2-compressed-3a and dw2-compressed-3b instead
of dw2-compress-3 and dw2-compressed-3.
include/
PR ld/19645
* bfdlink.h (bfd_link_elf_stt_common): New enum.
(bfd_link_info): Add elf_stt_common.
ld/
PR ld/19645
* NEWS: Mention -z common/-z nocommon for ELF targets.
* emultempl/elf32.em (gld${EMULATION_NAME}_handle_option): Handle
-z common and -z nocommon.
* ld.texinfo: Document -z common/-z nocommon.
* lexsup.c (elf_shlib_list_options): Add -z common/-z nocommon.
* testsuite/ld-elf/tls_common.exp: Test --elf-stt-common=no and
--elf-stt-common=yes with assembler.
* testsuite/ld-elfcomm/common-1.s: New file.
* testsuite/ld-elfcomm/common-1a.d: Likewise.
* testsuite/ld-elfcomm/common-1b.d: Likewise.
* testsuite/ld-elfcomm/common-1c.d: Likewise.
* testsuite/ld-elfcomm/common-1d.d: Likewise.
* testsuite/ld-elfcomm/common-1e.d: Likewise.
* testsuite/ld-elfcomm/common-1f.d: Likewise.
* testsuite/ld-elfcomm/common-2.s: Likewise.
* testsuite/ld-elfcomm/common-2a.d: Likewise.
* testsuite/ld-elfcomm/common-2b.d: Likewise.
* testsuite/ld-elfcomm/common-2c.d: Likewise.
* testsuite/ld-elfcomm/common-2d.d: Likewise.
* testsuite/ld-elfcomm/common-2e.d: Likewise.
* testsuite/ld-elfcomm/common-2f.d: Likewise.
* testsuite/ld-elfcomm/common-3a.rd: Likewise.
* testsuite/ld-elfcomm/common-3b.rd: Likewise.
* testsuite/ld-i386/pr19645.d: Likewise.
* testsuite/ld-i386/pr19645.s: Likewise.
* testsuite/ld-x86-64/largecomm-1.s: Likewise.
* testsuite/ld-x86-64/largecomm-1a.d: Likewise.
* testsuite/ld-x86-64/largecomm-1b.d: Likewise.
* testsuite/ld-x86-64/largecomm-1c.d: Likewise.
* testsuite/ld-x86-64/largecomm-1d.d: Likewise.
* testsuite/ld-x86-64/largecomm-1e.d: Likewise.
* testsuite/ld-x86-64/largecomm-1f.d: Likewise.
* testsuite/ld-x86-64/pr19645.d: Likewise.
* testsuite/ld-x86-64/pr19645.s: Likewise.
* testsuite/ld-elfcomm/elfcomm.exp: Test --elf-stt-common=yes
with assembler.
(assembler_generates_commons): Removed.
Run -z common/-z nocommon tests. Run *.d tests.
* testsuite/ld-i386/i386.exp: Run pr19645.
* testsuite/ld-x86-64/x86-64.exp: Likewise.
* testsuite/ld-x86-64/dwarfreloc.exp: Test --elf-stt-common with
assembler. Test STT_COMMON with readelf.
2016-02-22 17:18:52 +00:00
|
|
|
objcopy_test_elf_common_symbols
|
2005-10-19 20:49:03 +00:00
|
|
|
objcopy_test "ELF unknown section type" unknown.s
|
2005-10-20 17:06:41 +00:00
|
|
|
objcopy_test_readelf "ELF group" group.s
|
2008-10-01 21:54:59 +00:00
|
|
|
objcopy_test_readelf "ELF group" group-2.s
|
2008-10-01 23:10:48 +00:00
|
|
|
objcopy_test_readelf "ELF group" group-3.s
|
2008-10-02 01:06:12 +00:00
|
|
|
objcopy_test_readelf "ELF group" group-4.s
|
2010-02-18 00:13:30 +00:00
|
|
|
run_dump_test "group-5"
|
2011-09-16 04:23:19 +00:00
|
|
|
run_dump_test "group-6"
|
2006-05-01 14:09:35 +00:00
|
|
|
run_dump_test "copy-1"
|
2010-02-01 09:59:46 +00:00
|
|
|
run_dump_test "note-1"
|
2005-10-19 17:39:43 +00:00
|
|
|
}
|
2006-04-26 13:37:05 +00:00
|
|
|
|
|
|
|
run_dump_test "copy-2"
|
2006-05-03 14:21:18 +00:00
|
|
|
run_dump_test "copy-3"
|
2009-03-10 00:48:10 +00:00
|
|
|
run_dump_test "copy-4"
|
2015-09-29 16:35:47 +00:00
|
|
|
run_dump_test "pr19020a"
|
|
|
|
run_dump_test "pr19020b"
|
2006-06-23 16:23:09 +00:00
|
|
|
|
|
|
|
if [is_elf_format] {
|
2006-09-14 23:37:35 +00:00
|
|
|
run_dump_test "strip-1"
|
|
|
|
run_dump_test "strip-2"
|
2007-04-12 19:20:46 +00:00
|
|
|
run_dump_test "strip-3"
|
2008-10-01 21:54:59 +00:00
|
|
|
run_dump_test "strip-4"
|
|
|
|
run_dump_test "strip-5"
|
2008-10-01 23:10:48 +00:00
|
|
|
run_dump_test "strip-6"
|
|
|
|
run_dump_test "strip-7"
|
2008-10-02 01:06:12 +00:00
|
|
|
run_dump_test "strip-8"
|
|
|
|
run_dump_test "strip-9"
|
2015-08-07 17:28:42 +00:00
|
|
|
run_dump_test "strip-12"
|
2016-05-16 07:51:26 +00:00
|
|
|
# This requires STB_GNU_UNIQUE support with OSABI set to GNU.
|
|
|
|
if { [supports_gnu_unique] } {
|
2010-09-23 12:04:37 +00:00
|
|
|
run_dump_test "strip-10"
|
|
|
|
}
|
2014-12-26 07:56:38 +00:00
|
|
|
set extra_strip11 ""
|
|
|
|
if { [istarget "sh64*-*"] } {
|
|
|
|
# pr17755 testcase
|
|
|
|
set extra_strip11 { { "as" "--isa=SHmedia --abi=64" } }
|
|
|
|
}
|
|
|
|
run_dump_test "strip-11" $extra_strip11
|
2007-04-24 10:56:58 +00:00
|
|
|
|
2007-05-15 04:23:50 +00:00
|
|
|
if { [istarget "i*86-*"] || [istarget "x86_64-*-*"] } {
|
|
|
|
# Check to make sure we don't strip a symbol named in relocations.
|
|
|
|
set test "objcopy keeps symbols needed by relocs"
|
2007-04-24 10:56:58 +00:00
|
|
|
|
2007-05-15 04:23:50 +00:00
|
|
|
set srcfile $srcdir/$subdir/needed-by-reloc.s
|
2007-04-24 10:56:58 +00:00
|
|
|
|
2007-05-15 04:23:50 +00:00
|
|
|
if {![binutils_assemble $srcfile tmpdir/bintest.o]} then {
|
|
|
|
unresolved $test
|
|
|
|
} else {
|
|
|
|
set got [binutils_run $OBJCOPY "$OBJCOPYFLAGS --strip-symbol=foo tmpdir/bintest.o ${copyfile}.o"]
|
2007-04-24 10:56:58 +00:00
|
|
|
|
2007-05-15 04:23:50 +00:00
|
|
|
if [regexp "not stripping symbol `foo' because it is named in a relocation" $got] {
|
|
|
|
pass $test
|
|
|
|
} else {
|
|
|
|
fail $test
|
|
|
|
}
|
|
|
|
}
|
2007-04-24 10:56:58 +00:00
|
|
|
}
|
2007-05-15 04:23:50 +00:00
|
|
|
|
2012-03-13 00:41:22 +00:00
|
|
|
# The symbol table for some MIPS targets is sorted differently than
|
|
|
|
# the ELF canonical order, so the regexps in localize-hidden-1.d fail
|
2016-06-23 12:41:57 +00:00
|
|
|
# to match.
|
|
|
|
if { [is_bad_symtab] } then {
|
|
|
|
setup_xfail "*-*-*"
|
2012-03-13 00:41:22 +00:00
|
|
|
}
|
2007-05-15 04:23:50 +00:00
|
|
|
run_dump_test "localize-hidden-1"
|
2009-07-16 21:10:49 +00:00
|
|
|
run_dump_test "testranges"
|
|
|
|
run_dump_test "testranges-ia64"
|
2010-01-20 00:09:13 +00:00
|
|
|
|
|
|
|
run_dump_test "add-section"
|
2015-10-21 14:16:35 +00:00
|
|
|
run_dump_test "add-symbol"
|
2010-01-20 00:09:13 +00:00
|
|
|
run_dump_test "add-empty-section"
|
2010-05-18 03:31:07 +00:00
|
|
|
|
|
|
|
run_dump_test "exclude-1a"
|
|
|
|
run_dump_test "exclude-1b"
|
2015-08-24 12:02:39 +00:00
|
|
|
|
|
|
|
run_dump_test "only-section-01"
|
|
|
|
run_dump_test "remove-section-01"
|
objcopy/strip: Add option --remove-relocations=SECTIONPATTERN
The objcopy and strip tools make use of the bfd library to manipulate
the state of the input file (to produce an output file). Within the
input file (for ELF at least), relocations are held within a section,
and so, if the user wanted to remove the relocations, but keep the
section to which the relocations would have been applied, it is tempting
to think that specifying the name of a relocation section to objcopy's
--remove-section option might do what you want, for example:
objcopy --remove-section=.rela.text input.elf output.elf
However, this does not work. The reason is that when the input file is
loaded, relocations are not managed as sections, but are, instead,
loaded as data associated with the section to which the relocations
would be applied. In our example above the relocations in '.rela.text'
are held as data on the section '.text' once 'input.elf' is loaded.
One task that objcopy and strip do is copy the relocations from the
input file to the output file if the section is also being copied from
the input file to the output file.
This commit adds a new command line option for objcopy and strip,
--remove-relocations, which can be used to remove the relocations, while
keeping the section that the relocations would have been applied to, for
example:
objcopy --remove-relocations=.text input.elf output.elf
in this case the section '.text' will appear in both 'input.elf' and
'output.elf', but any relocations in 'input.elf' that apply to '.text'
will not be present in 'output.elf'.
I have also added a special case to the handling of --remove-section
that spots if a user tries to remove a relocation section (currently
this is done by spotting the '.rela.' or '.rel.' prefix) and forwards
the request to --remove-relocations.
As with --remove-section and --only-section the --remove-relocations
option supports the '!' prefix on the section-patterns it takes to allow
for sections to be specifically not matched.
There are tests for all the new functionality.
binutils/ChangeLog:
* doc/binutils.texi (objcopy): Document 'remove-relocations'.
(strip): Likewise.
* objcopy.c (SECTION_CONTEXT_REMOVE_RELOCS): Define.
(enum command_line_switch): Add 'OPTION_REMOVE_RELOCS'.
(struct option strip_options): Add 'remove-relocations'.
(struct option copy_options): Likewise.
(copy_usage): Likewise.
(strip_usage): Likewise.
(handle_remove_relocations_option): New function.
(discard_relocations): New function.
(handle_remove_section_option): New function.
(copy_relocations_in_section): Use discard_relocations.
(strip_main): Use handle_remove_section_option for
'remove-section', and handle 'remove-relocations' option.
(copy_main): Likewise.
* testsuite/binutils-all/objcopy.exp: Run new tests.
* testsuite/binutils-all/remove-relocs-01.d: New file.
* testsuite/binutils-all/remove-relocs-01.s: New file.
* testsuite/binutils-all/remove-relocs-02.d: New file.
* testsuite/binutils-all/remove-relocs-03.d: New file.
* testsuite/binutils-all/remove-relocs-04.d: New file.
* testsuite/binutils-all/remove-relocs-05.d: New file.
* testsuite/binutils-all/remove-relocs-06.d: New file.
2015-08-21 19:08:26 +00:00
|
|
|
|
|
|
|
# Test the remove relocation functionality
|
|
|
|
set test_list [lsort [glob -nocomplain $srcdir/$subdir/remove-relocs-*.d]]
|
|
|
|
foreach t $test_list {
|
|
|
|
# We need to strip the ".d", but can leave the dirname.
|
|
|
|
verbose [file rootname $t]
|
|
|
|
run_dump_test [file rootname $t]
|
|
|
|
}
|
2007-04-24 10:56:58 +00:00
|
|
|
}
|
2007-05-15 04:23:50 +00:00
|
|
|
run_dump_test "localize-hidden-2"
|
2016-02-02 11:30:21 +00:00
|
|
|
|
|
|
|
# Test objcopying an object file without global symbol
|
|
|
|
|
|
|
|
proc objcopy_test_without_global_symbol { } {
|
|
|
|
global OBJCOPY
|
|
|
|
global OBJCOPYFLAGS
|
|
|
|
global OBJDUMP
|
|
|
|
global OBJDUMPFLAGS
|
|
|
|
global srcdir
|
|
|
|
global subdir
|
|
|
|
|
|
|
|
set test "strip without global symbol "
|
|
|
|
|
|
|
|
if { [target_compile $srcdir/$subdir/pr19547.c tmpdir/pr19547.o object debug] != "" } {
|
|
|
|
untested $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if [is_remote host] {
|
|
|
|
set objfile [remote_download host tmpdir/pr19547.o]
|
|
|
|
} else {
|
|
|
|
set objfile tmpdir/pr19547.o
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $OBJCOPY "$OBJCOPYFLAGS --strip-unneeded $objfile"]
|
|
|
|
if ![string equal "" $exec_output] {
|
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
set exec_output [binutils_run $OBJDUMP "$OBJDUMPFLAGS -t $objfile"]
|
|
|
|
if {![regexp "no symbols" $exec_output]} {
|
|
|
|
fail $test
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
pass $test
|
|
|
|
}
|
|
|
|
|
2016-07-01 09:32:45 +00:00
|
|
|
# The AArch64 and ARM targets preserve mapping symbols
|
|
|
|
# in object files, so they will fail this test.
|
|
|
|
setup_xfail aarch64*-*-* arm*-*-*
|
|
|
|
|
2016-02-02 11:30:21 +00:00
|
|
|
objcopy_test_without_global_symbol
|