This is the mail archive of the
gcc-bugs@gcc.gnu.org
mailing list for the GCC project.
[Bug c/47427] [4.6 Regression] ICE in process_constraint, at tree-ssa-structalias.c:2901
- From: "rguenther at suse dot de" <gcc-bugzilla at gcc dot gnu dot org>
- To: gcc-bugs at gcc dot gnu dot org
- Date: Mon, 24 Jan 2011 13:00:29 +0000
- Subject: [Bug c/47427] [4.6 Regression] ICE in process_constraint, at tree-ssa-structalias.c:2901
- Auto-submitted: auto-generated
- References: <bug-47427-4@http.gcc.gnu.org/bugzilla/>
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=47427
--- Comment #3 from rguenther at suse dot de <rguenther at suse dot de> 2011-01-24 12:59:58 UTC ---
On Mon, 24 Jan 2011, jakub at gcc dot gnu.org wrote:
> http://gcc.gnu.org/bugzilla/show_bug.cgi?id=47427
>
> Jakub Jelinek <jakub at gcc dot gnu.org> changed:
>
> What |Removed |Added
> ----------------------------------------------------------------------------
> CC| |hubicka at gcc dot gnu.org,
> | |jakub at gcc dot gnu.org
>
> --- Comment #2 from Jakub Jelinek <jakub at gcc dot gnu.org> 2011-01-24 12:50:47 UTC ---
> I think this is pretty much the same issue as PR47428, except in this case it
> is not a PHI in which such a replacement is made, but for y_9 = 0; given that y
> is argument declared const the inliner replaces it with 1 = 0;.
> So perhaps the PR47428 patch isn't the right fix.
copyrename shouldn't do this (coalesce to TREE_READONLY vars - it also
doesn't seem to not coalesce to TREE_THIS_VOLATILE vars, though those
shouldn't be in SSA form).
> The reason why y_9 is on the LHS of a set is copyrename. I guess a fix could
> be either not doing copyrename if an SSA_NAME of a TREE_READONLY var would be
> on the LHS of an assignment or result of a PHI, or drop the TREE_READONLY from
> the parameter in such a case (but that would result in us dropping such info in
> debug info), or avoid the optimization
> /* If the parameter is never assigned to, has no SSA_NAMEs created,
> we would not need to create a new variable here at all, if it
> weren't for debug info. Still, we can just use the argument
> value. */
> if (TREE_READONLY (p)
> ...
> in setup_one_parameter.
>
> Richard/Honza, what do you think?
Fix copyrename.
Richard.