TI中文支持网
TI专业的中文技术问题搜集分享网站

TI ZigBee FAQ 常见问题解答

1,TI的ZigBee协议栈不同版本的区别,如何选择合适的协议栈进行产品开发
 
TI ZigBee 协议栈Z-Stack从最开始的Z-Stack 0.1到大家熟悉的Z-Stack 2.5.1a,以及到现在Z-Stack Home 1.2.1, Z-Stack Lghting 1.0.2, Z-Stack Energy 1.0.1, Z-Stack Mesh 1.0.0. 在协议栈的升级过程TI主要对协议栈做了两方面的工作,1) 根据ZigBee Alliance的ZigBee Specification进行一些新的Feature添加,比方说ZigBee2007是树形的路由,在ZigBee Pro中有了Mesh路由,并且提出了MTO和Source Routing等路由算法,所以TI的把相应新的功能添加到协议栈上去。当然有一部分是Spec中相关bug的修正,比方说有些描述模棱两可的;2) TI ZigBee协议栈本身软件bug的修复。一个版本的协议栈相对于之前一个版本协议栈的区别,都可以在协议栈安装目录下的Release Note中找到。
在Z-Stack 2.5.1a以后,TI的协议栈并没有继续以Z-Stack 2.6.x的形式直接发布,而是按照Application Profile的方式来发布了,原因在于TI希望开发者根据实际的应用选择更有针对的性的协议栈进行开发。像Z-Stack Home 1.2.1之类的协议栈,主要包括两部分,1)核心协议栈Core Stack,这部分起始就是之前的Z-Stack 2.5.1a以后的延续版本,可以在协议栈安装目录下 Z-Stack Core Release Notes.txt文件中找到,Version 2.6.2 。2)应用协议栈 Profile相关,这部分主要跟实际应用相关的,Home Automation 协议栈里都是ZigBee Home Automation Profile相关的实现。同样Z-Stack Lghting 1.0.2和Z-Stack Energy 1.0.1也是一个Core Stack再加上应用上的Profile。
1)Z-Stack Home 1.2.2a 针对智能家居相关产品的开发
2)Z-Stack Lighting 1.0.2 针对ZLL相关产品的开发
3)Z-Stack Energy 1.0.1 针对智能能源,Meter, In Home Display, 等相关产品的开发
4)Z-Stack Mesh 1.0.0 针对相关私有应用的产品的开发,只利用标准ZigBee协议相关功能, Mesh路由等,应用层有开发者自己定义。
在ZigBee联盟发布ZigBee 3.0协议以后,最新的ZigBee协议栈是Z-Stack 3.0, 目前支持的设备有CC2530, CC2538, CC2652R。
 
2,产品如何进行标准ZigBee测试认证,需要了解哪些,需要走什么流程
 

以开发标准ZigBee Home Automation相关产品为例。首先开发者开发产品时要按照ZigBee Home Automation Profile Specification 中描述的产品进行开发,这个文档可以在www.zigbee.org下载到。在完成产品的开发后,开发着需要了解ZigBee Home Automation Profile Test Specification, 这个文档描述了一个特定产品需要在Test House过的相关测试项,文档也可以在www.zigbee.org下载到,另外除了以上两个文档以外还有一个PICS文档,这个文档专门用于描述需要过认证测试产品所支持的功能,开发者根据开发产品的实际红能,和Specification中所要求的功能,在文档中进行打钩确认。下面是测试的流程,

1) 首先加入ZigBee联盟,一般可以有测试实验室帮助完成。
2) 寄送样品到测试实验室,完成PICS文档的填写。
3) 第一轮预测试,测试实验室对测试结果反馈,开发者修改样品代码。
4) 测试实验室对修改后的样品进行验证,然后开始正式测试。
5) 测试实验室协助开发者完成ZigBee联盟网上认证申请资料的准备和提交。
6) 测试实验室提交正式测试报告给ZigBee联盟。联盟会完成审核并发证
目前国内可以完成标准ZigBee测试的测试实验室有两家
1) CESI 北京 中国标准化电子研究所。
2) Element 深圳办事处(总部在英国)
详细可以参考下面的wiki地址,
http://processors.wiki.ti.com/index.php/ZigBee_Product_Certification_Guide
 
 

3,设备的64位 MAC地址是怎么样选取的?
在CC2530/CC2538/CC2630中分为两个IEEE地址,一个称为Primary IEEE地址,另外称为Secondary地址。Primary IEEE地址是存放在芯片的Information Page里面,这个地址是TI向IEEE协会购买的,每个芯片的地址都是唯一的。并且用户只能Read这个值,没办法擦除/修改。在协议栈中直接通过读地址可以获得 osal_memcpy(aExtendedAddress, (uint8 *)(P_INFOPAGE+HAL_INFOP_IEEE_OSET), Z_EXTADDR_LEN)。 Secondary地址是存放在CC2530里的Flash最后一个Page里面,用户可以进行Read/Write. 通过函数HalFlashRead(HAL_FLASH_IEEE_PAGE, HAL_FLASH_IEEE_OSET, aExtendedAddress, Z_EXTADDR_LEN);。
协议栈运行是,是如何选择Primary IEEE地址或者Secondary地址作为设备的MAC地址的,具体在函数zmain_ext_addr(void)操作。
1) 从NV中读取 IEEE地址,如果已经存在(都不为0xFF),就使用该地址作为MAC地址了。
2) 如果1)中没有,从Secondary IEEE地址存放位置读取,如果有(都不为0xFF),把该地址写入到NV中,以后就用该地址作为MAC地址了。
3) 如果2)中没有,从Primary IEEE地址存放位置读取,如果有(都不为0xFF),把该地址写入到NV中,以后就用该地址作为MAC地址了
4) 如果3)中没有,就随机产生一个64位的变量,写入到NV中,并作为MAC地址。
 
