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