Page MenuHomeFreeBSD

Handle trashed queue pointers in vm_page_acquire_unlocked().
ClosedPublic

Authored by markj on Apr 17 2020, 5:15 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Dec 24, 5:08 PM
Unknown Object (File)
Wed, Dec 24, 12:41 PM
Unknown Object (File)
Tue, Dec 23, 1:33 PM
Unknown Object (File)
Mon, Dec 8, 12:15 AM
Unknown Object (File)
Nov 27 2025, 7:23 AM
Unknown Object (File)
Nov 25 2025, 4:32 PM
Unknown Object (File)
Nov 21 2025, 12:53 AM
Unknown Object (File)
Nov 21 2025, 12:52 AM
Subscribers

Details

Summary

vm_page_acquire_unlocked() relies heavily on type-stability of vm_page
structures, and assumes that the listq linkage pointers always point to
a vm_page or are NULL. QUEUE_MACRO_DEBUG_TRASH breaks that assumption.

Reported by: pho

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 30562
Build 28307: arc lint + arc unit

Event Timeline

markj added reviewers: kib, alc, jeff.

Isn't it too fragile still ? What if prev->q reused for something yet again ?

This revision is now accepted and ready to land.Apr 17 2020, 11:49 PM
In D24472#538433, @kib wrote:

Isn't it too fragile still ? What if prev->q reused for something yet again ?

That is handled by the subsequent checks, if I understood your question correctly.

In D24472#538433, @kib wrote:

Isn't it too fragile still ? What if prev->q reused for something yet again ?

That is handled by the subsequent checks, if I understood your question correctly.

I mean that there were attempts to reuse m->q for pages not in the object queue, and there probably would be more. I believe it is somewhat mitigated by the requirement that prev is either busy or wired, this is why I agreed with the proposed patch.