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)
Wed, Dec 18, 7:28 PM
Unknown Object (File)
Nov 23 2024, 9:50 AM
Unknown Object (File)
Nov 20 2024, 5:28 PM
Unknown Object (File)
Nov 20 2024, 1:02 PM
Unknown Object (File)
Nov 14 2024, 8:37 AM
Unknown Object (File)
Nov 11 2024, 10:14 PM
Unknown Object (File)
Nov 11 2024, 5:59 PM
Unknown Object (File)
Nov 11 2024, 5:30 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

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 25036
Build 23750: arc lint + arc unit

Event Timeline

sys/vm/vm_page.c
1485

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

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.