[testsuite] Add scan-ltrans-tree-dump

2018-05-02  Tom de Vries  <tom@codesourcery.com>

	PR testsuite/85106
	* gcc.dg/ipa/ipa-icf-38.c: Use scan-ltrans-tree-dump.
	* lib/scanltranstree.exp: New file.
	* lib/target-supports.exp (scan-ltrans-tree-dump_required_options)
	(scan-ltrans-tree-dump-times_required_options)
	(scan-ltrans-tree-dump-not_required_options)
	(scan-ltrans-tree-dump-dem_required_options)
	(scan-ltrans-tree-dump-dem-not_required_options): New proc.
	* lib/gcc-dg.exp: Include scanltranstree.exp.

	* testsuite/lib/libatomic.exp: Include scanltranstree.exp.

	* testsuite/lib/libgomp.exp: Include scanltranstree.exp.

	* testsuite/lib/libitm.exp: Include scanltranstree.exp.

	* testsuite/lib/libvtv.exp: Include scanltranstree.exp.

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

From-SVN: r259838
This commit is contained in:
Tom de Vries 2018-05-02 12:16:32 +00:00 committed by Tom de Vries
parent 6c3c13c181
commit 9220b5116d
15 changed files with 216 additions and 3 deletions

View File

@ -1,3 +1,9 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* doc/sourcebuild.texi (Commands for use in dg-final, Scan optimization
dump files): Add ltrans-tree.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -2588,8 +2588,8 @@ assembly output.
@subsubsection Scan optimization dump files
These commands are available for @var{kind} of @code{tree}, @code{rtl},
@code{ipa}, and @code{wpa-ipa}.
These commands are available for @var{kind} of @code{tree}, @code{ltrans-tree},
@code{rtl}, @code{ipa}, and @code{wpa-ipa}.
@table @code
@item scan-@var{kind}-dump @var{regex} @var{suffix} [@{ target/xfail @var{selector} @}]

View File

@ -1,3 +1,15 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* gcc.dg/ipa/ipa-icf-38.c: Use scan-ltrans-tree-dump.
* lib/scanltranstree.exp: New file.
* lib/target-supports.exp (scan-ltrans-tree-dump_required_options)
(scan-ltrans-tree-dump-times_required_options)
(scan-ltrans-tree-dump-not_required_options)
(scan-ltrans-tree-dump-dem_required_options)
(scan-ltrans-tree-dump-dem-not_required_options): New proc.
* lib/gcc-dg.exp: Include scanltranstree.exp.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -1,5 +1,5 @@
/* { dg-do link } */
/* { dg-options "-O2 -fdump-ipa-icf -flto" } */
/* { dg-options "-O2 -fdump-ipa-icf -flto -fdump-tree-fixup_cfg4" } */
/* { dg-require-effective-target lto } */
/* { dg-additional-sources "ipa-icf-38a.c" }*/
@ -29,3 +29,5 @@ int main()
/* { dg-final { scan-wpa-ipa-dump "Semantic equality hit:foo->bar" "icf" } } */
/* { dg-final { scan-wpa-ipa-dump "Equal symbols: 1" "icf" } } */
/* { dg-final { scan-ltrans-tree-dump "Function foo" "fixup_cfg4" } } */
/* { dg-final { scan-ltrans-tree-dump-not "Function bar" "fixup_cfg4" } } */

View File

@ -21,6 +21,7 @@ load_lib target-supports-dg.exp
load_lib scanasm.exp
load_lib scanrtl.exp
load_lib scantree.exp
load_lib scanltranstree.exp
load_lib scanipa.exp
load_lib scanwpaipa.exp
load_lib scanlang.exp

View File

