一種新型嵌入式遠程監(jiān)控系統(tǒng)的設計開發(fā)
1 引言
嵌入式監(jiān)控系統(tǒng)是當前工業(yè)自動化監(jiān)控應用領域研究的熱點之一。微電子技術和微處理器制造工藝的提高以及網絡技術的飛速發(fā)展,使得構建基于Web的嵌入式遠程監(jiān)控系統(tǒng)得以實現(xiàn)。這樣的遠程監(jiān)控系統(tǒng)可以直接通過TCP/IP網絡協(xié)議接入Internet實現(xiàn)遠程監(jiān)控,成為真正不受時間和空間限制的遠程監(jiān)控系統(tǒng)。
由于近年來一些半導體廠家新推出的MCU的存儲能力都有了很大的提高,以及用C語言編寫的程序具有移植性強、可讀性好等優(yōu)點,因此本文監(jiān)控軟件采用標準C語言編寫,并在m6811-elf-gcc中編譯通過。本文將從嵌入式Web監(jiān)控系統(tǒng)的通信基礎--以太網接口模塊著手,分別講述各個功能模塊的設計與實現(xiàn)。
2 以太網接口程序設計
以太網接口程序是與硬件設計中的網絡控制芯片密切相關的,不同的網絡控制芯片具有不同的以太網接口程序,但是一個完整的以太網接口程序通常包括三個部分:硬件模塊初始化、以太幀的發(fā)送和以太幀的接收。
1、硬件模塊初始化
本文使用的Freescale公司的MC9S12NE64 MCU集成了EPHY和EMAC兩個硬件子模塊,它們的初始化必須嚴格按照技術手冊進行,避免忽略一些細節(jié)。
2、以太幀的發(fā)送
在NE64中發(fā)送一個以太幀,必須將該幀內容寫入至EMAC模塊的發(fā)送緩沖區(qū)(TX緩沖區(qū)),然后再通過發(fā)送命令將其發(fā)送出去,接下來的工作由下層硬件完成。與以太幀的發(fā)送相關的寄存器包括發(fā)送緩沖區(qū)幀結束指針寄存器(TXEFP)、發(fā)送控制和狀態(tài)寄存器(TXCTS)。
3、以太幀的接收
判斷以太幀的接收有兩種方法:查詢法和中斷法。由于中斷法有更好的執(zhí)行效率,本文使用了中斷法接收以太幀。由于NE64有兩個接收緩沖區(qū)A和B,因此到達的幀可能存儲在A緩沖區(qū)也可能存儲在B緩沖區(qū),所以中斷矢量也有兩個:A緩沖區(qū)接收完成中斷和B緩沖區(qū)接收完成中斷,其矢量地址分別是$FFB2和$FFB4。無論是A緩沖區(qū)還是B緩沖區(qū)接收到數(shù)據(jù),處理方法是一樣的,都是將接收到的數(shù)據(jù)幀讀出來,再進行相應的處理。
3 uIP協(xié)議實現(xiàn)的程序設計
3.1 TCP協(xié)議的實現(xiàn)
TCP協(xié)議是嵌入式Web的核心,它提供一種基于連接的帶確認的可靠的數(shù)據(jù)流傳輸方式,可增強網絡的服務質量。TCP協(xié)議的機制很復雜,它的完整實現(xiàn)對處理器的存儲能力和運算能力要求較高。這對于嵌入式系統(tǒng)來說是比較奢侈的,因此必須對其進行簡化。本文要實現(xiàn)的是一個基于嵌入式Web服務器的監(jiān)控系統(tǒng),經過仔細分析,本文得到如圖1所示的簡化的TCP狀態(tài)機。其中連接的斷開由服務器主動執(zhí)行,通過多次實驗總結出來該方式在本文系統(tǒng)中,比標準的TCP協(xié)議主動斷開連接的狀態(tài)機簡單且穩(wěn)定。
圖1 服務端簡化的TCP狀態(tài)圖
另外本系統(tǒng)可以根據(jù)不同的應用要求調整TCP所支持的連接數(shù)量,但是通常在同一時刻僅支持單個TCP連接。同時為了避免因為數(shù)據(jù)報的丟失而造成狀態(tài)機的死鎖,本文使用簡單定時機制,使TCP狀態(tài)機在超時后復位。
TCP協(xié)議連接建立的過程被稱為“三次握手”。首先,客戶端向服務端提出連接請求。此時客戶端在TCP報頭中插入自己的ISN,并置SYN標志為1,表示序列號字段合法,需要檢查。其次,服務端收到該TCP分段后,以自己的ISN回應,同時確認收到客戶端的TCP分段,置ACK標志為1。最后,客戶端確認收到服務端的ISN,置ACK標志為1。至此完整的TCP連接建立,開始全雙工模式的數(shù)據(jù)傳輸過程。
3.2 其他協(xié)議的實現(xiàn)
在實現(xiàn)以太網底層驅動的基礎上,接下來實現(xiàn)用于以太網通信的上層協(xié)議。ARP協(xié)議是為了通信雙方獲取對方MAC地址的通信協(xié)議,是網絡通信的基礎,本文實現(xiàn)了ARP請求報文的發(fā)送和接收以及ARP響應報文的接收和處理功能。為方便網絡調試,在uIP中實現(xiàn)了Ping命令,當監(jiān)控設備正常工作后可省略該部分內容。SD12-MCS是實現(xiàn)一個基于嵌入式Web的應用設備,并非嵌入式網關或路由器,因此為了節(jié)約嵌入式系統(tǒng)資源,本文裁減了IP協(xié)議的路由功能,有關路由問題都由默認網關完成。盡管基于Web方式的SD12-MCS使用了TCP協(xié)議,但是目前也有一些應用是基于UDP協(xié)議的,為了系統(tǒng)具有更好的擴展性,本文也實現(xiàn)了UDP協(xié)議。
4 Web服務器的設計與實現(xiàn)
該監(jiān)控系統(tǒng)的工作模式為嵌入式Web服務器方式,因此本文在實現(xiàn)uIP協(xié)議的基礎上,設計并實現(xiàn)了應用層的HTTP協(xié)議以及CGI處理程序。
4.1 HTTP協(xié)議的設計與實現(xiàn)[!--empirenews.page--]
Web的應用層協(xié)議HTTP是Web的核心。HTTP協(xié)議實現(xiàn)的客戶機/服務器模式是一種請求/響應結構。考慮到系統(tǒng)實現(xiàn)時嵌入式TCP協(xié)議同時支持的連接次數(shù)和安全性問題,本文采用HTTP1.0協(xié)議,Web服務器每次發(fā)送完響應就斷開連接。狀態(tài)碼的含義很多,本文使用了兩種:當請求網頁成功時,返回狀態(tài)碼200,原因短語為OK;當所請求的網頁不存在時,返回狀態(tài)碼404,原因短語為NOT FOUND。頭部字段名也是可選部分,但是本文使用了其中一個選項Content-Length:指出所發(fā)送對象的字節(jié)數(shù),以方便程序調試。實體部分就是響應的具體內容,譬如一個HTML網頁或者一張圖片等等。
本文HTTP協(xié)議靜態(tài)頁面的實現(xiàn)需要完成如下內容:首先獲取URL中的文件名,接著根據(jù)該文件名調用https_calculatehash()函數(shù)獲取文件句柄,即文件處理入口數(shù)據(jù)結構中的hash域值,根據(jù)該值查找文件的起始地址,然后將文件裝入TCP套接字發(fā)送緩沖區(qū)。當所發(fā)送的文件過長而大于發(fā)送緩沖區(qū)的大小時則會發(fā)生緩沖區(qū)的溢出問題,本文的解決辦法是:首先判斷文件的長度,當文件過長時,將文件分割成多個不大于發(fā)送緩沖區(qū)大小的分段,然后循環(huán)發(fā)送出去。HTTP協(xié)議中靜態(tài)頁面處理的程序流程如圖2所示。
圖2 HTTP靜態(tài)頁面處理流程圖
4.2 CGI的設計與實現(xiàn)
在該監(jiān)控系統(tǒng)中,除了支持靜態(tài)頁面,還必須支持動態(tài)內容和動態(tài)表單的處理,主要包括動態(tài)生成實時采集數(shù)據(jù)頁面和處理控制命令表單。為了實現(xiàn)該功能,本文設計了CGI接口處理程序。
考慮到實際應用情況,本文無需在NE64中移植操作系統(tǒng),因此為Web服務器創(chuàng)建CGI接口不能照搬標準CGI。首先,本文的Web服務器不能同時運行多個應用程序,每個應用程序的運行都會獨占CPU,直到完成才會釋放CPU。其次,本文未實現(xiàn)復雜的緩存機制,所以反復執(zhí)行應用程序是個低速的過程。因此,本文對標準CGI進行了裁減,設計了嵌入式CGI(Embedded CGI),通過該方法實現(xiàn)了嵌入式Web服務器的數(shù)據(jù)的采集和監(jiān)控。其工作處理流程如圖3所示。
圖3 CGI處理流程
5 A/D采集子程序
為了實現(xiàn)不同精度、更多路的數(shù)據(jù)采集,系統(tǒng)既使用了NE64集成的A/D采集模塊,又使用了通過SPI外擴的專用的A/D采集芯片TLC2543。因此,A/D采集子程序包含了這兩部分的內容。在具體實現(xiàn)時,本文通過變量TLCAD控制調用哪個采集子程序,當TLCAD=100時,調用TLC2543采集子程序;當TLCAD=99時,調用集成A/D采集子程序。系統(tǒng)在采集數(shù)據(jù)時,模擬量輸入信號從最小的通道號依次接入,實際模擬量的個數(shù)由變量NE64ADNmb和TLCADNmb決定,分別表示采集精度為10位的模擬量個數(shù)以及采集精度為12位的模擬量個數(shù)。
在A/D數(shù)據(jù)采集過程中,不可避免地會受到隨機噪聲的干擾,從而造成采集數(shù)據(jù)的不準確,進而得出錯誤的結論。為了防止脈沖干擾該系統(tǒng),本文作者采用了中值濾波的方法。在中值濾波的基礎上,為了保證采集數(shù)據(jù)的穩(wěn)定性,本文作者采用了算術平均值濾波的方法。
6 模塊測試
該監(jiān)控系統(tǒng)軟件的主要功能是實現(xiàn)多路數(shù)據(jù)采集、網絡協(xié)議通信以及對象控制機制。模塊測試部分主要針對各模塊進行軟件測試。由于篇幅限制,下面主要針對起數(shù)據(jù)采集部分介紹其測試部分。SD12-MCS共支持30路模擬量數(shù)據(jù)采集,其中8路10位精度的AD屬于NE64的A/D模塊,剩余22路屬于2片TLC2543采集芯片。為了驗證每個采集程序是否正確,本文設計了這樣一個測試用例:首先單獨運行其中一種精度的采集程序,發(fā)送所有通道采集到的數(shù)據(jù),通過串行口發(fā)送給高端PC機,并由PC機的測試用例顯示,若顯示數(shù)據(jù)正確,則程序正確。在此基礎上,發(fā)送參數(shù)確定調用哪種子程序,同時控制采集多路模擬量,由于本文設置模擬量采集都是從第0通道開始,并依此類推,因此不需要設置究竟是采集哪個通道的模擬量,從而簡化程序處理。
本文作者創(chuàng)新點:
本文主要介紹了一種基于Web的嵌入式監(jiān)控系統(tǒng)控制策略設計與實現(xiàn)。通過對各功能模塊測試顯示該監(jiān)控系統(tǒng)性能良好,符合相關設計要求。