4,End Device是低功耗设备, 有电池供电, 节点在断网以后,如何能够禁止节点持续搜索网络,或者把发送Beacon Request间隔增大

1)启动搜索网络 uint8 ZDApp_StartJoiningCycle( void )
停止搜索网络 uint8 ZDApp_StopJoiningCycle( void )
 
2) 更改发送Beacon Request的周期
修改变量zgDefaultStartingScanDuration
// Beacon Order Values
#define BEACON_ORDER_NO_BEACONS     15
#define BEACON_ORDER_4_MINUTES      14  // 245760 milliseconds
#define BEACON_ORDER_2_MINUTES      13  // 122880 milliseconds
#define BEACON_ORDER_1_MINUTE       12  //  61440 milliseconds
#define BEACON_ORDER_31_SECONDS     11  //  30720 milliseconds
#define BEACON_ORDER_15_SECONDS     10  //  15360 MSecs
#define BEACON_ORDER_7_5_SECONDS     9  //   7680 MSecs
#define BEACON_ORDER_4_SECONDS       8  //   3840 MSecs
#define BEACON_ORDER_2_SECONDS       7  //   1920 MSecs
#define BEACON_ORDER_1_SECOND        6  //    960 MSecs
#define BEACON_ORDER_480_MSEC        5
#define BEACON_ORDER_240_MSEC        4
#define BEACON_ORDER_120_MSEC        3
#define BEACON_ORDER_60_MSEC         2
#define BEACON_ORDER_30_MSEC         1
#define BEACON_ORDER_15_MSEC         0


5,如何让End Device进入低功耗状态,休眠时间是如何设定的?

在协议栈宏定义中使能POWER_SAVING后,然后在f8wConfig.cfg文件里面把-DRFD_RCVC_ALWAYS_ON=FALSE,就可以让End Device进入休眠状态。
关于休眠的时间是有OSAL操作系统的调度来决定,每次休眠时间都是按照最新会发生的一个Event Timeout作为休眠时间。具体在协议栈hal_sleep函数中有说明。
这个timeout主要分为两类,一类是应用层事件的timeout,另外一类是MAC层事件的timeout,
1)应用层的timeout的时间,是在osal_pwrmgr_powerconserve( void )函数中,通过osal_next_timeout();获得的。
2)MAC层的timeout时间,是通过halSleep( uint16 osal_timeout )函数里面,通过MAC_PwrNextTimeout();来获得的。
 
6,ZigBee 3.0协议栈有哪些新的东西?
请参考下面的链接,介绍了ZigBee 3.0协议栈相对于之前ZigBee Home Automation/ZigBee Light Link 所增加的东西。
http://processors.wiki.ti.com/index.php/What%27s_New_in_ZigBee_3.0
 
7,TI ZigBee协议栈中关于终端设备的状态机切换
http://www.deyisupport.com/question_answer/wireless_connectivity/zigbee/f/104/t/104629.aspx 
 
8,关于TI协议栈中OAD和OTA的区别
      OAD全称Over the Air Download, OTA全称Over the Air. 这两个实现的功能都一样,都可以叫做对程序的空中升级。在早期的ZigBee协议标准中,并没有关于节点程序空中升级方面的标准,但是很多客户都对空中升级有需求,所以TI自己开发了一套关于程序空中升级的协议栈,并且命名为OAD。后来ZigBee联盟看到产品对空中升级的需求越来越来,随机也指定了空中升级方面的标准,命名为OTA,该标准也是参考了TI的OAD实现方式,做了相关的修改。所以TI的早期协议栈中,空中升级叫OAD,后来的协议栈中跟随ZigBee联盟的空中升级协议,就叫OTA了。
 
9,如果在非低功耗设备中,未焊接32K晶振,Z-Stack协议栈需要怎么修改?
在Z-Stack协议栈中,初始化都有对使用的晶振是否稳定进行检测。如果未焊接32K晶振,则需要对下面的代码进行修改。TI Z-Stack 协议栈默认是使用32K晶振的。
在hal_board_cfg.h文件,
#define OSC32K_CRYSTAL_INSTALLED FALSE
 
