<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 移動嵌入ARM7串口9位方式編程技術(shù)

          移動嵌入ARM7串口9位方式編程技術(shù)

          作者: 時間:2011-06-17 來源:網(wǎng)絡 收藏
          2 arm7UART0內(nèi)部結(jié)構(gòu)

          本文引用地址:http://www.ex-cimer.com/article/150590.htm

            使用UARTO之前須設置5個寄存器,即中斷使能寄存器UOIER、UARTO格式控制寄存器UOLCR、FIFO控制寄存器UOFCR和波特率設置寄存器UODLM和UODLL。發(fā)送過程是:CPU內(nèi)核通過VPB接口對UARTO的寄存器進行讀寫訪問,數(shù)據(jù)首先進入發(fā)送緩存UOTHR,經(jīng)發(fā)送移位寄存器UOTSR逐位移出,經(jīng)TxDO引腳輸出。接收過程是:數(shù)據(jù)經(jīng)RxDO,先進入接收移位寄存器UORSR,經(jīng)接收緩存U0RBR,通過VPB與CPU內(nèi)核相連。特別注意的是,通信過程中arm7中的中斷標志寄存器U0IIR和UART0狀態(tài)寄存器UOLSR的各位將隨著通信收發(fā)而自動受到影響,也就是說這兩個寄存器記錄了數(shù)據(jù)通信過程的狀態(tài)信息,這些信息很有用。

            UOIIR寄存器的描述如表1所列。

            

            UOIIR提供狀態(tài)代碼,用于指示一個掛起中斷的中斷源和優(yōu)先級。在訪問UOIIR的過程中,中斷被凍結(jié)。如果在訪問UOIIR時產(chǎn)生了中斷,該中斷將被記錄,在下次訪問UOIIR時可以讀出,避免了中斷的丟失。

            UOLSR寄存器描述如下:

            

            RDR:接收數(shù)據(jù)就緒。判斷該位是否置1,決定能否從FIF0中讀取數(shù)據(jù)。

            0——UORBR為空。

            l——UORBR中包含有效數(shù)據(jù)。從接收FIFO中讀走所有數(shù)據(jù)后,恢復為O。

            0E:溢出錯誤標志。當U0RBR寄存器中已經(jīng)有新的字符就緒,而接收FIF0已滿時,該位置位。

            0——接收緩存區(qū)沒有溢出。

            1——接收緩存區(qū)發(fā)生溢出錯誤。

            PE:奇偶校驗錯誤。在使能奇偶校驗位之后,對所有接收的數(shù)據(jù)都進行奇偶校驗,如果與UOLCR中的設置不符,將引起奇偶校驗錯誤。

            O——沒有發(fā)生奇偶校驗錯誤。

            1——發(fā)生奇偶校驗錯誤。讀操作使該位恢復為O。

            FE:幀錯誤標志。當接收字符的停止位為O時,產(chǎn)生幀錯誤。

            O——沒有發(fā)生幀錯誤。

            1——發(fā)生幀錯誤。讀取該位時恢復為O。

            BI:間隔中斷標志。在發(fā)送數(shù)據(jù)時,如果RXDO引腳保持低電平,將產(chǎn)生間隔中斷。發(fā)生間隔中斷后,接收模塊停止數(shù)據(jù)接收。

            O——沒有發(fā)生間隔中斷。

            1——發(fā)生間隔中斷。

            THRE:反映UOTHR是否為空,也可以認為發(fā)送FIFO是否為空。

            O——不為空。

            1——空。對UOTHR進行寫操作,使該位恢復為O。

            TEMT:當發(fā)送移位寄存器和UOTHR均為空時,該位置位。

            0——不為空。

            1——空。對UOTHR進行寫操作,使該位恢復為0。

            RXFE:如果一個帶有接收錯誤(如幀錯誤、奇偶錯誤或間隔中斷)的字符裝入UORBR時,該位置位。

            O——UORBR中沒有接收錯誤,或UOFCR[O]為0。

            1——UORBR中包含至少一個UARTO Rx錯誤。

            另外,還有兩個很重要的寄存器:一個是前面提到的格式控制寄存器UOLCR,另一個是FIFO控制寄存器UOFCR。

            UOLCR寄存器的描述如下:

            

            其中第3位和第4、5位十分重要。

            奇偶使能:控制是否進行奇偶校驗。如果使能,發(fā)送時將添加一位校驗位。

            O——禁止奇偶產(chǎn)生和校驗。

            1——使能奇偶產(chǎn)生和校驗。

            奇偶選擇:設置奇偶校驗類型。

            OO——奇數(shù)(數(shù)據(jù)位+校驗位=奇數(shù))。

            01——偶數(shù)(數(shù)據(jù)位+校驗位=偶數(shù))。

            10——校驗位強制為1。

            11——校驗位強制為O。

            U0FCR寄存器的描述如下:

            

            這里面注意第6、7位。

            Rx觸發(fā)點設置:通過設置這兩位可以調(diào)整接收FIF0中觸發(fā)RDA中斷的有效字節(jié)數(shù)量。

            00——觸發(fā)點O(1字節(jié))。

            01——觸發(fā)點1(4字節(jié))。

            10——觸發(fā)點2(8字節(jié))。

            11——觸發(fā)點3(14字節(jié))。



          評論


          相關推薦

          技術(shù)專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();