Page MenuHomeFreeBSD

vm: Change result code for VM_FAULT_NOFILL
Needs ReviewPublic

Authored by freebsdphab-AX9_cmx.ietfng.org on Jun 22 2021, 1:49 PM.
Tags
None
Referenced Files
F133317202: D30864.diff
Fri, Oct 24, 9:37 PM
Unknown Object (File)
Sun, Oct 12, 2:14 AM
Unknown Object (File)
Wed, Oct 8, 5:15 PM
Unknown Object (File)
Tue, Oct 7, 3:55 PM
Unknown Object (File)
Sep 21 2025, 11:32 AM
Unknown Object (File)
Sep 11 2025, 1:42 PM
Unknown Object (File)
Sep 10 2025, 3:24 AM
Unknown Object (File)
Sep 3 2025, 12:40 PM
Subscribers
None

Details

Reviewers
markj
jhb
alc
kib
Summary

At present, a return from vm_fault() of KERN_OUT_OF_BOUNDS can signal a pager failure or can indicate that VM_FAULT_NOFILL was successful in avoiding a fill. As some callers (e.g., the prototype for CHERI capability revocation) may want to distinguish these cases, use a different return code. KERN_NOT_RECEIVER is not otherwise an expected return from vm_fault(), so go ahead and use it (again) as a special case.

The sole existing in-tree user of VM_FAULT_NOFILL seems to be sys/kern/kern_exec.c:/^core_output and that path does not discriminate on return codes beyond KERN_SUCCESS vs. anything else. This change thus does not alter its behaviour.

Test Plan

In use as part of the CHERI capability revocation prototype for a while; better test plans welcome.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

You should either assert that VM_FAULT_NOFILL is not passed to vm_fault_trap(), or do something with KERN_NOT_RECEIVER there.

That said, KERN_NOT_RECEIVER was an internal status for vm_fault.c, and it is cheap to allocate a unique error code for your use, avoiding any collisions.