ATmega161在嵌入式測控網(wǎng)絡中的應用研究
1引言
本文引用地址:http://www.biyoush.com/article/171953.htm隨著微電子技術、通信技術、控制技術和半導體技術的飛速發(fā)展以及工業(yè)、醫(yī)療衛(wèi)生、國防等部門對智能控制要求的不斷提高,嵌入式微處理器被越來越廣泛地應用。為了適應各方面的需求,嵌入式微處理器在運算速度、可擴充能力、系統(tǒng)可靠性、功耗和集成度等方面得到了突飛猛進的發(fā)展。嵌入式微處理器體系結構經(jīng)歷了一個從CISC(Complex In-struction Set Computer)到RISC(Reduced Instruction SetComputer),從4位、8位、16位到32位甚至64位,尋址空間從64kB到16MB甚至更大,處理速度從0.1MIPS到2000 MIPS的過程。
ATmega161是一款基于AVR(Advanced RISC)的低功耗CMOS8位單片機,它以其強大的功能和較高的性價比得到了不少嵌入式系統(tǒng)開發(fā)者的青睞。其主要特點表現(xiàn)在以下幾方面:
(1)ATmega161增強型RISC結構方面
●內含2周期乘法器;
●具有32個8位通用(工作)寄存器;
●工作在8MHz時,具有8MIPS的性能;
●具有130條指令,大多數(shù)為單周期指令;
(2)數(shù)據(jù)和程序存儲器方面
●內含16k非易失在系統(tǒng)可編程FLASH;
●具有1k的內部SRAM;
●帶有512字節(jié)非易失在系統(tǒng)編程EEPROM;
●能進行可編程程序加密。
(3)外圍特點
●帶有兩個可編程全雙工UART;
●帶有主/從SPI串行接口;
●具有自身振蕩器的實時時鐘RTC;
●具有2個8位定時器/計數(shù)器;
●帶有1個可預分頻的具有比較、捕捉和雙8/9/10位PWM功能的16位定時器/計數(shù)器;
●具有可編程的內部看門狗定時器;
●片內的模擬比較器可用作A/D轉換;
●帶有35個可編程I/O口。
(4)增強的MCU特點
●可進行上電復位和可編程低壓檢測;
●具有21級內外部中斷源;
●有空閑、節(jié)電及掉電三種節(jié)電模式。
(5)其它特性
●采用40腳PDIP,44腳PLCC及QFP封裝;
●工作電壓為4.0~5.5V。
2嵌入式測控網(wǎng)絡的設計
傳統(tǒng)的測控網(wǎng)絡由于連接有很多常規(guī)模擬儀表和執(zhí)行機構以及其它現(xiàn)場設備而具有很多缺點,如一對一結構連線龐雜,工程周期長,安裝費用高,維護不便;模擬信號傳輸精度低,易受干擾;操作員在控制室既不能對其進行參數(shù)調整,也不能對其進行故障診斷,因而會導致操作的“失控”。
所示是筆者設計的以ATmega161為核心的嵌入式測控網(wǎng)絡系統(tǒng)示意圖。圖中的嵌入式控制器通過兩級RS-485總線既可和上位機通信,又可和傳感器以及執(zhí)行機構等現(xiàn)場設備進行通信。操作人員可直接通過鍵盤、鼠標來完成對執(zhí)行機構的遠程控制,從而實現(xiàn)實時監(jiān)控;同時,總線似的數(shù)字信號通信可以克服常規(guī)模擬信號傳輸?shù)脑S多缺點,并具有接線簡單、維護方便、精度高、抗干擾能力強等優(yōu)點。
3硬件設計
可以用兩個UART通用串行口組成兩級RS-485網(wǎng)。一般的微處理器并不具備兩個UART,通??蓴U展一片串行接口芯片(如8251、8250或者 EXAR公司的ST16C2552等)構成兩個UART,但這樣會使電路變得復雜、PCB成本增大且系統(tǒng)的抗干擾能力下降。而ATmega161正好具有兩個可編程UART,所以無需擴展,這種方法不但可以使電路簡化并使PCB體積縮小,而且還可使抗干擾能力增強,同時也具有較高的性價比。
通信部分的硬件原理圖如圖2所示。圖中,將兩個UART的RXD、TXD分別接到兩片MAX485上,以使其轉換成RS-485電平,再以數(shù)據(jù)總線的形式連接到上位機和數(shù)字化的儀器儀表以及其它現(xiàn)場設備上,從而構成兩級測控網(wǎng)絡。
MAX485是一種專用的RS-485/RS-422接口芯片,它具有功耗低、體積小、操作簡單方便等優(yōu)點。每片MAX485最多能帶32個收發(fā)器,如果要增加每條總線上收發(fā)器的個數(shù),可以換成MAX487、MAX1487(可帶128個收發(fā)器)等芯片。
4軟件設計
4.1通信協(xié)議
通信協(xié)議采用ISO的OSI七層模型中的物理層、鏈路層和應用層。其中物理層為RS-485,它以雙絞線為傳輸總線,其最大通信距離可達1200米,最大從機個數(shù)為32臺(使用MAX485),數(shù)據(jù)傳送速率為2400b/s,數(shù)據(jù)傳輸格式為:1位起始位、8位數(shù)據(jù)位和1位停止位,該格式無奇偶校驗位,通信錯誤檢測采用累加和校驗。
數(shù)據(jù)鏈路層可參考ISO的“高級數(shù)據(jù)鏈路層協(xié)議”(HDLC)的有關規(guī)定,并選用適合于主從網(wǎng)絡的HDLC的正常響應操作模式(NRM),即從站只有在其受到主站的請求時才能發(fā)送信息。上位機采用輪詢的方式對嵌入式控制器進行訪問,而控制器又對數(shù)字化傳感器及現(xiàn)場設備以輪詢的方式進行訪問。其操作過程如圖3所示。
嵌入式控制器在整個通信過程中具有雙重身份,即在與上位機通信過程中,上位機是主站,控制器為從站;而在與傳感器及現(xiàn)場設備的通信過程中,控制器是主站,傳感器和現(xiàn)場設備為從站。
幀的格式定義為:幀開始符、源地址、目的地址、控制字、信息、累加和校驗(BCC)以及幀結束符。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評論