As mentioned, optimize_aggr_zeroprop and optimize_agr_copyprop don't change the
stmt
so they should take stmt instead of the iterator.
Pushed as obvious after bootstrap/test on x86_64-linux-gnu.
gcc/ChangeLog:
* tree-ssa-forwprop.cc (optimize_aggr_zeroprop): Take gimple*
instead of iterator.
(optimize_agr_copyprop): Likewise.
(simplify_builtin_call): Update call to optimize_aggr_zeroprop.
(pass_forwprop::execute): Update calls to optimize_aggr_zeroprop
and optimize_agr_copyprop.
Signed-off-by: Andrew Pinski <[email protected]>
---
gcc/tree-ssa-forwprop.cc | 14 ++++++--------
1 file changed, 6 insertions(+), 8 deletions(-)
diff --git a/gcc/tree-ssa-forwprop.cc b/gcc/tree-ssa-forwprop.cc
index 9998b2b5a71..4c438a0f86c 100644
--- a/gcc/tree-ssa-forwprop.cc
+++ b/gcc/tree-ssa-forwprop.cc
@@ -1294,10 +1294,9 @@ optimize_aggr_zeroprop_1 (gimple *defstmt, gimple *stmt,
and/or memcpy (&b, &a, sizeof (a)); instead of b = a; */
static void
-optimize_aggr_zeroprop (gimple_stmt_iterator *gsip, bool full_walk)
+optimize_aggr_zeroprop (gimple *stmt, bool full_walk)
{
ao_ref read;
- gimple *stmt = gsi_stmt (*gsip);
if (gimple_has_volatile_ops (stmt))
return;
@@ -1730,7 +1729,7 @@ optimize_agr_copyprop_arg (gimple *defstmt, gcall *call,
into
DEST = SRC;
DEST2 = SRC;
- GSIP is the first statement and SRC is the common
+ STMT is the first statement and SRC is the common
between the statements.
Also optimizes:
@@ -1742,9 +1741,8 @@ optimize_agr_copyprop_arg (gimple *defstmt, gcall *call,
*/
static void
-optimize_agr_copyprop (gimple_stmt_iterator *gsip)
+optimize_agr_copyprop (gimple *stmt)
{
- gimple *stmt = gsi_stmt (*gsip);
if (gimple_has_volatile_ops (stmt))
return;
@@ -2168,7 +2166,7 @@ simplify_builtin_call (gimple_stmt_iterator *gsi_p, tree
callee2, bool full_walk
{
/* Try to prop the zeroing/value of the memset to memcpy
if the dest is an address and the value is a constant. */
- optimize_aggr_zeroprop (gsi_p, full_walk);
+ optimize_aggr_zeroprop (stmt2, full_walk);
}
return simplify_builtin_memcpy_memset (gsi_p, as_a<gcall*>(stmt2));
@@ -5312,9 +5310,9 @@ pass_forwprop::execute (function *fun)
enum tree_code code = gimple_assign_rhs_code (stmt);
if (gimple_store_p (stmt))
{
- optimize_aggr_zeroprop (&gsi, full_walk);
+ optimize_aggr_zeroprop (stmt, full_walk);
if (gimple_assign_load_p (stmt))
- optimize_agr_copyprop (&gsi);
+ optimize_agr_copyprop (stmt);
}
else if (TREE_CODE_CLASS (code) == tcc_comparison)
changed |= forward_propagate_into_comparison (&gsi);
--
2.43.0