1 # Makefile for regression testing the frv simulator.
2 # Copyright (C) 1998, 2007, 2008, 2009 Free Software Foundation, Inc.
4 # This file is part of GDB.
6 # This program is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
9 # (at your option) any later version.
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
21 srcroot = $(srcdir)/../../..
24 exec_prefix = @exec_prefix@
26 host_alias = @host_alias@
27 target_alias = @target_alias@
28 program_transform_name = @program_transform_name@
29 build_canonical = @build@
30 host_canonical = @host@
31 target_canonical = @target@
32 target_cpu = @target_cpu@
37 RPATH_ENVVAR = @RPATH_ENVVAR@
39 EXPECT = `if [ -f ../../../expect/expect ] ; then \
40 echo ../../../expect/expect ; \
41 else echo expect ; fi`
43 RUNTEST = $(RUNTEST_FOR_TARGET)
47 RUNTEST_FOR_TARGET = `\
48 if [ -f $${srcroot}/dejagnu/runtest ]; then \
49 echo $${srcroot}/dejagnu/runtest; \
51 if [ "$(host_canonical)" = "$(target_canonical)" ]; then \
54 t='$(program_transform_name)'; echo runtest | sed -e '' $$t; \
60 if [ -x ../../../gas/as-new ]; then \
61 echo ../../../gas/as-new ; \
63 echo $(target_alias)-as ; \
67 if [ -x ../../../ld/ld-new ]; then \
68 echo ../../../ld/ld-new ; \
70 echo $(target_alias)-ld ; \
74 if [ -x ../../../sim/${target_cpu}/run ]; then \
75 echo ../../../sim/${target_cpu}/run ; \
77 echo $(target_alias)-run ; \
86 check: sanity $(TESTS)
88 @eval echo AS_FOR_TARGET = $(AS_FOR_TARGET)
89 @eval echo LD_FOR_TARGET = $(LD_FOR_TARGET)
90 @eval echo RUN_FOR_TARGET = $(RUN_FOR_TARGET)
94 # Rules for running all the tests, put into three types
95 # exit success, exit fail, print "Hello World"
99 $(RUN_FOR_TARGET) $* > $*.log
102 # Rules for running the tests
104 .SUFFIXES: .u .ok .run .hi .ko
107 ulimit -t 5 ; $(RUN_FOR_TARGET) $*.run > tmp-$*
110 rm -f tmp-$* $*.hi diff-$*
111 ulimit -t 5 ; $(RUN_FOR_TARGET) $*.run > tmp-$*
112 echo "Hello World" | diff - tmp-$* > diff-$*
113 cat tmp-$* diff-$* > $*.hi
117 ulimit -t 5 ; $(RUN_FOR_TARGET) $*.run > tmp-$* ; \
118 if [ $$? -eq 47 ] ; then \
126 # Rules for building all the tests and packing them into
129 uuencode: em-pstr.u em-e0.u em-e47.u em-pchr.u
131 .SUFFIXES: .u .s .run
134 $(AS_FOR_TARGET) $(srcdir)/$*.s -o $*.o
135 $(LD_FOR_TARGET) -o $* $*.o
136 uuencode < $* $* > $*.u
140 $(AS_FOR_TARGET) $(srcdir)/$*.s -o $*.o
141 $(LD_FOR_TARGET) -o $*.run $*.o
146 rm -f *~ core *.o a.out
149 distclean maintainer-clean realclean: clean
151 rm -f Makefile config.status *-init.exp
152 rm -fr *.log summary detail *.plog *.sum *.psum site.*
154 Makefile : Makefile.in config.status
155 $(SHELL) config.status
157 config.status: configure
158 $(SHELL) config.status --recheck