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

Z-Stack 3.0.2终端无法入网问题

Z-Stack 3.0.2,终端正常加入协调器后,工作正常,

需要升级终端估计是时候,直接把终端断电后刷新的固件,

此时终端再加入原来的协调器,发现加上了一会就被踢了,再加上又被踢了,无限循环,

之前有咨询,你们回复说把BDB_DEFAULT_TC_REQUIRE_KEY_EXCHANGE关闭,但是关闭了测试还有会出现被踢的现象

请帮忙分析可能的原因以及解决办法?

#ifdef TP2_LEGACY_ZC
#define BDB_DEFAULT_TC_REQUIRE_KEY_EXCHANGE                FALSE
#else
#define BDB_DEFAULT_TC_REQUIRE_KEY_EXCHANGE                FALSE//默认TRUE#endif

Alvin Chen:

需要升级终端估计是时候,直接把终端断电后刷新的固件, NV已经没有了 会被踢出。要是OTA可以正常。

user5367314:

回复 Alvin Chen:

1.现在出现终端刷固件后一直被踢的现象后只能把协调器也执行bdb_resetLocalAction后终端才能加入?
这样所有终端全部掉线了,需要全部执行bdb_resetLocalAction才能重新加入,很麻烦
如果不用OTA升级,有没有什么解决方案?在协调器里把不在线的终端删除了是否可以?
2.协调器和终端相互发私有的数据,双方发送都采用zcl_SendReportCmd函数
请问接收方是在static zclGeneral_AppCallbacks_t zclSampleLight_CmdCallbacks 里处理数据?
还是在下面函数里处理
case ZCL_INCOMING_MSG:// Incoming ZCL Foundation command/response messageszclSampleLight_ProcessIncomingMsg( (zclIncomingMsg_t *)MSGpkt );break;
我目前在case ZCL_INCOMING_MSG:里数据收到的数据,可以收到,请问在这里处理和在zclSampleLight_CmdCallbacks 里处理有啥区别?

YiKai Chen:

回复 user5367314:

1. 重刷固件后NV已经被擦除,所以必須重新加入,如果只是重新上電,终端有使能NV_RESTORE的狀態應該要能加入原來網絡的
2. zclSampleLight_CmdCallbacks 主要是處理一些標準的zcl command,私有的数据是在case ZCL_INCOMING_MSG:函数里处理

user5367314:

回复 YiKai Chen:

重刷固件后NV已经被擦除,所以必須重新加入
重新加入是肯定的,现在的问题是加入协调器后一会就被踢了,再加进入还是被踢,一直循环
#define BDB_DEFAULT_TC_REQUIRE_KEY_EXCHANGEFALSE//默认TRUE

YiKai Chen:

回复 user5367314:

重新加入時协调器有使能permit join嗎?

user5367314:

回复 YiKai Chen:

1.协调器和终端都使能了BDB_COMMISSIONING_MODE_NWK_STEERING,能加入,只是加入后大概十几秒就被踢了,现象和#define BDB_DEFAULT_TC_REQUIRE_KEY_EXCHANGE TRUE时的现象类似,能加入,只是加入一会就被踢了
2.用zcl_SendReportCmd发送私有数据的时候,我是在ZCL_CLUSTER_ID_GEN_ON_OFF cluster下定义了私有的attribute,这样是否可以?
如果可以的话还需要初始化哪些?zclSampleXXX_InClusterList和zclSampleXXX_OutClusterList,zclSampleXXX_SimpleDesc,zclSampleXXX_ResetAttributesToDefaultValues,zclSampleXXX_Attrs这些都要初始化吗还是只要初始化其中的一部分?

YiKai Chen:

回复 user5367314:

1. 有抓包檔可以附上來看看嗎?
2. 可以在ZCL_CLUSTER_ID_GEN_ON_OFF cluster下定义了私有的attribute,基本上其他地方不需要初始化

user5367314:

回复 YiKai Chen:

放私有数据的数组,是否要在zclSampleXXX_Attrs里面初始化一下?类似下面的?
如果不做下面的初始化是有问题?// ***私有数据*** //{ZCL_CLUSTER_ID_GEN_ON_OFF,{// Attribute recordATTRID_ON_OFF_OFF_ELEC,//私有attributeZCL_DATATYPE_CHAR_STR,ACCESS_CONTROL_READ | ACCESS_CONTROL_WRITE | ACCESS_REPORTABLE,(void *)zclSampleSw_SensorData//私有数据所在的数组}},

YiKai Chen:

回复 user5367314:

在zclSampleXXX_Attrs里面需要加上那段初始化程序沒錯

user5367314:

回复 YiKai Chen:

好的,因为协调器和终端是互发私有数据,是不是在协调器和终端上都需要做如下的初始化?
我是基于ZCL_CLUSTER_ID_GEN_ON_OFFcluster定义的私有attribute
请问是否要在InClusterList和OutClusterList里面都把ZCL_CLUSTER_ID_GEN_ON_OFF加进去?
const cId_t zclSampleXXX_InClusterList[] =
{……ZCL_CLUSTER_ID_GEN_ON_OFF……
};
const cId_t zclSampleXXX_OutClusterList[] =
{……ZCL_CLUSTER_ID_GEN_ON_OFF……
};

赞(0)
未经允许不得转载:TI中文支持网 » Z-Stack 3.0.2终端无法入网问题
分享到: 更多 (0)