Page MenuHomeFreeBSD

vm_fault: update page pred after lock rel/acq in copy_entry
ClosedPublic

Authored by dougm on Mar 26 2025, 4:27 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Oct 7, 2:48 PM
Unknown Object (File)
Fri, Oct 3, 12:40 AM
Unknown Object (File)
Tue, Sep 30, 9:17 PM
Unknown Object (File)
Mon, Sep 29, 1:25 AM
Unknown Object (File)
Sun, Sep 28, 3:22 PM
Unknown Object (File)
Fri, Sep 26, 11:14 PM
Unknown Object (File)
Thu, Sep 25, 8:40 PM
Unknown Object (File)
Thu, Sep 25, 1:29 PM
Subscribers

Details

Summary

In vm_fault_copy_entry, variable 'mpred' is invalided as the predecessor of the next page to be inserted when an allocation failure leads to lock release and reacquisition. Recompute it in that case.

Addresses a problem identified by @markj in D49103.

Diff Detail

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

Event Timeline

dougm requested review of this revision.Mar 26 2025, 4:27 PM
dougm created this revision.

Sorry, that was all to complicated. Simplify.

Update the correct variable.

Could you please include a Fixes tag in the commit log?

This revision is now accepted and ready to land.Mar 27 2025, 8:58 AM
This revision was automatically updated to reflect the committed changes.
sys/vm/vm_fault.c
2211

Sorry I didn't catch this - this should be dst_object, not src_object.