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
Unknown Object (File)
Sun, May 12, 4:28 PM
Unknown Object (File)
Wed, May 1, 11:41 AM
Unknown Object (File)
Sat, Apr 27, 1:18 AM
Unknown Object (File)
Fri, Apr 26, 5:05 AM
Unknown Object (File)
Apr 16 2024, 3:30 AM
Unknown Object (File)
Apr 14 2024, 4:58 PM
Unknown Object (File)
Apr 12 2024, 2:59 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