【導讀】ZigBee憑借自組織、穩定性好、抗干擾性強、功耗低等優勢,在農業、工業、軍事、醫療領域都廣泛應用。但因其控制中心大多是PC,所以在野外特殊環境下無法應用。WiFi是覆蓋面廣、無需布線的無線通信技術。本文提出了基于ZigBee與WiFi的雙模網關的設計方案,這種設計能夠適應復雜環境,具有良好的發展前景。
1 系統總體結構
系統由ZigBee模塊、開發板模塊和WiFi模塊組成。ZigBee模塊中,Coordinator作為ZigBee網絡的中心節點,負責控制和監測ZigBee路由節點,每一個路由節點攜帶一個傳感器,負責把傳感器采集的數據發送給Coordinator。開發板模塊作為協議轉換的樞紐,用于解析 Coordinator傳輸的數據。WiFi模塊,將開發板解析的數據封裝成WiFi幀。這樣就實現雙模無線網關的轉換,系統結構如圖1所示。
圖1 系統總體結構
2 無線網關的設計
2.1 ZigBee數據流分析
ZB253002模塊是基于CC2530F256芯片,執行ZigBee2007/PRO協議的 ZigBee模塊,它具有ZigBee協議的全部特點。其主要的特點:
①自動組網。所有的模塊通電即自動組網,協調器(Coordinator)自動給所有的節點分配地址,不需要用戶手動分配地址,網絡加入、應答等專業ZigBee組網流程。
②簡單數據傳輸。ZB253002模塊可以理解為“無線的 RS232 連接”,通過串行端口即可在任意節點間進行數據傳輸。ZigBee模塊有兩種數據的傳輸方式:數據透明傳輸,只要傳送的第一個字節不是0xFE、0xFD 或0xFC,則自動進入數據透明傳輸方式;點對點的數據傳輸方式,數據傳輸的格式為0xFD(數據傳輸命令)+ 0x0A(數據長度)+(目標地址)+(數據)。由協調節點傳輸給開發板的數據添加以0xFE開頭的15字節的節點信息,用來提供給 TI Sensor Monitor,觀察網絡結構。
Zigbee模塊設置命令表如表1所列。
表1 Zigbee模塊設置命令表
2.2 通信協調器的設計
Coordinator是整個網關轉換和無線傳感器網絡建立的中心,是數據傳輸的中心樞紐。因此,Coordinator的設計關系到整個系統的穩定性和可靠性。Coordinator CC2530采用ZigBee2007協議棧。ZStack是TI公司提供的一種輪詢式操作系統,借助于Z-Stack,Coordinator上電后,首先進行硬件和網絡初始化,然后創建3個任務:
①ZigBee網絡任務,該任務通過Coordinator與其子節點的“綁定”完成。其綁定的過程,協調器建立網絡,創建綁定表,并設定允許綁定模式,子節點發送綁定請求,Coordinator更新綁定表并響應子節點。
②串口協議解析任務,該任務用于解析來自開發板和子節點的數據,并將解析后的數據傳輸給子節點任務或發送給開發板。
③子節點任務,該任務主要用于接收子節點返回的數據,并將數據傳輸給串口協議解析任務。這樣ZigBee協議幀的解析就轉到開發板端,由Linux操作系統完成,Linux解析完成后,將有效的數據放入指定的共享內存。當 BOA收到外部Web請求,調用相應的CGI獲取共享內存中的數據,并經由無線網卡以WiFi的形式傳送給用戶。
2.3 傳輸協議的實現
本設計經由Linux操作系統完成ZigBee協議的解析和WiFi協議幀的形成,主要的重點在于Coordinator與Linux串口傳輸協議的設計。串口傳輸協議自定義幀格式如下:
串口傳輸協議自定義幀格式
自定義幀的格式由幀頭、功能號、有效數據長度、有效數據和FCS校驗5部分組成。幀頭定義為0x02;功能號因獲取的數據類型不同而異,有關幀格式功能碼定義如表2所列;有效數據長度用于標識讀取有效數據的長度范圍,最大值為255;有效數據存放ZigBee協議幀;FCS校驗用于數據段的校驗。
表2 協議幀功能碼
根據設計中的自定義幀格式,報文中的有效數據被封裝成固定格式,通過串口進行傳送。開發板和Coordinator通過監聽串口數據分別對收到得數據包進行解析。解析流程(以Coordinator為例)如圖2所示,具體解析過程如下。
Step1:Coordinator監聽串口(以中斷的方式),直到串口有數據。
Step2:讀取一個字節,判定是否為自定義幀頭。若不是,丟棄數據,回到Step1。
Step3:讀取兩個字節,匹配功能碼。匹配失敗,置錯誤標志位,丟棄數據,回到Step1。
Step4:讀取一個字節,若該字節數據為0,則直接跳到Step6。
Step5:若讀到的數據值為N(0 Step6:讀取兩個自己數據,對Step1~5讀到得數據FCS校驗,若無差錯,發送N個字節的有效數據給Z-Stack協議棧,由ZStack協議棧發送給子節點?;氐絊tep1。
Step7:若FCS校驗錯誤,置錯誤標志位,丟棄已讀數據,回到Step1。
圖2 串口協議解析流程圖
[page] 3 系統軟件設計
3.1 系統軟件架構
無線網關軟件采用模塊化設計,如圖3所示,由硬件驅動層、操作系統、網絡協議層和應用程序組成。硬件驅動層主要描述網關節點中ZigBee模塊、 WiFi模塊以及其他外設的一些驅動;操作系統層移植ARM Linux,添加無線網卡驅動模塊;網絡協議層主要包括ZigBee協議棧和WiFi協議棧;應用程序層主要移植了嵌入式Web服務器(BOA)、嵌入式數據庫(Sqlite)、CGIC庫和圖形化用戶界面(Qt)。
圖3 系統軟件架構圖
3.2 系統軟件流程
根據系統軟件架構圖,系統軟件數據流詳細設計如圖4所示。
圖4 系統數據流圖
以ZigBee終端節點發送至異地終端瀏覽器的數據為例,介紹數據傳送的整個過程。當ZigBee協調器接收到來自ZigBee終端節點的數據后,封裝成自定義幀的格式經由串口傳送給Linux傳輸協議,經協議解析,將有效數據寫入共享內存。當收到外部Web請求時,Web服務器通過CGI實時獲取共享內存中的數據,并動態更新網頁,經由WiFi無線網卡以無線的形式傳送至終端瀏覽器。3.3 測試與驗證
利用嵌入式技術對兩種協議進行解析,完成協議轉換,最終利用手機通過WiFi遠程訪問Web頁面,讀取ZigBee終端傳感器數據,并對ZigBee終端的小燈開關進行遠程控制,實現雙模網關的基本功能。實驗結果如圖5所示。
圖5 實驗結果圖
結語
本文通過分析ZigBee與WiFi協議棧的特點,提出了一種雙模無線網關轉換的方案,該方案可以很好地完成ZigBee組網、遠程數據采集和遠程控制等任務。實驗結果表明,基于ZigBee和WiFi的雙模網關切實可行,可以實現全無線網絡的組建,為網絡通信從有線向無線過渡提供了一種解決方案。
相關閱讀:
技術快訊:未來家電的充電將會向“WiFi”看齊
深度解析ZigBee無線終端溫度測試系統電路
論智能家庭的物聯網連接—ZigBee技術