Page MenuHomeFreeBSD

Allow vm_fault_quick_hold_pages() to specify that nofault mode should be honored.
ClosedPublic

Authored by kib on Mar 24 2018, 2:02 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 6:55 PM
Unknown Object (File)
Dec 3 2024, 10:58 AM
Unknown Object (File)
Nov 22 2024, 2:12 PM
Unknown Object (File)
Oct 4 2024, 4:44 AM
Unknown Object (File)
Oct 3 2024, 10:41 PM
Unknown Object (File)
Oct 3 2024, 7:03 PM
Unknown Object (File)
Oct 3 2024, 10:40 AM
Unknown Object (File)
Oct 2 2024, 7:15 PM
Subscribers

Details

Summary

This is a bit from D14633 needed to implement copyout(9).

We must not sleep or acquire any MI VM locks if TDP_NOFAULTING is specified. On the other hand, there were some callers in the tree which set TDP_NOFAULTING for larger scope than needed, I fixed the code which I wrote, but I suspect that linuxkpi and out of tree drm drivers might abuse this still.

So I only enable the mode for vm_fault_quick_hold_pages() where vm_fault_hold() is not called when specifically asked by user. I decided to use vm_prot_t flag to not change KPI. Since number of flags in vm_prot_t is limited, I reused the same flag which was already consumed for vm_map_lookup().

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

markj added inline comments.
sys/vm/vm.h
83–85

This is pedantic but 0x10 would look more correct. vm_prot_t is only 8 bits wide.

sys/vm/vm_fault.c
1526–1534

I'd add a comment explaining the motivation for QUICK_NOFAULT here.

This revision is now accepted and ready to land.Mar 24 2018, 3:45 PM
kib marked 2 inline comments as done.

Mark' notes.

This revision now requires review to proceed.Mar 24 2018, 4:01 PM
markj added inline comments.
sys/vm/vm_fault.c
1529

There should be a comma after i.e.

I would remove the comma after "sleep."

1530

"which means we must not call vm_fault_hold()"?

1532

"too wide a code area"

This revision is now accepted and ready to land.Mar 24 2018, 6:18 PM
kib marked 3 inline comments as done.

Correct grammar.

This revision now requires review to proceed.Mar 24 2018, 6:28 PM
This revision was not accepted when it landed; it landed in state Needs Review.Mar 26 2018, 4:31 PM
This revision was automatically updated to reflect the committed changes.