本帖最后由 12tangyang12 于 2019-5-7 06:18 编辑
情况是这样的:主控是stm32f103c8t6,72M ,串口115200 bps 接收采用DMA 方式,buf 是10字节。接收到数据后会有空闲中断 或者是 接受满中断。
DAM 采用普通单次方式接收。问题是这样:接收超过10字节数据时“1234567890ab” 首先触发了DMA完成中断,然后在中断里会把数据存入FIFO,在存的时候DMA是关闭状态,导致后面的"a"会漏掉。
最终收到的是1234567890b。请大家分析下,怎么处理
满了之后如果再来一个数据,数据放哪?MCU的处理是需要时间的。
实际上直接用FIFO(深度至少是最大帧长度的2倍),不开DMA也是可以的。接收到直接进FIFO,然后在大循环或者任务中去取FIFO中的数据
那你的思路有问题,如果你这样的话双缓冲无济于事,哪怕是三缓冲也一样,如果你不知道送来的数据一帧有多长,那么环形接受吧,dma只是节省了点频繁中断的进出,最终数据帧的解析不是靠dma的方式能完成的
那你处理的速度也跟得上才行,这种方式就不合理,101字节那你就需要设置更大的buf,不可能一包无限大的。
https://www.amobbs.com/thread-5486343-1-1.html
(出处: amoBBS 阿莫电子论坛)
看看这个帖子有用吗?
一周热门 更多>