中文字幕 另类精品,亚洲欧美一区二区蜜桃,日本在线精品视频免费,孩交精品乱子片免费

<sup id="3hn2b"></sup>

    1. <sub id="3hn2b"><ol id="3hn2b"></ol></sub><legend id="3hn2b"></legend>

      1. <xmp id="3hn2b"></xmp>

      2. 新聞中心

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

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

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

        本文引用地址:http://www.antipu.com.cn/article/150590.htm

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

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

          

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

          UOLSR寄存器描述如下:

          

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

          0——UORBR為空。

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

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

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

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

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

          O——沒有發(fā)生奇偶校驗(yàn)錯(cuò)誤。

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

          FE:幀錯(cuò)誤標(biāo)志。當(dāng)接收字符的停止位為O時(shí),產(chǎn)生幀錯(cuò)誤。

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

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

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

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

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

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

          O——不為空。

          1——空。對(duì)UOTHR進(jìn)行寫操作,使該位恢復(fù)為O。

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

          0——不為空。

          1——空。對(duì)UOTHR進(jìn)行寫操作,使該位恢復(fù)為0。

          RXFE:如果一個(gè)帶有接收錯(cuò)誤(如幀錯(cuò)誤、奇偶錯(cuò)誤或間隔中斷)的字符裝入U(xiǎn)ORBR時(shí),該位置位。

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

          1——UORBR中包含至少一個(gè)UARTO Rx錯(cuò)誤。

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

          UOLCR寄存器的描述如下:

          

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

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

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

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

          奇偶選擇:設(shè)置奇偶校驗(yàn)類型。

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

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

          10——校驗(yàn)位強(qiáng)制為1。

          11——校驗(yàn)位強(qiáng)制為O。

          U0FCR寄存器的描述如下:

          

          這里面注意第6、7位。

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

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

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

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

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



        評(píng)論


        相關(guān)推薦

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

        關(guān)閉