Page MenuHomeFreeBSD

libthr pshared: correct a bug in allocation
ClosedPublic

Authored by kib on Feb 1 2023, 8:18 PM.
Tags
None
Referenced Files
F106936924: D38345.diff
Tue, Jan 7, 6:11 PM
Unknown Object (File)
Sun, Jan 5, 10:48 PM
Unknown Object (File)
Wed, Dec 11, 4:55 PM
Unknown Object (File)
Nov 29 2024, 4:30 PM
Unknown Object (File)
Nov 28 2024, 4:16 PM
Unknown Object (File)
Nov 28 2024, 6:40 AM
Unknown Object (File)
Nov 28 2024, 6:40 AM
Unknown Object (File)
Nov 28 2024, 6:40 AM
Subscribers

Details

Summary
When __thr_pshared_offpage() is called for allocation, it must not use
the cached offpage for the key.  Instead, the cached offpage must be
unmapped and removed from the cache, if any.

It is legitimate for the user code to unmap the shared lock object without
destroying it, and then mapping something over the freed VA to carry
another shared lock.  In this case the cached offpage must be un-cached.

PR:     269277

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

kib requested review of this revision.Feb 1 2023, 8:18 PM

Add pshared_destroy() helper (a separate commit).

This revision is now accepted and ready to land.Feb 1 2023, 9:56 PM