大家都说STM32 USB的虚拟串口有问题, 只要PC端串口打开着, 然后拔掉USB, 再插上USB的时候就打不开串口, 就拔掉USB以后在PC端没有彻底关闭掉串口, 造成再插上的时候也是认为是串口已经在打开状态。 对比CH340和CP2102等 都没有这种问题, 把问题归结于ST提供的PC端虚拟串口驱动, 然后发邮件给ST咨询, ST说: 我们的驱动是没有问题的, 是串口助手的问题。 彻底失望, 人家340、2102等都没有问题, 就你有问题, 怎么把问题归结于串口助手呢, 怎么能说出这么不负责任的话呢? 我们的产品中其它问题都能解决, 就是解决不了这个问题。 失望ST官方能够正视并且尽量解决这个问题, 那真的是广大开发者的福音 |
如何用c#使用ST25R3911DISCOComm.dll来读取和写入NDEF区的数据,需要相关例程,感谢各位大佬拯救一下我啊!????
使用STM32G431做HID Keyboard与CDC符合设备,发现根本做不成,可能是ST提供的库的问题
STM32U073的usb问题。
STM32F103标准库配置的虚拟串口,设备描述符请求失败
STM32L4R9最大支持SD卡的容量是?支持SDXC 64G卡吗?
usb虚拟多个串口如何操作?
USBX在F407上创建CDC不能正常使用
stm32F407作为usb device时,PC发数据下去,为什么会收到一样的数据?
USB复合设备MSC+CDC,MSC异常影响CDC收发
STM32F407 作USB host 驱动 声卡 问题
1、USB 在串口助手打开的时候拔掉, 此时如果串口助手没有关闭刚才的com口, 重新插上USB就会出现USB端口永远被占用的情况, 只能重启电脑解决;
2、在部分“克隆版”的系统中无法安装 ST的虚拟串口驱动, 估计系统被裁剪太多了;
3、情况助手我们不是不能开发,但是就是要要求客户只能用我们的串口助手了, 并且还要安装.NET才能解决问题“1”, 而我们的原则是不对客户进行太多的要求, 尽量少安装、普通串口助手也能使用;
4、很多童鞋说“这是USB本身的问题”, 那么CH340、CP2102怎么就不存在这些问题呢?难道人家不是USB?
1. 循环法 1-256, 用Windows API一个个打开,返回不存在信息的删掉,其它保留。
这个方法很笨,但确定都是正确的。
2. 查询注册表,得到串口列表。
这个方法很快,但有时不正确(可能会多,只多不少)。
例如超级终端打开,占用了一个USB串口,你不关闭超级终端,但把USB串口强行拔掉。
这时用查询注册表的方法,得到的串口列表,仍然包括已经不存在的USB串口。
修正的方法也简单,再次使用windows API依次打开列表中的串口,发现不存在,更新下列表。
二、STM32组成的USB多路串口中设备端点号的搜索
现在我们要掌握USB转多路串口的端点号,以便清楚地了解当前使用的STM32,是用哪个串口和
外面的设备通讯的。这里我们安排的USB端点号和物理串口的对应关系如下:
MI_00 <--> USART1
MI_02 <--> USART2
MI_04 <--> USART3
STM32的多路串口对应的串口号是变化的,但3个端点号不会变。我们想要在上位机软件中找到诸如
MI_00此类的信息,就要另外想办法。
想要得到串口的具体信息,是比较麻烦的,以往程序员都采用根据设备GUID的特征进行查询,
我发现用这个方法特别不靠谱,例如上面的串口列表,就发现了错误。
端点信息的查询也是个麻烦事。参考Windows API相关的书,找到枚举设备的函数,
枚举所有存在的设备,串口相关的信息如下:
(标准端口类型)
通信端口 (COM1)
通信端口 (COM1)
\Device\00000083
ELTIMA Software
ELTIMA Virtual Serial Port (COM2->COM3)
Eltima Virtual Serial Bus
\Device\00000092
ELTIMA Software
ELTIMA Virtual Serial Port (COM3->COM2)
Eltima Virtual Serial Bus
\Device\00000093
STMicroelectronics Virtual COM Port
USB\VID_0483&PID_5740&REV_0200&MI_00
USB\Class_02&SubClass_02&Prot_01
USB\Class_02&SubClass_02&Prot_01
STMicroelectronics.
STMicroelectronics Virtual COM Port (COM70)
0000.001d.0000.001.005.000.000.000.000
\Device\0000009c
我们发现,在搜索到" STMicroelectronics Virtual COM Port "字符串时,下一行的信息是
"USB\VID_0483&PID_5740&REV_0200&MI_00",可以根据这个信息,打开注册表,枚举这个
注册表分支下键值的名称,友好名称的键值字符串是"STMicroelectronics Virtual COM Port (COM70)",
然后我们分析下这个串口友好名称里的串口号,把这个串口号和实时串口列表中的号码匹配,如果一致,
就可以确认MI_00是这个串口的端点。到此,任务完毕。
如果只是搜索到" STMicroelectronics Virtual COM Port (COM70) "字符串,则不能确认MI_00就一定
是它的端点号,因为其它USB设备也有可能使用MI_00,这里只能是根据MI_00信息打开注册表,
匹配到友好名称及端口号,才可以确认MI_00就是该USB串口实际所使用的端点。
这个功能会在以后新版本的USB Serial Tools软件中提供。
备注: USB Serial Tools 自2012年启动开发,迄今为止,一直在成长。
从机理上讲,硬件串口,不管串口线是否连接,硬件始终是于电脑相连的,是可以与电脑通信的,串口的驱动程序是一直工作的。
而USB转串口,一但USB线拨掉,该串口已经不存在系统中了,系统分配给该串口的资源,就已经被回收给系统了,打开串口时返回的句柄,已经是个废句柄了(它指向的资料已经被系统释放了)。
楼主的问题,既不是ST的问题,也不是微软的问题,USB工作机理的问题。
解决的办法是:
接收USB改变的消息,一但发生USB 设备改变,就对该消息进行判断,是不是你所打开的串口被拨出或插上了。
所以,早期编写的串口助手,并不完全适合于USB转串口这种情况。
没被折腾到蓝屏,但是串口助手软件会死掉。
如果点击关闭串口之后再拔 USB 线,则没有问题。
1.正如你说的,串口助手没反应,仍然是显示串口打开状态
2.拔掉后,不停地弹出错误窗口,关都关不掉,只能任务管理器结束
3.拔掉后,电脑卡死或者软件卡死转圈圈
4.拔掉后电脑蓝屏
5.拔掉后串口助手突然消失
ST毕竟是大厂,大厂的东西还是可以值得信赖的,还是多从自身找找问题吧。
不用的,.NET可以直接读取到串口列表的。