新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 移動嵌入ARM7串口9位方式編程技術

        移動嵌入ARM7串口9位方式編程技術

        作者: 時間:2011-06-17 來源:網絡 收藏
        2 arm7UART0內部結構

        本文引用地址:http://www.104case.com/article/150590.htm

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

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

          

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

          UOLSR寄存器描述如下:

          

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

          0——UORBR為空。

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

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

          0——接收緩存區沒有溢出。

          1——接收緩存區發生溢出錯誤。

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

          O——沒有發生奇偶校驗錯誤。

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

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

          O——沒有發生幀錯誤。

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

          BI:間隔中斷標志。在發送數據時,如果RXDO引腳保持低電平,將產生間隔中斷。發生間隔中斷后,接收模塊停止數據接收。

          O——沒有發生間隔中斷。

          1——發生間隔中斷。

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

          O——不為空。

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

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

          0——不為空。

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

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

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

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

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

          UOLCR寄存器的描述如下:

          

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

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

          O——禁止奇偶產生和校驗。

          1——使能奇偶產生和校驗。

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

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

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

          10——校驗位強制為1。

          11——校驗位強制為O。

          U0FCR寄存器的描述如下:

          

          這里面注意第6、7位。

          Rx觸發點設置:通過設置這兩位可以調整接收FIF0中觸發RDA中斷的有效字節數量。

          00——觸發點O(1字節)。

          01——觸發點1(4字節)。

          10——觸發點2(8字節)。

          11——觸發點3(14字節)。



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 奉新县| 澎湖县| 黄陵县| 陕西省| 永春县| 茌平县| 利川市| 宾阳县| 莲花县| 茂名市| 宁德市| 揭阳市| 寿宁县| 寻乌县| 丰原市| 招远市| 沾化县| 遂宁市| 北宁市| 新邵县| 麦盖提县| 金塔县| 黔西| 十堰市| 内江市| 都兰县| 贵阳市| 孝感市| 宝鸡市| 铁岭市| 光山县| 扬州市| 教育| 阳江市| 德惠市| 库尔勒市| 宝山区| 阳新县| 吴旗县| 宾川县| 道孚县|