+2004-09-21 Jeff Law <law@redhat.com>
+
+ * tree-ssa-ccp.c (get_default_value): If we have a constant
+ value recorded for an SSA_NAME, then use that constant as
+ the initial lattice value.
+ (substitute_and_fold): Transfer equivalences discovered into
+ SSA_NAME_EQUIV.
+
+ * tree.h (SSA_NAME_EQUIV): Add comments.
+ (SET_SSA_NAME_EQUIV): Similarly.
+
2004-09-21 David Edelsohn <edelsohn@gnu.org>
* config/rs6000/linux64.h (PROCESSOR_DEFAULT64): Default to POWER4.
val.lattice_val = UNDEFINED;
val.const_val = NULL_TREE;
- if (TREE_CODE (sym) == PARM_DECL || TREE_THIS_VOLATILE (sym))
+ if (TREE_CODE (var) == SSA_NAME
+ && SSA_NAME_EQUIV (var)
+ && is_gimple_min_invariant (SSA_NAME_EQUIV (var)))
+ {
+ val.lattice_val = CONSTANT;
+ val.const_val = SSA_NAME_EQUIV (var);
+ }
+ else if (TREE_CODE (sym) == PARM_DECL || TREE_THIS_VOLATILE (sym))
{
/* Function arguments and volatile variables are considered VARYING. */
val.lattice_val = VARYING;
substitute_and_fold (void)
{
basic_block bb;
+ unsigned int i;
if (dump_file && (dump_flags & TDF_DETAILS))
fprintf (dump_file,
}
}
}
+
+ /* And transfer what we learned from VALUE_VECTOR into the
+ SSA_NAMEs themselves. This probably isn't terribly important
+ since we probably constant propagated the values to their
+ use sites above. */
+ for (i = 0; i < num_ssa_names; i++)
+ {
+ tree name = ssa_name (i);
+ value *value;
+
+ if (!name)
+ continue;
+
+ value = get_value (name);
+ if (value->lattice_val == CONSTANT
+ && is_gimple_reg (name)
+ && is_gimple_min_invariant (value->const_val))
+ SET_SSA_NAME_EQUIV (name, value->const_val)
+ }
}
#define SSA_NAME_OCCURS_IN_ABNORMAL_PHI(NODE) \
SSA_NAME_CHECK (NODE)->common.asm_written_flag
-
/* Nonzero if this SSA_NAME expression is currently on the free list of
SSA_NAMES. Using NOTHROW_FLAG seems reasonably safe since throwing
has no meaning for an SSA_NAME. */
#define SSA_NAME_IN_FREE_LIST(NODE) \
SSA_NAME_CHECK (NODE)->common.nothrow_flag
+/* If NAME is equivalent to some other SSA_NAME or an invariant, then
+ return the equivalent SSA_NAME or invariant, else return NULL. */
#define SSA_NAME_EQUIV(NAME) __extension__ \
({ tree equiv = SSA_NAME_CHECK (NAME)->ssa_name.equiv; \
if (equiv && TREE_CODE (equiv) == SSA_NAME) \
equiv; \
})
+/* Record that NAME (an SSA_NAME) is equivalent to EQUIV. */
+
#define SET_SSA_NAME_EQUIV(NAME, EQUIV)\
SSA_NAME_CHECK (NAME)->ssa_name.equiv = (EQUIV);