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
Unknown Object (File)
Sat, May 16, 1:07 PM
Unknown Object (File)
Sun, May 3, 7:11 PM
Unknown Object (File)
Sun, May 3, 12:37 AM
Unknown Object (File)
Sat, May 2, 11:04 PM
Unknown Object (File)
Tue, Apr 21, 11:23 PM
Unknown Object (File)
Mon, Apr 20, 10:24 AM
Unknown Object (File)
Apr 15 2026, 12:46 AM
Unknown Object (File)
Apr 14 2026, 6:49 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.