Page MenuHomeFreeBSD

snd_uaudio: Do not use pcm_channel->lock to protect uaudio_chan
ClosedPublic

Authored by christos on Dec 6 2025, 2:52 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, May 21, 9:36 PM
Unknown Object (File)
Thu, May 21, 12:42 AM
Unknown Object (File)
Thu, May 21, 12:30 AM
Unknown Object (File)
Tue, May 19, 12:08 PM
Unknown Object (File)
Wed, May 13, 2:51 PM
Unknown Object (File)
Wed, May 13, 8:52 AM
Unknown Object (File)
Wed, Apr 29, 5:04 AM
Unknown Object (File)
Wed, Apr 29, 1:45 AM
Subscribers

Details

Summary

This is a layering violation, but it also makes the control flow
confusing; snd_uaudio(4) should have its own lock to protect its
structures.

Fixes: 5cc34a83e1 ("Revert "sound: Merge chn_intr() with chn_intr_locked()"")
Sponsored by: The FreeBSD Foundation
MFC after: 1 week

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 69100
Build 65983: arc lint + arc unit

Event Timeline

What problem does this fix?

What problem does this fix?

From the commit referenced in "Fixes" (5cc34a83e1):

It turns out that snd_uaudio(4) uses sound(4)'s channel lock for its USB
transfer callbacks. I will try to address this at some point, because
this is layering violation, but for now we need to revert the commit, as
it causes a lock recursion panic with USB audio devices.

What problem does this fix?

From the commit referenced in "Fixes" (5cc34a83e1):

It turns out that snd_uaudio(4) uses sound(4)'s channel lock for its USB
transfer callbacks. I will try to address this at some point, because
this is layering violation, but for now we need to revert the commit, as
it causes a lock recursion panic with USB audio devices.

Bump.

This revision was not accepted when it landed; it landed in state Needs Review.Jan 2 2026, 5:21 PM
This revision was automatically updated to reflect the committed changes.