<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > ARM7串口9位方式多機通信的編程技術(shù)

ARM7串口9位方式多機通信的編程技術(shù)

作者: 時(shí)間:2010-04-09 來(lái)源:網(wǎng)絡(luò ) 收藏

  1 主從式

  所謂主從式多機系統,即在數個(gè)(或單片機)中,有一個(gè)是主機,其余的為從機。從機要服從主機的調度、支配,其拓撲結構如圖1所示。

拓撲結構

  主機信息可以發(fā)到各個(gè)從機,從機發(fā)送的信息只能被主機接收,從機之間不進(jìn)行通信。

  51單片機串口不同尋常的特征是包括第(在串口模式2和模式3下)。它允許把在串行口通信增加的第9位用于標志特殊字節的接收。一般約定第9位為高時(shí)表示該字節為地址字節,第9位為低時(shí)為數據字節。第允許接收單片機信息,僅當字節具有一個(gè)第9位時(shí)才能被中斷。用這種方式,主機首先廣播1字節,并讓其第9位為高,同時(shí)收到該字節的各個(gè)從機,只有地址相符的打開(kāi),以接收后面的數據字節。所接續的數據字節(第9位為低)不能引起其他從機中斷,因為未送它們的地址。

  51單片機用時(shí),串口模式必須在方式2或方式3。

  其實(shí)現的原理和工作過(guò)程如下:作主機的8051的SM2應設定為O,作從機的sM2設定為1。主機發(fā)送并被從機接收的信息有兩類(lèi):一類(lèi)是地址,用于指示需要和主機通信的從機地址,由串行數據第9位為“1”來(lái)標志;另一類(lèi)是數據,由串行數據第9位為“0”來(lái)標志。由于所有從機的SM2=1,故每個(gè)從機總能在R1=O收到主機發(fā)來(lái)的地址(因為串行數據的第9位為“l(fā)”),并進(jìn)入各自的中斷服務(wù)程序。在中斷服務(wù)程序中,每臺從機把接收到的從機地址和它的本機地址(系統設計時(shí)所分配)進(jìn)行比較。所有比較不相等的從機均從各自的中斷服務(wù)程序中退出(SM2仍為1),只有比較成功的從機才足被主機尋址通信的從機。被尋址的從機在程序中使SM2=0,以便接收隨之而來(lái)的數據或命令(RB8=0)。上述過(guò)程進(jìn)一步歸結如下:

 ?、僦鳈C的SM2為O,所有從機的SM2=1,以便接收主機發(fā)來(lái)的地址。

 ?、谥鳈C給從機發(fā)送地址時(shí),第9數據位應設置l,以指示從機接收這個(gè)地址。

 ?、鬯袕臋C在SM2=1、RB8=1和RI=O時(shí),接收主機發(fā)來(lái)的從機地址,進(jìn)入相應中斷服務(wù)程序,并與本機地址相比較,以便確認是否為被尋址從機。

 ?、鼙粚ぶ窂臋C通過(guò)指令清除SM2,以便正常接收數據,并向主機發(fā)回接收到的從機地址,供主機核對。未被尋址的從機保持SM2=1,并退出各自中斷服務(wù)程序。

 ?、萃瓿芍鳈C和被尋址之間的數據通信,被尋址從機在通信完成后重新使SM2=l,并退出中斷服務(wù)程序,等待下次通信。

  從以上8051實(shí)現9位方式多機通信的過(guò)程可見(jiàn),關(guān)鍵問(wèn)題在于:

 ?、侔l(fā)送端(主機)如何發(fā)送第9位,并且可編程設置1或O;

 ?、诮邮斩?從機)如何接收到這第9位,并判斷出是l還是0。

  以上問(wèn)題,8051串口可通過(guò)控制寄存器SCON中的TB8、RB8和SM2位的設置和讀取輕松解決,但在中并沒(méi)有與805l類(lèi)似功能的寄存器。那么7多機系統怎樣實(shí)現如上9位方式多機通信呢?下面通過(guò)分析ARM串口(以0為例)的內部結構和相關(guān)寄存器,給出一個(gè)有效的解決方案。

  2 ARM7串口0內部結構

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

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

UOIIR寄存器的描述

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

  UOLSR寄存器描述如下:

UOLSR寄存器

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

  0——UORBR為空。

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

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

  0——接收緩存區沒(méi)有溢出。

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

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

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

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

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

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

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

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

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

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

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

  O——不為空。

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

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

  0——不為空。

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

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

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

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

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

  UOLCR寄存器的描述如下:

UOLCR寄存器

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

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


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: ARM 多機通信 UART 9位方式

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>