利用捕獲比較功能實現(xiàn)MSP430與微機串行通信的研究
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) | FORCEON | FORCEOFF | EN | 接收器輸入信號Rin | 驅(qū)動器狀態(tài) | 接收器狀態(tài) |
完全待機狀態(tài)最低功耗 | X | 0 | 0 | X | 關(guān)閉 | 激活 |
X | 0 | 1 | X | 關(guān)閉 | 關(guān)閉 | |
正常工作狀態(tài)人工調(diào)節(jié)能耗 | 1 | 1 | 0 | X | 激活 | 激活 |
1 | 1 | 1 | X | 激活 | 關(guān)閉 | |
器件自理狀態(tài)自動調(diào)節(jié)能耗 | 0 | 1 | 0 | 有效 | 自動激活 | 激活 |
0 | 1 | 1 | 有效 | 自動激活 | 關(guān)閉 | |
0 | 1 | 0 | 無效 | 關(guān)閉 | 激活 | |
0 | 1 | 1 | 無效 | 關(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) |
RLA | RTbuff | ; 將帶發(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) | |
JNZ | UART_RX | ; 是接收狀態(tài),轉(zhuǎn)接收處理 | |
UART_TX | CMP | #00h,Counter | ; 是發(fā)送狀態(tài),判斷幀發(fā)送是否結(jié)束 |
JNE | TX_Next | ; 沒有結(jié)束,轉(zhuǎn)入發(fā)送 | |
BIC | #CCIE,&CCTL0 | ; 幀發(fā)送結(jié)束,關(guān)閉中斷 | |
RETI | ; 中斷返回 | ||
TX_Next | RRA | RTbuff | ; 待發(fā)送位移入進位位C |
JC | TX_One | ; 該位為1?跳轉(zhuǎn) | |
BIS | #OUTMOD2,&CCTL0 | ; 該位為0,發(fā)送0 | |
JMP | TX_nxt2 | ; 跳轉(zhuǎn)繼續(xù)處理 | |
TX_One | BIC | #OUTMOD2,&CCTL0 | ; 該位為1,發(fā)送1 |
TX_nxt2 | DEC | Counter | ; 發(fā)送幀計數(shù)器減1 |
RETI | ; 中斷返回 | ||
; | |||
UART_RX | BIT | #CAP,&CCTL0 | ; 判斷是否是捕獲到起始位 |
JZ | RX_Bit | ; 接收的不是起始位,轉(zhuǎn)入處理 | |
RX_Start | BIC | #CAP,&CCTL0 | ; 捕獲到起始位,將狀態(tài)轉(zhuǎn)為比較模式 |
ADD | #Tbit_5,&CCR0 | ; 再增加半位時間間隔(T0+T1.5),以實現(xiàn)1.5 時間間隔 | |
RETI | ; 中斷返回 | ||
RX_Bit | BIT | #SCCI,&CCTL0 | ; 將接收到的位存入進位位C |
RRC | RTbuff | ; 將接收到位,移入收發(fā)緩沖字 | |
RX_Test | DEC | Counter | ; 接收數(shù)據(jù)計數(shù)器減1 |
JNZ | RX_Next | ; 判斷是否接收了所有數(shù)據(jù)位,沒有跳轉(zhuǎn)到后續(xù)處理 | |
BIC | #CCIE,&CCTL0 | ; 接收到所有數(shù)據(jù)位,關(guān)閉捕獲比較中斷 | |
RX_Next | RETI | ; 中斷返回 |