<i class="pstatus"> 本帖最后由 shuen729 于 2018-4-28 11:57 编辑 </i><br>
<br><p>
今天调代码的时候,遇到这个问题,USART在DMA模式下,进DMA发送完成中断后发现数据其实USART那边还没有真正的完成发送,论坛里面搜“DMA 发送完成”有一篇帖子,但是很遗憾不让看,要密码。</p><br><p>
然后不得已,看参考手册,找到下面的时序图</p><br>
<p><img src="https://www.xiaopingtou.net/data/attach/1912/s7logd01cd1ixh2sli8xicabop2ykx9w.jpg" lazyloadthumb="1" border="0" alt=""></p><br><p>
然后在中断里面改了下,先把DMA禁止掉,然后等待TC置位,TC置位就可以确认所有数据已经送出。</p><br><p>
void DMA1_Channel7_IRQHandler(void)</p><br><p>
{</p><br><p>
if(SET==DMA_GetITStatus(DMA1_IT_TC7))</p><br><p>
{</p><br><p>
DMA_ClearITPendingBit(DMA1_IT_TC7);</p><br><p>
DMA_Cmd(DMA_USART2_TX, DISABLE);</p><br><p>
DMA_USART2_TX->CNDTR = 0;</p><br><p>
while(RESET == USART_GetFlagStatus(USART2,USART_FLAG_TC))</p><br><p>
{</p><br><p>
USART_ClearFlag(USART2,USART_FLAG_TC);</p><br><p>
}</p><br><p>
Usart2_TR_Sw(RS485_RX);</p><br><p>
return ;</p><br><p>
}</p><br><p>
}</p>
<br>
<p><img src="https://image.xiaopingtou.net/data/attach/191214/zbahRxQ9.png" alt="135857g95xy0xgxfpkfxmm"><br></p><p><br></p>
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
DMA接收,我是一直开启的。DMA使用循环队列功能,只负责把DR寄存器的数据往内存中写,后台直接处理数据。这样接收中断都不用了,在高速通用的时候很有用。
485半双工的定要注意切换,保险起见,准备发送数据时,把串口接收使能关闭。TCIE中断触发后再打开接收使能。 否则在DMA模式下更容易出现内存溢出
一个可怕的事情是非内存溢出,而是DMA模式下会把矩阵总线搞乱,真是学习了
全双工随便搞,反正接收和发送是俩个独立的影子寄存器
=============
为了不跑出地址,建议接收DMA开启循环模式。
现在1ms 收发无压力
一周热门 更多>