《電子技術(shù)應用》
您所在的位置:首頁 > 其他 > 設計應用 > 基于mc35i的m2m終端設計與研究
基于mc35i的m2m終端設計與研究
摘要: 嵌入式系統(tǒng)是當前國內(nèi)外研究的熱點之一。采用嵌入式系統(tǒng)技術(shù)設計一種可以解決遠程監(jiān)控領域數(shù)據(jù)傳輸問題的通用終端是必要的。本文重點闡述了基于嵌入式ARM處理器,結(jié)合GPRS模塊MC35i設計M2M終端的總體設計方案。
關(guān)鍵詞: 控制網(wǎng)絡 MC35i M2M 終端 GPRS
Abstract:
Key words :

  引言

  目前,對輸油管道、電力裝置、油井等進行遠程監(jiān)控主要采用人工巡邏的方式,這種方式存在實時性差、成本高、浪費人力資源、無法對環(huán)境惡劣的地區(qū)進行監(jiān)控、可能出現(xiàn)誤報等缺點。隨著工業(yè)領域現(xiàn)代化水平的提高和通信技術(shù)的發(fā)展,這種生產(chǎn)方式亟待得到改善。

  m2m是指應用無線移動通信技術(shù),實現(xiàn)機器與機器、機器與人之間數(shù)據(jù)通信和交流的一系列技術(shù)及其組合的總稱。GPRS具有覆蓋地域廣、通信距離遠、網(wǎng)絡可靠性高等優(yōu)點。隨著GPRS的推廣和應用,以及基于GPRS的M2M產(chǎn)品的推出,采用GPRS技術(shù)來解決上述問題成為一種較好的方案。

  嵌入式系統(tǒng)是當前國內(nèi)外研究的熱點之一。采用嵌入式系統(tǒng)技術(shù)設計一種可以解決遠程監(jiān)控領域數(shù)據(jù)傳輸問題的通用終端是必要的。本文重點闡述了基于嵌入式ARM處理器,結(jié)合GPRS模塊mc35i設計M2M終端的總體設計方案。

  系統(tǒng)硬件組成

  M2M終端的硬件核心為GPRS通信模塊MC35i和ARM處理器AT91SAM7S64,它們的接口設計如圖1所示。M2M終端對外留有2個 RS232串口,通過發(fā)送預先定義好的數(shù)字指令,可以實現(xiàn)M2M終端的啟動、關(guān)閉等。當M2M終端與Internet建立連接后,只需把封裝好的數(shù)據(jù)通過串口發(fā)送到M2M終端,由其完成向監(jiān)控中心發(fā)送數(shù)據(jù)的功能。

系統(tǒng)硬件組成

  GPRS模塊

  GPRS模塊是實現(xiàn)M2M終端平臺的核心部分,設計中采用西門子公司的GPRS通信模塊MC35i。本模塊包括CPU接口電路、SIM卡接口電路和MC35i外圍電路,MC35i支持GPRS的四種編碼協(xié)議CS-1、CS-2、CS-3和CS-4,理論上最高傳輸速率可達172kbps。它具備完整的GSM和GPRS功能,可以廣泛應用在相關(guān)的M2M數(shù)據(jù)傳輸平臺上。MC35i提供了標準AT命令界面和一個RS232接口,用于與外部應用系統(tǒng)連接。

  ARM處理器

  本數(shù)據(jù)傳輸平臺處理器采用ATMEL公司生產(chǎn)的32位ARM7TDMI體系結(jié)構(gòu)處理器AT91SAM7S64,該芯片采用3.3V電壓進行供電,支持低功耗模式,它具有64kB的FLASH和16kB的SRAM,具備豐富的外圍設備資源,其中包括3個UART通信串口和1個USB2.0全速設備,利用本芯片完成系統(tǒng)功能的同時可以實現(xiàn)系統(tǒng)的高性價比。CPU模塊硬件電路包括:時鐘電路、JTAG接口電路,RS232接口電路等。

  電源設計

  系統(tǒng)采用9V電源進行供電,經(jīng)過TI公司LDO降壓芯片UA7805進行一次降壓,使電壓降至5V。GPRS模塊MC35i要求的電源電壓為 3.3V~4.8V,而且要求電源必須能夠提供2A的尖峰電流,因此需要將5V電源通過一個0.7V壓降的肖特基二極管1N5819后輸入MC35i,同時需要接入耐壓25V、1000μF的電解電容,以為MC35i提供足夠的尖峰電流,將5V電源經(jīng)過TI公司電源模塊REG1117-3.3將電壓降至 3.3V,為微處理器及其他芯片提供電源。

  嵌入式軟件設計

  采用嵌入式實時操作系統(tǒng)可以更合適、有效地利用CPU的資源,簡化應用軟件的設計,縮短系統(tǒng)開發(fā)時間,更好地保證系統(tǒng)的實時陛和可靠性。 FreeRTOS是在Sourceforge網(wǎng)站上發(fā)布的微內(nèi)核嵌入式實時操作系統(tǒng),它是完全免費的操作系統(tǒng),具有源碼公開、可移植、可裁減、調(diào)度策略靈活的特點。作為一個輕量級的操作系統(tǒng),F(xiàn)reeRTOS提供的功能包括:任務管理、時間管理、信號量、消息隊列、內(nèi)存管理等

  FreeRTOS支持優(yōu)先級和輪換時間片兩種調(diào)度算法,可根據(jù)用戶需要設置為可剝奪型內(nèi)核或不可剝奪型內(nèi)核。本文基于FreeRTOS給出了M2M終端實現(xiàn)PPP協(xié)商以及數(shù)據(jù)封裝傳輸?shù)能浖O計方案。

  基于狀態(tài)機設計GPRS連接任務

  由于網(wǎng)絡和信號較弱等原因,可能導致節(jié)點與GPRS網(wǎng)絡連接的失敗,采用基于狀態(tài)機的結(jié)構(gòu)設計方法對各個階段產(chǎn)生的錯誤進行處理,能保障模塊與GPRS網(wǎng)絡建立可靠連接。程序狀態(tài)機如圖2所示。

