diff options
author | Andrew Pinski <apinski@marvell.com> | 2023-05-02 00:08:19 -0700 |
---|---|---|
committer | Andrew Pinski <apinski@marvell.com> | 2023-05-03 11:26:38 -0700 |
commit | 3b7eecca20bcb05e0220b3d012df012902a23534 (patch) | |
tree | 603613fa8a5c3e1f867eb1829eb6d758ebe96736 | |
parent | 2b8a27634f5d28e3e7c4a08bf065f2daada7aed2 (diff) | |
download | gcc-3b7eecca20bcb05e0220b3d012df012902a23534.zip gcc-3b7eecca20bcb05e0220b3d012df012902a23534.tar.gz gcc-3b7eecca20bcb05e0220b3d012df012902a23534.tar.bz2 |
Add stats to simple_dce_from_worklist
While looking to move substitute_and_fold_engine
over to use simple_dce_from_worklist, I noticed
that we don't record the stats of the removed stmts/phis.
So this does that.
OK? Bootstrapped and tested on x86_64-linux-gnu.
gcc/ChangeLog:
* tree-ssa-dce.cc (simple_dce_from_worklist): Record
stats on removed number of statements and phis.
-rw-r--r-- | gcc/tree-ssa-dce.cc | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/gcc/tree-ssa-dce.cc b/gcc/tree-ssa-dce.cc index 1fd88e8..e4c32e6 100644 --- a/gcc/tree-ssa-dce.cc +++ b/gcc/tree-ssa-dce.cc @@ -2099,6 +2099,8 @@ make_pass_cd_dce (gcc::context *ctxt) void simple_dce_from_worklist (bitmap worklist) { + int phiremoved = 0; + int stmtremoved = 0; while (! bitmap_empty_p (worklist)) { /* Pop item. */ @@ -2144,12 +2146,20 @@ simple_dce_from_worklist (bitmap worklist) } gimple_stmt_iterator gsi = gsi_for_stmt (t); if (gimple_code (t) == GIMPLE_PHI) - remove_phi_node (&gsi, true); + { + remove_phi_node (&gsi, true); + phiremoved++; + } else { unlink_stmt_vdef (t); gsi_remove (&gsi, true); release_defs (t); + stmtremoved++; } } + statistics_counter_event (cfun, "PHIs removed", + phiremoved); + statistics_counter_event (cfun, "Statements removed", + stmtremoved); } |