
1 问题现象 有一客户使用 STM32F405 参照 USB 标准库下的 HID+CDC 的示例代码做产品,发现在 WIN7 上使用得好好的,可放到 WIN10 上,CDC 第一次能够识别,再次拔插后就不能再识别,且此后无论插拔多少次都无法再识别,除非再次上电,又会重复上述现象,只有板子上电后第一次才能正确被识别,后续均不行。 2 问题分析 客户使用 ST 官方示例代码 STM32_USB-Host Device_Lib_V2.2.0\Project\USB_Device_Examples\Composite_Examples\CDC_HID_Composite(下载页面: http://www.stmicroelectronics.com.cn/content/st_com/en/products/embedded-software/mcus-embedded-software/stm32- embedded-software/stm32-standard-peripheral-library-expansion/stsw-stm32046.html)。当我尝试使用此示例代码重现客户所遇到的问题时,发现此代码在 WIN7 运行 OK,但与客户不同的是,我测试到的情况是在 WIN10 下 CDC 一次都无法识别,HID 却一直可以识别。 下面来分析下问题,既然 WIN7 下 HID 和 CDC 都能正常识别,放在 WIN10 上才不正常,那么初步可以判断,此问题应该与 WIN10 操作系统的 USB 主机驱动实现有关。 通过 USB 分析仪分析客户代码在 WIN10 下 USB 枚举异常的数据通讯: ![]() Figure 1 第一次 USB 枚举过程上图是客户代码第一次正常枚举的通讯数据,从中可以看出,WIN10 USB 主机在正常获取 HID 报告描述符后,紧接着会获取虚拟串口状态和设置波特率,这样就正常枚举结束了。接着继续采集异常 USB 枚举过程进行对比: ![]() 上图是 WIN10 下异常枚举过程。由上图可以看出,WIN10 系统上 USB 主机在获取到设备描述符和配置描述符后直接将设备挂起了。很明显,WIN10 操作系统的 USB 主机驱动实现对设备描述符或者配置描述符的内容并不认可,才会导致无法识别HID+CDC 复合设备。 ![]() 于是,我们首先检查客户代码的设备描述符:Figure 3 获取的设备描述符复合设备的 class,subclass,protocol 必须为 0xef,0x02,0x01,这里 VID=0x0483,PID=0x3256(Cube 库下 为 0x5740,但这个不重要),接下来看配置描述符: ![]() Figure 4 win10 不能识别的配置描述符由此可见,客户的描述符是 HID interface + IAD + CDC interfaces 结构。对于 WIN7,这种结构可以识别,但对于 WIN10,这种结构 WIN10 未必能够兼容,我们尝试在 HID interface 外部加上一层 IAD 结构,使其成为 IAD1 + HID interface + IAD2 + CDC interfaces 结构,此时客户的问题得以解决,在 WIN10 也可以正确识别了,修改后的描述符结构如下: ![]() Figure 5 win10 能够正确识别的配置描述符结束本篇实战经验之前,让我们再次回顾 IAD 的概念: IAD(Interface Association Descriptor),为 USB 设备定义了一个标准来表述捆绑在一个逻辑功能(比如这里的 CDC 虚拟串口)上的多个接口的聚合的方法。USB 协会分配了一个设备级别的类编码(即图 3 中 0xEF),使用 IAD 的设备必须使用它(如图 3 的设备描述符);这样可以很容易在设备枚举时就能识别出采用了 IAD 的设备。IAD 描述符通常放在它所要捆绑的多个接口的接口描述符之前。 3 结论 在 WIN10 系统中,建议复合设备每个逻辑功能的接口描述符前都搭载一个 IAD 描述符,不论这个逻辑功能是单个接口描述符完成(比如这里的 HID 功能)还是要由多个接口描述符完成(比如这里的 CDC 功能)。 完整版请查看:附件 |
HID_CDC复合设备在WIN10的识别问题_V1.pdf
下载412.46 KB, 下载次数: 0
STM32 GUI LTDC 最大像素时钟评估方法
【2025·STM32峰会】GUI解决方案实训分享1-对LVGL咖啡机例程的牛刀小试以及问题排查
OpenBLT移植到STM32F405开发板
为什么要先开启STM32外设时钟?
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【经验分享】STM32实例-RTC实时时钟实验④-获取RTC时间函数与中断服务函数
STM32 以太网 MAC Loopback 的实现
STM32功能安全设计包,助力产品功能安全认证
基于STM32启动过程startup_xxxx.s文件经验分享
HRTIM 指南