Page MenuHomeFreeBSD

fattime: fix fattime to timespec conversion of dates beyond 2106-02-06
ClosedPublic

Authored by jeffpc_josefsipek.net on Apr 12 2024, 2:59 AM.
Tags
None
Referenced Files
F147988106: D44755.id.diff
Sun, Mar 15, 1:22 AM
Unknown Object (File)
Wed, Mar 11, 8:44 AM
Unknown Object (File)
Wed, Mar 11, 5:26 AM
Unknown Object (File)
Mon, Mar 9, 7:38 PM
Unknown Object (File)
Mon, Mar 9, 7:07 PM
Unknown Object (File)
Mon, Mar 9, 6:35 PM
Unknown Object (File)
Thu, Mar 5, 6:08 AM
Unknown Object (File)
Wed, Mar 4, 6:43 PM
Subscribers

Details

Summary

It turns out that the only conversion issue was in fattime2timespec, where
multiplying the number of seconds in a day by the number of days overflowed
32-bit unsigned int for dates beyond 2106-02-07 06:28:15.

Casting one of the multiplicands as time_t forces a 64-bit multiplication on
systems where time_t is 64-bits and produces no binary changes on the one
remaining system with 32-bit time_t (namely i386).

Since the code is now tested & fixed, this change removes the fixme comments.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable