cookie 32-bit time wrapping and possible gcc problem
data:image/s3,"s3://crabby-images/051ef/051eff104641bc99809aaf5c5dd5ca6f166ffbf5" alt=""
Tried running my test/cookies program and got two failures from the 32-bit timestamp wrapping tests. Turned out that I had -O2 set. -O succeeds, and no optimization succeeds. If I insert a MSG("exptime+local_shift %ld\n", exptime + local_shift); after setting local_shift in Cookies_expires_attr(), it works even with -O2. This is with gcc-4.3.3. I'm going to get 4.4.3 and see what happens... PS I don't particularly expect anyone to rush off and try it for themselves, but if you do, it is good to run 'dpidc stop' between runs.
data:image/s3,"s3://crabby-images/88bde/88bde7c2a46e891bac8f4d2777963c12cad3ef78" alt=""
On Mon, Mar 08, 2010 at 06:33:12PM +0000, corvid wrote:
Tried running my test/cookies program and got two failures from the 32-bit timestamp wrapping tests.
Turned out that I had -O2 set. -O succeeds, and no optimization succeeds. If I insert a MSG("exptime+local_shift %ld\n", exptime + local_shift); after setting local_shift in Cookies_expires_attr(), it works even with -O2.
This is with gcc-4.3.3. I'm going to get 4.4.3 and see what happens...
Can you reproduce the issue with a small test program? If yes, we could look at the generated code.
data:image/s3,"s3://crabby-images/051ef/051eff104641bc99809aaf5c5dd5ca6f166ffbf5" alt=""
Johannes wrote:
On Mon, Mar 08, 2010 at 06:33:12PM +0000, corvid wrote:
Tried running my test/cookies program and got two failures from the 32-bit timestamp wrapping tests.
Turned out that I had -O2 set. -O succeeds, and no optimization succeeds. If I insert a MSG("exptime+local_shift %ld\n", exptime + local_shift); after setting local_shift in Cookies_expires_attr(), it works even with -O2.
This is with gcc-4.3.3. I'm going to get 4.4.3 and see what happens...
Same behaviour with 4.4.3.
Can you reproduce the issue with a small test program? If yes, we could look at the generated code.
*makes toy program* Haven't been able to get it to break.
data:image/s3,"s3://crabby-images/051ef/051eff104641bc99809aaf5c5dd5ca6f166ffbf5" alt=""
I wrote:
Johannes wrote:
On Mon, Mar 08, 2010 at 06:33:12PM +0000, corvid wrote:
Tried running my test/cookies program and got two failures from the 32-bit timestamp wrapping tests.
Turned out that I had -O2 set. -O succeeds, and no optimization succeeds. If I insert a MSG("exptime+local_shift %ld\n", exptime + local_shift); after setting local_shift in Cookies_expires_attr(), it works even with -O2.
This is with gcc-4.3.3. I'm going to get 4.4.3 and see what happens...
Same behaviour with 4.4.3.
Found out what's going on. Signed overflow is undefined, and -O2 gives -fstrict-overflow, which assumes that overflow won't happen. So I will do something of some sort about this :)
data:image/s3,"s3://crabby-images/88bde/88bde7c2a46e891bac8f4d2777963c12cad3ef78" alt=""
On Mon, Mar 08, 2010 at 10:20:05PM +0000, corvid wrote:
I wrote:
Johannes wrote:
On Mon, Mar 08, 2010 at 06:33:12PM +0000, corvid wrote:
Tried running my test/cookies program and got two failures from the 32-bit timestamp wrapping tests.
Turned out that I had -O2 set. -O succeeds, and no optimization succeeds. If I insert a MSG("exptime+local_shift %ld\n", exptime + local_shift); after setting local_shift in Cookies_expires_attr(), it works even with -O2.
This is with gcc-4.3.3. I'm going to get 4.4.3 and see what happens...
Same behaviour with 4.4.3.
Found out what's going on.
Signed overflow is undefined, and -O2 gives -fstrict-overflow, which assumes that overflow won't happen.
good catch!
So I will do something of some sort about this :)
BTW. wikipedia states that generally arithmetic operations on time_t have no defined meaning, but you can use difftime() instead.
participants (2)
-
corvid@lavabit.com
-
Johannes.Hofmann@gmx.de