diff options
| author | Matthias Benkard <code@mail.matthias.benkard.de> | 2008-03-03 21:39:37 +0100 | 
|---|---|---|
| committer | Matthias Benkard <code@mail.matthias.benkard.de> | 2008-03-03 21:39:37 +0100 | 
| commit | cd11ae061b002913740483529e31b3f6d3da753d (patch) | |
| tree | a6d84df9a4a8ed53476aa079a7202fdec69f4d98 /libffi-3.0.4/testsuite/lib | |
| parent | b2342735e543f8fec2f6914d5e628391dd0ffc46 (diff) | |
Update libffi to 3.0.4.
darcs-hash:d0cdf89441c98da668f268b1af91e536dc3ed76e
Diffstat (limited to 'libffi-3.0.4/testsuite/lib')
| -rw-r--r-- | libffi-3.0.4/testsuite/lib/libffi-dg.exp | 289 | ||||
| -rw-r--r-- | libffi-3.0.4/testsuite/lib/target-libpath.exp | 263 | ||||
| -rw-r--r-- | libffi-3.0.4/testsuite/lib/wrapper.exp | 45 | 
3 files changed, 597 insertions, 0 deletions
| diff --git a/libffi-3.0.4/testsuite/lib/libffi-dg.exp b/libffi-3.0.4/testsuite/lib/libffi-dg.exp new file mode 100644 index 0000000..226893d --- /dev/null +++ b/libffi-3.0.4/testsuite/lib/libffi-dg.exp @@ -0,0 +1,289 @@ +#   Copyright (C) 2003, 2005, 2008 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. + +proc load_gcc_lib { filename } { +    global srcdir +    load_file $srcdir/lib/$filename +} + +load_lib dg.exp +load_lib libgloss.exp +load_gcc_lib target-libpath.exp +load_gcc_lib wrapper.exp + + +# Define libffi callbacks for dg.exp. + +proc libffi-dg-test-1 { target_compile prog do_what extra_tool_flags } { + +    # To get all \n in dg-output test strings to match printf output +    # in a system that outputs it as \015\012 (i.e. not just \012), we +    # need to change all \n into \r?\n.  As there is no dejagnu flag +    # or hook to do that, we simply change the text being tested. +    # Unfortunately, we have to know that the variable is called +    # dg-output-text and lives in the caller of libffi-dg-test, which +    # is two calls up.  Overriding proc dg-output would be longer and +    # would necessarily have the same assumption. +    upvar 2 dg-output-text output_match + +    if { [llength $output_match] > 1 } { +	regsub -all "\n" [lindex $output_match 1] "\r?\n" x +	set output_match [lreplace $output_match 1 1 $x] +    } + +    # Set up the compiler flags, based on what we're going to do. + +    set options [list] +    switch $do_what { +	"compile" { +	    set compile_type "assembly" +	    set output_file "[file rootname [file tail $prog]].s" +	} +	"link" { +	    set compile_type "executable" +	    set output_file "[file rootname [file tail $prog]].exe" +	    # The following line is needed for targets like the i960 where +	    # the default output file is b.out.  Sigh. +	} +	"run" { +	    set compile_type "executable" +	    # FIXME: "./" is to cope with "." not being in $PATH. +	    # Should this be handled elsewhere? +	    # YES. +	    set output_file "./[file rootname [file tail $prog]].exe" +	    # This is the only place where we care if an executable was +	    # created or not.  If it was, dg.exp will try to run it. +	    remote_file build delete $output_file; +	} +	default { +	    perror "$do_what: not a valid dg-do keyword" +	    return "" +	} +    } + +    if { $extra_tool_flags != "" } { +	lappend options "additional_flags=$extra_tool_flags" +    } + +    set comp_output [libffi_target_compile "$prog" "$output_file" "$compile_type" $options]; + + +    return [list $comp_output $output_file] +} + + +proc libffi-dg-test { prog do_what extra_tool_flags } { +    return [libffi-dg-test-1 target_compile $prog $do_what $extra_tool_flags] +} + +proc libffi-init { args } { +    global gluefile wrap_flags; +    global srcdir +    global blddirffi +    global objdir +    global TOOL_OPTIONS +    global tool +    global libffi_include +    global libffi_link_flags +    global tool_root_dir +    global ld_library_path + +    set blddirffi [pwd]/.. +    verbose "libffi $blddirffi" + +    set gccdir [lookfor_file $tool_root_dir gcc/libgcc.a] +    if {$gccdir != ""} { +	set gccdir [file dirname $gccdir] +    } +    verbose "gccdir $gccdir" + +    set ld_library_path "." +    append ld_library_path ":${gccdir}" + +    set compiler "${gccdir}/xgcc" +    if { [is_remote host] == 0 && [which $compiler] != 0 } { +	foreach i "[exec $compiler --print-multi-lib]" { +	    set mldir "" +	    regexp -- "\[a-z0-9=_/\.-\]*;" $i mldir +	    set mldir [string trimright $mldir "\;@"] +	    if { "$mldir" == "." } { +		continue +	    } +	    if { [llength [glob -nocomplain ${gccdir}/${mldir}/libgcc_s*.so.*]] >= 1 } { +		append ld_library_path ":${gccdir}/${mldir}" +	    } +	} +    } +    # add the library path for libffi. +    append ld_library_path ":${blddirffi}/.libs" + +    verbose "ld_library_path: $ld_library_path" + +    # Point to the Libffi headers in libffi. +    set libffi_include "${blddirffi}/include" +    verbose "libffi_include $libffi_include" + +    set libffi_dir  "${blddirffi}/.libs" +    verbose "libffi_dir $libffi_dir" +    if { $libffi_dir != "" } { +	set libffi_dir [file dirname ${libffi_dir}] +	set libffi_link_flags "-L${libffi_dir}/.libs" +    } + +    set_ld_library_path_env_vars +    libffi_maybe_build_wrapper "${objdir}/testglue.o" +} + +proc libffi_exit { } { +    global gluefile; + +    if [info exists gluefile] { +	file_on_build delete $gluefile; +	unset gluefile; +    } +} + +proc libffi_target_compile { source dest type options } { +    global gluefile wrap_flags; +    global srcdir +    global blddirffi +    global TOOL_OPTIONS +    global libffi_link_flags +    global libffi_include +    global target_triplet + + +    if { [target_info needs_status_wrapper]!="" && [info exists gluefile] } { +	lappend options "libs=${gluefile}" +	lappend options "ldflags=$wrap_flags" +    } + +    # TOOL_OPTIONS must come first, so that it doesn't override testcase +    # specific options. +    if [info exists TOOL_OPTIONS] { +	lappend  options [concat "additional_flags=$TOOL_OPTIONS" $options]; +    } + +    # search for ffi_mips.h in srcdir, too +    lappend options "additional_flags=-I${libffi_include} -I${srcdir}/../include  -I${libffi_include}/.." +    lappend options "additional_flags=${libffi_link_flags}" + +    # If you're building the compiler with --prefix set to a place +    # where it's not yet installed, then the linker won't be able to +    # find the libgcc used by libffi.dylib.  We could pass the +    # -dylib_file option, but that's complicated, and it's much easier +    # to just make the linker find libgcc using -L options. +    if { [string match "*-*-darwin*" $target_triplet] } { +	lappend options "libs= -shared-libgcc" +    } + +    lappend options "libs= -lffi" + +    verbose "options: $options" +    return [target_compile $source $dest $type $options] +} + +# Utility routines. + +# +# 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 +} + +# Modified dg-runtest that can cycle through a list of optimization options +# as c-torture does. +proc libffi-dg-runtest { testcases default-extra-flags } { +    global runtests + +    foreach test $testcases { +	# If we're only testing specific files and this isn't one of +	# them, skip it. +	if ![runtest_file_p $runtests $test] { +	    continue +	} + +	# Look for a loop within the source code - if we don't find one, +	# don't pass -funroll[-all]-loops. +	global torture_with_loops torture_without_loops +	if [expr [search_for $test "for*("]+[search_for $test "while*("]] { +	    set option_list $torture_with_loops +	} else { +	    set option_list $torture_without_loops +	} + +	set nshort [file tail [file dirname $test]]/[file tail $test] + +	foreach flags $option_list { +	    verbose "Testing $nshort, $flags" 1 +	    dg-test $test $flags ${default-extra-flags} +	} +    } +} + + +# Like check_conditional_xfail, but callable from a dg test. + +proc dg-xfail-if { args } { +    set args [lreplace $args 0 0] +    set selector "target [join [lindex $args 1]]" +    if { [dg-process-target $selector] == "S" } { +	global compiler_conditional_xfail_data +	set compiler_conditional_xfail_data $args +    } +} + + +# We need to make sure that additional_files and additional_sources +# are both cleared out after every test.  It is not enough to clear +# them out *before* the next test run because gcc-target-compile gets +# run directly from some .exp files (outside of any test).  (Those +# uses should eventually be eliminated.) + +# Because the DG framework doesn't provide a hook that is run at the +# end of a test, we must replace dg-test with a wrapper. + +if { [info procs saved-dg-test] == [list] } { +    rename dg-test saved-dg-test + +    proc dg-test { args } { +	global additional_files +	global additional_sources +	global errorInfo + +	if { [ catch { eval saved-dg-test $args } errmsg ] } { +	    set saved_info $errorInfo +	    set additional_files "" +	    set additional_sources "" +	    error $errmsg $saved_info +	} +	set additional_files "" +	set additional_sources "" +    } +} + +# Local Variables: +# tcl-indent-level:4 +# End: diff --git a/libffi-3.0.4/testsuite/lib/target-libpath.exp b/libffi-3.0.4/testsuite/lib/target-libpath.exp new file mode 100644 index 0000000..8999aa4 --- /dev/null +++ b/libffi-3.0.4/testsuite/lib/target-libpath.exp @@ -0,0 +1,263 @@ +# Copyright (C) 2004, 2005, 2007 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 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 GCC; see the file COPYING3.  If not see +# <http://www.gnu.org/licenses/>. + +# This file was contributed by John David Anglin (dave.anglin@nrc-cnrc.gc.ca) + +set orig_environment_saved 0 +set orig_ld_library_path_saved 0 +set orig_ld_run_path_saved 0 +set orig_shlib_path_saved 0 +set orig_ld_libraryn32_path_saved 0 +set orig_ld_library64_path_saved 0 +set orig_ld_library_path_32_saved 0 +set orig_ld_library_path_64_saved 0 +set orig_dyld_library_path_saved 0 + + +####################################### +# proc set_ld_library_path_env_vars { } +####################################### + +proc set_ld_library_path_env_vars { } { +  global ld_library_path +  global orig_environment_saved +  global orig_ld_library_path_saved +  global orig_ld_run_path_saved +  global orig_shlib_path_saved +  global orig_ld_libraryn32_path_saved +  global orig_ld_library64_path_saved +  global orig_ld_library_path_32_saved +  global orig_ld_library_path_64_saved +  global orig_dyld_library_path_saved +  global orig_ld_library_path +  global orig_ld_run_path +  global orig_shlib_path +  global orig_ld_libraryn32_path +  global orig_ld_library64_path +  global orig_ld_library_path_32 +  global orig_ld_library_path_64 +  global orig_dyld_library_path +  global GCC_EXEC_PREFIX + +  # Set the relocated compiler prefix, but only if the user hasn't specified one. +  if { [info exists GCC_EXEC_PREFIX] && ![info exists env(GCC_EXEC_PREFIX)] } { +    setenv GCC_EXEC_PREFIX "$GCC_EXEC_PREFIX" +  } + +  # Setting the ld library path causes trouble when testing cross-compilers. +  if { [is_remote target] } { +    return +  } + +  if { $orig_environment_saved == 0 } { +    global env + +    set orig_environment_saved 1 + +    # Save the original environment. +    if [info exists env(LD_LIBRARY_PATH)] { +      set orig_ld_library_path "$env(LD_LIBRARY_PATH)" +      set orig_ld_library_path_saved 1 +    } +    if [info exists env(LD_RUN_PATH)] { +      set orig_ld_run_path "$env(LD_RUN_PATH)" +      set orig_ld_run_path_saved 1 +    } +    if [info exists env(SHLIB_PATH)] { +      set orig_shlib_path "$env(SHLIB_PATH)" +      set orig_shlib_path_saved 1 +    } +    if [info exists env(LD_LIBRARYN32_PATH)] { +      set orig_ld_libraryn32_path "$env(LD_LIBRARYN32_PATH)" +      set orig_ld_libraryn32_path_saved 1 +    } +    if [info exists env(LD_LIBRARY64_PATH)] { +      set orig_ld_library64_path "$env(LD_LIBRARY64_PATH)" +      set orig_ld_library64_path_saved 1 +    } +    if [info exists env(LD_LIBRARY_PATH_32)] { +      set orig_ld_library_path_32 "$env(LD_LIBRARY_PATH_32)" +      set orig_ld_library_path_32_saved 1 +    } +    if [info exists env(LD_LIBRARY_PATH_64)] { +      set orig_ld_library_path_64 "$env(LD_LIBRARY_PATH_64)" +      set orig_ld_library_path_64_saved 1 +    } +    if [info exists env(DYLD_LIBRARY_PATH)] { +      set orig_dyld_library_path "$env(DYLD_LIBRARY_PATH)" +      set orig_dyld_library_path_saved 1 +    } +  } + +  # We need to set ld library path in the environment.  Currently, +  # unix.exp doesn't set the environment correctly for all systems. +  # It only sets SHLIB_PATH and LD_LIBRARY_PATH when it executes a +  # program.  We also need the environment set for compilations, etc. +  # +  # On IRIX 6, we have to set variables akin to LD_LIBRARY_PATH, but +  # called LD_LIBRARYN32_PATH (for the N32 ABI) and LD_LIBRARY64_PATH +  # (for the 64-bit ABI).  The same applies to Darwin (DYLD_LIBRARY_PATH), +  # Solaris 32 bit (LD_LIBRARY_PATH_32), Solaris 64 bit (LD_LIBRARY_PATH_64), +  # and HP-UX (SHLIB_PATH).  In some cases, the variables are independent +  # of LD_LIBRARY_PATH, and in other cases LD_LIBRARY_PATH is used if the +  # variable is not defined. +  # +  # Doing this is somewhat of a hack as ld_library_path gets repeated in +  # SHLIB_PATH and LD_LIBRARY_PATH when unix_load sets these variables. +  if { $orig_ld_library_path_saved } { +    setenv LD_LIBRARY_PATH "$ld_library_path:$orig_ld_library_path" +  } else { +    setenv LD_LIBRARY_PATH "$ld_library_path" +  } +  if { $orig_ld_run_path_saved } { +    setenv LD_RUN_PATH "$ld_library_path:$orig_ld_run_path" +  } else { +    setenv LD_RUN_PATH "$ld_library_path" +  } +  # The default shared library dynamic path search for 64-bit +  # HP-UX executables searches LD_LIBRARY_PATH before SHLIB_PATH. +  # LD_LIBRARY_PATH isn't used for 32-bit executables.  Thus, we +  # set LD_LIBRARY_PATH and SHLIB_PATH as if they were independent. +  if { $orig_shlib_path_saved } { +    setenv SHLIB_PATH "$ld_library_path:$orig_shlib_path" +  } else { +    setenv SHLIB_PATH "$ld_library_path" +  } +  if { $orig_ld_libraryn32_path_saved } { +    setenv LD_LIBRARYN32_PATH "$ld_library_path:$orig_ld_libraryn32_path" +  } elseif { $orig_ld_library_path_saved } { +    setenv LD_LIBRARYN32_PATH "$ld_library_path:$orig_ld_library_path" +  } else { +    setenv LD_LIBRARYN32_PATH "$ld_library_path" +  } +  if { $orig_ld_library64_path_saved } { +    setenv LD_LIBRARY64_PATH "$ld_library_path:$orig_ld_library64_path" +  } elseif { $orig_ld_library_path_saved } { +    setenv LD_LIBRARY64_PATH "$ld_library_path:$orig_ld_library_path" +  } else { +    setenv LD_LIBRARY64_PATH "$ld_library_path" +  } +  if { $orig_ld_library_path_32_saved } { +    setenv LD_LIBRARY_PATH_32 "$ld_library_path:$orig_ld_library_path_32" +  } elseif { $orig_ld_library_path_saved } { +    setenv LD_LIBRARY_PATH_32 "$ld_library_path:$orig_ld_library_path" +  } else { +    setenv LD_LIBRARY_PATH_32 "$ld_library_path" +  } +  if { $orig_ld_library_path_64_saved } { +    setenv LD_LIBRARY_PATH_64 "$ld_library_path:$orig_ld_library_path_64" +  } elseif { $orig_ld_library_path_saved } { +    setenv LD_LIBRARY_PATH_64 "$ld_library_path:$orig_ld_library_path" +  } else { +    setenv LD_LIBRARY_PATH_64 "$ld_library_path" +  } +  if { $orig_dyld_library_path_saved } { +    setenv DYLD_LIBRARY_PATH "$ld_library_path:$orig_dyld_library_path" +  } else { +    setenv DYLD_LIBRARY_PATH "$ld_library_path" +  } + +  verbose -log "set_ld_library_path_env_vars: ld_library_path=$ld_library_path" +} + +####################################### +# proc restore_ld_library_path_env_vars { } +####################################### + +proc restore_ld_library_path_env_vars { } { +  global orig_environment_saved +  global orig_ld_library_path_saved +  global orig_ld_run_path_saved +  global orig_shlib_path_saved +  global orig_ld_libraryn32_path_saved +  global orig_ld_library64_path_saved +  global orig_ld_library_path_32_saved +  global orig_ld_library_path_64_saved +  global orig_dyld_library_path_saved +  global orig_ld_library_path +  global orig_ld_run_path +  global orig_shlib_path +  global orig_ld_libraryn32_path +  global orig_ld_library64_path +  global orig_ld_library_path_32 +  global orig_ld_library_path_64 +  global orig_dyld_library_path + +  if { $orig_environment_saved == 0 } { +    return +  } + +  if { $orig_ld_library_path_saved } { +    setenv LD_LIBRARY_PATH "$orig_ld_library_path" +  } elseif [info exists env(LD_LIBRARY_PATH)] { +    unsetenv LD_LIBRARY_PATH +  } +  if { $orig_ld_run_path_saved } { +    setenv LD_RUN_PATH "$orig_ld_run_path" +  } elseif [info exists env(LD_RUN_PATH)] { +    unsetenv LD_RUN_PATH +  } +  if { $orig_shlib_path_saved } { +    setenv SHLIB_PATH "$orig_shlib_path" +  } elseif [info exists env(SHLIB_PATH)] { +    unsetenv SHLIB_PATH +  } +  if { $orig_ld_libraryn32_path_saved } { +    setenv LD_LIBRARYN32_PATH "$orig_ld_libraryn32_path" +  } elseif [info exists env(LD_LIBRARYN32_PATH)] { +    unsetenv LD_LIBRARYN32_PATH +  } +  if { $orig_ld_library64_path_saved } { +    setenv LD_LIBRARY64_PATH "$orig_ld_library64_path" +  } elseif [info exists env(LD_LIBRARY64_PATH)] { +    unsetenv LD_LIBRARY64_PATH +  } +  if { $orig_ld_library_path_32_saved } { +    setenv LD_LIBRARY_PATH_32 "$orig_ld_library_path_32" +  } elseif [info exists env(LD_LIBRARY_PATH_32)] { +    unsetenv LD_LIBRARY_PATH_32 +  } +  if { $orig_ld_library_path_64_saved } { +    setenv LD_LIBRARY_PATH_64 "$orig_ld_library_path_64" +  } elseif [info exists env(LD_LIBRARY_PATH_64)] { +    unsetenv LD_LIBRARY_PATH_64 +  } +  if { $orig_dyld_library_path_saved } { +    setenv DYLD_LIBRARY_PATH "$orig_dyld_library_path" +  } elseif [info exists env(DYLD_LIBRARY_PATH)] { +    unsetenv DYLD_LIBRARY_PATH +  } +} + +####################################### +# proc get_shlib_extension { } +####################################### + +proc get_shlib_extension { } { +    global shlib_ext + +    if { [ istarget *-*-darwin* ] } { +	set shlib_ext "dylib" +    } elseif { [ istarget *-*-cygwin* ] || [ istarget *-*-mingw* ] } { +	set shlib_ext "dll" +    } elseif { [ istarget hppa*-*-hpux* ] } { +	set shlib_ext "sl" +    } else { +	set shlib_ext "so" +    } +    return $shlib_ext +} + diff --git a/libffi-3.0.4/testsuite/lib/wrapper.exp b/libffi-3.0.4/testsuite/lib/wrapper.exp new file mode 100644 index 0000000..4e5ae43 --- /dev/null +++ b/libffi-3.0.4/testsuite/lib/wrapper.exp @@ -0,0 +1,45 @@ +#   Copyright (C) 2004, 2007 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 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 GCC; see the file COPYING3.  If not see +# <http://www.gnu.org/licenses/>. + +# This file contains GCC-specifics for status wrappers for test programs. + +# ${tool}_maybe_build_wrapper -- Build wrapper object if the target +# needs it.  FILENAME is the path to the wrapper file.  If there are +# additional arguments, they are command-line options to provide to +# the compiler when compiling FILENAME. + +proc ${tool}_maybe_build_wrapper { filename args } { +    global gluefile wrap_flags + +    if { [target_info needs_status_wrapper] != "" \ + 	 && [target_info needs_status_wrapper] != "0" \ +	 && ![info exists gluefile] } { +	set saved_wrap_compile_flags [target_info wrap_compile_flags] +	set flags [join $args " "] +	# The wrapper code may contain code that gcc objects on.  This +	# became true for dejagnu-1.4.4.  The set of warnings and code +	# that gcc objects on may change, so just make sure -w is always +	# passed to turn off all warnings. +	set_currtarget_info wrap_compile_flags \ +	    "$saved_wrap_compile_flags -w $flags" +	set result [build_wrapper $filename] +	set_currtarget_info wrap_compile_flags "$saved_wrap_compile_flags" +	if { $result != "" } { +	    set gluefile [lindex $result 0] +	    set wrap_flags [lindex $result 1] +	} +    } +} | 
