UAC开发调试笔记
+ -

USB-UAC麦克风音频数据传输USBD_STATUS_ISOCH_REQUEST_FAILED/USTSU状态C0000B00分析

2024-01-31 66 0

今天,同事突然说麦克风出声问题了,插拔硬件可以恢复。让协助定位分析一下问题。
首先本人通过音频控制面板看到,当麦克风打开时,使用麦克风采集有声音的环境的声音,指定设备的音频控制面板的能量条无任何的波动。

本图似为效果演示,实际并非本设备
能量条

所以本人初步定位,音频设备无法读取到数据引起的。

无能量条一般有以下几种情况:

  • 设备无数据
  • 采集的数据为静音数据或PCM数据太小,能量条的跳动被忽略。
  • 设备被静音。这种情况本人也经常遇到过,就是把麦克风的级别静音了。
    级别静音

为了确认是否无数据,使用了音频采集软件AudCity来录制,提示录制失败。所以几乎可确定是没有数据引起的。

为了进一步验证问题所在,采用了BUSHOUND抓包工具来抓包,经过了大量的测试,终于复现。
BUSHOUND抓到的数据:

  • IRP状态码为:STATUS_SUCCESS/0xC0000001
  • URB状态码为:USBD_STATUS_ISOCH_REQUEST_FAILED/0xC0000B00

关于IRP的分析这里本人不再说明,本身就是与windows驱协开发相关。这里我们重点关URB的状态码,这是可以通过BUSHOUND直接显示出来的.只要我们在BUSHOUND配置中选中USTS状态即可抓取到:
USTS状态
当错误时,可以看到类似这样的示例,这里以bad pipe handle错误信息配置演示:
bad pipe handle

言归正转,当URB的USTS状态码为USBD_STATUS_ISOCH_REQUEST_FAILED/0xC0000B00,该错误码的解释如下:

The host controller returns this error whenever all packets in an isochronous transfer complete with an error.

翻译过来说是USB主机控制器返回的同步传输中的URB中所有的数据包返回一个错误。
其实到这里,从操作系统的层面来讲,这已经是我们可以探究的极限了,但这远远还不能是我们极限。
我们知道,一个USB设备的URB请求包是发给其总线设备PDO的,该PDO一般由其总线驱动程序USB集线器创建,可能经过多层的USB集线器转发后,最终到达USB主机控制器这里,该设备是一个PCI/e设备。通过大概了解XP相关USB主机控制器及结合USBD_STATUS_ISOCH_REQUEST_FAILED,这里应为未收到相关的数据引起的。

实际任意一URB到USB主机控制器这一块,都是通过主机控制器对应的请求接口实现的。该请求接口的返回状态USB_MINIPORT_STATUS表示了URB的执行结果。对于同步传输,执行的宏为MP_SubmitIsoTransfer。

#define MP_SubmitIsoTransfer(de, ep, t, mpStatus) \
    {\
    KIRQL irql;\
    USBPORT_ASSERT((de)->Fdo.MiniportDriver->\
        RegistrationPacket.MINIPORT_SubmitIsoTransfer != NULL); \
    USBPORT_AcquireSpinLock((de)->HcFdoDeviceObject, &(de)->Fdo.CoreFunctionSpin, &irql);\
    (mpStatus) = \
        (de)->Fdo.MiniportDriver->RegistrationPacket.MINIPORT_SubmitIsoTransfer(\
                               (de)->Fdo.MiniportDeviceData,\
                               &(ep)->MiniportEndpointData[0],\
                               &(t)->Tp,\
                               (t)->MiniportContext,\
                               (t)->IsoTransfer);\
    USBPORT_ReleaseSpinLock((de)->HcFdoDeviceObject, &(de)->Fdo.CoreFunctionSpin, irql);\
    }

对于同步传输,执行的结果有:

  • USBMP_STATUS_SUCCESS
  • USBMP_STATUS_BUSY
  • 其它,使用USBPORT_ErrorCompleteIsoTransfer函数标识为USBD_STATUS_ISOCH_REQUEST_FAILED并返回.

到这里,其实只要再分析MINIPORT_SubmitIsoTransfer的函数即可。但这里再研究下去,感觉意义不是很大。不如从USB总线分析仪的角度来抓包分析。

USB总线分析仪这里使用的是南京沁恒USB总线分析仪-USB2.0-Monitor 来抓包。

当前向沁恒客服报暗号:USB中文网9折优惠,可享受沁恒USB总线分析仪9折优惠。数量有限,早到早得。

抓包的结果如下图示:
同步传输

同步传输

可以看到,当同步传输过程中,突然混入了一些控制请求,最终导致后面的同步传输IN令牌包后无DATA0数据引起的主机读不到数据。

HID人机交互QQ群:564808376    UAC音频QQ群:218581009    UVC相机QQ群:331552032    BOT&UASP大容量存储QQ群:258159197    STC-USB单片机QQ群:315457461    USB技术交流QQ群2:580684376    USB技术交流QQ群:952873936   

0 篇笔记 写笔记

