aboutsummaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-cris/cris.exp
blob: 82b817100173cbb88be80547d3ce2c7e6e21ee1b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# Expect script for ld-cris tests
#   Copyright 2002, 2005, 2007, 2009 Free Software Foundation, Inc.
#
# This file is part of the GNU Binutils.
#
# 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
# the Free Software Foundation; either version 3 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.
#
# Written by Hans-Peter Nilsson (hp@axis.com)
#

if ![istarget cris-*-*] {
    return
}

set rd_test_list [lsort [glob -nocomplain $srcdir/$subdir/*.d]]

# First, execute those tests that are named to indicate that they create a
# DSO.  Copy the file from the run_dump_test "tmpdir/dump" to a unique
# expected name.
# FIXME: Add option "output: filename" to run_dump_test.
# FIXME: Add option "ldtail: option" to run_dump_test, so we can link
# libraries in the right order.
foreach atest $rd_test_list {
    # We need to check against runtest_file_p too, or we'd mindlessly copy
    # the last tmpdir/dump in selective test-runs.
    if { [string match $srcdir/$subdir/*dso-*.d $atest] \
	    && [runtest_file_p $runtests [file tail $atest]] } {
	verbose [file rootname $atest]
	run_dump_test [file rootname $atest]
	set cmd "cp tmpdir/dump tmpdir/[file rootname [file tail $atest]].so"
	send_log "$cmd\n"
	set cmdret [catch "exec $cmd" comp_output]
	send_log "$comp_output\n"
	# FIXME: What if it fails?  Need we do something?
    }
}

# Then run the ordinary tests.  This round, exclude the dso-* tests.
foreach atest $rd_test_list {
    # We need to strip the ".d", but can leave the dirname.
    if { ! [string match $srcdir/$subdir/*dso-*.d $atest] } {
	verbose [file rootname $atest]
	run_dump_test [file rootname $atest]
    }
}