基于DMA控制器的UART串行通信設(shè)計(jì)
2)設(shè)置定時(shí)器UART_DMA_TX_TIMER,定時(shí)值為Ts,即每T秒定時(shí)器UART_DMA_TX_TIMER發(fā)生一次中斷。中斷服務(wù)為檢查DMAx_LINK_LIST_FI LL_TABLE的隊(duì)列長(zhǎng)度L,判斷是否有可用的鏈表地址。如果有,則執(zhí)行出隊(duì)操作取出一個(gè)緩存地址FILL_CACHE_0,將其入隊(duì)到UART_LINK_LIST _STORE_TABLE中。然后利用其中的源地址、目標(biāo)地址和ControIValue值,將其分配給DMA通道x的相應(yīng)寄存器。若L>1,則再取出一個(gè)地址,入隊(duì)到UART_LINK_LIST_STORE_TABLE,將其值賦給DMAx的LLI寄存器。如果仍有可用鏈表地址,則取出,入隊(duì)到UART_LINK_LIST_STORE_TABLE,將其值賦給上一個(gè)鏈表地址中的LinkList_NextListAddress,然后依次類似操作,直到最一個(gè)取出后,將其LinkList_Next-ListAddress賦為0。若L=1,則將DMAx的LLI寄存器的值置為0。最后設(shè)置DMAx的Config寄存器,設(shè)置內(nèi)容有目標(biāo)外設(shè)為UART_TX、傳送類型為MEMORY TO PERIP HERAL、不屏避Terminal Count中斷、DMAx通道使能,啟動(dòng)DMAx傳輸。流程如圖2所示。本文引用地址:http://www.ex-cimer.com/article/160710.htm
評(píng)論