On Fri, May 27, 2005 at 02:32:46PM -0400, Andrew Pinski wrote:
> >
> > This is happening in gcc.dg/tree-ssa/20040121-1.c. The test
> > specifically tests that (p!=0) + (q!=0) should be computed as
> > int:
> >
> > char *foo(char *p, char *q) {
> > int x = (p !=0) + (q != 0);
> > ...
> > }
> >
> > During VRP, we get this IL
> >
> > D.1294_10 = first_8 != 0B;
> > D.1295_11 = last_9 != 0B;
> > x_12 = D.1294_10 + D.1295_11;
> For me (on the mainline as of last night),
> both D.1294 and D.1295 are of type int so it
> looks like a bug in VRP assuming the resulting
> type of a comparison will a boolean type.
>
Of course they are both of type int, but the *value* they hold is
of type _Bool.
When we call int_const_binop, we send the *values* and it
computes the operation using the type of the *values*.
The workaround I am using right now is for VRP to force the type
of the values to the type of the expression. But that doesn't
fix the FE bug.
Diego.