基于DMA控制器的UART串行通信設(shè)計
2)設(shè)置定時器UART_DMA_TX_TIMER,定時值為Ts,即每T秒定時器UART_DMA_TX_TIMER發(fā)生一次中斷。中斷服務(wù)為檢查DMAx_LINK_LIST_FI LL_TABLE的隊列長度L,判斷是否有可用的鏈表地址。如果有,則執(zhí)行出隊操作取出一個緩存地址FILL_CACHE_0,將其入隊到UART_LINK_LIST _STORE_TABLE中。然后利用其中的源地址、目標(biāo)地址和ControIValue值,將其分配給DMA通道x的相應(yīng)寄存器。若L>1,則再取出一個地址,入隊到UART_LINK_LIST_STORE_TABLE,將其值賦給DMAx的LLI寄存器。如果仍有可用鏈表地址,則取出,入隊到UART_LINK_LIST_STORE_TABLE,將其值賦給上一個鏈表地址中的LinkList_NextListAddress,然后依次類似操作,直到最一個取出后,將其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通道使能,啟動DMAx傳輸。流程如圖2所示。本文引用地址:http://m.butianyuan.cn/article/160710.htm
評論