當(dāng)前位置:首頁 > 通信技術(shù) > 通信技術(shù)
[導(dǎo)讀]本文介紹了一種利用MSP430捕獲比較功能實現(xiàn)串行通信的方法,研究了實現(xiàn)該方法的硬件以及軟件特點。介紹了MSP430F413與TI的通信接口器件MAX3221構(gòu)成的與微機進行串行通信的超低功耗方案,并介紹了該方法在其中的具體應(yīng)用。通過實驗證明,該方法為沒有硬件UART模塊的MSP430系列單片機實現(xiàn)串行通信提供了一種有效的方法。并對有UART模塊,但需要擴展串口的應(yīng)用提供了新的思路。

1 引言:
MSP430系列單片機是美國TI公司于2000年推出的新一代超的低功耗16位單片機。由于它具有功能完善、超低功耗、開發(fā)簡便、成本低廉等特點,目前已經(jīng)在國內(nèi)得到了廣大工程技術(shù)人員的關(guān)注和應(yīng)用。工程師們在進行機型選擇時主要考慮該機型的性能和成本,因此在小型儀表以及普通應(yīng)用中MSP430的11x系列、31x系列、41x系列受到了許多工程師的青睞。這些機型有一個共同的特點就是內(nèi)部沒有硬件UART模塊。這就帶來一個問題,這些單片機怎樣實現(xiàn)串行通信呢?本文就針對這一問題進行研究,分析研究了MSP430中捕獲比較功能的特點,以及利用捕獲比較功能實現(xiàn)串行通信的方法。并以MSP430F413為例介紹了實現(xiàn)它與微機之間進行串行通信的軟件代碼和硬件電路。

1 捕獲比較功能的介紹:
MSP430系列單片機中都集成了捕獲比較的功能模塊。捕獲比較功能的引入主要是為了提高I/O端口處理事務(wù)的能力和速度。捕獲比較并不是非常新的概念,使用過Intel 的16位單片機中如80196MC的讀者就會發(fā)現(xiàn),MSP430中的捕獲比較功能和80196系列單片機中的EPA功能有一些相似之處。以下結(jié)合實現(xiàn)串行通信的需要,簡要介紹有關(guān)捕獲比較的有關(guān)概念。

捕獲比較模塊用于捕獲應(yīng)用事件的發(fā)生時間,或產(chǎn)生定時間隔。如果相應(yīng)的中斷允許,那么完成一個時間捕獲或一次定時間隔,捕獲/比較模塊都將產(chǎn)生中斷。每一個捕獲比較模塊都可以對應(yīng)一組硬件引腳。圖1是捕獲比較模塊的結(jié)構(gòu)框圖。

捕獲功能可以捕捉選定輸入引腳的狀態(tài)的變化,它可以選擇捕捉上升沿、下降沿、前后沿。如果捕捉到了相應(yīng)的變化,則定時器計數(shù)值將被復(fù)制到捕獲比較寄存器CCR中,并會產(chǎn)生相應(yīng)的中斷。在串行通信中,正是利用捕獲功能的特點來捕捉起始位的信息。


圖1:捕獲比較模塊結(jié)構(gòu)框圖

比較功能是借助比較器不斷地將CCR中的設(shè)定值與定時器中的計數(shù)值相比較,當(dāng)二者相等時,就產(chǎn)生中斷,并產(chǎn)生設(shè)定的輸出。利用比較功能,可以獲得精確的時間間隔,利用該特性可以構(gòu)造一個精確的波特率發(fā)生器,為串行通信提供時間基準。

2 利用捕獲比較實現(xiàn)串行通信的方法
本節(jié)具體介紹實現(xiàn)異步串行通信時,捕獲和比較功能是如何工作的。

2.1 接收過程


圖2:在串行通信接收過程中捕獲比較功能時序分析示意圖

