Page MenuHomeFreeBSD

Add a return value to vm_page_remove().
ClosedPublic

Authored by markj on Jun 25 2019, 4:02 PM.
Tags
None
Referenced Files
Unknown Object (File)
Feb 7 2024, 11:54 AM
Unknown Object (File)
Jan 25 2024, 1:47 PM
Unknown Object (File)
Jan 25 2024, 1:41 PM
Unknown Object (File)
Jan 25 2024, 1:41 PM
Unknown Object (File)
Jan 25 2024, 9:59 AM
Unknown Object (File)
Dec 20 2023, 5:59 AM
Unknown Object (File)
Dec 6 2023, 5:04 AM
Unknown Object (File)
Oct 14 2023, 5:21 PM
Subscribers

Details

Summary

This is a small piece of D20486. In that revision we count the object's
reference in the page's ref_count field, and atomically decrement that
reference and check for others.

All callers except for vm_page_free_prep() must provide a page contained
in an object, so move the m->object != NULL check out of
vm_page_remove().

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

sys/vm/vm_page.c
1485 ↗(On Diff #59010)

Before, object could have been NULL, evidently. Here, you depend on it being not NULL. Can you assert that somewhere?

sys/vm/vm_page.c
1485 ↗(On Diff #59010)

In general we don't add assertions for conditions which will unconditionally crash the kernel anyway. In particular, the VM_OBJECT_ASSERT_WLOCKED() above effectively provides the same assertion.

This revision is now accepted and ready to land.Jun 25 2019, 4:52 PM
This revision was automatically updated to reflect the committed changes.