# Test basic linker script functionality
# By Ian Lance Taylor, Cygnus Support
-# Copyright 1999, 2000, 2001, 2002, 2004, 2005, 2006, 2007, 2009, 2010
-# Free Software Foundation, Inc.
+# Copyright (C) 1999-2015 Free Software Foundation, Inc.
#
# This file is part of the GNU Binutils.
#
set passes 0
}
+ if {[info exists nm_output(tred)] \
+ && $nm_output(tred) != (0x100 + 0x8000)} {
+ send_log "tred == $nm_output(tred)\n"
+ verbose "tred == $nm_output(tred)"
+ set passes 0
+ }
+
if {$nm_output(text_end) < $text_end \
|| $nm_output(text_end) > 0x110} {
send_log "text_end == $nm_output(text_end)\n"
set passes 0
}
+ if {[info exists nm_output(fred)] \
+ && $nm_output(fred) != (0x1000 + 0x10000)} {
+ send_log "fred == $nm_output(fred)\n"
+ verbose "fred == $nm_output(fred)"
+ set passes 0
+ }
+
if {$nm_output(data_end) < $data_end \
|| $nm_output(data_end) > 0x1010} {
send_log "data_end == $nm_output(data_end)\n"
}
}
+proc extract_symbol_test { testfile testname } {
+ global objcopy
+ global nm
+ global size
+ global target_triplet
+
+ set copyfile tmpdir/extract
+ set args "--extract-symbol $testfile $copyfile"
+ set exec_output [run_host_cmd $objcopy $args]
+ if ![string equal "" $exec_output] {
+ fail $testname
+ return
+ }
+
+ set orig_syms [run_host_cmd $nm $testfile]
+ set syms_massaged $orig_syms
+ switch -regexp $target_triplet {
+ ^mmix-knuth-mmixware$ {
+ # Without section sizes (stripped together with the
+ # contents for this target), we can't deduce the symbol
+ # types. Artificially tracking the symbol types is
+ # considered not worthwhile as there's no known use-case
+ # for --extract-symbols for this target. The option is
+ # supported just enough to emit the same symbol values,
+ # but absolute symbol types are expected.
+ regsub -all " \[TD\] " $syms_massaged " A " syms_massaged
+ }
+ }
+
+ set extract_syms [run_host_cmd $nm $copyfile]
+ if ![string equal $syms_massaged $extract_syms] {
+ fail $testname
+ return
+ }
+
+ set exec_output [run_host_cmd $size $copyfile]
+ if ![regexp ".* 0\[ \]+0\[ \]+0\[ \]+0\[ \]+0\[ \]+.*" $exec_output] {
+ fail $testname
+ return
+ }
+
+ pass $testname
+}
+
# PE targets need to set the image base to 0 to avoid complications from nm.
set flags ""
if {[istarget "*-*-pe*"] \
check_script
}
+set testname "MEMORY with symbols"
+if ![ld_simple_link $ld tmpdir/script "$flags -defsym DATA_ORIGIN=0x1000 -defsym DATA_LENGTH=0x10000 -T $srcdir/$subdir/memory_sym.t tmpdir/script.o"] {
+ fail $testname
+ untested "extract symbols"
+} else {
+ check_script
+ extract_symbol_test tmpdir/script "extract symbols"
+}
+
set test_script_list [lsort [glob $srcdir/$subdir/region-alias-*.t]]
foreach test_script $test_script_list {
- set testname [file tail $test_script]
- if ![ld_simple_link $ld tmpdir/script "$flags -T $test_script tmpdir/script.o"] {
- xfail "REGION_ALIAS: $testname"
- } else {
- xpass "REGION_ALIAS: $testname"
- }
+ run_dump_test [string range $test_script 0 end-2]
}
+
+run_dump_test "align-with-input"