實現基于GPRS的無線遠程IAP功能
針對地下水資源已經嚴重透支,水資源受到嚴重破壞的問題設計本系統(tǒng),目的就是為了監(jiān)控農用機井的用水情況。農用機井分布站點廣,站點之間距離幾十m到一兩百km,采用人工抄表監(jiān)控會浪費大量的人力和物力,而且實時性差。以前采用GSM方式也存在實時性差、控制困難的問題。
目前,對此類問題可靠的、現實的解決方案就是,將現場設備接入Internet上的服務器,在上層實現實時監(jiān)控、管理;但是現場沒有專門Internet接入點和設備。采用GPRS接入Internet進行遠程數據傳輸,是近兩年企業(yè)、研究所等科研機構的熱門課題。隨著GPRS技術的日益成熟,GPRS已經成功地應用在遠程抄表、夜燈照明、油田監(jiān)測、自動測量、智能儀表等不方便甚至根本不可能人工操作的遠程數據傳輸系統(tǒng)中。因此,本系統(tǒng)選用GPRS和GSM混合工作模式:在網絡狀況通暢的情況使用GPRS工作模式;反之可以切換到GSM工作模式。每個站點數據傳輸終端定時登陸到GPRS,接入Internet上的主機服務器,把采集數據和站點狀態(tài)下載到服務器硬盤上;上層采用B/S瀏覽器方式供地級、區(qū)級、市級等不同級別設置權限瀏覽;同時可以隨時監(jiān)控站點的實時狀態(tài),報告實時現場狀況,調用系統(tǒng)歷史數據信息。
市場的機遇和應用技術的成熟常常是一對矛盾,尤其對于GPRS這類新技術,通常不得不一邊開拓市場一邊完善技術。然而實踐是檢驗真理的唯一標準。系統(tǒng)交接使用之后,用戶反饋一些改善功能的意見,另外,長時間使用之后,終端程序隱藏的“bug”也可能會隨之浮出水面。這就需要對數據傳輸終端的程序進行升級,但是設想一下,假如投入使用了200個站點,就算用ISP現場在線編程,工作人員得到每個站點把程序更新一遍。不但浪費大量的人力、物力,而且直接貽誤了開辟市場的時機,對企業(yè)造成的后果可能是致命的。
本設計方案就是應用在此類GPRS遠程監(jiān)控系統(tǒng)上,融合GPRS網絡通信技術解決數據傳輸終端程序升級問題的。
1 IAP功能簡介與系統(tǒng)應用
IAP(In-Application Programming)是應用在Flash程序存儲器的一種編程模式。簡單地說就是在應用程序控制下,對程序某段存儲空間進行讀取、擦除、寫入操作。與ISP(In-System-Programming)操作非常相似,都不需要從電路板上取下芯片用編程器燒寫再安裝上去運行新程序,即具有在線編程功能。但是它們有其不同點:ISP通常是整片擦除、編程,在手工操作下通過PC串口下載程序到Flash,需要簡單的硬件資源――串口RX、TX和RS232驅動芯片;而IAP卻是在某段程序的控制下對另外一段程序Flash進行讀寫操作,可以控制對某段、某頁甚至某個字節(jié)的讀寫操作。
根據IAP的功能特點,可以制作仿真軟件替代仿真器功能。在PC上做個簡單的界面應用程序就可以直接實現用戶程序在線仿真:設置斷點、單步運行、改變運行結果調試等功能。同理,根據ISP的功能特點可以替代編程器。本系統(tǒng)就是把IAP模式融入到GPRS通信系統(tǒng)中,用GPRS遠程升級指定目標芯片的軟件。
2 IAP功能系統(tǒng)架構
IAP功能系統(tǒng)架構如圖1所示。
圖1 系統(tǒng)架構(只標示與lAP功能相關部分)P89LPC936是PhiIips公司推出的一款高穩(wěn)定性、多功能的51內核MCU;集成了I2C總線,讀寫操作I2C器件FM24C256速度快、穩(wěn)定性高;增強型UART,具有幀錯誤檢測、幀間隔檢測、可選雙緩沖、接收和發(fā)送中斷可選分開等強大串口通信功能,增強了和GPRS模塊串口通信的可靠性;內置AD/DA轉換器;16 KB Flash存取器,支持ISP和IAP;采用TSSOP28或HWQFN28低成本封裝。設計系統(tǒng)的外圍電路可以減少到最少,不但提高了系統(tǒng)的性能,甚至可以IAP升級終端部分功能而不用改變外圍硬件電路。
FM24C256,256 Kb的FRAM(鐵電存儲器),兼有ROM的掉電數據保存特性和RAM的讀寫速度和次數,讀寫次數達到1000億次,采用I2C總線讀寫操作,使用穩(wěn)定可靠;用8腳SOIC封裝,與MCU的接口電路簡單、通信可靠。通信速率O~400 kHz可調。P89LP(2936的12SCLH和。12SCLL兩個SFR的值就是確定串行時鐘發(fā)生器占空比。本系統(tǒng)選擇7.372 8 MHz晶振,12SCLH=12SCLL=75,12C速率為25 Kbps。
GPRS模塊使用WAVECOM公司生產的Q2406B,雙頻GPRS/GSM模塊(EGSM900/1 800 MHz或EGSM900/1 900 MHz),內置TCP/IP,與標準AT指令完全兼容;其設計開發(fā)符合ETSI GSM Phase 2+標準。本系統(tǒng)模塊使用9.6 kbps波特率,而模塊出廠波特率為115 200 bps,用串口終端初始化模塊時,特別要注意這一點。
3 IAP功能的軟件編程
3.1 系統(tǒng)工作狀態(tài)分析
①用戶程序工作狀態(tài),在遠程數據傳輸系統(tǒng)中,用戶程序完成數據采集、存儲、發(fā)送,系統(tǒng)監(jiān)控、報警,接收執(zhí)行上位機設置、控制命令等正常用戶功能。
②IAP工作狀態(tài),如圖2所示。上位機發(fā)送升級程序信令,數傳終端收到并回復確認信息后,開始等待下載信令;收到正確下載信令后開始下載代碼到FM24C2256暫存。按幀順序號發(fā)送、接收數據,校驗幀的正確性,采用握手數據流保證每幀完全正確接收、存儲。代碼發(fā)送完畢后,發(fā)送下載完畢信令,包括代碼總長度和塊校驗碼;每階段都采取延時處理:延時時間到繼續(xù)重發(fā)過程三次,還沒收到就報告出錯信息,強行下線,切換到待升級用戶程序運行。如果通信正常,就進入最關鍵一步――Flash擦除和編程。
Philips在P89LPC936地址FF00H~FFFFH的空間里固化一個256字節(jié)的引導ROM,所有MCU對內部Flash的操作都可以調用這個子程序完成。使用IAP功能時就是提供這個子程序的入口參數(參考Philips的數據手冊),然后調用程序的入口地址FF00H,就可以實現讀、寫、擦除Flash。擦除、編程Flash時需要關閉所有中斷,不能對同一塊Flash同時進行擦除和編程,而且編程之前要先把扇區(qū)清除。對Flash的扇區(qū)進行擦除操作的程序清單(入口參數A、R7、R4和R5,返回參數(F0(C)、R7)如下:
ERASE_FLASH:
MOV A,#04H ;A為操作類型(A=04H,告訴IAP
;執(zhí)行的是擦除操作)
MOV R7,#01H ;R7刪除操作方式(00H表示刪除
;頁;01H表示刪除扇區(qū))
MOV R4,#HIGH ;操作的Flash地址高8位
M0v R5,#L0w ;操作的Flash地址低8位
LCALL FF00H
JC ERASE_FLASH ;FO(C):O表示擦除成功,1表示
;擦除失敗
3.2 IAP功能系統(tǒng)SFR配置
(1)用戶保密扇區(qū)設置
MOV SEC6,#04H;禁止對Flash扇區(qū)6的擦除
MOV SEC7,#04H;禁止對Flash扇區(qū)7的擦除
扇區(qū)6和扇區(qū)7代碼是控制擦除、編程Flash。為保證不被誤操作,只允許在出廠時用專門的編程器擦寫。
(2)IAP特許關鍵值設置
執(zhí)行擦除或寫Flash的IAP功能,需要在調用IAP功能程序前,把96H寫入RAM單元FFH來設置特許關鍵值。程序代碼如下:
MOV RO,#OFFH
MOV @RO,#96H
IAP程序處理完功能調用后,特許關鍵值被清除。因此在每次調用IAP功能程序前必須設置特許關鍵值。
3.3 lAP功能實現流程
IAP功能實現流程如圖3、圖4所示。flagIAP為下載程序完畢,并且校驗碼確認后,準備擦寫Flash的標志。在FM24C256開辟單元存儲功能很重要:在程序擦寫發(fā)生異常,如掉電復位,可以在程序啟動后,與上位機確認擦寫后,繼續(xù)完成升級任務。每次編程的字節(jié)數和上位機傳輸的1幀數據中,代碼字節(jié)數保持一致,幀序號數表示程序分成多少幀傳輸和多少次編程操作。
3.4 協(xié)議設計
GPRS網絡速度理論上有11 7 kbps,實際上遠遠沒達到;GPRS與Internet連接建立后,進入數據透明傳輸階段。本系統(tǒng)在完善的TCP/IP機制基礎上設計用戶應用層協(xié)議,為實現對系統(tǒng)某個終端的系統(tǒng)軟件升級,可將要升級的程序代碼通過寫碼軟件轉化為系統(tǒng)信令,接入Internet到GPRS網絡,透明傳輸下載到目標數傳終端。本系統(tǒng)的信令格式采用如下代碼幀格式:
開始信令幀和結束信令幀代碼數據段都是FFH。同步碼設置為AAH,55H;字節(jié)長度(1B)表示此數據幀包含代碼數據的字節(jié)數,通常小于64;下載目標地址(5B)設定為出廠ID號,賦予一個特定代碼含義,只有校驗ID號正確后數據傳輸終端才可能接收命令,而且是唯一標識,不可改變;從安全性出發(fā),本系統(tǒng)中設置為出廠日期和編號的組合:0501160000表示2005年1月16號出廠的第一個產品。幀序號(1B)表明此次升級程序分成的傳送幀數,在命令傳送過程中,此域為OOH??刂谱侄?1B)表示傳送的是操作命令還是數據。結束碼設置55H,AAH。數據傳輸終端上行和下行數據格式完全相同,上行響應數據除代碼數據段不同之外,其他字段都是下行控制數據的復制,實現數據流控制。
4 lAP功能可靠性探討
系統(tǒng)升級過程不免受到環(huán)境的干擾,如系統(tǒng)斷電或網絡通信阻塞、故障等意外事故,而導致IAP升級失敗。因此必須有一套可靠的軟、硬件機制來保障IAP的完全正常工作。以下介紹本系統(tǒng)所采取的一些措施:
①掉電情況處理?,F場環(huán)境的電網波動相當大,而且經常性停電,甚至影響到系統(tǒng)的正常工作??刹捎眯铍姵毓╇?,提供穩(wěn)定的、可靠的工作電源;外加一充電板電路,能在有電的時候直接給電路充電。此外,軟件上還做了完善的握手機制,信令設置回執(zhí),確保通信正確不會發(fā)生誤操作;下載和擦寫Flash部分時序上隔離,網絡通信性能和掉電異常對系統(tǒng)正常工作的影響減到最小。
②數據傳輸過程產生的誤碼。通用的、有效的解決辦法就是用CRC循環(huán)冗余效驗和重傳機制。數據校驗碼正確后存入FM24C256,錯誤或超時就發(fā)幀序號請求重發(fā),直到檢測到結束幀。
最后一幀數據長度不夠就用FFH填滿一幀發(fā)送。
③數據傳輸過程大延遲或阻塞情況處理。數據傳輸采用超時處理,三次握手失敗,作異常處理機制。
該技術方案從根本上解決了本系統(tǒng)現場升級困難的問題,大大提高了系統(tǒng)的可維護性,加速了新產品上市時間,可以提供更快、更完美的用戶服務,增強產品的市場競爭力。以GPRS網絡為載體,在廣大接入Internet困難的監(jiān)控現場或農村地區(qū),該技術提出了一個解決方案。
tcp/ip相關文章:tcp/ip是什么
評論