Page MenuHomeFreeBSD

fhopen: Enable handling of O_PATH, fix some bugs
ClosedPublic

Authored by markj on Apr 8 2025, 9:55 PM.
Tags
None
Referenced Files
F133456291: D49717.id153511.diff
Sat, Oct 25, 10:39 PM
Unknown Object (File)
Fri, Oct 24, 7:14 AM
Unknown Object (File)
Wed, Oct 22, 8:12 AM
Unknown Object (File)
Mon, Oct 20, 2:24 AM
Unknown Object (File)
Sat, Oct 18, 4:23 AM
Unknown Object (File)
Thu, Oct 16, 12:22 AM
Unknown Object (File)
Sat, Oct 11, 1:26 AM
Unknown Object (File)
Wed, Oct 8, 8:49 AM
Subscribers

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 63458
Build 60342: arc lint + arc unit

Event Timeline

markj requested review of this revision.Apr 8 2025, 9:55 PM
rmacklem added inline comments.
sys/kern/vfs_syscalls.c
4681

This looks fine, although I'll admit I would
have written the clause as "(fmode & (O_CREAT | O_PATH)) != 0
(To me, this somehow makes what it is doing more obvious?)

But go whichever way you prefer.

This revision is now accepted and ready to land.Apr 8 2025, 11:38 PM

You completely disallowed O_PATH for fhopen(), but why? I would instead make it behave same as normal open() by ignoring mode for O_PATH.

Without this patch:
kern_fhopen() requires FREAD or FWRITE.
It checks for these and fails with EINVAL if neither are set.

On the other hand, a fhopen(&fh, O_RDONLY | O_NAMEDATTR | O_PATH)
does work and openat() can use the fd.
So for fhopen(), O_RDONLY is not ignored and is required.
(A comment says that any mode other than O_EXEC is ignored for O_PATH.)

It seems that either O_PATH should fail as the above patch does
or
O_EXEC should be allowed for fhopen()

I don't know which is preferable, although I will note that a NFS server
does not handle "exec" separately from "read" and I thought the idea
behind fhopen() was a userspace NFS server?

Just to clarify what the previous comment was talking about.
Without this patch:
fhopen(&fh, O_RDONLY | O_NAMEDATTR | O_PATH) works
but
fhopen(&fh, O_EXEC | O_NAMEDATTR | O_PATH) fails with EINVAL
(You can basically ignore the O_NAMEDATTR. I just did the tests with
some test code I had lying about for O_NAMEDATTR.)

It seems that either O_PATH should fail as the above patch does or O_EXEC should be allowed for fhopen()

I think that fhopen(&fh, O_EXEC | O_RDWR) would be permitted, but this is a bug. Note that O_RDONLY == 0x0.

In D49717#1133727, @kib wrote:

You completely disallowed O_PATH for fhopen(), but why? I would instead make it behave same as normal open() by ignoring mode for O_PATH.

Mostly because of the pre-existing check for FREAD|FWRITE. If the caller is always expected to do I/O to the file, then O_PATH doesn't make much sense.

As Rick notes, use of O_EXEC is de facto disallowed as well. I suppose we could unify the flag handling with openatfp() and permit both O_EXEC and O_PATH.

In D49717#1133727, @kib wrote:

You completely disallowed O_PATH for fhopen(), but why? I would instead make it behave same as normal open() by ignoring mode for O_PATH.

Mostly because of the pre-existing check for FREAD|FWRITE. If the caller is always expected to do I/O to the file, then O_PATH doesn't make much sense.

As Rick notes, use of O_EXEC is de facto disallowed as well. I suppose we could unify the flag handling with openatfp() and permit both O_EXEC and O_PATH.

I think this would be the best. I do not think that the argument that before, read|write was required, blocks addiing O_PATH support.

Unify handling of access modes and O_PATH between openat() and fhopen().

This revision now requires review to proceed.Apr 10 2025, 1:01 PM
kib added inline comments.
sys/kern/vfs_syscalls.c
1165
4705

I think this statement can be written as

if (named_attr ^^ (flags & O_NAMEDATTR) != 0)

but up to you

This revision is now accepted and ready to land.Apr 10 2025, 9:19 PM
sys/kern/vfs_syscalls.c
1167

BTW, I think I would use a different function signature:

error = openflags(&flags);

i.e.

int openflags (int *flagsp);

It is more in-line with the common kernel pattern to return the error instead of a value.

Apply kib's suggestion; add a comment.

This revision now requires review to proceed.Apr 11 2025, 1:28 PM
This revision is now accepted and ready to land.Apr 11 2025, 2:57 PM

Fix incomplete O_PATH support: we were failing to set f_ops =
path_fileops. Deduplicate some more code between open() and fhopen().

This also fixes another bug in fhopen(): it would unconditionally set
the file ops to vnops, but this is wrong for FIFOs and for some devfs
nodes.

This revision now requires review to proceed.Apr 11 2025, 4:17 PM
markj retitled this revision from fhopen: Disallow O_PATH to fhopen: Enable handling of O_PATH, fix some bugs.Apr 11 2025, 4:21 PM
markj edited the summary of this revision. (Show Details)
This revision is now accepted and ready to land.Apr 11 2025, 5:33 PM