On Wed, Nov 13, 2019 at 5:59 AM Darrick J. Wong <darrick.wong@xxxxxxxxxx> wrote: > On Wed, Nov 13, 2019 at 06:42:09AM +0200, Amir Goldstein wrote: > > [CC:Arnd,Deepa] > > On Wed, Nov 13, 2019 at 5:56 AM Darrick J. Wong <darrick.wong@xxxxxxxxxx> wrote: > > > > > > On Wed, Nov 13, 2019 at 08:11:53AM +1100, Dave Chinner wrote: > > > > On Tue, Nov 12, 2019 at 06:00:19AM +0200, Amir Goldstein wrote: > > > > > On Tue, Nov 12, 2019 at 12:35 AM Darrick J. Wong > > > > > <darrick.wong@xxxxxxxxxx> wrote: > > > > > > > I didn't get why you dropped the di_pad idea (Arnd's and Dave's patches). > > Is it to save the pad for another rainy day? > > Something like that. Someone /else/ can worry about the y2486 problem. > > <duck> > > Practically speaking I'd almost rather drop the precision in order to > extend the seconds range, since timestamp updates are only precise to > HZ anyway. I think there would be noticeable overhead from anything that requires a 64-bit division to update a timestamp, or to read it into an in-memory inode, especially on 32-bit architectures. I think the reason why separate seconds/nanoseconds are easy is that this is what both the in-kernel and user space interface are based around. We clearly don't use the precision, but anything else is more expensive at runtime. > > > > IOWs, we pretty much decided on a new 64 bit encoding format using a > > > > epoch of 1900 and a unsigned 64bit nanosecond counter to get us a > > > > range of almost 600 years from year 1900-2500. It's simple, easy to > > > > encode/decode, and very easy to validate. It's also trivially easy > > > > to do in-place upgrades with an inode flag.... > > > > > > > > All right, so how do we proceed? > > Arnd, do you want to re-work your series according to this scheme? > > Lemme read them over again. :) > > > Is there any core xfs developer that was going to tackle this? > > > > I'm here, so if you need my help moving things forward let me know. > > I wrote a trivial garbage version this afternoon, will have something > more polished tomorrow. None of this is 5.6 material, we have time. I think from a user perspective, it would be the nicest to just add the extra high bits (however many, I don't care) and treat it as an ro-compatible extension, possibly even as completely compatible both ways. Note that for any released kernel (5.4 changes this), this matches the existing behavior: setting a timestamp after 2038 using utimensat() silently wraps the seconds back to the regular epoch. With the extension patch, you get the correct results as long as the inode was both written and read on a new enough kernel, while all pre-5.4 kernels produce the same incorrect data that they always have. Arnd