diff options
Diffstat (limited to 'ld/testsuite/ld-elf/binutils.exp')
-rw-r--r-- | ld/testsuite/ld-elf/binutils.exp | 67 |
1 files changed, 53 insertions, 14 deletions
diff --git a/ld/testsuite/ld-elf/binutils.exp b/ld/testsuite/ld-elf/binutils.exp index 77ba761..aa59b69 100644 --- a/ld/testsuite/ld-elf/binutils.exp +++ b/ld/testsuite/ld-elf/binutils.exp @@ -20,26 +20,41 @@ # Make sure that binutils can correctly handle ld output in ELF. -# This test can only be run on ELF platforms. -if ![is_elf_format] { +# Run on Linux only. +if { ![istarget *-*-linux*] } { return } -proc strip_test { ld_options test } { +if { [istarget *-*-linux*aout*] + || [istarget *-*-linux*oldld*] } { + return +} + +proc binutils_test { prog_name ld_options test } { global as global ld global READELF + global objcopy global strip global srcdir global subdir + global link_output + + eval set prog \$$prog_name + set test_name "$prog_name $ld_options ($test)" if { ![ld_assemble $as $srcdir/$subdir/$test.s tmpdir/$test.o ] } { - unresolved "$ld_options" + unresolved "$test_name" return } if { ![ld_simple_link $ld tmpdir/$test "$ld_options tmpdir/$test.o"] } { - unresolved "$ld_options" + if { [string match "*not supported*" $link_output] + || [string match "*unrecognized option*" $link_output] } { + unsupported "$ld_options is not supported by this target" + } else { + unresolved "$test_name" + } return } @@ -47,15 +62,15 @@ proc strip_test { ld_options test } { catch "exec $READELF -l --wide tmpdir/$test > tmpdir/$test.exp" got if ![string match "" $got] then { send_log "$got\n" - unresolved "$ld_options" + unresolved "$test_name" return } - send_log "$strip tmpdir/$test\n" - catch "exec $strip tmpdir/$test" got + send_log "$prog tmpdir/$test\n" + catch "exec $prog tmpdir/$test" got if ![string match "" $got] then { send_log "$got\n" - unresolved "$ld_options" + fail "$test_name" return } @@ -63,18 +78,42 @@ proc strip_test { ld_options test } { catch "exec $READELF -l --wide tmpdir/$test > tmpdir/$test.out" got if ![string match "" $got] then { send_log "$got\n" - unresolved "$ld_options" + unresolved "$test_name" return } if { [catch {exec cmp tmpdir/$test.exp tmpdir/$test.out}] } then { send_log "tmpdir/$test.exp tmpdir/$test.out differ.\n" - fail "$ld_options" + fail "$test_name" return } - pass "$ld_options" + pass "$test_name" } -strip_test "-z max-page-size=0x200000" maxpage1 -strip_test "-z max-page-size=0x200000 -z common-page-size=0x100000" maxpage1 +binutils_test strip "-z max-page-size=0x200000" maxpage1 +binutils_test strip "-z max-page-size=0x200000 -z common-page-size=0x100000" maxpage1 +binutils_test strip "-z max-page-size=0x100000" maxpage1 +binutils_test strip "-z max-page-size=0x100000 -z common-page-size=0x1000" maxpage1 + +binutils_test strip "" maxpage1 +binutils_test strip "-shared" maxpage1 +binutils_test objcopy "" maxpage1 +binutils_test objcopy "-shared" maxpage1 + +binutils_test objcopy "" tbss1 +binutils_test objcopy "-shared" tbss1 +binutils_test objcopy "-z max-page-size=0x100000" tbss1 +binutils_test objcopy "-z max-page-size=0x100000 -z common-page-size=0x1000" tbss1 +binutils_test objcopy "" tdata1 +binutils_test objcopy "-shared" tdata1 +binutils_test objcopy "-z max-page-size=0x100000" tdata1 +binutils_test objcopy "-z max-page-size=0x100000 -z common-page-size=0x1000" tdata1 +binutils_test objcopy "" tbss2 +binutils_test objcopy "-shared" tbss2 +binutils_test objcopy "-z max-page-size=0x100000" tbss2 +binutils_test objcopy "-z max-page-size=0x100000 -z common-page-size=0x1000" tbss2 +binutils_test objcopy "-z max-page-size=0x100000" tdata2 +binutils_test objcopy "" tdata2 +binutils_test objcopy "-shared" tdata2 +binutils_test objcopy "-z max-page-size=0x100000 -z common-page-size=0x1000" tdata2 |