记一次UAC无法使用的bug
现象
最近遇到一个BUG,一个USB摄像头自带的MIC没法在Linux下使用。
记录下UAC相关排查过程
分析
查看驱动加载及节点
使用lsusb可以看到,该UAC的设备已经加载对应通用驱动snd-usb-audio:
/: Bus 01.Port 1: Dev 1, Class=root_hub, Driver=xhci_hcd/4p, 480M
|__ Port 1: Dev 2, If 0, Class=Hub, Driver=hub/4p, 480M
|__ Port 4: Dev 4, If 0, Class=Hub, Driver=hub/4p, 480M
|__ Port 1: Dev 6, If 0, Class=Mass Storage, Driver=usb-storage, 480M
|__ Port 2: Dev 8, If 0, Class=Wireless, Driver=btusb, 12M
|__ Port 2: Dev 8, If 1, Class=Wireless, Driver=btusb, 12M
|__ Port 4: Dev 10, If 0, Class=Vendor Specific Class, Driver=, 12M
|__ Port 2: Dev 22, If 0, Class=Hub, Driver=hub/7p, 480M
|__ Port 4: Dev 25, If 0, Class=Human Interface Device, Driver=, 12M
|__ Port 2: Dev 23, If 3, Class=Audio, Driver=snd-usb-audio, 480M
|__ Port 2: Dev 23, If 1, Class=Video, Driver=uvcvideo, 480M
|__ Port 2: Dev 23, If 2, Class=Audio, Driver=snd-usb-audio, 480M
|__ Port 2: Dev 23, If 0, Class=Video, Driver=uvcvideo, 480M
但是在/dev/snd/下未生成对应的采集节点,只有控制器节点
查看相关日志
从dmesg日志中可以看到有关UAC报错:
LOG
[ 591.789645] usb 1-2.2: 3:1 : invalid UAC_FORMAT_TYPE desc
......
本文记录了一次在Linux环境下USB摄像头的麦克风(UAC)无法使用的问题。通过`lsusb`命令发现设备已加载snd-usb-audio驱动,但`/dev/snd/`目录下未生成采集节点,并在dmesg日志中发现UAC_FORMAT_TYPE描述错误。博客详细描述了驱动加载情况和排查步骤。
https://notes.z-dd.online/2022/05/10/%E8%AE%B0%E4%B8%80%E6%AC%A1UAC%E6%97%A0%E6%B3%95%E4%BD%BF%E7%94%A8%E7%9A%84bug/

4150

被折叠的 条评论
为什么被折叠?



