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
Unknown Object (File)
Thu, May 14, 6:08 AM
Unknown Object (File)
Wed, May 13, 5:22 PM
Unknown Object (File)
Wed, May 13, 4:34 PM
Unknown Object (File)
Wed, May 13, 4:34 PM
Unknown Object (File)
Tue, May 12, 1:34 AM
Unknown Object (File)
Sun, May 10, 11:09 PM
Unknown Object (File)
Sat, May 9, 10:25 PM
Unknown Object (File)
Sat, May 9, 10:19 PM
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!