基于DMA控制器的UART串行通信設(shè)計
3)DMAx傳輸完成產(chǎn)生Terminal Count中斷,在其中斷服務(wù)程序中取出FIFO隊列UART_LINK_LIST_STORE_TABLE中保存的地址ADDR,將ADDR中的源地址入隊到UARTn空緩存隊列,然后將ADDR值填充到DMAx的可用空緩存FIFO隊列DMAx_LINK_LIST_FREE_TABLE中。流程如圖3所示。本文引用地址:http://www.ex-cimer.com/article/160710.htm
3.3 串行數(shù)據(jù)接收過程實現(xiàn)
UARTn的DMA數(shù)據(jù)發(fā)送過程相對于必送過程較為簡單,在配置好相應(yīng)的寄存器和目標緩存地址后,使能相應(yīng)DMA通道。當(dāng)UART接收數(shù)據(jù)達到觸發(fā)點后,會觸發(fā)DMA相應(yīng)通道的突發(fā)請求進行傳輸。傳輸結(jié)束后,在TerminalCount中斷服務(wù)中更換目標緩存地址,使能一輪即可。當(dāng)然在
配置中,DMA通道的突發(fā)個數(shù)應(yīng)設(shè)置與UART接收FIFO觸發(fā)點數(shù)相同。
4 結(jié)束語
在DMA發(fā)送進行的過程中,UART_LINK_LIST_STORE_TABLE保存的地址值序列ADDRs中的地址所指空間不能被釋放或被其它程序占用,同樣的ADDRs中地址的源地址所指的UART緩存空間也不能被釋放或被其它程序占用。如果在這個過程中出現(xiàn)了不滿足上述要求的情況,則會出現(xiàn)不可預(yù)測的錯誤。
評論