On Wed, Mar 9, 2011 at 10:51 AM, Richard Guenther
<richard.guent...@gmail.com> wrote:
> On Wed, Mar 9, 2011 at 4:44 AM, DJ Delorie <d...@redhat.com> wrote:
>>
>> Affects tpf, mips64, and m32c.  Hand-checked tpf by inspection, m32c
>> tests running now.  Look OK so far?
>>
>>        * tree-ssa.c (useless_type_conversion_p): Conversions between
>>        pointers of different modes are not useless.
>>
>> Index: tree-ssa.c
>> ===================================================================
>> --- tree-ssa.c  (revision 170807)
>> +++ tree-ssa.c  (working copy)
>> @@ -1227,6 +1227,14 @@
>>          != TYPE_ADDR_SPACE (TREE_TYPE (inner_type)))
>>        return false;
>>
>> +      /* Some targets support multiple pointer sizes, others support
>> +        partial-int modes for some pointer types.  Do not lose casts
>> +        between these.  */
>> +      if (TYPE_SIZE (inner_type) != TYPE_SIZE (outer_type)
>> +         || (GET_MODE_CLASS (TYPE_MODE (inner_type))
>> +             != GET_MODE_CLASS (TYPE_MODE (outer_type))))
>> +       return false;
>
> Why not simply
>
>  if (TYPE_MODE (inner_type) != TYPE_MODE (outer_type))
>    return false;
>
> ?  This only breaks because of the VOID_TYPE_P check below,
> right?

Oh, btw - I expect that a lot more code will be confused about different
size pointer types, notably IVOPTs and the POINTER_PLUS_EXPR
restriction of only accepting sizetype offsets.

Richard.

Reply via email to