0 引言
嵌入式系統(tǒng)開發(fā)已經進入了32位時代,8位MCU市場趨于穩(wěn)定,32位的MPU代表著嵌入式技術的發(fā)展方向。然而,作為嵌入式系統(tǒng)低端應用的代表,8位單片機在家用電器、儀器儀表等領域仍然被廣泛應用;而且隨著IC技術的不斷發(fā)展,單片機的擴展能力越來越強,8位單片機的開發(fā)、應用仍然受到很大重視。
隨著網(wǎng)絡技術和通信技術的不斷發(fā)展,對單片機的通信能力要求越來越高,異步通信技術通信距離遠、節(jié)約成本、通信可靠,特別是以其通信速度越來越快的特點廣泛應用在分級、分層和分布式控制系統(tǒng)以及遠程通信中,尤其適合單機轉向多機或聯(lián)網(wǎng)的應用方向。目前普遍應用的MCS-51系列和其他一些專用的單片機通常只具有一個UART異步串行通信接口,而在實際應用系統(tǒng)中(如在多機通信系統(tǒng)中,主機既要和從機通信又要和終端通信)往往需要多個串行接口。對于三總線開放的單片機,通常的方法是利用Intel 8251或8250通用同步/異步收發(fā)器(USART)對系統(tǒng)進行擴展,這就增加了系統(tǒng)開發(fā)的硬件開銷和成本。而且有些專用單片機(如ST62T32B)的三總線是不開放的,無法用通信接口芯片來擴展接口,給多機通信帶來困難。本文僅僅利用51單片機內部的擴展模塊(一個I/O端口、一個定時器T/C和一個外部中斷INT)實現(xiàn)了一個通用的軟件UART,可以以4800、9600、19200的波特率接收和發(fā)送數(shù)據(jù),沒有使用任何外圍器件,通信可靠性高,節(jié)約了開發(fā)成本,而且軟件使用C語言編寫,具有很好的移植性。該軟件UART已在多個單片機系統(tǒng)中應用,工作穩(wěn)定可靠,是一種可以借鑒的通信方案。
1 異步通信簡介
在異步通信中,數(shù)據(jù)通常是以字符(字節(jié))為單位組成字符幀進行傳送的。字符幀由發(fā)送端一幀一幀的發(fā)送,通過傳輸線在接收端一幀一幀的接收。發(fā)送端和接收端可以有各自的時鐘來控制數(shù)據(jù)的發(fā)送和接收,這兩個時鐘彼此獨立、互不同步。另外,發(fā)送端和接收端通過字符幀規(guī)定的格式和波特率來協(xié)調數(shù)據(jù)發(fā)送和接收。字符幀和波特率是兩個重要指標,由用戶根據(jù)實際情況選擇。
字符幀由起始位、數(shù)據(jù)位、奇偶校驗位和停止位四部分組成,如圖1所示,各部分的功能和結構為:
起始位 位于字符幀的開始位置,占一位,使數(shù)據(jù)線處于space(邏輯0)狀態(tài),用于向接收設備表明發(fā)送端開始發(fā)送數(shù)據(jù)。
數(shù)據(jù)位 緊跟起始位之后,根據(jù)字符編碼方式的不同可取5位、6位、7位和8位。在數(shù)據(jù)傳送過程中,低位在前,高位在后。如傳送數(shù)據(jù)為ASCII碼,則常取7位。
奇偶校驗位 位于數(shù)據(jù)位之后,占一位,用于對數(shù)據(jù)傳送作正確性檢查。奇偶校驗位有三種選擇,即奇、偶和無校驗,由用戶根據(jù)需要設定。
停止位 位于字符幀末尾,可占1、1.5和2位,在實際應用中由用戶根據(jù)需要確定,它對應于mark(邏輯1)狀態(tài),用于向接收端表明一幀信息發(fā)送完畢[1]。
2 通用軟件UART的設計思想
在設計的硬件方面該通用軟件UART僅僅使用了51系列單片機的一個通用I/O端口、一個T/C計數(shù)定時器和一個外部中斷INT,最大限度地降低了系統(tǒng)硬件開銷。該軟件UART數(shù)據(jù)發(fā)送的設計思想是利用單片機的任意一個I/O端口作通用軟件UART的發(fā)送端(TxD),通過T/Cx計數(shù)定時器設置通信波特率,將數(shù)據(jù)幀的起始位、數(shù)據(jù)位、奇偶校驗位和停止位依次發(fā)送出去;數(shù)據(jù)接收的設計思想是將單片機的某一個外部中斷作為數(shù)據(jù)接收端(RxD),并且將該中斷源設置為下降沿觸發(fā)方式,以利于及時檢測到起始位的space(邏輯0)電平,在中斷處理程序中對數(shù)據(jù)進行接收,這樣設計有利于提高UART的響應速度和單片機的利用率。
UART的波特率和采樣時鐘是利用T/Cx計數(shù)定時器實現(xiàn)的。對于不同的波特率,向T/Cx計數(shù)定時器賦予不同的初值,然后在指定的波特率下,利用軟件實現(xiàn)UART的并行數(shù)據(jù)到串行數(shù)據(jù)的轉換、每幀數(shù)據(jù)格式的生成、發(fā)送和接收功能。
在本設計中,硬件系統(tǒng)采用正當頻率為12M的主晶振,T/Cx記錄振蕩頻率12分頻后的脈沖個數(shù)(即機器周期個數(shù)),即每個機器周期使T/Cx的計數(shù)器增加1,直至記滿回零后自動產生溢出中斷請求。因此,達到指定波特率的定時器初值公式為:
其中, 為定值器初值, 為計數(shù)器的模值, 為需要計數(shù)的個數(shù)[2]-[3]。
表格 1不同波特率對應的定時器初值
由于該通用軟件UART發(fā)送和接收過程中使用的是同一個定時器,因此是一個半雙工的軟件UART。在軟件中利用宏定義和條件編譯實現(xiàn)了根據(jù)用戶需要對數(shù)據(jù)幀的格式和波特率進行設置,提高了軟件的可移植性。
3 通用軟件UART的實現(xiàn)
發(fā)送
發(fā)送過程采用的是單片機主動控制I/O端口,根據(jù)設置好的數(shù)據(jù)幀格式將數(shù)據(jù)發(fā)送出去,在發(fā)送過程中為保證每個發(fā)送位的發(fā)送時鐘相同而將其它無關中斷關閉。首先,設定定時器為定時初值,啟動定時器,關閉其它無關中斷,然后開始發(fā)送數(shù)據(jù)幀;發(fā)送完起始位space之后,通過循環(huán)結構將移位寄存器中的數(shù)據(jù)按照從低到高的順序發(fā)送出去,同時計算數(shù)據(jù)的奇偶校驗位,并在發(fā)送完數(shù)據(jù)位之后發(fā)送出去,最后發(fā)送停止位mark;關閉定時器,開放中斷,一幀數(shù)據(jù)發(fā)送結束。發(fā)送流程圖見圖2。
接收
接收過程利用單片機的外部中斷實現(xiàn)。將中斷源的觸發(fā)方式設置為下降沿觸發(fā),當出現(xiàn)中斷時在中斷處理程序中接收數(shù)據(jù),并將數(shù)據(jù)放入提前設定的緩沖區(qū)內,等待單片機將數(shù)據(jù)讀取。在數(shù)據(jù)讀取的過程中,為了保證數(shù)據(jù)讀取的正確性,必須在每個數(shù)據(jù)位的中間進行數(shù)據(jù)采樣。在主程序中設置外部中斷的觸發(fā)方式,并將該中斷設置為高優(yōu)先級以保證連續(xù)接收數(shù)據(jù),然后等待外部中斷產生;在中斷處理程序中,首先設置定時器初值,啟動定時器,關閉其它無關中斷;然后等待一個半位時鐘,使采樣點落在第一個數(shù)據(jù)位的中間位置,接著通過循環(huán)結構將數(shù)據(jù)讀入移位寄存器,同時計算奇偶校驗位,接收完畢后如果奇偶校驗正確則將數(shù)據(jù)放到數(shù)據(jù)緩沖單元中,否則棄之不用;最后關閉定時器,恢復中斷。接收流程圖見圖3。
在接收和發(fā)送的過程中需要注意的問題是中斷響應時間校準、計數(shù)定時器T/C的溢出校準和實時讀取。為了能夠及時、連續(xù)、準確的發(fā)送和接收數(shù)據(jù)幀,在實際的應用過程中需要對定時器初值進行相應的調整,并且在發(fā)送和接收的過程中要將無關的中斷關閉。
4 結論
本文實現(xiàn)的通用軟件UART在多個工程項目中得到應用,并且經過多次改進使之具有了較好的可移植性,加快了系統(tǒng)的開發(fā)速度,可以應用在各種51系列的單片機中,并且達到了降低應用系統(tǒng)硬件開銷、提高單片機資源利用率的目的。是一種值得推廣的系統(tǒng)設計思想。
參考文獻
[1] 趙曉.MCS-51單片機原理及應用[M].天津:天津大學出版社,2001.187-200
[2] 何立民.單片機應用技術選篇 6[C].北京:北京航空航天大學出版社,1999
[3] 李偉.基于ST62T32B單片機I/O口的異步串口的軟件實現(xiàn)[J].浙江工程學院學報,第20卷,第3期:193-196
[4] 閆玉德,俞虹.MCS-51單片機原理及應用(C語言版)[M].北京:機械工業(yè)出版社,2003
[5] 徐愛鈞,彭秀華.單片機高級語言C51 Windows環(huán)境編程與應用[M].北京:電子工業(yè)出版社,2003