[testsuite] Add scan-offload-tree-dump
authorTom de Vries <tom@codesourcery.com>
Thu, 3 May 2018 13:47:14 +0000 (13:47 +0000)
committerTom de Vries <vries@gcc.gnu.org>
Thu, 3 May 2018 13:47:14 +0000 (13:47 +0000)
2018-05-03  Tom de Vries  <tom@codesourcery.com>

PR testsuite/85106
* lib/scanoffloadtree.exp: New file.

* testsuite/lib/libgomp-dg.exp (libgomp-dg-test): Add save-temps to
extra_tool_flags if it contains an -foffload=-fdump-* flag.
* testsuite/lib/libgomp.exp: Include scanoffloadtree.exp.
* testsuite/libgomp.oacc-c/vec.c: Use scan-offload-tree-dump.

* doc/sourcebuild.texi (Commands for use in dg-final, Scan optimization
dump files): Add offload-tree.

From-SVN: r259892

gcc/ChangeLog
gcc/doc/sourcebuild.texi
gcc/testsuite/ChangeLog
gcc/testsuite/lib/scanoffloadtree.exp [new file with mode: 0644]
libgomp/ChangeLog
libgomp/testsuite/lib/libgomp-dg.exp
libgomp/testsuite/lib/libgomp.exp
libgomp/testsuite/libgomp.oacc-c/vec.c

index 893a459e09a3a6c12b2bba7043fb59c02ec6a185..767d4682450322689ebc81fb30adec6450ad7598 100644 (file)
@@ -1,3 +1,9 @@
+2018-05-03  Tom de Vries  <tom@codesourcery.com>
+
+       PR testsuite/85106
+       * doc/sourcebuild.texi (Commands for use in dg-final, Scan optimization
+       dump files): Add offload-tree.
+
 2018-05-03  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/85615
index 16164ae2cf3e7728c0430fd8991f6ac8b6c00c36..4605a492694af3de30ff29840635e6f2583e9bf7 100644 (file)
@@ -2589,7 +2589,7 @@ assembly output.
 @subsubsection Scan optimization dump files
 
 These commands are available for @var{kind} of @code{tree}, @code{ltrans-tree},
-@code{rtl}, @code{ipa}, and @code{wpa-ipa}.
+@code{offload-tree}, @code{rtl}, @code{ipa}, and @code{wpa-ipa}.
 
 @table @code
 @item scan-@var{kind}-dump @var{regex} @var{suffix} [@{ target/xfail @var{selector} @}]
index 6d135894c271e08bb17e316a0dc71369b85d4168..9d12280599e13475f2eb1d86db9bd9d030dfaf3b 100644 (file)
@@ -1,3 +1,8 @@
+2018-05-03  Tom de Vries  <tom@codesourcery.com>
+
+       PR testsuite/85106
+       * lib/scanoffloadtree.exp: New file.
+
 2018-05-03  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/85615