在異步串行通信中,每個數(shù)據(jù)幀一般由1位起始位、8位數(shù)據(jù)位、1位奇偶校位、1位停止位組成。圖2所示為一個數(shù)據(jù)幀前3位的時序。在接收這種格式的數(shù)據(jù)幀時,首先要確定起始位,用來進行幀同步。在MSP430中是利用捕獲功能來捕捉起始位的下跳沿(詳見附錄程序代碼)。如圖2,在A點捕獲到起始位,系統(tǒng)將此刻的定時器值(T0)存放入CCR中,并產(chǎn)生中斷。對A點所產(chǎn)生中斷的處理非常重要。在該中斷處理程序中,將捕獲功能轉(zhuǎn)換為比較功能,并將1.5位的時間間隔(T1.5)加到CCR中,即CCR=T0+T1.5。這樣當(dāng)?shù)竭_1.5位時間間隔時(B點),即定時器的值等于T0+T1.5。將會由此比較功能觸發(fā)一次中斷,這樣就實現(xiàn)了1.5位時間間隔的精確定時。在該中斷處理程序中,可以讀取輸入引腳的狀態(tài),從而接收到Bit1的信息,然后再利用比較功能產(chǎn)生1位時間間隔(T1)的定時。此后,當(dāng)下一個T1時間到達時,比較功能又會觸發(fā)一次中斷(C點)。在這時的中斷服務(wù)程序中可以讀取Bit2的信息。如此重復(fù)8次,就可以完成一個字節(jié)數(shù)據(jù)的接收。

2.2 發(fā)送過程
相對于接收過程,發(fā)送過程比較簡單。利用比較功能產(chǎn)生一個間隔為1位時間(T1)的時序,相當(dāng)于一個波特率發(fā)生器。在每一次比較功能觸發(fā)的中斷服務(wù)程序中發(fā)送一位數(shù)據(jù),如此循環(huán)執(zhí)行,這樣就可以完成一個數(shù)據(jù)幀的發(fā)送。異步串行通信的一個數(shù)據(jù)幀往往是10位或11位。對于這點可以利用MSP430是16位機的特點,將數(shù)據(jù)幀的所有位安排在一個待發(fā)送字中,然后移位發(fā)送,而不需要專門編程產(chǎn)生起始位和停止位。(詳見附錄中的程序代碼及說明)

2.3 波特率的確定以及中斷的安排
從以上的分析可以看出,串行通信的波特率主要是與1位時間間隔T1有關(guān),T1可以通過以下公式確定:

  公式1

其中Tclk是指與該捕獲比較模塊相對應(yīng)的定時器的基準頻率,如使用ACLK作為時基則Tclk=32768;使用MCLK作為時基則Tclk=1M。式中的Baud就是期待的波特率值。MSP430每個捕獲比較模塊中的捕獲和比較對應(yīng)同一個中斷地址,因此兩者需要共享一段中斷服務(wù)程序。這樣就要求在中斷服務(wù)程序中能區(qū)分觸發(fā)中斷的類別。主要是通過CCTL控制寄存器中的CAP位來區(qū)分[3]。另一方面接收和發(fā)送的也都需要在這段服務(wù)程序中處理,應(yīng)該加以區(qū)分。(詳見附錄中的程序代碼及說明)

3 超低功耗串行通信實例

3.1電路結(jié)構(gòu)及其特點
本文中使用上述的原理和方法,在MSP430F413和MAX3221構(gòu)成的電路中實現(xiàn)了與微機的串行通信,電路原理如圖3。該電路不但完成了串行通信,還進一步實踐了超低功耗的應(yīng)用原理。MSP430單片機的一大特點就是超低功耗,它有多種功耗狀態(tài)可以編程控制[4]。MAX3221也是具有低功耗特點的接口器件,通過EN、FORCEON、FORCEOFF引腳可以控制驅(qū)動器、接收器的工作狀態(tài),啟動或禁止自動降低功耗功能,從而使其工作在不同的能耗狀態(tài),達到降低功耗的目的[2]??刂萍捌錉顟B(tài)詳見表1


