[Bug middle-end/42749] [4.5 Regression] -O2 and verify_stmts failed again

rakdver at kam dot mff dot cuni dot cz gcc-bugzilla@gcc.gnu.org
Sat Jan 16 13:24:00 GMT 2010



------- Comment #12 from rakdver at kam dot mff dot cuni dot cz  2010-01-16 13:24 -------
Subject: Re:  [4.5 Regression] -O2 and verify_stmts
        failed again

> > ------- Comment #10 from rakdver at gcc dot gnu dot org  2010-01-16 12:53 -------
> >  /* Reject a tailcall if the type conversion might need
> > 285                       additional code.  */
> > 286                    if (gimple_assign_cast_p (stmt)
> > 287                        && TYPE_MODE (TREE_TYPE (dest)) != TYPE_MODE
> > (TREE_TYPE (src_var)))
> > 288                      return false;
> > 
> > This is suspicious; replacing the weird TYPE_MODE check with
> > useless_type_conversion_p fixes the problem.
> 
> Correct, but for useless_type_conversion_p we can reject any conversions
> in the IL since only !useless_type_conversion_p remain.

right

> I suppose the code was explicitly trying to allow sign-changing
> (but not precision changing as it does), or conversion to/from
> pointers.
> 
> Thus, if you want to go the useless_type_conversion_p route simply
> reject all conversions and only allow plain SSA name copies...

this might be overly restrictive; it should be quite easy to add the
appropriate casts, instead.


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=42749



More information about the Gcc-bugs mailing list