程序狀態(tài)機

   閑待命態(tài):此時mc35i處在離線關(guān)閉狀態(tài),節(jié)點處在低功耗模式下,系統(tǒng)復位后處于此狀態(tài)。

  GPRS參數(shù)設置態(tài):處理器控制啟動MC35i模塊后進入此狀態(tài),通過發(fā)送AT命令對模塊及必要的網(wǎng)絡參數(shù)進行設置,為使各個參數(shù)均設置成功,軟件設計中增加了容錯重試機制。

  PPP協(xié)商態(tài):GPRS參數(shù)設置完成后,通過發(fā)送AT*99***1#命令開始MC35i模塊與GPRS網(wǎng)絡ISP(網(wǎng)絡服務提供商) 的PPP協(xié)商軟件設計中采用LCPHandler()函數(shù)完成LCP協(xié)商,PAPHandler()完成認證,由IPCPHandler()完成IPCP 協(xié)商,如果最后獲得ISP和本節(jié)點的IP地址,則進入PPPOVER態(tài),此后就能進行數(shù)據(jù)的傳輸了,由于GPRS網(wǎng)絡等原因,PPP協(xié)商有時會失敗,此時應重啟MC35i模塊,再按照狀態(tài)機流程重新連接。

 

  UDP數(shù)據(jù)傳輸態(tài):當程序采用UDP方式進行數(shù)據(jù)傳輸時,程序進入此狀態(tài),通過xDataTrsmtTask()任務進行數(shù)據(jù)的UDP/IP封裝和解析。

  TCP數(shù)據(jù)傳輸態(tài):當節(jié)點調(diào)用uip_cionnect()函數(shù)與監(jiān)控中心建立連接后,程序進入TCP數(shù)據(jù)傳輸態(tài),進行基于TCP的數(shù)據(jù)傳輸。

  數(shù)據(jù)的封裝和傳輸

  通過GPRS進行數(shù)據(jù)的傳輸需要經(jīng)過Internet網(wǎng)絡進行中轉(zhuǎn),因而傳輸?shù)臄?shù)據(jù)封裝必須進行TCP/IP協(xié)議。文中利用軟件進行了數(shù)據(jù)封裝,需要傳輸?shù)臄?shù)據(jù)經(jīng)過傳輸層UDP協(xié)議頭封裝,然后是IP協(xié)議頭的封裝,最后進行PPP協(xié)議的封裝。經(jīng)過封裝傳輸?shù)組C35i的數(shù)據(jù)格式如表1所示。