圖3 MSP430F413超低功耗串行通信電路原理圖

3.2超低功耗的解決方案
選擇了低功耗的器件,還要合理的控制才能達到最低的能耗[1]。對于本應(yīng)用,MSP430處于從機工作狀態(tài)。針對這種應(yīng)用以下方案可以有效地降低能耗:初始化程序結(jié)束后,設(shè)定MSP430F413工作在功耗模式4等待P1.2引腳的中斷。這時CPU將關(guān)閉,其能耗最低(0.1μA)。另一方面,初始控制MAX3221進入自動調(diào)節(jié)能耗狀態(tài)。如果微機不發(fā)送信號,即Rin輸入無效,驅(qū)動器和接收器都將關(guān)閉,進入很低功耗的待機狀態(tài)(1μA)。

當(dāng)微機發(fā)送信號時,即Rin輸入有效,接收器會自動打開,并產(chǎn)生有效的INVALID信號。該信號將觸發(fā)P1.2引腳的中斷。在中斷處理程序中將MSP430F413的功耗模式設(shè)定為模式3(功耗電流0.7μA),這時利用頻率為32768的ACLK時鐘工作就可以完成低速的串行通信任務(wù)。當(dāng)接收、處理完微機的數(shù)據(jù)后需要將結(jié)果返回給微機。這時可以打開MAX3221的驅(qū)動器,關(guān)閉接收器完成此工作。當(dāng)發(fā)送完畢后可以將MSP430和MAX3221再設(shè)定為準備接收信息的最低功耗狀態(tài)。

利用上述方法可以在滿足串行通信的同時達到非常低的功耗。

表1:MAX3221收發(fā)器工作控制及其工作狀態(tài)對照表

工作及能耗狀態(tài)FORCEONFORCEOFFEN接收器輸入信號Rin驅(qū)動器狀態(tài)接收器狀態(tài)
完全待機狀態(tài)最低功耗X00X關(guān)閉激活
X01X關(guān)閉關(guān)閉
正常工作狀態(tài)人工調(diào)節(jié)能耗110X激活激活
111X激活關(guān)閉
器件自理狀態(tài)自動調(diào)節(jié)能耗010有效自動激活激活
011有效自動激活關(guān)閉
010無效關(guān)閉激活
011無效關(guān)閉關(guān)閉

注:驅(qū)動器將MOS電平轉(zhuǎn)換為RS232電平,接收器將RS232電平轉(zhuǎn)換為MOS電平

4 結(jié)束語
應(yīng)用上述的設(shè)計方法和電路,很好地實現(xiàn)了MSP430與微機之間的串行通信,并且達到了非常理想的功耗水平。實踐證明該方法對于沒有硬件UART的MSP430系列單片機進行串行通信非常有效,并給需要擴展串口的其他類型MSP430單片機提供了一種可行的方案。此外,文中的超低功耗電路設(shè)計方法對于功耗敏感的應(yīng)用是一種很好的解決方案。

參考文獻:
[1] Brian Merritt. Ultralow Power Thermostat ([R]). Texas, U.S.A. : Texas Instruments Incorporated, 2001.
[2] MAX3221 3-V TO 5.5-V single-channel RS-232 line driver/receiver (Manual). Texas, U.S.A. : Texas Instruments Incorporated, 2001.
[3] 胡大可. MSP430系列超低功耗16位單片機原理與應(yīng)用,北京航空航天出版社,2001。
[4] 胡大可. MSP430系列FLASH型超低功耗16位單片機,北京航空航天出版社,2001。

附錄:利用捕獲比較實現(xiàn)異步串行通信的程序代碼:
;------------------------------------------------------------------------------

