------- Comment #20 from rguenth at gcc dot gnu dot org 2007-11-07 17:28
-------
Basically things like
D.2196_13 = (struct Ref *) &D.2150.lhs;
D.2196_13->m ={v} &I;
where D.2150.lhs is const and thus there is a (not useless) cast from
(const struct Ref *) to (struct Ref *). So what the code does is to
store to "const" qualified memory:
D.2150.lhs.m = &I;
of course only as part of constructing it, so it is legal, but the middle-end
cannot tell apart legal from illegal cases.
So we can just declare all of them legal based on the fact that otherwise
this would certainly invoke undefined behavior. In which case tree-level
forwprop can be teached to disregard conversions that change constness
only on address-forwarding.
Something like a more careful
Index: tree-ssa-forwprop.c
===================================================================
--- tree-ssa-forwprop.c (revision 129897)
+++ tree-ssa-forwprop.c (working copy)
@@ -952,8 +952,14 @@ tree_ssa_forward_propagate_single_use_va
continue;
}
- if (TREE_CODE (rhs) == ADDR_EXPR)
+ if (TREE_CODE (rhs) == ADDR_EXPR
+ || ((TREE_CODE (rhs) == NOP_EXPR
+ || TREE_CODE (rhs) == CONVERT_EXPR)
+ && TREE_CODE (TREE_OPERAND (rhs, 0)) == ADDR_EXPR
+ && (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (rhs)))
+ == TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE
(TREE_OPERAND (rhs, 0)))))))
{
+ STRIP_NOPS (rhs);
if (forward_propagate_addr_expr (lhs, rhs))
{
release_defs (stmt);
--
rguenth at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
AssignedTo|unassigned at gcc dot gnu |rguenth at gcc dot gnu dot
|dot org |org
Status|NEW |ASSIGNED
Last reconfirmed|2007-11-07 13:09:53 |2007-11-07 17:28:11
date| |
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=33604