# Damn dejagnu for not having proper library search paths for load_lib. # We have to explicitly load everything that gcc-dg.exp wants to load. proc load_gcc_lib { filename } { global srcdir loaded_libs load_file $srcdir/../../gcc/testsuite/lib/$filename set loaded_libs($filename) "" } load_lib dg.exp # Required to use gcc-dg.exp - however, the latter should NOT be # loaded until ${tool}_target_compile is defined since it uses that # to determine default LTO options. load_gcc_lib prune.exp load_gcc_lib target-libpath.exp load_gcc_lib wrapper.exp load_gcc_lib target-supports.exp load_gcc_lib target-utils.exp load_gcc_lib gcc-defs.exp load_gcc_lib timeout.exp load_gcc_lib file-format.exp load_gcc_lib target-supports-dg.exp load_gcc_lib scanasm.exp load_gcc_lib scandump.exp load_gcc_lib scanrtl.exp load_gcc_lib scantree.exp load_gcc_lib scanipa.exp load_gcc_lib timeout-dg.exp load_gcc_lib torture-options.exp load_gcc_lib fortran-modules.exp # Try to load a test support file, built during libgomp configuration. load_file libgomp-test-support.exp # Populate offload_targets_s (offloading targets separated by a space), and # offload_targets_s_openacc (the same, but with OpenACC names; OpenACC spells # some of them a little differently). set offload_targets_s [split $offload_targets ","] set offload_targets_s_openacc {} foreach offload_target_openacc $offload_targets_s { switch $offload_target_openacc { intelmic { # Skip; will all FAIL because of missing # GOMP_OFFLOAD_CAP_OPENACC_200. continue } nvptx { set offload_target_openacc "nvidia" } } lappend offload_targets_s_openacc "$offload_target_openacc" } lappend offload_targets_s_openacc "host" set dg-do-what-default run # # GCC_UNDER_TEST is the compiler under test. # set libgomp_compile_options "" # # libgomp_init # if [info exists TOOL_OPTIONS] { set multilibs [get_multilibs $TOOL_OPTIONS] } else { set multilibs [get_multilibs] } proc libgomp_init { args } { global srcdir blddir objdir tool_root_dir global libgomp_initialized global tmpdir global blddir global gluefile wrap_flags global ALWAYS_CFLAGS global CFLAGS global TOOL_EXECUTABLE TOOL_OPTIONS global GCC_UNDER_TEST global TESTING_IN_BUILD_TREE global target_triplet global always_ld_library_path set blddir [lookfor_file [get_multilibs] libgomp] # We set LC_ALL and LANG to C so that we get the same error # messages as expected. setenv LC_ALL C setenv LANG C # Many hosts now default to a non-ASCII C locale, however, so # they can set a charset encoding here if they need. if { [ishost "*-*-cygwin*"] } { setenv LC_ALL C.ASCII setenv LANG C.ASCII } if ![info exists GCC_UNDER_TEST] then { if [info exists TOOL_EXECUTABLE] { set GCC_UNDER_TEST $TOOL_EXECUTABLE } else { set GCC_UNDER_TEST "[find_gcc]" } } if ![info exists tmpdir] { set tmpdir "/tmp" } if [info exists gluefile] { unset gluefile } if {![info exists CFLAGS]} { set CFLAGS "" } # Locate libgcc.a so we don't need to account for different values of # SHLIB_EXT on different platforms set gccdir [lookfor_file $tool_root_dir gcc/libgcc.a] if {$gccdir != ""} { set gccdir [file dirname $gccdir] } # Compute what needs to be put into LD_LIBRARY_PATH set always_ld_library_path ".:${blddir}/.libs" # Add liboffloadmic build directory in LD_LIBRARY_PATH to support # non-fallback testing for Intel MIC targets global offload_targets if { [string match "*,intelmic,*" ",$offload_targets,"] } { append always_ld_library_path ":${blddir}/../liboffloadmic/.libs" append always_ld_library_path ":${blddir}/../liboffloadmic/plugin/.libs" # libstdc++ is required by liboffloadmic append always_ld_library_path ":${blddir}/../libstdc++-v3/src/.libs" } global offload_additional_lib_paths if { $offload_additional_lib_paths != "" } { append always_ld_library_path "${offload_additional_lib_paths}" } # Compute what needs to be added to the existing LD_LIBRARY_PATH. if {$gccdir != ""} { # Add AIX pthread directory first. if { [llength [glob -nocomplain ${gccdir}/pthread/libgcc_s*.a]] >= 1 } { append always_ld_library_path ":${gccdir}/pthread" } append always_ld_library_path ":${gccdir}" set compiler [lindex $GCC_UNDER_TEST 0] 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 always_ld_library_path ":${gccdir}/${mldir}" } } } } set ALWAYS_CFLAGS "" if { $blddir != "" } { lappend ALWAYS_CFLAGS "additional_flags=-B${blddir}/" # targets that use libgomp.a%s in their specs need a -B option # for uninstalled testing. lappend ALWAYS_CFLAGS "additional_flags=-B${blddir}/.libs" lappend ALWAYS_CFLAGS "additional_flags=-I${blddir}" lappend ALWAYS_CFLAGS "ldflags=-L${blddir}/.libs" # The top-level include directory, for gomp-constants.h. lappend ALWAYS_CFLAGS "additional_flags=-I${srcdir}/../../include" } lappend ALWAYS_CFLAGS "additional_flags=-I${srcdir}/.." # For build-tree testing, also consider the CUDA paths used for builing. # For installed testing, we assume all that to be provided in the sysroot. if { $blddir != "" } { global cuda_driver_include global cuda_driver_lib if { $cuda_driver_include != "" } { # Stop gfortran from freaking out: # Warning: Nonexistent include directory "[...]" if {[file exists $cuda_driver_include]} { lappend ALWAYS_CFLAGS "additional_flags=-I$cuda_driver_include" } } if { $cuda_driver_lib != "" } { lappend ALWAYS_CFLAGS "additional_flags=-L$cuda_driver_lib" append always_ld_library_path ":$cuda_driver_lib" } } # We use atomic operations in the testcases to validate results. if { ([istarget i?86-*-*] || [istarget x86_64-*-*]) && [check_effective_target_ia32] } { lappend ALWAYS_CFLAGS "additional_flags=-march=i486" } if [istarget *-*-darwin*] { lappend ALWAYS_CFLAGS "additional_flags=-shared-libgcc" } if [istarget sparc*-*-*] { lappend ALWAYS_CFLAGS "additional_flags=-mcpu=v9" } if [info exists TOOL_OPTIONS] { lappend ALWAYS_CFLAGS "additional_flags=$TOOL_OPTIONS" } # Make sure that lines are not wrapped. That can confuse the # error-message parsing machinery. lappend ALWAYS_CFLAGS "additional_flags=-fmessage-length=0" # Disable caret lappend ALWAYS_CFLAGS "additional_flags=-fno-diagnostics-show-caret" # Disable color diagnostics lappend ALWAYS_CFLAGS "additional_flags=-fdiagnostics-color=never" # Used for support non-fallback offloading. # Help GCC to find target mkoffload. global offload_additional_options if { $offload_additional_options != "" } { lappend ALWAYS_CFLAGS "additional_flags=${offload_additional_options}" } } # # libgomp_target_compile -- compile a source file # proc libgomp_target_compile { source dest type options } { global blddir global libgomp_compile_options global gluefile wrap_flags global ALWAYS_CFLAGS global GCC_UNDER_TEST global lang_test_file global lang_library_path global lang_link_flags global lang_include_flags global lang_source_re if { [info exists lang_test_file] } { if { $blddir != "" } { # Some targets use libgfortran.a%s in their specs, so they need # a -B option for uninstalled testing. lappend options "additional_flags=-B${blddir}/${lang_library_path}" lappend options "ldflags=-L${blddir}/${lang_library_path}" } lappend options "ldflags=${lang_link_flags}" if { [info exists lang_include_flags] \ && [regexp ${lang_source_re} ${source}] } { lappend options "additional_flags=${lang_include_flags}" } } if { [target_info needs_status_wrapper] != "" && [info exists gluefile] } { lappend options "libs=${gluefile}" lappend options "ldflags=${wrap_flags}" } lappend options "additional_flags=[libio_include_flags]" lappend options "timeout=[timeout_value]" lappend options "compiler=$GCC_UNDER_TEST" set options [concat $libgomp_compile_options $options] if [info exists ALWAYS_CFLAGS] { set options [concat "$ALWAYS_CFLAGS" $options] } set options [dg-additional-files-options $options $source] set result [target_compile $source $dest $type $options] return $result } proc libgomp_option_help { } { send_user " --additional_options,OPTIONS\t\tUse OPTIONS to compile the testcase files. OPTIONS should be comma-separated.\n" } proc libgomp_option_proc { option } { if [regexp "^--additional_options," $option] { global libgomp_compile_options regsub "--additional_options," $option "" option foreach x [split $option ","] { lappend libgomp_compile_options "additional_flags=$x" } return 1 } else { return 0 } } # Return 1 if offload device is available. proc check_effective_target_offload_device { } { return [check_runtime_nocache offload_device_available_ { #include int main () { int a; #pragma omp target map(from: a) a = omp_is_initial_device (); return a; } } ] } # Return 1 if at least one nvidia board is present. proc check_effective_target_openacc_nvidia_accel_present { } { return [check_runtime openacc_nvidia_accel_present { #include int main () { return !(acc_get_num_devices (acc_device_nvidia) > 0); } } "" ] } # Return 1 if at least one nvidia board is present, and the nvidia device type # is selected by default by means of setting the environment variable # ACC_DEVICE_TYPE. proc check_effective_target_openacc_nvidia_accel_selected { } { if { ![check_effective_target_openacc_nvidia_accel_present] } { return 0; } global offload_target_openacc if { $offload_target_openacc == "nvidia" } { return 1; } return 0; } # Return 1 if the host target is selected for offloaded proc check_effective_target_openacc_host_selected { } { global offload_target_openacc if { $offload_target_openacc == "host" } { return 1; } return 0; } # Return 1 if the host_nonshm target is selected for offloaded proc check_effective_target_openacc_host_nonshm_selected { } { global offload_target_openacc if { $offload_target_openacc == "host_nonshm" } { return 1; } return 0; }