Page MenuHomeFreeBSD

Use vm_page_unwire_noq() instead of vm_page_unwire(PQ_NONE).
ClosedPublic

Authored by markj on May 30 2019, 4:36 PM.
Tags
None
Referenced Files
F152447119: D20470.id59490.diff
Wed, Apr 15, 12:46 AM
F152407411: D20470.id.diff
Tue, Apr 14, 6:49 PM
F152384077: D20470.id59490.diff
Tue, Apr 14, 2:44 PM
Unknown Object (File)
Tue, Apr 14, 5:22 AM
Unknown Object (File)
Sun, Apr 5, 6:18 PM
Unknown Object (File)
Thu, Apr 2, 5:32 AM
Unknown Object (File)
Wed, Mar 18, 4:00 AM
Unknown Object (File)
Mar 10 2026, 12:48 PM
Subscribers

Details

Summary

For managed pages, these two calls are not equivalent:
vm_page_unwire(PQ_NONE) will remove the page from its page queue, if
any, while vm_page_unwire_noq() leaves it alone. However, the existing
callers of vm_page_unwire(PQ_NONE) are applying it to fictitious or
unmanaged pages, so there should be no functional impact.

Diff Detail

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

Event Timeline

kib added inline comments.
sys/vm/vm_glue.c
233 ↗(On Diff #58077)

Just a note that the page is managed. It is because it is freed immediately after, we can use vm_page_unwire_noq().

This revision is now accepted and ready to land.May 30 2019, 5:27 PM
sys/vm/vm_glue.c
233 ↗(On Diff #58077)

This call was added in D19247, so it will not be committed with the rest of this diff.

This revision was automatically updated to reflect the committed changes.