10,如果开发基于ZigBee Mesh网络的私有应用,应该选择哪个协议栈?
很多用户只想把zigbee mesh网络的功能运用在自己的系统或者产品中,并不需要完全按照zigbee 定义的应用层规范来做,特别是一些行业性的应用。针对这样的应用需求,应该如何选择TI 合适的协议栈进行产品开发呢?
http://www.deyisupport.com/question_answer/wireless_connectivity/zigbee/f/104/t/132197.aspx
 
11,使用CC2630/CC2650进行ZigBee开发,Debug时可以在Core stack代码进行下断点调试吗?
可以下的,你要下载断电的代码对应的文件,一定要提前打开,然后进行Debug,就可以去打开的文件进行Debug了。
 
12,Zigbee协调器是如何选择合适的信道创建网络?
Zigbee网络的创建必须有协调器来完成,一个Zigbee网络有且只有一个协调器。Zigbee协调器在创建网络时主要完成的是网络信道的选择和PANID的生成。关于信道的选择,大致可以分为两个步骤,1)被动扫描也叫能量扫描Energy Scan,所谓被动扫描就是协调器将自己的接收机打开,然后在事先设定的信道列表上依次扫描,扫描后会得到每个信道的能量值,这个能量主要来自其他的Zigbee网络,或者其他的2.4GHz无线信号。协调器会将能量值高于事先设定的阈值的信道认为有较大的干扰存在,将该信道排除。2) 主动扫描Active Scan,在第一轮扫描以后留下的信道中,依次发送Beacon Request,如果收到对应的Beacon数据包,认为该信道中存在其他的Zigbee。最后协调器会选择一个没有其他的Zigbee网络PANID., 或者存在Zigbee网络最少的信道建立自己的网络并且设定一个没有冲突的PANID.
 
13,如何使用免费的Wireshark做Zigbee Sniffer抓包工具?
https://e2echina.ti.com/question_answer/wireless_connectivity/zigbee/f/104/t/150032
14,删除UI,使用TI Zigbee 3.0协议栈快速进入产品开发模式
https://e2echina.ti.com/question_answer/wireless_connectivity/zigbee/f/104/t/146528
 
15, 但使用如何优化CC2530的Flash 和RAM
 http://www.ti.com/lit/wp/swra635/swra635.pdf
Susan Yang:

多谢VV分享!

miffy:

关于Z-stack 3.0中ZNP部分文档Z-Stack ZNP Interface Specification.pdf描述错误的说明:

在第18页部分关于ZNP上电时序的说明

3.2.3 ZNP startup procedure for Z3.0 implementation

第一步中的ZB_WRITE_CONFIGURATION命令在该文档没有详细说明,在早期协议栈附带文档有说明,现摘录如下,基本原理就是把一些配置参数预先写入到芯片自带的ROM里面,例如信道,启动后的设备类型(coordinator、router、end-device)

Jin Li9:

请教V大,我要路由器协调器烧2007pro,终端烧mesh1.0,有问题吗?因为想的是终端用msp430+cc2520的方式,协调器 路由器用cc2530.或者外挂mcu怎么移植一体mcu的程序

Jin Li9:

还有就是只找到了exp5438的mesh例程 没找到f2系列的.而且在5438例程里面,好像SPI驱动cc2520的的程序要自己写?

qian li8:

VV大神我想问一下,为什么zstack3.0,编译工程模板生成的bin文件都有512k大呢?而CC2538最大的flash也只有512k啊,我使用的是IAR FOR ARM 8.1的版本,编译官方模板,生成的bin文件就有512k了,求解答怎么回事呢?

Xian Wang42:

您好,我现在在用cc2538做zigbee的相关开发,想问一下您有关MAC地址的问题。

1)在初始化的时候是在哪个地方读取的MAC地址的信息?

2)如果要手工write一个MAC地址到flash的最后一页然后再读取是不是就是先调用HalFlashWrite(),然后再调用HalFlashRead(HAL_FLASH_IEEE_PAGE, HAL_FLASH_IEEE_OSET, aExtendedAddress, Z_EXTADDR_LEN)。

3)如果要是用HalFlashWrite()写到里头一个MAC地址的话,它的函数定义是HalFlashWrite(uint16 addr, uint8 *buf, uint16 cnt), 这个里头的addr要怎么定义才能写到flash相应的存放secondary MAC的地方呢?

4)您在HalFlashRead(HAL_FLASH_IEEE_PAGE, HAL_FLASH_IEEE_OSET, aExtendedAddress, Z_EXTADDR_LEN)这个函数中使用的参数HAL_FLASH_IEEE_PAGE和HAL_FLASH_IEEE_OSET,我在zstack的代码里都没找到,请问我可以直接调用这两个参数么?需要额外加什么头文件之类的东西么?

youfeng lai:

13 无法打开连接,无权访问

YiKai Chen:

回复 youfeng lai:

13,如何使用免费的Wireshark做Zigbee Sniffer抓包工具? 

可以連結到 dev.ti.com/…/ 的Packet sniffer章節下的wireshark就有詳細說明

Susan Yang:

赞!

Alvin Chen:

消灭零回复!

赞(0)
未经允许不得转载:TI中文支持网 » TI ZigBee FAQ 常见问题解答
分享到: 更多 (0)