usb做虚拟串口时与uart的一些不同

文章讨论了在使用STM32的USB进行虚拟串口通信时遇到的问题,发现使用局部变量数组作为缓冲区可能导致数据发送不完整和乱码。通过改用全局变量并控制缓存更新频率,解决了这些问题。作者推测HAL库的USB发送并非同步逐字节完成,因此对缓存管理有特殊要求。
摘要由CSDN通过智能技术生成

用usb做虚拟串口发送时,总是会出现发送的数据电脑收不到,或者收到一半,有的时候还会收到\0这些乱码,没去深入看看stm32的usb具体是怎么发送的,使用uart发送的时候,其实是一直用while死等发送标志位直到发送结束,所以数据不会出现电脑接收不到的情况。所以我猜测,是用的局部变量数组做为发送缓冲区,虽然调用了usb的发送函数,但很快啊还没等usb发送完,上一层函数执行完毕,出栈,局部变量数组的缓冲区被回收,usb此时还在发,但此时的缓冲区数据已经不可靠了,可能被另作他用了,所以出现只发了一半正常的内容后面的内容变乱码了。后面改用全局变量作为发送缓冲区,情况得以改善。

我猜测,hal库的usb发送并不是死等每一个字节都发送完成,所以使用全局变量数组作为发送缓冲区的时候,不能非常频繁的修改缓存数组的内容,否则就会出现,上一条内容前半段和下一条内容的后半段拼在一起的情况,这是因为上一条还没发完,发送区却被下一条内容覆盖了,导致两条合在一起了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值