對UART的FIFO的理解
接收超時問題。如果沒有接收超時功能,則在對方已經(jīng)發(fā)送完畢而接收FIFO未填滿時并不會觸發(fā)中斷(FIFO滿才會觸發(fā)中斷),結果造成最后接收的有效數(shù)據(jù)得不到處理的問題。有了接收超時功能后,如果接收FIFO未填滿而對方發(fā)送已經(jīng)停,則在不超過3個數(shù)據(jù)的接收時間內(nèi)就會觸發(fā)超時中斷,因此數(shù)據(jù)會照常得到處理。
發(fā)送時,只要發(fā)送FIFO不滿,數(shù)據(jù)只管往里連續(xù)放,放完后就直接退出發(fā)送子程序。隨后,F(xiàn)IFO真正發(fā)送完成后會自動產(chǎn)生中斷,通知主程序說:我已經(jīng)完成真正的發(fā)送。
接收時,如果對方是連續(xù)不間斷發(fā)送,則填滿FIFO后會以中斷的方式通知主程序說:現(xiàn)在有一批數(shù)據(jù)來了,請?zhí)幚怼?/div>
如果對方是間斷性發(fā)送,也不要緊,當間隔時間過長時(2~3個字符傳輸時間),也會產(chǎn)生中斷,這次是超時中斷,通知主程序說:對方可能已經(jīng)發(fā)送完畢,但FIFO未滿,也請?zhí)幚怼?/div>
關鍵詞:
UARTFIF
評論