blob: ce49fe417130780579292d90a35d41e270c2b005 [file] [log] [blame]
# Copyright (C) 1998,1999 Free Software Foundation, Inc.
# 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 2 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Please email any bugs, comments, and/or additions to this file to:
# bug-gcc@prep.ai.mit.edu
# This file was created for by Vladimir Makarov (vmakarov@cygnus.com)
# on the base c-torture.exp.
# The script requires setting up BASE_COMPILER (e.g. in RUNTESTFLAGS).
# The default options can be overridden by
# CONSISTENCY_OPTIONS="option ... " (e.g. in RUNTESTFLAGS).
if $tracelevel then {
strace $tracelevel
}
if ![info exists BASE_COMPILER] {
fail "BASE_COMPILER is not set"
return
}
if ![info exists CONSISTENCY_OPTIONS] {
set CONSISTENCY_OPTIONS "-O2"
}
if ![info exists NO_LONG_DOUBLE] {
set NO_LONG_DOUBLE 0
}
if ![info exists NO_LIBGLOSS_LIBRARY_OPTIONS] {
set NO_LIBGLOSS_LIBRARY_OPTIONS 0
}
puts $CONSISTENCY_OPTIONS
regsub -- -.* $target_triplet "" target_chip
#
# c-consistency-execute -- utility to compile and execute a testcase
#
# SRC is the full pathname of the testcase.
#
# If the testcase has an associated .cexp file, we source that to run the
# test instead. We use .cexp instead of .exp so that the testcase is still
# controlled by the main .exp driver (this is useful when one wants to only
# run the compile.exp tests for example - one need only pass compile.exp to
# dejagnu, and not compile.exp, foo1.exp, foo2.exp, etc.).
#
proc c-consistency-execute { src cpp_flag out_suffix} {
global tmpdir tool srcdir output
global exec_output target_chip BASE_COMPILER target_triplet
global CONSISTENCY_OPTIONS NO_LONG_DOUBLE
set consistency_options $CONSISTENCY_OPTIONS
set rootname [file rootname $src]
set dirname [file dirname $src]
set basename [file tail $rootname]
# Check for alternate driver.
if [file exists $rootname.cexp] {
verbose "Using alternate driver $basename.cexp" 2
set done_p 0
catch "set done_p \[source $rootname.cexp\]"
if { $done_p } {
return
}
}
set executable $tmpdir/$basename.x
regsub "^$srcdir/?" $src "" testcase
# If we couldn't rip $srcdir out of `src' then just do the best we can.
# The point is to reduce the unnecessary noise in the logs. Don't strip
# out too much because different testcases with the same name can confuse
# `test-tool'.
if [string match "/*" $testcase] {
set testcase "[file tail $dirname]/[file tail $src]"
}
# consistency_{compile,execute}_xfail are set by the .cexp script
# (if present)
if [info exists consistency_compile_xfail] {
setup_xfail $consistency_compile_xfail
}
remote_file build delete $executable
verbose "Testing $testcase, $consistency_options" 1
set options ""
lappend options "additional_flags=-w $consistency_options"
set wrap_file ""
if {[file exists "$dirname/WRAP_FILE"] \
&& [file readable "$dirname/WRAP_FILE"]} {
set fd [open "$dirname/WRAP_FILE"]
set wrap_file "$dirname/[read -nonewline $fd]"
close $fd
}
set comp_output [gcc_target_compile "$cpp_flag $src -x none $wrap_file" "$executable" executable $options];
# Set a few common compiler messages.
set fatal_signal "*cc: Internal compiler error: program*got fatal signal"
if [string match "$fatal_signal 6" $comp_output] then {
fail $testcase "Got Signal 6, $cpp_flag $consistency_options"
remote_file build delete $executable
return
}
if [string match "$fatal_signal 11" $comp_output] then {
fail $testcase "Got Signal 11, $cpp_flag $consistency_options"
remote_file build delete $executable
return
}
# We shouldn't get these because of -w, but just in case.
if [string match "*cc:*warning:*" $comp_output] then {
warning "$testcase: (with warnings) $cpp_flag $consistency_options"
send_log "$comp_output\n"
unresolved "$testcase, $cpp_flag $consistency_options"
remote_file build delete $executable
return
}
set comp_output [prune_warnings $comp_output]
if { ![file exists $executable] } {
if ![is3way] {
fail "$testcase compilation, $cpp_flag $consistency_options"
untested "$testcase execution, $cpp_flag $consistency_options"
return
} else {
# FIXME: since we can't test for the existance of a remote
# file without short of doing an remote file list, we assume
# that since we got no output, it must have compiled.
pass "$testcase compilation, $cpp_flag $consistency_options"
}
} else {
pass "$testcase compilation, $cpp_flag $consistency_options"
}
# Check for compilation only.
if [file exists $rootname.conly] {
remote_file build delete $executable
return;
}
# See if this source file uses "long long" types, if it does, and
# no_long_long is set, skip execution of the test.
if [target_info exists no_long_long] then {
if [expr [search_for $src "long long"]] then {
untested "$testcase execution, $options"
continue
}
}
if [info exists consistency_execute_xfail] {
setup_xfail $consistency_execute_xfail
}
set exec_output ""
set result [consistency_load "$executable" "" ""]
set status [lindex $result 0];
set exec_output [lindex $result 1];
# Strip random whitespace junk from the output. the
# whitejunk is an artifact of the way we get output
# from boards.
regsub "^\[ \t\r]+" $exec_output "" clean_output
regsub -all "\r" $clean_output "" clean_output
regsub -all "\[ \t]*\n\[ \t]*" $clean_output "\n" clean_output
regsub -all "\n+" $clean_output "\n" clean_output
regsub -all "^\n+$" $clean_output "" clean_output
if { $status == "pass" } {
remote_file build delete $executable
}
$status "$testcase execution, $cpp_flag $consistency_options"
if { $status != "pass" } {
return
}
# Now save the output of the test programs
set outfile_name "$tmpdir/$basename.$out_suffix"
set outf [open $outfile_name "w"]
if { $clean_output != "" } {
puts -nonewline $outf $clean_output
}
close $outf
set base_outfile_name "$dirname/${BASE_COMPILER}-results/$basename.$out_suffix"
# Check that the output for another processor has been saved
if { ![file exists $base_outfile_name] } {
untested "$testcase consistency - $base_outfile_name doesn't exist"
return
} elseif { ![file readable $base_outfile_name] } {
untested "$testcase consistency - $base_outfile_name is not readable"
return
}
# See if this source file uses "long double" types, if it does, and
# NO_LONG_DOUBLE is TRUE, skip comparison of the test.
if {$NO_LONG_DOUBLE} then {
if [expr [search_for $src "long double"]] then {
setup_xfail "$target_triplet"
}
}
# Compare the outputs
if {![catch "exec diff -b $outfile_name $base_outfile_name" message]} {
pass "$testcase consistency, $cpp_flag $consistency_options"
} else {
regsub "\n\[^>\n]\[^\n]*\$" $message "\n" difference
fail "$testcase consistency, $cpp_flag $consistency_options\n$difference"
}
}
#
# search_for -- looks for a string match in a file
#
proc search_for { file pattern } {
set fd [open $file r]
while { [gets $fd cur_line]>=0 } {
if [string match "*$pattern*" $cur_line] then {
close $fd
return 1
}
}
close $fd
return 0
}
if {$NO_LIBGLOSS_LIBRARY_OPTIONS} {
# Remove standard libgloss library paths
set board_info(powerpc-sim,ldflags) "-msim"
}
#
# main test loop
#
foreach dir [lsort [glob -nocomplain $srcdir/$subdir/\[a-z\]*]] {
if [file isdirectory $dir] {
set all_sources [concat [glob -nocomplain $dir/*.c] [glob -nocomplain $dir/*.cpp]]
foreach src [lsort $all_sources] {
# If we're only testing specific files and this isn't one of
# them, skip it.
if ![runtest_file_p $runtests $src] then {
continue
}
regsub "^.*\\." $src "" suffix
if {$suffix != "cpp"} {
c-consistency-execute $src "" "out"
}
c-consistency-execute $src "-x c++" "out++"
}
}
}