UVC 等时传输中的URB_ISOCH_TRANSFER
通过UVC规范可知,视频图像数据的读取可使用两种端点传输方式,分别为:BULK 块/批量传输方式ISO 等时/同步传输方式在Windows内核中,USB数据的读取是通过URB来进行传输的,其结构体是一个大大的共用体,根据数据传输的方式对应其不同的结构体,其内容如下:typedef _Struct_s......
UVC等时传输中的dwMaxPayloadTransferSize
UVC的视频流接口控制请求的数据大小可为26字节,34字节和48字节,其分别对应的是UVC的1.0,1,1和UVC1.5版本。在其整个视频流控制接口参数偏移地址22处的字段为一4字节的dwMaxPayloadTransferSize,根据其字段解释为“指定设备在单个有效负载传输中可以传输或接收的最大......
USB 等时/同步传输、块传输与转换设置在UVC摄像头驱动中的探讨
最近在Windows10 x64环境下,开发了一个虚拟UVC摄像头驱动。确切的来说这不是摄像头驱动,而是一个虚拟USB总线驱动。使用该虚拟总线驱动使用应用软件通过IOCTL控制总线子设备的创建与卸载。框架设计驱动安装完成后,是一个单纯的USB虚拟总线。应用软件通过发送自定义IOCTL码IOCTL......
USB 同步/等时传输方式
USB协议规定了四种传输类型:控制传输、批量传输、同步传输、中断传输。等时传输也有“同步传输”的叫法,一般用于要求数据连续、实时且数据量大的场合,其对传输延时十分敏感,类似用于USB摄像设备,USB语音设备等等。同步事务没有握手包。当一个同步传输中有多个事务时,最后一个事务之前的事务的数据长......
USB超高速 同步传输
正如USB2.0一样,超速同步传输类型是用来支持想要能容忍错误,周期性的轮询服务的传输流。超速跟USB2.0一样不发送起始帧,但是时序信息要通过同步时间戳包(ITP)被发送给设备。这个规格的协议层章详细描述了用来完成同步传输的包,总线事务和事务处理流程。也描述了怎么样传送时序信息给设备。超速同步传输......
基于UVC规范的USB摄像头数据传输模式的总结
根据UVC(USB VIDEO CLASS)规范,UVC视频数据传输方式支持:同步传输即ISO传输批量传输即BULK传输但是不同的操作系统对UVC规范的支持不一定是全量支持的:Windows操作系统对于windows操作系统,对UVC版本的支持情况如下:UVC 版本Windows ......
手动分析使用BUSHOUND抓取同步传输的URB
BUSHOUND大家太熟了,使用它来进行数据抓包那不太太方便。但在BUSHOUND的抓取配置项中,有一个叫了URB的东西,我相信大家都没有选中过,因为一般来说,对WINDOWS USB驱动开发人员来说都不一定有用,更何况大家也只是用来抓取一下几个数据的输入输出,更没有必要进行USB的分析了。本人今天......
USB 同步传输端点的数据包PID序列及额外传输端点大小
对于同步传输:如果输入端点提供的负载数据小于端点描述符指定的最大负载数据,则主机端将不再该端点提供进一步的输入事务。这是因为所对USB设备来说,所有的数据传输都是由主机发起的。对于数据输入IN事务,虽然数据的传输方向为设备端到主机,但是该事务却是由主机发起。由于设备的输入端点提供的负载数据小于该......
USB摄像头同步传输的完成后URB参数
这几天不是闲来无事,一个工作的任务就是对手中一个USB摄像头进行驱动开发,并进行视频格式的转换。通过分析该USB摄像头可知,其采用的是同步传输,所以本人在开发的驱动中,使用同步的URB进行下发请求数据,然后在完成例程中获取数据。同步传输的URB本人在 手动分析使用BUSHOUND抓取同步传输的URB......
UAC麦克风同步传输的URB分析
之前写过同步传输的UVC摄像头的URB,文章名称为:手动分析使用BUSHOUND抓取同步传输的URB 。今天恰好手中有一个UVC麦克风,所以也拿来分析。也许和之前的文章有所重复,但是因为侧重点的不同,也许会有意想不到的小收获取。言归正转,我们知道,在UAC音频规范中,数据的传输不像UVC摄像头那样,......
USB摄像头同步传输H264遇到的花屏问题
以往拿到的摄像头数据传输都是批量传输,本人也只在音频驱动的开发中使用了同步传输。这次突然拿到一个摄像头,数据采用的是同步传输,本以为很简单的代码移植,却没有想到还是遇到了一个坑,自己花费了大力气来排查,在这期间自己也看了大量的资料,今天在这里做一个简单的总结。以前的摄像头拿到的USB摄像头如批量传......
USB2.0 同步传输数据包PID序列
同步传输方式分为全速模式和高速模式,低速模式不存在同步传输。全速传输模式下的数据包PID序列全速模式下的同步传输数据方式只使用DATA0包,因此接收方在接收数据时只会收到DATA0数据包。高速传输模式下的数据包PID序列高速模式下的数据包序列根据一个微帧中的事务个数不同,采用不同的数据包序列,使......
UAC音频设备的同步传输(同步、自适应、异步)模式区分
USB定义了四种数据传输,分别为控制传输,中断传输、批量传输和同步传输。其中同步传输按端点的配置可分为同步方式,自适应方式和异步方式。这是通过端点描述符的bEndpointType的bit3-2的值来进行配置的。bEndpointType的bit3-2传输方式00无同步0......
USB2.0低速、全速、高速模式四种传输模式速宽对比
USB 数据传输通过事务来实现。事务在帧的主机控制时间间隔内进行。事务的长度和频率取决于端点使用的传输类型。可以在一个帧中发送的传输类型和帧长度由 USB 的指定速度定义。低速模式下控制传输、中断传输、批量传输、同步传输对比低速帧速率为1ms传输类型最大传输长度每帧的传输次数最大理......
USB传输模式选择及各传输特性对比
通用串行总线 (USB) 传输类型是指主机和设备端点之间使用的通信模式。传输类型决定了用于与端点通信的事务的频率和长度。传输类型还可以分配一个循环冗余校验和 (CRC),以对每个传输的数据包进行验证。传输类型由设备设置,并在枚举过程中与主机通信。USB分为四种传输模式,分别为中断传输模式,控制传输......
关注公众号
取消
感谢您的支持,我会继续努力的!
扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

您的支持,是我们前进的动力!