Page MenuHomeFreeBSD

kstack: Fix iterator usage in vm_thread_stack_create()
ClosedPublic

Authored by markj on Oct 8 2025, 2:03 PM.
Tags
None
Referenced Files
F150622163: D52982.diff
Thu, Apr 2, 9:36 PM
Unknown Object (File)
Sat, Mar 28, 8:54 PM
Unknown Object (File)
Sat, Mar 21, 8:34 PM
Unknown Object (File)
Sun, Mar 15, 10:01 PM
Unknown Object (File)
Sun, Mar 15, 9:42 PM
Unknown Object (File)
Wed, Mar 11, 8:22 AM
Unknown Object (File)
Wed, Mar 11, 7:24 AM
Unknown Object (File)
Wed, Mar 11, 3:52 AM
Subscribers

Details

Summary

After commit 7a79d0669761 we no longer hold the VM object lock when
initializing or advancing the domainset iterator in
vm_thread_stack_create().

We could lift the lock out of vm_thread_stack_back() but that poses
complications since we cannot allocate KVA with a VM object lock held.

Instead of overridding the object's iterator, just borrow that of the
current thread. Kernel stacks are basically always allocated with a
DOMAINSET_POLICY_PREFER policy, so it's not very important to maintain a
global iterator for round-robin allocation.

As a part of this, fix up flag handling: make sure we handle
M_NOWAIT/M_WAITOK from the caller. Delete a comment in vm_thread_new()
which refers to a non-existent consideration (stack swapping has been
removed). I suspect vm_thread_new() can use M_WAITOK but opted not to
make that change here.

Fixes: 7a79d0669761 ("vm: improve kstack_object pindex calculation to avoid pindex holes")

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

markj requested review of this revision.Oct 8 2025, 2:03 PM
This revision is now accepted and ready to land.Oct 8 2025, 4:19 PM

Please add Reported by: olce at commit, thanks!