[testsuite] Add scan-offload-rtl-dump
authorTom de Vries <tom@codesourcery.com>
Wed, 19 Dec 2018 14:20:33 +0000 (14:20 +0000)
committerTom de Vries <vries@gcc.gnu.org>
Wed, 19 Dec 2018 14:20:33 +0000 (14:20 +0000)
Add scan-offload-rtl-dump, similar to scan-offload-tree-dump.

Build and reg-tested on x86_64 with nvptx accelerator.

2018-12-19  Tom de Vries  <tom@codesourcery.com>

* lib/scanoffloadrtl.exp: New file.
* gcc.dg-selftests/dg-final.exp (dg_final_directive_check_num_args): Add
offload-rtl.

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

From-SVN: r267266

gcc/ChangeLog
gcc/doc/sourcebuild.texi
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg-selftests/dg-final.exp
gcc/testsuite/lib/scanoffloadrtl.exp [new file with mode: 0644]

index 6fe6ec342c1f4dd1a806ff179e773a0b30dd92a8..597dca78773785b376a26d25e7eaf4444cc073ce 100644 (file)
@@ -1,3 +1,8 @@
+2018-12-19  Tom de Vries  <tom@codesourcery.com>
+
+       * doc/sourcebuild.texi (Commands for use in dg-final, Scan optimization
+       dump files): Add offload-rtl.
+
 2018-12-19  Segher Boessenkool  <segher@kernel.crashing.org>
 
        PR target/88213
index 224ab89921a7a8cbe747e6558921f827c5c92fca..46ef388e109bea5a8a50349a39c886127ffa9733 100644 (file)
@@ -2644,7 +2644,8 @@ assembly output.
 @subsubsection Scan optimization dump files
 
 These commands are available for @var{kind} of @code{tree}, @code{ltrans-tree},
-@code{offload-tree}, @code{rtl}, @code{ipa}, and @code{wpa-ipa}.
+@code{offload-tree}, @code{rtl}, @code{offload-rtl}, @code{ipa}, and
+@code{wpa-ipa}.
 
 @table @code
 @item scan-@var{kind}-dump @var{regex} @var{suffix} [@{ target/xfail @var{selector} @}]
index cb5d6195432ed2bd2d1478d82c961399802a1aff..8f1353465c331c3f420e4e6318dba188b7e98f6d 100644 (file)
@@ -1,3 +1,9 @@
+2018-12-19  Tom de Vries  <tom@codesourcery.com>
+
+       * lib/scanoffloadrtl.exp: New file.
+       * gcc.dg-selftests/dg-final.exp (dg_final_directive_check_num_args): Add
+       offload-rtl.
+
 2018-12-19  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/88533
index 1d98666e13730c0b70d664a2b5106c21af79e082..90a6e894abdae4e876f8b6884a7ddb4151cc7147 100644 (file)
@@ -25,6 +25,7 @@ load_lib "scanasm.exp"
 load_lib "scanwpaipa.exp"
 load_lib "scanltranstree.exp"
 load_lib "scanoffloadtree.exp"
+load_lib "scanoffloadrtl.exp"
 load_lib "gcc-dg.exp"
 
 proc verify_call_1 { args } {
@@ -82,7 +83,8 @@ proc dg_final_directive_check_num_args {} {
        verify_call $proc_name $too_few "too few arguments"
     }
 
-    foreach kind [list "tree" "rtl" "ipa" "ltrans-tree" "wpa-ipa" "offload-tree"] {
+    foreach kind [list "tree" "rtl" "ipa" "ltrans-tree" "wpa-ipa" \
+                     "offload-tree" "offload-rtl"] {
        verify_args scan-$kind-dump 2 3
        verify_args scan-$kind-dump-times 3 4
        verify_args scan-$kind-dump-not 2 3
diff --git a/gcc/testsuite/lib/scanoffloadrtl.exp b/gcc/testsuite/lib/scanoffloadrtl.exp
new file mode 100644 (file)
index 0000000..e836f6d
--- /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 rtl 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 rtl pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-rtl-dump { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-rtl-dump: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-rtl-dump: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump "offload-rtl" [lindex $args 0] \
+                 "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 1]" ".o" \
+                 [lindex $args 2]
+    } else {
+       scan-dump "offload-rtl" [lindex $args 0] \
+                 "\[0-9\]\[0-9\]\[0-9]r.[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 rtl pass
+# Argument 3 handles expected failures and the like
+proc scan-offload-rtl-dump-times { args } {
+
+    if { [llength $args] < 3 } {
+       error "scan-offload-rtl-dump-times: too few arguments"
+       return
+    }
+    if { [llength $args] > 4 } {
+       error "scan-offload-rtl-dump-times: too many arguments"
+       return
+    }
+    if { [llength $args] >= 4 } {
+       scan-dump-times "offload-rtl" [lindex $args 0] [lindex $args 1] \
+                       "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 2]" ".o" \
+                       [lindex $args 3]
+    } else {
+       scan-dump-times "offload-rtl" [lindex $args 0] [lindex $args 1] \
+                       "\[0-9\]\[0-9\]\[0-9]r.[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 rtl pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-rtl-dump-not { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-rtl-dump-not: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-rtl-dump-not: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-not "offload-rtl" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 1]" ".o" \
+                     [lindex $args 2]
+    } else {
+       scan-dump-not "offload-rtl" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]r.[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 rtl pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-rtl-dump-dem { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-rtl-dump-dem: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-rtl-dump-dem: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-dem "offload-rtl" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 1]" ".o" \
+                     [lindex $args 2]
+    } else {
+       scan-dump-dem "offload-rtl" [lindex $args 0] \
+                     "\[0-9\]\[0-9\]\[0-9]r.[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 rtl pass
+# Argument 2 handles expected failures and the like
+proc scan-offload-rtl-dump-dem-not { args } {
+
+    if { [llength $args] < 2 } {
+       error "scan-offload-rtl-dump-dem-not: too few arguments"
+       return
+    }
+    if { [llength $args] > 3 } {
+       error "scan-offload-rtl-dump-dem-not: too many arguments"
+       return
+    }
+    if { [llength $args] >= 3 } {
+       scan-dump-dem-not "offload-rtl" [lindex $args 0] \
+                         "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 1]" ".o" \
+                         [lindex $args 2]
+    } else {
+       scan-dump-dem-not "offload-rtl" [lindex $args 0] \
+                         "\[0-9\]\[0-9\]\[0-9]r.[lindex $args 1]" ".o"
+    }
+}