初级会员

- 积分
- 170
- 金钱
- 170
- 注册时间
- 2019-2-18
- 在线时间
- 42 小时
|
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()函数已经返回成功,发送数据缓存应该可以被释放吧??
- static int8_t CDC_Receive_FS(uint8_t* Buf, uint32_t *Len)
- {
- /* USER CODE BEGIN 6 */
- uint8_t cmd;
- uint16_t para1, data;
- uint16_t *rd_buf;
- uint32_t rd_bytes;
- cmd = *Buf;
- switch (cmd) {
- case RD_BUF:
- rd_bytes = 2048;
- rd_buf = (uint16_t *)malloc(rd_bytes);
- memcpy(rd_buf, (uint16_t *)FPGA_DAT_ADDR, rd_bytes);
-
- if (CDC_Transmit_FS((uint8_t *)rd_buf, rd_bytes) == USBD_BUSY) {
- free(rd_buf);
- rd_buf = NULL;
- return USBD_BUSY;
- }
- free(rd_buf); ------这里rd buf首4字节被修改为00 00 00 00
- rd_buf = NULL;
- break;
- default:
- break;
- }
- USBD_CDC_SetRxBuffer(&hUsbDeviceFS, &Buf[0]);
- USBD_CDC_ReceivePacket(&hUsbDeviceFS);
- return (USBD_OK);
- /* USER CODE END 6 */
- }
复制代码
|
|