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