Page MenuHomeFreeBSD

fusefs: fix invalid value for st_birthtime.tv_nsec
ClosedPublic

Authored by asomers on Jan 25 2024, 3:23 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 5:48 PM
Unknown Object (File)
Fri, Jan 24, 5:18 PM
Unknown Object (File)
Sun, Jan 12, 4:03 AM
Unknown Object (File)
Dec 13 2024, 3:18 AM
Unknown Object (File)
Nov 26 2024, 11:45 PM
Unknown Object (File)
Nov 15 2024, 4:37 PM
Unknown Object (File)
Nov 15 2024, 2:43 PM
Unknown Object (File)
Sep 27 2024, 8:05 AM
Subscribers

Details

Summary

If a file system's on-disk format does not support st_birthtime, it
isn't clear what value it should return in stat(2). Neither our man
page nor the OpenGroup specifies. But our convention for UFS and
msdosfs is to return { .tv_sec = -1, .tv_nsec = 0 }. fusefs is
different. It returns { .tv_sec = -1, .tv_nsec = -1 }. It's done that
ever since the initial import in SVN r241519.

Most software apparently handles this just fine. It must, because we've
had no complaints. But the Rust standard library will panic when
reading such a timestamp during std::fs::metadata, even if the caller
doesn't care about that particular value. That's a separate bug, and
should be fixed.

Change our invalid value to match msdosfs and ufs, pacifying the Rust
standard library.

PR: 276602
MFC after: 1 week
Sponsored by: Axcient

Test Plan

additional assertions added to existing test cases

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 55607
Build 52496: arc lint + arc unit

Event Timeline

I think this is good but I wonder if we should have a trivial macro/inline for recording an unset/invalid va_birthtime?

I think this is good but I wonder if we should have a trivial macro/inline for recording an unset/invalid va_birthtime?

What would you call it?

@emaste what about something like this?

#define VA_NOTIME(ts) { \
    ts->tv_sec = -1; \
    ts->tv_nsec = 0; \
}

@emaste what about something like this?

#define VA_NOTIME(ts) { \
    ts->tv_sec = -1; \
    ts->tv_nsec = 0; \
}

Seems reasonable to me as a potential followup.

sys/fs/fuse/fuse_internal.c
328

va_gen and va_vaflags not set in the block below, comparing with vattr_null?

This revision is now accepted and ready to land.Feb 4 2024, 7:48 PM
sys/fs/fuse/fuse_internal.c
328

That's because they get set by vop_stdstat, which sets them first and then calls VOP_GETATTR.