基于CC2430實現終端選擇協調器入網
近年來,ZigBee無線數據網絡在我國應用越來越多。在很多地方取代了局域網。實際應用于樓宇監控系統、無線方式集中抄表以及礦山救援系統和家電控制等等。文中談及在我國有較多客戶使用的TI公司的產品CC2430。
1 問題的提出
在一片不大的區域內,有數個信道相同的協調器,但是PAN ID不同。當設置了終端的PAN ID后,終端只加入和其上存儲的PAN ID相同的協調器。目前本無線組網項目使用的是TI公司的CC2430,其上的ZigBee協議棧為TI的Z-STACK 1.4.3-1.2.1。由于TI公司的策略是終端比較隨機的加入其中的一個協調器,即使其上已經定義了特定的PAN ID。從少量的實驗來看,CC2430作為終端優先加入PAN ID號比較小的協調器。用戶一般無法讓終端選擇,并且終端掃描網絡和請求入網的過程都沒有給出源代碼。這樣便給這類實際應用帶來不便。
2 問題分析
關于CC2430/2431網絡的形成,可以參考《ZigBee技,術實踐教程》一書。該書為北京航空航天大學出版社出版,高守瑋和吳燦陽主編。
路由器和終端試圖加入一個網絡時,首先調用NLME_NetworkDiscoveryRequest()函數。該函數將進行網絡掃描,其結果由函數ZDO_NetworkDiscoveryConfirmCB()返回。而發現網絡存在后,將調用NLME_OrphanJoinRequest()函數試圖加入網絡。其結果由函數ZDO_JoinIndicationCB()返回。
遺憾的是,網絡掃描和請求入網兩個函數都沒有源代碼,造成無法修改的困境??陀^地說,在TI公司的ZSTACK上修改某些參數常常是比較困難的。只好從提供了源代碼的ZDO_NetworkDiscoveryConfirmCB()函數和ZDO_JoinIndicationCB()函數來想辦法。檢測ZDO_NetworkDiscoveryConfirmCB()的代碼,發現其最終調用ZDO_FinishProcessingMgmtNwkDiscReq()函數。
而在該函數中,有對路由器的特殊處理。條件編譯變量RTR_NWK代表有路由器功能的設備,雖然協調器可以兼做路由器,但執行這段代碼的只可能是普通的路由器。
#if defined(RTR_NWK)
……
#endif
……中的代碼檢索返回的網絡信息描述結構,查看有沒有和存儲的PAN ID相同的協調器。觀察ZDObject.c文件中的ZDO_StartDevice()函數,當啟動設備模式為“再繼續”時,即startMode==MODE_RESUME,終端設備以孤點方式請求加入網絡。再繼續模式實際上是標識非協調器設備處于網絡掃描完成,準備請求入網的狀態。分析到此,可以想出辦法了。首先定義一個檢查是否有PAN ID相同的協調器的全局變量bool變量p_matching。初始化時設其為FALSE。
3 解決方法和實際代碼
對剛才提及的代碼段,增加終端對返回的網絡信息描述結構的查詢。

在ZDApp.c中修改ZDApp_event_loop()函數,在調用ZDO_StartDevice(…)之前,亦即在終端設備掃描網絡和請求入網前增加一段代碼。當終端和協調器PAN ID不同,并且是再繼續模式時,重新搜索是否有與PAN ID相同的協調器,而不請求人網。

評論