MC35i的數(shù)據(jù)格式

  MC35i將接收到的數(shù)據(jù)透明地傳輸?shù)絀nternet網(wǎng)絡中。通過Internet網(wǎng)絡路由器中轉(zhuǎn),最終將數(shù)據(jù)傳輸?shù)奖O(jiān)控中心。接收端對接收到的數(shù)據(jù)按照相應的層次進行解析,從而確定數(shù)據(jù)的目標程序。

  系統(tǒng)軟件設計采用分層的結(jié)構(gòu),從底到上分別為:串口驅(qū)動層(物理層)、PPP協(xié)議層(鏈路層)、IP協(xié)議層(網(wǎng)絡層)、UDP協(xié)議和 ICMP層(傳輸層)以及應用層。在移植好的LwIP協(xié)議棧中,通過在各層中建立相應功能的線程,實現(xiàn)數(shù)據(jù)的封裝。底層軟件為上層軟件提供函數(shù)支持,上層軟件利用底層軟件完成應用程序的編寫和實現(xiàn)。軟件采用自底向上的設計方法逐步實現(xiàn)系統(tǒng)中各個函數(shù)的功能,各部分函數(shù)實現(xiàn)均采用模塊化的設計方法。每個任務對應一個模塊

  對每個任務單獨進行設計后,最終由FreeRTOS操作系統(tǒng)統(tǒng)一管理,通過采用信號量和郵箱的方式實現(xiàn)多個任務之間的通信,軟件各部分主要函數(shù)之間的關(guān)系如圖3所示。

軟件各部分主要函數(shù)之間的關(guān)系

  在MC35SerialISR()中將接收的數(shù)據(jù)存放到xQRxChars隊列中后,發(fā)送SemMC35Rx信號量來激活PPPRxTask()任務,通過對接收數(shù)據(jù)的解析,確定數(shù)據(jù)包的類型,然后由相應的函數(shù)對接收數(shù)據(jù)進行處理。

  如果接收的數(shù)據(jù)是應用程序的數(shù)據(jù),將由IPRx()函數(shù)判斷目標主機是否正確,再經(jīng)過傳輸層解析數(shù)據(jù)從而判定對數(shù)據(jù)處理的應用程序。最后由應用程序解析數(shù)據(jù)并執(zhí)行相應的功能,如將數(shù)據(jù)通過串口發(fā)送到主機、向數(shù)據(jù)采集系統(tǒng)發(fā)送控制命令、接收數(shù)據(jù)采集系統(tǒng)的數(shù)據(jù)并發(fā)送等。當接收隊列中所有數(shù)據(jù)均處理完畢后,延時250ms如果還沒有接收到數(shù)據(jù),則任務通過等待信號量SemMC35Rx將自己掛起。數(shù)據(jù)的發(fā)送過程是一個相反的過程。

  應用程序根據(jù)需要的功能建立UDPTxTask()或ICMPTxTask()任務,并將數(shù)據(jù)發(fā)送到xAPPTxQ隊列中。相應的任務再調(diào)用IPTx()和PPPTx()函數(shù)進行數(shù)據(jù)的封裝并將數(shù)據(jù)發(fā)送到XqTxChar隊列中,從而喚醒MC35SerialISR()中斷程序?qū)?shù)據(jù)通過串口發(fā)送到MC35i中進行傳輸。為提高系統(tǒng)的實時性,本文中FreeRTOS采用可剝奪內(nèi)核方式進行調(diào)度。采用FreeRTOS操作系統(tǒng)對任務進行管理簡化了軟件的編寫難度,同時提高了程序的可讀性和可移植性。

  總結(jié)

  基于GPRS m2m產(chǎn)品的無線數(shù)據(jù)傳輸以及遠程監(jiān)控系統(tǒng)是目前國內(nèi)外研究的熱點。本文采用完全免費的操作系統(tǒng)和TCP/IP協(xié)議棧給出的系統(tǒng)設計方案具備成本低、性能好、可升級等優(yōu)點,為遠程監(jiān)控系統(tǒng)相關(guān)領域的數(shù)據(jù)傳輸提供了一個可行的設計方案。

  參考文獻

1 余先濤,張濤,莫易敏.基于GPRS技術(shù)的無線遠程抄表的實現(xiàn)[J].機電一體化,2005,(2):52-55
2 摩托羅拉工程學院主編. GPRS網(wǎng)絡技術(shù)[M]. 北京-電子工業(yè)出版社,2005
3 Siemens mobile.MC35i Hardware Interface Description. MC35i_HD_V00.02. 2003.2
4 www.FreeRTOS.Org
5 Simpson. The Point-to-Point Protocol (PPP). RFC 1661. 1994

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。