[Bug tree-optimization/94216] [10 Regression] ICE in maybe_canonicalize_mem_ref_addr, at gimple-fold.c:4899 since r10-7237-g4e3d3e40726e1b68bf52fa205c68495124ea60b8
jakub at gcc dot gnu.org
gcc-bugzilla@gcc.gnu.org
Thu Mar 19 11:44:28 GMT 2020
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=94216
--- Comment #8 from Jakub Jelinek <jakub at gcc dot gnu.org> ---
(In reply to Richard Biener from comment #5)
> (In reply to Jakub Jelinek from comment #1)
> > I wonder if we shouldn't do:
> > --- gcc/fold-const.c.jj 2020-03-18 12:47:36.000000000 +0100
> > +++ gcc/fold-const.c 2020-03-18 17:34:14.586455801 +0100
> > @@ -82,6 +82,7 @@ along with GCC; see the file COPYING3.
> > #include "attribs.h"
> > #include "tree-vector-builder.h"
> > #include "vec-perm-indices.h"
> > +#include "tree-ssa.h"
> >
> > /* Nonzero if we are folding constants inside an initializer; zero
> > otherwise. */
> > @@ -10262,6 +10263,10 @@ fold_binary_loc (location_t loc, enum tr
> > switch (code)
> > {
> > case MEM_REF:
> > + STRIP_USELESS_TYPE_CONVERSION (arg0);
>
> We already applied STRIP_NOPS to arg0
Though, if we don't want to strip non-useless conversions, that is wrong even
for the two special cases we have afterwards.
So, shouldn't case MEM_REF: start then with
arg0 = op0;
STRIP_USELESS_TYPE_CONVERSION (arg0);
arg1 = op1;
?
Or fold_convert to the type of op0 if the type conversion isn't useless?
Also, isn't the arg1 handling incorrect or at least dangerous?
I mean, if it does int_const_binop (PLUS_EXPR, arg1, ...) in both cases
then it will have the type of arg1 which is op1 after STRIP_NOPS, so could have
completely different type. One needs to hope that the last argument to
fold_binary_loc of MEM_REF will always be an INTEGER_CST from which nothing can
be stripped...
More information about the Gcc-bugs
mailing list