Yes I guess otherwise you could never produce a complex address like
that. Actually I think I remember that day that I found that C
explicitly leaves it undefined and to the machine.
Thanks
Hendrik

On Wed, Aug 7, 2013 at 1:40 PM, Oleg Endo <oleg.e...@t-online.de> wrote:
> On Tue, 2013-07-09 at 09:37 -0700, Hendrik Greving wrote:
>> On a machine with ABI ILP32LL64:
>>
>> (insn 123 122 124 (nil) (set (reg:SI 392)
>>         (mem:SI (plus:SI (reg/v:SI 386)
>>                 (reg/v:SI 349)) [0 sec 0 space 0, cmsmode 0 S4 A32])) -1 
>> (nil)
>>     (nil))
>>
>> If we support legitimate memory addresses like [r1+r2] (e.g. indexed
>> addresses), can the above RTL match such a load?
>
> On 32 bit address machines it should match.
>
>> I am asking because
>> of overflows, I am not sure how that part is defined, and where the
>> Spec is. What do I need to check in the backend for such a definition?
>> Is this POINTER_SIZE? E.g. what if the machine supports > 32 bits, who
>> is responsible to make sure that there is no overflow > 32 bits in
>> this case? Compiler? Assembler? Or even the user?
>
> AFAIK overflow is undefined and thus anything can happen.  Induction
> variable and loop optimizations may produce interesting things if
> addresses overflow.  For example, see
> http://gcc.gnu.org/bugzilla/show_bug.cgi?id=55190
>
> Cheers,
> Oleg
>

Reply via email to