------- Comment #9 from pinskia at gcc dot gnu dot org  2005-12-19 18:36 -------
(In reply to comment #8)
> (Why should we get 1?  Upon entry to f, a will be 1, since 32769 will be
> reduced modulo 2^16.  Then, b will be 1 - 32768, or -32767.  I don't see why
> that should be converted to 1 -- but I certainly don't see why it should be
> 32768 either.)

32769 == 0x8001 .
so a will not be 1.  You are thinking it is reduced modulo 2^15.

so c will be negative as 0x8001 is negative so we don't take the branch.

and then we have 0x00008001 + -0x00008000 which is equal to 1.

Thanks,
Andrew Pinski


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=25125

Reply via email to