@ -0,0 +1,148 @@
# Copyright (C) 2000-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 ltrans tree dump output, used by gcc-dg.exp and
# g++-dg.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-ltrans-tree-dump { args } {
if { [llength $args] < 2 } {
error "scan-ltrans-tree-dump: too few arguments"
return
}
if { [llength $args] > 3 } {
error "scan-ltrans-tree-dump: too many arguments"
return
}
if { [llength $args] >= 3 } {
scan-dump "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0" \
[lindex $args 2]
} else {
scan-dump "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0"
}
}
# 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-ltrans-tree-dump-times { args } {
if { [llength $args] < 3 } {
error "scan-ltrans-tree-dump-times: too few arguments"
return
}
if { [llength $args] > 4 } {
error "scan-ltrans-tree-dump-times: too many arguments"
return
}
if { [llength $args] >= 4 } {
scan-dump-times "ltrans-tree" [lindex $args 0] [lindex $args 1] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 2]" \
".exe.ltrans0" [lindex $args 3]
} else {
scan-dump-times "ltrans-tree" [lindex $args 0] [lindex $args 1] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 2]" ".exe.ltrans0"
}
}
# 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-ltrans-tree-dump-not { args } {
if { [llength $args] < 2 } {
error "scan-ltrans-tree-dump-not: too few arguments"
return
}
if { [llength $args] > 3 } {
error "scan-ltrans-tree-dump-not: too many arguments"
return
}
if { [llength $args] >= 3 } {
scan-dump-not "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0" \
[lindex $args 2]
} else {
scan-dump-not "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0"
}
}
# 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-ltrans-tree-dump-dem { args } {
if { [llength $args] < 2 } {
error "scan-ltrans-tree-dump-dem: too few arguments"
return
}
if { [llength $args] > 3 } {
error "scan-ltrans-tree-dump-dem: too many arguments"
return
}
if { [llength $args] >= 3 } {
scan-dump-dem "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0" \
[lindex $args 2]
} else {
scan-dump-dem "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" ".exe.ltrans0"
}
}
# 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-ltrans-tree-dump-dem-not { args } {
if { [llength $args] < 2 } {
error "scan-ltrans-tree-dump-dem-not: too few arguments"
return
}
if { [llength $args] > 3 } {
error "scan-ltrans-tree-dump-dem-not: too many arguments"
return
}
if { [llength $args] >= 3 } {
scan-dump-dem-not "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" \
".exe.ltrans0" [lindex $args 2]
} else {
scan-dump-dem-not "ltrans-tree" [lindex $args 0] \
"\[0-9\]\[0-9\]\[0-9\]t.[lindex $args 1]" \
".exe.ltrans0"
}
}

View File

@ -8809,6 +8809,26 @@ proc force_conventional_output_for { test } {
}
}
# Record that dg-final test scan-ltrans-tree-dump* requires -flto-partition=one
# in order to force a single partition, allowing scan-ltrans-tree-dump* to scan
# a dump file *.exe.ltrans0.*.
proc scan-ltrans-tree-dump_required_options {} {
return "-flto-partition=one"
}
proc scan-ltrans-tree-dump-times_required_options {} {
return "-flto-partition=one"
}
proc scan-ltrans-tree-dump-not_required_options {} {
return "-flto-partition=one"
}
proc scan-ltrans-tree-dump-dem_required_options {} {
return "-flto-partition=one"
}
proc scan-ltrans-tree-dump-dem-not_required_options {} {
return "-flto-partition=one"
}
# Return 1 if the x86-64 target supports PIE with copy reloc, 0
# otherwise. Cache the result.

View File

@ -1,3 +1,8 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* testsuite/lib/libatomic.exp: Include scanltranstree.exp.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -37,6 +37,7 @@ load_gcc_lib scandump.exp
load_gcc_lib scanlang.exp
load_gcc_lib scanrtl.exp
load_gcc_lib scantree.exp
load_gcc_lib scanltranstree.exp
load_gcc_lib scanipa.exp
load_gcc_lib scanwpaipa.exp
load_gcc_lib multiline.exp

View File

@ -1,3 +1,8 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* testsuite/lib/libgomp.exp: Include scanltranstree.exp.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -29,6 +29,7 @@ load_gcc_lib scandump.exp
load_gcc_lib scanlang.exp
load_gcc_lib scanrtl.exp
load_gcc_lib scantree.exp
load_gcc_lib scanltranstree.exp
load_gcc_lib scanipa.exp
load_gcc_lib scanwpaipa.exp
load_gcc_lib timeout-dg.exp

View File

@ -1,3 +1,8 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* testsuite/lib/libitm.exp: Include scanltranstree.exp.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -43,6 +43,7 @@ load_gcc_lib scandump.exp
load_gcc_lib scanlang.exp
load_gcc_lib scanrtl.exp
load_gcc_lib scantree.exp
load_gcc_lib scanltranstree.exp
load_gcc_lib scanipa.exp
load_gcc_lib scanwpaipa.exp
load_gcc_lib timeout-dg.exp

View File

@ -1,3 +1,8 @@
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106
* testsuite/lib/libvtv.exp: Include scanltranstree.exp.
2018-05-02 Tom de Vries <tom@codesourcery.com>
PR testsuite/85106

View File

@ -42,6 +42,7 @@ load_gcc_lib scanasm.exp
load_gcc_lib scandump.exp
load_gcc_lib scanrtl.exp
load_gcc_lib scantree.exp
load_gcc_lib scanltranstree.exp
load_gcc_lib scanipa.exp
load_gcc_lib scanwpaipa.exp
load_gcc_lib timeout-dg.exp