Page MenuHomeFreeBSD

vm_fault: handle KERN_PROTECTION_FAILURE
ClosedPublic

Authored by kib on Mar 27 2021, 11:13 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jul 9, 9:59 AM
Unknown Object (File)
Fri, Jul 4, 7:59 AM
Unknown Object (File)
Sun, Jun 29, 12:53 PM
Unknown Object (File)
Sun, Jun 22, 4:37 AM
Unknown Object (File)
Mon, Jun 16, 8:23 PM
Unknown Object (File)
Mon, Jun 16, 10:30 AM
Unknown Object (File)
Jun 6 2025, 10:29 AM
Unknown Object (File)
May 23 2025, 11:10 PM
Subscribers
None

Details

Summary

pmap_enter(PMAP_ENTER_LARGEPAGE) may return KERN_PROTECTION_FAILURE due to PKRU inconsistency. Handle it in the call place from vm_fault_populate(), and in places which decode errors from vm_fault_populate()/vm_fault_allocate().

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

This revision is now accepted and ready to land.Mar 27 2021, 2:00 PM
markj added inline comments.
sys/vm/vm_fault.c
563

If psind == 0, we do not assert rv == KERN_SUCCESS, but it looks like we should.

sys/vm/vm_fault.c
563

Never mind, @jah fixed it in D29439.

This revision was automatically updated to reflect the committed changes.
OSZAR »