Page MenuHomeFreeBSD

uma: Avoid allocating buckets with the cross-domain lock held
ClosedPublic

Authored by markj on Nov 23 2020, 2:33 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 20 2023, 7:40 AM
Unknown Object (File)
Jul 13 2023, 5:19 PM
Unknown Object (File)
Jul 9 2023, 5:22 PM
Unknown Object (File)
Jul 9 2023, 5:22 PM
Unknown Object (File)
Jul 9 2023, 5:21 PM
Unknown Object (File)
Jul 5 2023, 3:44 AM
Unknown Object (File)
Jun 16 2023, 3:33 AM
Unknown Object (File)
Jun 3 2023, 8:21 AM
Subscribers

Details

Summary

Allocation of a bucket can trigger a cross-domain free in the bucket
zone, e.g., if the per-CPU alloc bucket is empty, we free it and get
migrated to a remote domain. I believe this can lead to deadlocks,
since a bucket zone may allocate buckets from itself, or a pair of
bucket zones could be allocating from each other.

Fix the problem by dropping the cross-domain lock before allocating a
new bucket and handling refill races. I added a list of empty buckets
to ensure that we can make forward progress.

Diff Detail

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

Event Timeline

markj requested review of this revision.Nov 23 2020, 2:33 PM
markj created this revision.
This revision was not accepted when it landed; it landed in state Needs Review.Nov 30 2020, 4:19 PM
This revision was automatically updated to reflect the committed changes.