On Fri, Sep 30, 2005 at 01:49:59PM -0400, Andrew Pinski wrote:
> Something like this will fix the issue with TYPE_REF_CAN_ALIAS_ALL
> by removing the use.  Maybe we could move may_alias to a bit in the
> types and move TYPE_REF_CAN_ALIAS_ALL from the pointer type to the
> type which is being accessed instead of this mess.

Close.  

> +     build_type_attribute_variant (ttype,
> +                                   merge_attributes
> +                                     (TYPE_ATTRIBUTES (to_type), 
> +                                      tree_cons (get_identifier 
> ("may_alias"),
> +                                                 NULL_TREE, NULL_TREE)));

If ALIAS_SET had been computed on ttype, this will leave it set.
You'd need to force set it to zero here.  You can also avoid 
creating a new type for C for the case in question by checking 
that the original type has alias set zero.

>        return build_pointer_type_for_mode (build_type_no_quals (TREE_TYPE 
> (t)),
>                                         TYPE_MODE (t),
> -                                       TYPE_REF_CAN_ALIAS_ALL (t));
> +                                       false);

You'd also want to delete all traces of TYPE_REF_CAN_ALIAS_ALL.


r~

Reply via email to