On Mon, Nov 26, 2012 at 04:24:41PM +0100, Richard Biener wrote:
> On Thu, Nov 15, 2012 at 9:09 PM, Jakub Jelinek <ja...@redhat.com> wrote:
> > On the following testcase substitute_and_fold ICEs because memmove
> > of length 1 on an empty class is optimized away, and this function wasn't
> > prepared to handle that.
> >
> > Fixed thusly, bootstrapped/regtested on x86_64-linux and i686-linux, ok for
> > trunk/4.7?
> 
> I think the bug is that the stmt is removed.  fold_stmt is not supposed to
> "remove" the stmt in any case - it may replace it with a gimple_nop at most.
> 
> Thus, gimplify_and_update_call_from_tree is at fault here.
> 
> I am testing a patch that fixes it.

Note that fold_stmt_1 also has code to handle a call folding into nothing,
so perhaps that could be removed too if you change it to fold into a nop
instead.

        Jakub

Reply via email to