On Tue, Jan 20, 2026 at 08:27:46PM +1100, NeilBrown wrote: > > If you think NFS actually explains the semantics pretty well, please > > explain that too, especially in forms that can be put into > > documentation, including for the user ABI. > > There are multiple issues here: > > - filehandle stability. As far as I know all filesystems provide > stable filehandles when the "subtree_check" export option is not used.
That is news to me, but certainly interesting. Does this include not reusing the file handle for a new incarnation of the same thing? > Certainly cgroupfs does. So having an EXPORT_OP_STABLE_HANDLES > flag would mean it was set for every filesystem - unless there is > something else I'm not aware of. That is certainly possible and I > hope someone will let me know if I'm missing something. Well, if does not provide stable file handles with the subtree_check export option, or more importantly with the CONNECTABLE flag passed to encode_fh, which is the level we're operating on, it can't set the flag. > - filehandle uniqueness. This is somewhat important and if a > filesystem doesn't provide it, that should be considered a bug. In a > different thread Christian has observed that there would be benefit > if pidfs and nsfs provided uniqueness across reboots. It is quite > easy for a virtual filesystem to generate a 64 bit random number when > the fs is initialised, and include that in file handles. Having a > EXPORT_OP_REUSES_HANDLES flag could mark filesystems that are still > buggy if that is thought to be useful. Yes. > - GETATTR always reporting file size of 0. This is the only concrete > symptom that Jeff has reported (that I have seen). This makes it > impossible to read files over NFS even if they have content. > Would EXPORT_OP_INACCURATE_SIZE be useful? i_size = 0 for a regular file sounds like a genuine bug to me. I'm actually surprised anything works with that. > - maintainer feature choice. A maintainer may choose not to support > export over NFS because they feel that there is no value and the > possible support burden would not be worth it. The maintainer has no way to disallow exporting through nfs. They can at best disallow exporting using the kernel nfs daemon if we provide that facility. But as I've argued multiple times, making arbitrary, selective and very narrow choices about use cases without technical backing for them (which then would be expressable as a flag like those listed by you above) is really bad software development practice, and not something that we usually do in the Linux kernel. > There may be locking > / lease / etc issues that further complicate things. So it might be > reasonable for a maintainer to choose to forbid NFS export while > allowing local fhandle access. EXPORT_OP_NO_NFS_EXPORT. We already have a EXPORT_OP_NOLOCKS flag to deal with this. > > It took me a while to sift through the code/patches/comments and come to > this understanding and I apologise if I wasn't as clear earlier. But > my intuition was always that file handle stability was never the real > issue, and maintainer choice was. Hence my rejection of the > "STABLE_HANDLES" name. Why do you keep ignoring the fat that the stable handles are really important for anyone wanting to actually use them for their original storage purpose, be that for knfsd, a userland nfs damon, or other storage applications in userspace despite explaining this countless times?
