-# Copyright (C) 1999, 2001, 2003, 2004, 2005 Free Software Foundation, Inc.
+# Copyright (C) 1999, 2001, 2003, 2004, 2005, 2006
+# 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
global target_triplet
# On NetWare, support makes no sense.
- if { [string match "*-*-netware*" $target_triplet] } {
+ if { [istarget *-*-netware*] } {
return 0
}
return 0
}
+ # At present, there is no profiling support on NetWare.
+ if { [istarget *-*-netware*] } {
+ return 0
+ }
+
# Now examine the cache variable.
if {![info exists profiling_available_saved]} {
# Some targets don't have any implementation of __bb_init_func or are
return $et_pcc_bitfield_type_matters_saved
}
+# Return 1 if thread local storage (TLS) is supported, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_tls {} {
+ global et_tls_saved
+
+ if [info exists et_tls_saved] {
+ verbose "check_effective_target_tls: using cached result" 2
+ } else {
+ set et_tls_saved 1
+
+ set src tls[pid].c
+ set asm tls[pid].S
+ verbose "check_effective_target_tls: compiling testfile $src" 2
+ set f [open $src "w"]
+ # Compile a small test program.
+ puts $f "__thread int i;\n"
+ close $f
+
+ # Test for thread-local data supported by the platform.
+ set comp_output \
+ [target_compile $src $asm assembly ""]
+ file delete $src
+ if { [string match "*not supported*" $comp_output] } {
+ set et_tls_saved 0
+ }
+ remove-build-file $asm
+ }
+ verbose "check_effective_target_tls: returning $et_tls_saved" 2
+ return $et_tls_saved
+}
+
+# Return 1 if TLS executables can run correctly, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_tls_runtime {} {
+ global et_tls_runtime_saved
+
+ if [info exists et_tls_runtime_saved] {
+ verbose "check_effective_target_tls_runtime: using cached result" 2
+ } else {
+ set et_tls_runtime_saved 0
+
+ set src tls_runtime[pid].c
+ set exe tls_runtime[pid].x
+ verbose "check_effective_target_tls_runtime: compiling testfile $src" 2
+ set f [open $src "w"]
+ # Compile a small test program.
+ puts $f "__thread int thr = 0;\n"
+ puts $f "int main(void)\n {\n return thr;\n}"
+ close $f
+
+ set comp_output \
+ [target_compile $src $exe executable ""]
+ file delete $src
+
+ if [string match "" $comp_output] then {
+ # No error messages, everything is OK.
+
+ set result [remote_load target "./$exe" "" ""]
+ set status [lindex $result 0]
+ remote_file build delete $exe
+
+ verbose "check_effective_target_tls_runtime status is <$status>" 2
+
+ if { $status == "pass" } {
+ set et_tls_runtime_saved 1
+ }
+
+ verbose "check_effective_target_tls_runtime: returning $et_tls_runtime_saved" 2
+ }
+ }
+
+ return $et_tls_runtime_saved
+}
+
# Return 1 if -fpic and -fPIC are supported, as in no warnings or errors
# emitted, 0 otherwise. Whether a shared library can actually be built is
# out of scope for this test.
puts $f "integer,parameter :: k = &"
puts $f " selected_real_kind (precision (0.0_8) + 1)"
puts $f "real(kind=k) :: x"
+ puts $f "x = cos (x);"
puts $f "end"
close $f
return $et_fortran_large_int_saved
}
+# Return 1 if we can statically link libgfortran, 0 otherwise.
+#
+# When the target name changes, replace the cached result.
+
+proc check_effective_target_static_libgfortran { } {
+ global et_static_libgfortran
+ global et_static_libgfortran_target_name
+ global tool
+
+ if { ![info exists et_static_libgfortran_target_name] } {
+ set et_static_libgfortran_target_name ""
+ }
+
+ # If the target has changed since we set the cached value, clear it.
+ set current_target [current_target_name]
+ if { $current_target != $et_static_libgfortran_target_name } {
+ verbose "check_effective_target_static_libgfortran: `$et_static_libgfortran_target_name' `$current_target'" 2
+ set et_static_libgfortran_target_name $current_target
+ if [info exists et_static_libgfortran_saved] {
+ verbose "check_effective_target_static_libgfortran: removing cached result" 2
+ unset et_static_libgfortran_saved
+ }
+ }
+
+ if [info exists et_static_libgfortran_saved] {
+ verbose "check_effective_target_static_libgfortran returning saved $et_static_libgfortran_saved" 2
+ } else {
+ set et_static_libgfortran_saved 0
+
+ # Set up, compile, and execute a test program using static linking.
+ # Include the current process ID in the file names to prevent
+ # conflicts with invocations for multiple testsuites.
+ set opts "additional_flags=-static"
+ set src static[pid].f
+ set exe static[pid].x
+
+ set f [open $src "w"]
+ puts $f " print *, 'test'"
+ puts $f " end"
+ close $f
+
+ verbose "check_effective_target_static_libgfortran compiling testfile $src" 2
+ set lines [${tool}_target_compile $src $exe executable "$opts"]
+ file delete $src
+
+ if [string match "" $lines] then {
+ # No error message, compilation succeeded.
+ set et_static_libgfortran_saved 1
+ }
+ }
+
+ return $et_static_libgfortran_saved
+}
+
# Return 1 if the target supports executing AltiVec instructions, 0
# otherwise. Cache the result.
return $et_lp64_saved
}
+# Return 1 if the target supports compiling decimal floating point,
+# 0 otherwise.
+
+proc check_effective_target_dfp_nocache { } {
+ verbose "check_effective_target_dfp_nocache: compiling source" 2
+ set ret [string match "" [get_compiler_messages dfp object {
+ _Decimal32 x; _Decimal64 y; _Decimal128 z;
+ }]]
+ verbose "check_effective_target_dfp_nocache: returning $ret" 2
+ return $ret
+}
+
+proc check_effective_target_dfprt_nocache { } {
+ global tool
+
+ set ret 0
+
+ verbose "check_effective_target_dfprt_nocache: compiling source" 2
+ # Set up, compile, and execute a test program containing decimal
+ # float operations.
+ set src dfprt[pid].c
+ set exe dfprt[pid].x
+
+ set f [open $src "w"]
+ puts $f "_Decimal32 x = 1.2df; _Decimal64 y = 2.3dd; _Decimal128 z;"
+ puts $f "int main () { z = x + y; return 0; }"
+ close $f
+
+ verbose "check_effective_target_dfprt_nocache: compiling testfile $src" 2
+ set lines [${tool}_target_compile $src $exe executable ""]
+ file delete $src
+
+ if [string match "" $lines] then {
+ # No error message, compilation succeeded.
+ set result [${tool}_load "./$exe" "" ""]
+ set status [lindex $result 0]
+ remote_file build delete $exe
+ verbose "check_effective_target_dfprt_nocache: testfile status is <$status>" 2
+ if { $status == "pass" } then {
+ set ret 1
+ }
+ }
+ return $ret
+ verbose "check_effective_target_dfprt_nocache: returning $ret" 2
+}
+
+# Return 1 if the target supports compiling Decimal Floating Point,
+# 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_dfp { } {
+ global et_dfp_saved
+
+ if [info exists et_dfp_saved] {
+ verbose "check_effective_target_dfp: using cached result" 2
+ } else {
+ set et_dfp_saved [check_effective_target_dfp_nocache]
+ }
+ verbose "check_effective_target_dfp: returning $et_dfp_saved" 2
+ return $et_dfp_saved
+}
+
+# Return 1 if the target supports linking and executing Decimal Floating
+# Point, # 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_dfprt { } {
+ global et_dfprt_saved
+ global tool
+
+ if [info exists et_dfprt_saved] {
+ verbose "check_effective_target_dfprt: using cached result" 2
+ } else {
+ set et_dfprt_saved [check_effective_target_dfprt_nocache]
+ }
+ verbose "check_effective_target_dfprt: returning $et_dfprt_saved" 2
+ return $et_dfprt_saved
+}
+
# Return 1 if the target needs a command line argument to enable a SIMD
# instruction set.
#
return $et_vect_no_bitwise_saved
}
+# Return 1 if the target plus current options supports a vector
+# widening summation, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_vect_widen_sum { } {
+ global et_vect_widen_sum
+
+ if [info exists et_vect_widen_sum_saved] {
+ verbose "check_effective_target_vect_widen_sum: using cached result" 2
+ } else {
+ set et_vect_widen_sum_saved 0
+ if { [istarget powerpc*-*-*]
+ || [istarget ia64-*-*] } {
+ set et_vect_widen_sum_saved 1
+ }
+ }
+ verbose "check_effective_target_vect_widen_sum: returning $et_vect_widen_sum_saved" 2
+ return $et_vect_widen_sum_saved
+}
+
+# Return 1 if the target plus current options supports a vector
+# dot-product of signed chars, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_vect_sdot_qi { } {
+ global et_vect_sdot_qi
+
+ if [info exists et_vect_sdot_qi_saved] {
+ verbose "check_effective_target_vect_sdot_qi: using cached result" 2
+ } else {
+ set et_vect_sdot_qi_saved 0
+ if { [istarget ia64-*-*] } {
+ set et_vect_sdot_qi_saved 1
+ }
+ }
+ verbose "check_effective_target_vect_sdot_qi: returning $et_vect_sdot_qi_saved" 2
+ return $et_vect_sdot_qi_saved
+}
+
+# Return 1 if the target plus current options supports a vector
+# dot-product of unsigned chars, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_vect_udot_qi { } {
+ global et_vect_udot_qi
+
+ if [info exists et_vect_udot_qi_saved] {
+ verbose "check_effective_target_vect_udot_qi: using cached result" 2
+ } else {
+ set et_vect_udot_qi_saved 0
+ if { [istarget powerpc*-*-*]
+ || [istarget ia64-*-*] } {
+ set et_vect_udot_qi_saved 1
+ }
+ }
+ verbose "check_effective_target_vect_udot_qi: returning $et_vect_udot_qi_saved" 2
+ return $et_vect_udot_qi_saved
+}
+
+# Return 1 if the target plus current options supports a vector
+# dot-product of signed shorts, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_vect_sdot_hi { } {
+ global et_vect_sdot_hi
+
+ if [info exists et_vect_sdot_hi_saved] {
+ verbose "check_effective_target_vect_sdot_hi: using cached result" 2
+ } else {
+ set et_vect_sdot_hi_saved 0
+ if { [istarget powerpc*-*-*]
+ || [istarget i?86-*-*]
+ || [istarget x86_64-*-*]
+ || [istarget ia64-*-*] } {
+ set et_vect_sdot_hi_saved 1
+ }
+ }
+ verbose "check_effective_target_vect_sdot_hi: returning $et_vect_sdot_hi_saved" 2
+ return $et_vect_sdot_hi_saved
+}
+
+# Return 1 if the target plus current options supports a vector
+# dot-product of unsigned shorts, 0 otherwise.
+#
+# This won't change for different subtargets so cache the result.
+
+proc check_effective_target_vect_udot_hi { } {
+ global et_vect_udot_hi
+
+ if [info exists et_vect_udot_hi_saved] {
+ verbose "check_effective_target_vect_udot_hi: using cached result" 2
+ } else {
+ set et_vect_udot_hi_saved 0
+ if { [istarget powerpc*-*-*] } {
+ set et_vect_udot_hi_saved 1
+ }
+ }
+ verbose "check_effective_target_vect_udot_hi: returning $et_vect_udot_hi_saved" 2
+ return $et_vect_udot_hi_saved
+}
+
+
# Return 1 if the target plus current options does not support a vector
# alignment mechanism, 0 otherwise.
#
|| [istarget x86_64-*-*]
|| [istarget alpha*-*-*]
|| [istarget s390*-*-*]
- || [istarget powerpc*-*-*] } {
+ || [istarget powerpc*-*-*]
+ || [istarget sparc64-*-*]
+ || [istarget sparcv9-*-*] } {
set et_sync_int_long_saved 1
}
}
|| [istarget i?86-*-*]
|| [istarget x86_64-*-*]
|| [istarget alpha*-*-*]
- || [istarget powerpc*-*-*] } {
+ || [istarget s390*-*-*]
+ || [istarget powerpc*-*-*]
+ || [istarget sparc64-*-*]
+ || [istarget sparcv9-*-*] } {
set et_sync_char_short_saved 1
}
}