HomeFreeBSD

mtx: Avoid nested panics on lock class mismatch assertions

Description

mtx: Avoid nested panics on lock class mismatch assertions

It is only (somewhat) safe to dereference lo_name if we know the mutex
has a specific lock class that is incorrect, not if just has "some"
incorrect lock class. In particular, in the case of memory
overwritten with 0xdeadc0de, the lock class won't match either mutex
type. However, trying to dereference lo_name via a 0xdeadc0de pointer
triggers a nested panic building the panicstr which then prevents a
crash dump.

Reviewed by: olce, kib, markj
Sponsored by: AFRL, DARPA
Differential Revision: https://reviews.freebsd.org/D49313

Details

Provenance
jhbAuthored on Mar 12 2025, 2:24 PM
Reviewer
olce
Differential Revision
D49313: mtx: Avoid nested panics on lock class mismatch assertions
Parents
rG87eaa30e9b39: depend-cleanup: Add examples for common cases
Branches
Unknown
Tags
Unknown