OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3229|回复: 1

USB虚拟串口发送缓存释放时刻问题

[复制链接]

17

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
170
金钱
170
注册时间
2019-2-18
在线时间
42 小时
发表于 2019-7-26 08:44:52 | 显示全部楼层 |阅读模式
10金钱
我用Cubemx生成VCP程序,通过电脑串口发出1byte的cmd到STM32, 进入CDC_Receive_FS的RD_BUF分支后,通过USB将rd_buf中的2048个字节发送到电脑,电脑上用串口软件显示数据内容。测试过程中发现两个异常:1. 需要输入两次cmd,第一次输入cmd后串口无数据显示,第二次输入cmd后串口一次显示两个2048字节的内容;
2. 2048字节的头部4个字节的内容被修改为00 00 00 00;
不知道有没有人使用虚拟串口时出现过类似的现象,或者实现类似功能时用其他方法?

补充信息:
1. Heap和Stack Size都设置的很大,均为0x2000;
2. 针对问题2,我通过断点方式定位,发现在USB发送结束后的free(rd_buf)命令时首4字节被修改为00 00 00 00,但是此时CDC_Transmit_FS()函数已经返回成功,发送数据缓存应该可以被释放吧??

  1. static int8_t CDC_Receive_FS(uint8_t* Buf, uint32_t *Len)
  2. {
  3.   /* USER CODE BEGIN 6 */
  4.   uint8_t cmd;
  5.   uint16_t para1, data;
  6.   uint16_t *rd_buf;
  7.   uint32_t rd_bytes;

  8.   cmd = *Buf;

  9.   switch (cmd) {
  10.   case RD_BUF:
  11.     rd_bytes  = 2048;
  12.     rd_buf    = (uint16_t *)malloc(rd_bytes);
  13.     memcpy(rd_buf, (uint16_t *)FPGA_DAT_ADDR, rd_bytes);
  14.    
  15.     if (CDC_Transmit_FS((uint8_t *)rd_buf, rd_bytes) == USBD_BUSY) {
  16.       free(rd_buf);
  17.       rd_buf = NULL;
  18.       return USBD_BUSY;
  19.     }
  20.     free(rd_buf);         ------这里rd buf首4字节被修改为00 00 00 00
  21.     rd_buf = NULL;
  22.     break;

  23.   default:
  24.     break;
  25.   }

  26.   USBD_CDC_SetRxBuffer(&hUsbDeviceFS, &Buf[0]);
  27.   USBD_CDC_ReceivePacket(&hUsbDeviceFS);
  28.   return (USBD_OK);
  29.   /* USER CODE END 6 */
  30. }
复制代码




正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

18

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2019-7-15
在线时间
11 小时
发表于 2019-7-26 08:57:57 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-6 22:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表