re PR testsuite/34168 (runtime tests in gfortran.dg/vect fail for unsupported [non-SSE2] targets)
PR testsuite/34168 * lib/target-supports.exp (check_sse2_hw_available): New procedure. * gcc.dg/vect/vect.exp: Set dg-do-what-default to "compile" if SSE2 hardware is not available. * g++.dg/vect/vect.exp: Update target-dependent overrides to match gcc.dg/vect/vect.exp. * gfortran.dg/vect/vect.exp: Ditto. (check_effective_target_lp64_or_vect_no_align): Remove procedure. Co-Authored-By: Uros Bizjak <ubizjak@gmail.com> From-SVN: r133393
This commit is contained in:
parent
8894d2ba38
commit
8a313b8119
@ -1,3 +1,15 @@
|
|||||||
|
2008-03-20 Victor Kaplansky <victork@gcc.gnu.org>
|
||||||
|
Uros Bizjak <ubizjak@gmail.com>
|
||||||
|
|
||||||
|
PR testsuite/34168
|
||||||
|
* lib/target-supports.exp (check_sse2_hw_available): New procedure.
|
||||||
|
* gcc.dg/vect/vect.exp: Set dg-do-what-default to "compile"
|
||||||
|
if SSE2 hardware is not available.
|
||||||
|
* g++.dg/vect/vect.exp: Update target-dependent overrides to match
|
||||||
|
gcc.dg/vect/vect.exp.
|
||||||
|
* gfortran.dg/vect/vect.exp: Ditto.
|
||||||
|
(check_effective_target_lp64_or_vect_no_align): Remove procedure.
|
||||||
|
|
||||||
2008-03-20 Andreas Schwab <schwab@suse.de>
|
2008-03-20 Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
* gcc.dg/cpp/cmdlne-dD-M.c: Fix test for makefile rule and remove
|
* gcc.dg/cpp/cmdlne-dD-M.c: Fix test for makefile rule and remove
|
||||||
|
@ -45,7 +45,14 @@ lappend DEFAULT_VECTCFLAGS "-O2" "-ftree-vectorize" "-fno-vect-cost-model" \
|
|||||||
# Skip these tests for targets that do not support generating vector
|
# Skip these tests for targets that do not support generating vector
|
||||||
# code. Set additional target-dependent vector flags, which can be
|
# code. Set additional target-dependent vector flags, which can be
|
||||||
# overridden by using dg-options in individual tests.
|
# overridden by using dg-options in individual tests.
|
||||||
if [istarget "powerpc*-*-*"] {
|
if [istarget "powerpc-*paired*"] {
|
||||||
|
lappend DEFAULT_VECTCFLAGS "-mpaired"
|
||||||
|
if [check_750cl_hw_available] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
|
} elseif [istarget "powerpc*-*-*"] {
|
||||||
# Skip targets not supporting -maltivec.
|
# Skip targets not supporting -maltivec.
|
||||||
if ![is-effective-target powerpc_altivec_ok] {
|
if ![is-effective-target powerpc_altivec_ok] {
|
||||||
return
|
return
|
||||||
@ -53,19 +60,23 @@ if [istarget "powerpc*-*-*"] {
|
|||||||
|
|
||||||
lappend DEFAULT_VECTCFLAGS "-maltivec"
|
lappend DEFAULT_VECTCFLAGS "-maltivec"
|
||||||
if [check_vmx_hw_available] {
|
if [check_vmx_hw_available] {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} else {
|
} else {
|
||||||
if [is-effective-target ilp32] {
|
if [is-effective-target ilp32] {
|
||||||
# Specify a cpu that supports VMX for compile-only tests.
|
# Specify a cpu that supports VMX for compile-only tests.
|
||||||
lappend DEFAULT_VECTCFLAGS "-mcpu=7400"
|
lappend DEFAULT_VECTCFLAGS "-mcpu=970"
|
||||||
}
|
}
|
||||||
set dg-do-what-default compile
|
set dg-do-what-default compile
|
||||||
}
|
}
|
||||||
} elseif { [istarget "spu-*-*"] } {
|
} elseif { [istarget "spu-*-*"] } {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
||||||
lappend DEFAULT_VECTCFLAGS "-msse2"
|
lappend DEFAULT_VECTCFLAGS "-msse2"
|
||||||
set dg-do-what-default run
|
if [check_sse2_hw_available] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} elseif { [istarget "mips*-*-*"]
|
} elseif { [istarget "mips*-*-*"]
|
||||||
&& [check_effective_target_mpaired_single]
|
&& [check_effective_target_mpaired_single]
|
||||||
&& [check_effective_target_nomips16] } {
|
&& [check_effective_target_nomips16] } {
|
||||||
@ -73,21 +84,37 @@ if [istarget "powerpc*-*-*"] {
|
|||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} elseif [istarget "sparc*-*-*"] {
|
} elseif [istarget "sparc*-*-*"] {
|
||||||
lappend DEFAULT_VECTCFLAGS "-mcpu=ultrasparc" "-mvis"
|
lappend DEFAULT_VECTCFLAGS "-mcpu=ultrasparc" "-mvis"
|
||||||
set dg-do-what-default run
|
if [check_effective_target_ultrasparc_hw] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} elseif [istarget "alpha*-*-*"] {
|
} elseif [istarget "alpha*-*-*"] {
|
||||||
|
# Alpha's vectorization capabilities are extremely limited.
|
||||||
|
# It's more effort than its worth disabling all of the tests
|
||||||
|
# that it cannot pass. But if you actually want to see what
|
||||||
|
# does work, command out the return.
|
||||||
|
return
|
||||||
|
|
||||||
lappend DEFAULT_VECTCFLAGS "-mmax"
|
lappend DEFAULT_VECTCFLAGS "-mmax"
|
||||||
if [check_alpha_max_hw_available] {
|
if [check_alpha_max_hw_available] {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} else {
|
} else {
|
||||||
set dg-do-what-default compile
|
set dg-do-what-default compile
|
||||||
}
|
}
|
||||||
} elseif [istarget "ia64-*-*"] {
|
} elseif [istarget "ia64-*-*"] {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
|
} elseif [is-effective-target arm_neon_ok] {
|
||||||
|
lappend DEFAULT_VECTCFLAGS "-mfpu=neon" "-mfloat-abi=softfp"
|
||||||
|
if [is-effective-target arm_neon_hw] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# Initialize `dg'.
|
# Initialize `dg'.
|
||||||
dg-init
|
dg-init
|
||||||
|
|
||||||
|
@ -63,7 +63,11 @@ if [istarget "powerpc-*paired*"] {
|
|||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
||||||
lappend DEFAULT_VECTCFLAGS "-msse2"
|
lappend DEFAULT_VECTCFLAGS "-msse2"
|
||||||
set dg-do-what-default run
|
if [check_sse2_hw_available] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} elseif { [istarget "mips*-*-*"]
|
} elseif { [istarget "mips*-*-*"]
|
||||||
&& [check_effective_target_mpaired_single]
|
&& [check_effective_target_mpaired_single]
|
||||||
&& [check_effective_target_nomips16] } {
|
&& [check_effective_target_nomips16] } {
|
||||||
|
@ -38,8 +38,18 @@ set save-dg-do-what-default ${dg-do-what-default}
|
|||||||
# Skip these tests for targets that do not support generating vector
|
# Skip these tests for targets that do not support generating vector
|
||||||
# code. Set additional target-dependent vector flags, which can be
|
# code. Set additional target-dependent vector flags, which can be
|
||||||
# overridden by using dg-options in individual tests.
|
# overridden by using dg-options in individual tests.
|
||||||
if [istarget "powerpc*-*-*"] {
|
if [istarget "powerpc-*paired*"] {
|
||||||
# If there are powerpc targets to skip, do it here.
|
lappend DEFAULT_VECTCFLAGS "-mpaired"
|
||||||
|
if [check_750cl_hw_available] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
|
} elseif [istarget "powerpc*-*-*"] {
|
||||||
|
# Skip targets not supporting -maltivec.
|
||||||
|
if ![is-effective-target powerpc_altivec_ok] {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
lappend DEFAULT_VECTCFLAGS "-maltivec"
|
lappend DEFAULT_VECTCFLAGS "-maltivec"
|
||||||
if [check_vmx_hw_available] {
|
if [check_vmx_hw_available] {
|
||||||
@ -47,20 +57,38 @@ if [istarget "powerpc*-*-*"] {
|
|||||||
} else {
|
} else {
|
||||||
if [is-effective-target ilp32] {
|
if [is-effective-target ilp32] {
|
||||||
# Specify a cpu that supports VMX for compile-only tests.
|
# Specify a cpu that supports VMX for compile-only tests.
|
||||||
lappend DEFAULT_VECTCFLAGS "-mcpu=7400"
|
lappend DEFAULT_VECTCFLAGS "-mcpu=970"
|
||||||
}
|
}
|
||||||
set dg-do-what-default compile
|
set dg-do-what-default compile
|
||||||
}
|
}
|
||||||
|
} elseif { [istarget "spu-*-*"] } {
|
||||||
|
set dg-do-what-default run
|
||||||
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
} elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } {
|
||||||
lappend DEFAULT_VECTCFLAGS "-msse2"
|
lappend DEFAULT_VECTCFLAGS "-msse2"
|
||||||
set dg-do-what-default run
|
if [check_sse2_hw_available] {
|
||||||
} elseif [istarget "mipsisa64*-*-*"] {
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
|
} elseif { [istarget "mips*-*-*"]
|
||||||
|
&& [check_effective_target_mpaired_single]
|
||||||
|
&& [check_effective_target_nomips16] } {
|
||||||
lappend DEFAULT_VECTCFLAGS "-mpaired-single"
|
lappend DEFAULT_VECTCFLAGS "-mpaired-single"
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
} elseif [istarget "sparc*-*-*"] {
|
} elseif [istarget "sparc*-*-*"] {
|
||||||
lappend DEFAULT_VECTCFLAGS "-mcpu=ultrasparc" "-mvis"
|
lappend DEFAULT_VECTCFLAGS "-mcpu=ultrasparc" "-mvis"
|
||||||
set dg-do-what-default run
|
if [check_effective_target_ultrasparc_hw] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} elseif [istarget "alpha*-*-*"] {
|
} elseif [istarget "alpha*-*-*"] {
|
||||||
|
# Alpha's vectorization capabilities are extremely limited.
|
||||||
|
# It's more effort than its worth disabling all of the tests
|
||||||
|
# that it cannot pass. But if you actually want to see what
|
||||||
|
# does work, command out the return.
|
||||||
|
return
|
||||||
|
|
||||||
lappend DEFAULT_VECTCFLAGS "-mmax"
|
lappend DEFAULT_VECTCFLAGS "-mmax"
|
||||||
if [check_alpha_max_hw_available] {
|
if [check_alpha_max_hw_available] {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
@ -69,23 +97,17 @@ if [istarget "powerpc*-*-*"] {
|
|||||||
}
|
}
|
||||||
} elseif [istarget "ia64-*-*"] {
|
} elseif [istarget "ia64-*-*"] {
|
||||||
set dg-do-what-default run
|
set dg-do-what-default run
|
||||||
|
} elseif [is-effective-target arm_neon_ok] {
|
||||||
|
lappend DEFAULT_VECTCFLAGS "-mfpu=neon" "-mfloat-abi=softfp"
|
||||||
|
if [is-effective-target arm_neon_hw] {
|
||||||
|
set dg-do-what-default run
|
||||||
|
} else {
|
||||||
|
set dg-do-what-default compile
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
# Return 1 if the effective target is LP64 or if the effective target
|
|
||||||
# does not support a vector alignment mechanism.
|
|
||||||
|
|
||||||
proc check_effective_target_lp64_or_vect_no_align { } {
|
|
||||||
if { [is-effective-target lp64]
|
|
||||||
|| [is-effective-target vect_no_align] } {
|
|
||||||
set answer 1
|
|
||||||
} else {
|
|
||||||
set answer 0
|
|
||||||
}
|
|
||||||
return $answer
|
|
||||||
}
|
|
||||||
|
|
||||||
# Initialize `dg'.
|
# Initialize `dg'.
|
||||||
dg-init
|
dg-init
|
||||||
|
|
||||||
|
@ -764,6 +764,29 @@ proc check_750cl_hw_available { } {
|
|||||||
}]
|
}]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Return 1 if the target supports executing SSE2 instructions, 0
|
||||||
|
# otherwise. Cache the result.
|
||||||
|
|
||||||
|
proc check_sse2_hw_available { } {
|
||||||
|
return [check_cached_effective_target sse2_hw_available {
|
||||||
|
# If this is not the right target then we can skip the test.
|
||||||
|
if { !([istarget x86_64-*-*] || [istarget i?86-*-*]) } {
|
||||||
|
expr 0
|
||||||
|
} else {
|
||||||
|
check_runtime_nocache sse2_hw_available {
|
||||||
|
#include "cpuid.h"
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
unsigned int eax, ebx, ecx, edx = 0;
|
||||||
|
if (__get_cpuid (1, &eax, &ebx, &ecx, &edx))
|
||||||
|
return !(edx & bit_SSE2);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
} ""
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
|
||||||
# Return 1 if the target supports executing AltiVec instructions, 0
|
# Return 1 if the target supports executing AltiVec instructions, 0
|
||||||
# otherwise. Cache the result.
|
# otherwise. Cache the result.
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user