From: Kyrylo Tkachov Date: Wed, 20 Aug 2014 09:28:25 +0000 (+0000) Subject: [testsuite] Mark tests unsupported when relocation truncation occurs on tiny memory... X-Git-Tag: releases/gcc-5.1.0~5328 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=0febb26e6e31a7da9932eb7337884f8717eaea5f;p=thirdparty%2Fgcc.git [testsuite] Mark tests unsupported when relocation truncation occurs on tiny memory targets * lib/gcc-defs.exp (${tool}_check_unsupported_p): Return memory full when we have a tiny target and relocation truncation occurs. * lib/gcc-dg.exp (gcc-dg-prune): Likewise. * lib/objc.exp (${tool}_check_unsupported_p): Likewise. * lib/target-supports.exp (check_effective_target_tiny): New function. From-SVN: r214215 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b8473c3a6229..16d0c07b247e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,12 @@ +2014-08-20 Kyrylo Tkachov + + * lib/gcc-defs.exp (${tool}_check_unsupported_p): + Return memory full when we have a tiny target and relocation + truncation occurs. + * lib/gcc-dg.exp (gcc-dg-prune): Likewise. + * lib/objc.exp (${tool}_check_unsupported_p): Likewise. + * lib/target-supports.exp (check_effective_target_tiny): New function. + 2014-08-20 Joost VandeVondele * gfortran.dg/errnocheck_1.f90: New test. diff --git a/gcc/testsuite/lib/gcc-defs.exp b/gcc/testsuite/lib/gcc-defs.exp index 69a597162b0e..1ea7028b636c 100644 --- a/gcc/testsuite/lib/gcc-defs.exp +++ b/gcc/testsuite/lib/gcc-defs.exp @@ -157,6 +157,11 @@ proc ${tool}_check_unsupported_p { output } { if [regexp "(^|\n)\[^\n\]*: region \[^\n\]* is full" $output] { return "memory full" } + if { [regexp "(^|\n)\[^\n\]*: relocation truncated to fit" $output] + && [check_effective_target_tiny] } { + return "memory full" + } + if { [istarget spu-*-*] && \ [string match "*exceeds local store*" $output] } { return "memory full" diff --git a/gcc/testsuite/lib/gcc-dg.exp b/gcc/testsuite/lib/gcc-dg.exp index 3390caac47bb..dfdb25710a82 100644 --- a/gcc/testsuite/lib/gcc-dg.exp +++ b/gcc/testsuite/lib/gcc-dg.exp @@ -233,6 +233,11 @@ proc gcc-dg-prune { system text } { return "::unsupported::memory full" } + if { [regexp "(^|\n)\[^\n\]*: relocation truncated to fit" $text] + && [check_effective_target_tiny] } { + return "::unsupported::memory full" + } + # Likewise, if we see ".text exceeds local store range" or # similar. if {[string match "spu-*" $system] && \ diff --git a/gcc/testsuite/lib/objc.exp b/gcc/testsuite/lib/objc.exp index 5ecefa92f96d..e19b26438634 100644 --- a/gcc/testsuite/lib/objc.exp +++ b/gcc/testsuite/lib/objc.exp @@ -357,6 +357,10 @@ proc ${tool}_check_unsupported_p { output } { if [regexp "(^|\n)\[^\n\]*: region \[^\n\]* is full" $output] { return "memory full" } + if { [regexp "(^|\n)\[^\n\]*: relocation truncated to fit" $output] + && [check_effective_target_tiny] } { + return "memory full" + } return "" } diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp index 6506e42fc89b..ca20099722c3 100644 --- a/gcc/testsuite/lib/target-supports.exp +++ b/gcc/testsuite/lib/target-supports.exp @@ -5950,6 +5950,14 @@ proc check_effective_target_fenv_exceptions {} { } [add_options_for_ieee "-std=gnu99"]] } +proc check_effective_target_tiny {} { + if { [istarget aarch64*-*-*] + && [check_effective_target_aarch64_tiny] } { + return 1 + } + return 0 +} + # Return 1 if LOGICAL_OP_NON_SHORT_CIRCUIT is set to 0 for the current target. proc check_effective_target_logical_op_short_circuit {} {