說明:
硬件連接如圖3,P1.0作為發(fā)送引腳,P1.1作為接收引腳,二者共用捕獲比較模塊0
Tbit1 是1位時間間隔數(shù)據(jù)(T1),Tbit_5是半位時間間隔數(shù)據(jù)。(由公式1得出)
RTbuff 是接收發(fā)送緩沖字單元,存放接收和發(fā)送的數(shù)據(jù)
Counter 是收發(fā)過程中使用的計數(shù)器
;------------------------------------------------------------------------------

發(fā)送子程序

MOV&TAR,&CCR0; 將當(dāng)前定時器值存入CCR中(T0)
ADD#Tbit1,&CCR0; 將1位時間間隔加入CCR中(T0+T1)
RLARTbuff; 將帶發(fā)送的字節(jié)數(shù)據(jù)左移一位,構(gòu)造最低位為起始位
BIS#0200h, RTbuff; 將停止位數(shù)據(jù)放入待發(fā)送字的第10位
MOV#10,Counter; 初始化數(shù)據(jù)幀計數(shù)器為10
MOV#OUTMOD0+CCIE,&CCTL0; 標記發(fā)送狀態(tài),打開捕獲比較中斷,啟動發(fā)送
RET ; 返回

;------------------------------------------------------------------------------
接收準備子程序

MOV#08,Counter; 初始化接收數(shù)據(jù)計數(shù)器為8(接收一個字節(jié)數(shù)據(jù))
MOV#SCS+CCIS0+OUTMOD0+CM1+CAP+CCIE,&CCTL0;初始化捕獲比較控制字,
  ; 設(shè)定為下降沿捕獲模式,標記接收狀態(tài),打開中斷,啟動接收
RET ; 返回

;------------------------------------------------------------------------------

捕獲比較模塊0的中斷服務(wù)程序
;------------------------------------------------------------------------------

 ADD#Tbit1,&CCR0; 將1位時間間隔加入CCR0中
 BIT#CCIS0,&CCTL0; 判斷接收、發(fā)送狀態(tài)
 JNZUART_RX; 是接收狀態(tài),轉(zhuǎn)接收處理
UART_TXCMP#00h,Counter; 是發(fā)送狀態(tài),判斷幀發(fā)送是否結(jié)束
JNETX_Next; 沒有結(jié)束,轉(zhuǎn)入發(fā)送
BIC#CCIE,&CCTL0; 幀發(fā)送結(jié)束,關(guān)閉中斷
RETI ; 中斷返回
TX_NextRRARTbuff; 待發(fā)送位移入進位位C
JCTX_One; 該位為1?跳轉(zhuǎn)
BIS#OUTMOD2,&CCTL0; 該位為0,發(fā)送0
JMPTX_nxt2; 跳轉(zhuǎn)繼續(xù)處理
TX_OneBIC#OUTMOD2,&CCTL0; 該位為1,發(fā)送1
TX_nxt2DECCounter; 發(fā)送幀計數(shù)器減1
RETI ; 中斷返回
;
UART_RXBIT#CAP,&CCTL0; 判斷是否是捕獲到起始位
JZRX_Bit; 接收的不是起始位,轉(zhuǎn)入處理
RX_StartBIC#CAP,&CCTL0; 捕獲到起始位,將狀態(tài)轉(zhuǎn)為比較模式
ADD#Tbit_5,&CCR0; 再增加半位時間間隔(T0+T1.5),以實現(xiàn)1.5 時間間隔
RETI ; 中斷返回
RX_BitBIT#SCCI,&CCTL0; 將接收到的位存入進位位C
RRCRTbuff; 將接收到位,移入收發(fā)緩沖字
RX_TestDECCounter; 接收數(shù)據(jù)計數(shù)器減1
JNZRX_Next; 判斷是否接收了所有數(shù)據(jù)位,沒有跳轉(zhuǎn)到后續(xù)處理
BIC#CCIE,&CCTL0; 接收到所有數(shù)據(jù)位,關(guān)閉捕獲比較中斷
RX_NextRETI ; 中斷返回

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