diff --git a/gcc/testsuite/lib/scanoffloadtree.exp b/gcc/testsuite/lib/scanoffloadtree.exp
new file mode 100644 (file)
index 0000000..ee92c2b
--- /dev/null
@@ -0,0 +1,147 @@
+#   Copyright (C) 2018 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/>.
+
+# Various utilities for scanning offloading tree dump output, used by
+# libgomp.exp.
+
+load_lib scandump.exp
+
+# Utility for scanning compiler result, invoked via dg-final.
+# Call pass if pattern is present, otherwise fail.
+#
+# Argument 0 is the regexp to match
+# Argument 1 is the name of the dumped tree pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-tree-dump { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-tree-dump: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-tree-dump: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump "offload-tree" [lindex $args 0] \
+                 "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o" \
+                 [lindex $args 2]
+    } else {
+       scan-dump "offload-tree" [lindex $args 0] \
+                 "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o"
+    }
+}
+
+# Call pass if pattern is present given number of times, otherwise fail.
+# Argument 0 is the regexp to match
+# Argument 1 is number of times the regexp must be found
+# Argument 2 is the name of the dumped tree pass
+# Argument 3 handles expected failures and the like
+proc scan-offload-tree-dump-times { args } {
+
+    if { [llength $args] < 3 } {
+       error "scan-offload-tree-dump-times: too few arguments"
+       return
+    }
+    if { [llength $args] > 4 } {
+       error "scan-offload-tree-dump-times: too many arguments"
+       return
+    }
+    if { [llength $args] >= 4 } {
+       scan-dump-times "offload-tree" [lindex $args 0] [lindex $args 1] \
+                       "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 2]" ".o" \
+                       [lindex $args 3]
+    } else {
+       scan-dump-times "offload-tree" [lindex $args 0] [lindex $args 1] \
+                       "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 2]" ".o"
+    }
+}
+
+# Call pass if pattern is not present, otherwise fail.
+#
+# Argument 0 is the regexp to match
+# Argument 1 is the name of the dumped tree pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-tree-dump-not { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-tree-dump-not: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-tree-dump-not: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-not "offload-tree" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o" \
+                     [lindex $args 2]
+    } else {
+       scan-dump-not "offload-tree" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o"
+    }
+}
+
+# Utility for scanning demangled compiler result, invoked via dg-final.
+# Call pass if pattern is present, otherwise fail.
+#
+# Argument 0 is the regexp to match
+# Argument 1 is the name of the dumped tree pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-tree-dump-dem { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-tree-dump-dem: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-tree-dump-dem: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-dem "offload-tree" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o" \
+                     [lindex $args 2]
+    } else {
+       scan-dump-dem "offload-tree" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o"
+    }
+}
+
+# Call pass if demangled pattern is not present, otherwise fail.
+#
+# Argument 0 is the regexp to match
+# Argument 1 is the name of the dumped tree pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-tree-dump-dem-not { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-tree-dump-dem-not: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-tree-dump-dem-not: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-dem-not "offload-tree" [lindex $args 0] \
+                         "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o" \
+                         [lindex $args 2]
+    } else {
+       scan-dump-dem-not "offload-tree" [lindex $args 0] \
+                         "\[0-9\]\[0-9\]\[0-9]t.[lindex $args 1]" ".o"
+    }
+}
index 1d55d8bf361c0c64ad090a9bf9302f8d34f08caa..b2f8c45c8646486d63b7430de2fb7793846f3d5c 100644 (file)
@@ -1,3 +1,11 @@
+2018-05-03  Tom de Vries  <tom@codesourcery.com>
+
+       PR testsuite/85106
+       * testsuite/lib/libgomp-dg.exp (libgomp-dg-test): Add save-temps to
+       extra_tool_flags if it contains an -foffload=-fdump-* flag.
+       * testsuite/lib/libgomp.exp: Include scanoffloadtree.exp.
+       * testsuite/libgomp.oacc-c/vec.c: Use scan-offload-tree-dump.
+
 2018-05-02  Tom de Vries  <tom@codesourcery.com>
 
        PR libgomp/85411
index ebf78e17e6d8db2ca4c1697dcf468c209b2aaeee..726b924d67f3d26d97b4dfe4b4b34290564360ed 100644 (file)
@@ -1,4 +1,12 @@
 proc libgomp-dg-test { prog do_what extra_tool_flags } {
+    # Force the dumpbase for test.c to test.o, such that scan-offload-*-dump
+    # will work.
+    foreach opt $extra_tool_flags {
+       if { [regexp ^-foffload=-fdump- $opt] } {
+           lappend extra_tool_flags "-save-temps"
+       }
+    }
+
     return [gcc-dg-test-1 libgomp_target_compile $prog $do_what $extra_tool_flags]
 }
 
index c694f17c62ff77769447ad45d229caa95d2b1346..8ac24463be6a66f53a97fcb8854dde290bad71ae 100644 (file)
@@ -30,6 +30,7 @@ load_gcc_lib scanlang.exp
 load_gcc_lib scanrtl.exp
 load_gcc_lib scantree.exp
 load_gcc_lib scanltranstree.exp
+load_gcc_lib scanoffloadtree.exp
 load_gcc_lib scanipa.exp
 load_gcc_lib scanwpaipa.exp
 load_gcc_lib timeout-dg.exp
index 79c1c175fe611891fe9384670b452b57bedaf1b6..608538fbd1f8106f0a7d600936404536cd24f6c1 100644 (file)
@@ -1,6 +1,6 @@
 /* { dg-skip-if "" { *-*-* } { "-O0" } { "" } } */
 /* { dg-skip-if "" { *-*-* } { "*" } { "-DACC_MEM_SHARED=0" } } */
-/* { dg-additional-options "-std=c99 -ftree-slp-vectorize -foffload=-ftree-slp-vectorize -foffload=-fdump-tree-slp1 -foffload=-save-temps -save-temps" } */
+/* { dg-additional-options "-std=c99 -ftree-slp-vectorize -foffload=-fdump-tree-slp1" } */
 
 #include <stdio.h>
 #include <sys/time.h>
@@ -43,6 +43,4 @@ main (void)
   return 0;
 }
 
-/* Todo: make a scan-tree-dump variant that scans vec.o instead.  */
-/* { dg-final { file copy -force [glob vec.o.*] [regsub \.o\. [glob vec.o.*] \.c\.] } } */
-/* { dg-final { scan-tree-dump "vector\\(2\\) long long unsigned int" "slp1" } } */
+/* { dg-final { scan-offload-tree-dump "vector\\(2\\) long long unsigned int" "slp1" } } */