Zigbee: Zigbee example update

* minor update for the zigbee example
This commit is contained in:
likunqiao 2022-01-11 15:52:34 +08:00
parent 3ba47f1628
commit 2c7f950084
14 changed files with 41 additions and 110 deletions

View File

@ -59,6 +59,9 @@ void zboss_signal_handler(zb_bufid_t bufid)
zb_zdo_app_signal_hdr_t *p_sg_p = NULL; zb_zdo_app_signal_hdr_t *p_sg_p = NULL;
zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p); zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p);
zb_ret_t status = ZB_GET_APP_SIGNAL_STATUS(bufid); zb_ret_t status = ZB_GET_APP_SIGNAL_STATUS(bufid);
zb_zdo_signal_device_annce_params_t *dev_annce_params = NULL;
zb_zdo_signal_macsplit_dev_boot_params_t *rcp_version = NULL;
zb_uint32_t gateway_version;
switch (sig) { switch (sig) {
case ZB_ZDO_SIGNAL_SKIP_STARTUP: case ZB_ZDO_SIGNAL_SKIP_STARTUP:
@ -68,6 +71,13 @@ void zboss_signal_handler(zb_bufid_t bufid)
case ZB_MACSPLIT_DEVICE_BOOT: case ZB_MACSPLIT_DEVICE_BOOT:
ESP_LOGI(TAG, "Zigbee rcp device booted"); ESP_LOGI(TAG, "Zigbee rcp device booted");
gateway_version = zb_esp_macsplit_get_version();
rcp_version = ZB_ZDO_SIGNAL_GET_PARAMS(p_sg_p, zb_zdo_signal_macsplit_dev_boot_params_t);
ESP_LOGI(TAG, "Zigbee rcp device version: %d.%d.%d", (rcp_version->dev_version >> 24 & 0x000000FF), (rcp_version->dev_version >> 16 & 0x000000FF), (rcp_version->dev_version & 0x000000FF));
ESP_LOGI(TAG, "Zigbee gateway version: %d.%d.%d", (gateway_version >> 24 & 0x000000FF), (gateway_version >> 16 & 0x000000FF), (gateway_version & 0x000000FF));
if (gateway_version != rcp_version->dev_version) {
ESP_LOGE(TAG, "rcp has different Zigbee stack version with Zigbee gateway! Please check the rcp software or other issues");
}
break; break;
case ZB_BDB_SIGNAL_DEVICE_FIRST_START: case ZB_BDB_SIGNAL_DEVICE_FIRST_START:
@ -100,11 +110,11 @@ void zboss_signal_handler(zb_bufid_t bufid)
} }
break; break;
case ZB_ZDO_SIGNAL_DEVICE_ANNCE: { case ZB_ZDO_SIGNAL_DEVICE_ANNCE:
zb_zdo_signal_device_annce_params_t *dev_annce_params = ZB_ZDO_SIGNAL_GET_PARAMS(p_sg_p, zb_zdo_signal_device_annce_params_t); dev_annce_params = ZB_ZDO_SIGNAL_GET_PARAMS(p_sg_p, zb_zdo_signal_device_annce_params_t);
ESP_LOGI(TAG, "New device commissioned or rejoined (short: 0x%04hx)", dev_annce_params->device_short_addr); ESP_LOGI(TAG, "New device commissioned or rejoined (short: 0x%04hx)", dev_annce_params->device_short_addr);
} break;
break;
default: default:
ESP_LOGI(TAG, "status: %d", status); ESP_LOGI(TAG, "status: %d", status);
break; break;
@ -115,7 +125,7 @@ void zboss_signal_handler(zb_bufid_t bufid)
} }
} }
void zboss_task() static void zboss_task(void *pvParameters)
{ {
ZB_INIT("zigbee gateway"); ZB_INIT("zigbee gateway");
zb_set_network_coordinator_role(IEEE_CHANNEL_MASK); zb_set_network_coordinator_role(IEEE_CHANNEL_MASK);
@ -125,11 +135,10 @@ void zboss_task()
ESP_ERROR_CHECK(zboss_start_no_autostart()); ESP_ERROR_CHECK(zboss_start_no_autostart());
while (1) { while (1) {
zboss_main_loop_iteration(); zboss_main_loop_iteration();
vTaskDelay(10 / portTICK_PERIOD_MS);
} }
} }
void app_main() void app_main(void)
{ {
zb_esp_platform_config_t config = { zb_esp_platform_config_t config = {
.radio_config = ZB_ESP_DEFAULT_RADIO_CONFIG(), .radio_config = ZB_ESP_DEFAULT_RADIO_CONFIG(),
@ -137,5 +146,5 @@ void app_main()
}; };
/* load Zigbee gateway platform config to initialization */ /* load Zigbee gateway platform config to initialization */
ESP_ERROR_CHECK(zb_esp_platform_config(&config)); ESP_ERROR_CHECK(zb_esp_platform_config(&config));
xTaskCreate(zboss_task, "zboss_main", 10240, xTaskGetCurrentTaskHandle(), 5, NULL); xTaskCreate(zboss_task, "zboss_main", 4096, NULL, 5, NULL);
} }

View File

@ -3,15 +3,4 @@ dependencies:
espressif/esp-zboss-lib: "~=0.0.4" espressif/esp-zboss-lib: "~=0.0.4"
## Required IDF version ## Required IDF version
idf: idf:
version: ">=4.1.0" version: ">=5.0.0"
# # Put list of dependencies here
# # For components maintained by Espressif:
# component: "~1.0.0"
# # For 3rd party components:
# username/component: ">=1.0.0,<2.0.0"
# username2/component2:
# version: "~1.0.0"
# # For transient dependencies `public` flag can be set.
# # `public` flag doesn't have an effect dependencies of the `main` component.
# # All dependencies of `main` are public by default.
# public: true

View File

@ -1,9 +1,3 @@
#
# libsodium
#
CONFIG_LIBSODIUM_USE_MBEDTLS_SHA=y
# end of libsodium
# #
# Partition Table # Partition Table
# #

View File

@ -46,13 +46,13 @@
#endif #endif
static const char *TAG = "ESP_ZB_RCP"; static const char *TAG = "ESP_ZB_RCP";
void zboss_signal_handler(zb_uint8_t param) void zboss_signal_handler(zb_bufid_t bufid)
{ {
zb_zdo_app_signal_hdr_t *sg_p = NULL; zb_zdo_app_signal_hdr_t *sg_p = NULL;
/* get application signal from the buffer */ /* get application signal from the buffer */
zb_zdo_app_signal_type_t sig = zb_get_app_signal(param, &sg_p); zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &sg_p);
if (ZB_GET_APP_SIGNAL_STATUS(param) == 0) { if (ZB_GET_APP_SIGNAL_STATUS(bufid) == 0) {
switch (sig) { switch (sig) {
case ZB_COMMON_SIGNAL_CAN_SLEEP: case ZB_COMMON_SIGNAL_CAN_SLEEP:
#if defined(ZB_USE_SLEEP) #if defined(ZB_USE_SLEEP)
@ -64,15 +64,15 @@ void zboss_signal_handler(zb_uint8_t param)
} else if (sig == ZB_ZDO_SIGNAL_PRODUCTION_CONFIG_READY) { } else if (sig == ZB_ZDO_SIGNAL_PRODUCTION_CONFIG_READY) {
ESP_LOGI(TAG, "Production config is not present or invalid"); ESP_LOGI(TAG, "Production config is not present or invalid");
} else { } else {
ESP_LOGI(TAG, "Device started FAILED status %d", ZB_GET_APP_SIGNAL_STATUS(param)); ESP_LOGI(TAG, "Device started FAILED status %d", ZB_GET_APP_SIGNAL_STATUS(bufid));
} }
if (param) { if (bufid) {
zb_buf_free(param); zb_buf_free(bufid);
} }
} }
void zboss_task() static void zboss_task(void * pvParameters)
{ {
ZB_INIT("esp_zigbee_rcp"); ZB_INIT("esp_zigbee_rcp");
while (1) { while (1) {
@ -80,7 +80,7 @@ void zboss_task()
} }
} }
void app_main() void app_main(void)
{ {
zb_esp_platform_config_t config = { zb_esp_platform_config_t config = {
.radio_config = ZB_ESP_DEFAULT_RADIO_CONFIG(), .radio_config = ZB_ESP_DEFAULT_RADIO_CONFIG(),
@ -88,5 +88,5 @@ void app_main()
}; };
/* load Zigbee rcp platform config to initialization */ /* load Zigbee rcp platform config to initialization */
ESP_ERROR_CHECK(zb_esp_platform_config(&config)); ESP_ERROR_CHECK(zb_esp_platform_config(&config));
xTaskCreate(zboss_task, "zboss_main", 4096, xTaskGetCurrentTaskHandle(), 5, NULL); xTaskCreate(zboss_task, "zboss_main", 4096, NULL, 5, NULL);
} }

View File

@ -3,15 +3,4 @@ dependencies:
espressif/esp-zboss-lib: "~=0.0.4" espressif/esp-zboss-lib: "~=0.0.4"
## Required IDF version ## Required IDF version
idf: idf:
version: ">=4.1.0" version: ">=5.0.0"
# # Put list of dependencies here
# # For components maintained by Espressif:
# component: "~1.0.0"
# # For 3rd party components:
# username/component: ">=1.0.0,<2.0.0"
# username2/component2:
# version: "~1.0.0"
# # For transient dependencies `public` flag can be set.
# # `public` flag doesn't have an effect dependencies of the `main` component.
# # All dependencies of `main` are public by default.
# public: true

View File

@ -106,7 +106,7 @@ static void bdb_start_top_level_commissioning_cb(zb_uint8_t mode_mask)
* *
* @param bufid Zigbee zboss stack buffer id used to pass signal. * @param bufid Zigbee zboss stack buffer id used to pass signal.
*/ */
void zboss_signal_handler(zb_uint8_t bufid) void zboss_signal_handler(zb_bufid_t bufid)
{ {
zb_uint8_t status = ZB_GET_APP_SIGNAL_STATUS(bufid); zb_uint8_t status = ZB_GET_APP_SIGNAL_STATUS(bufid);
zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, NULL); zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, NULL);
@ -212,7 +212,7 @@ static void esp_zb_light_cb(zb_bufid_t bufid)
} }
} }
void app_main() void app_main(void)
{ {
zb_ret_t zb_err_code; zb_ret_t zb_err_code;
zb_esp_platform_config_t config = { zb_esp_platform_config_t config = {

View File

@ -3,15 +3,4 @@ dependencies:
espressif/esp-zboss-lib: "~=0.0.4" espressif/esp-zboss-lib: "~=0.0.4"
## Required IDF version ## Required IDF version
idf: idf:
version: ">=4.1.0" version: ">=5.0.0"
# # Put list of dependencies here
# # For components maintained by Espressif:
# component: "~1.0.0"
# # For 3rd party components:
# username/component: ">=1.0.0,<2.0.0"
# username2/component2:
# version: "~1.0.0"
# # For transient dependencies `public` flag can be set.
# # `public` flag doesn't have an effect dependencies of the `main` component.
# # All dependencies of `main` are public by default.
# public: true

View File

@ -1,11 +1,5 @@
CONFIG_IDF_TARGET="esp32h2" CONFIG_IDF_TARGET="esp32h2"
#
# libsodium
#
CONFIG_LIBSODIUM_USE_MBEDTLS_SHA=y
# end of libsodium
# #
# Partition Table # Partition Table
# #

View File

@ -60,6 +60,7 @@ void zboss_signal_handler(zb_bufid_t bufid)
zb_zdo_app_signal_hdr_t *p_sg_p = NULL; zb_zdo_app_signal_hdr_t *p_sg_p = NULL;
zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p); zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p);
zb_ret_t status = ZB_GET_APP_SIGNAL_STATUS(bufid); zb_ret_t status = ZB_GET_APP_SIGNAL_STATUS(bufid);
zb_zdo_signal_device_annce_params_t *dev_annce_params = NULL;
switch (sig) { switch (sig) {
case ZB_ZDO_SIGNAL_SKIP_STARTUP: case ZB_ZDO_SIGNAL_SKIP_STARTUP:
@ -97,11 +98,11 @@ void zboss_signal_handler(zb_bufid_t bufid)
} }
break; break;
case ZB_ZDO_SIGNAL_DEVICE_ANNCE: { case ZB_ZDO_SIGNAL_DEVICE_ANNCE:
zb_zdo_signal_device_annce_params_t *dev_annce_params = ZB_ZDO_SIGNAL_GET_PARAMS(p_sg_p, zb_zdo_signal_device_annce_params_t); dev_annce_params = ZB_ZDO_SIGNAL_GET_PARAMS(p_sg_p, zb_zdo_signal_device_annce_params_t);
ESP_LOGI(TAG, "New device commissioned or rejoined (short: 0x%04hx)", dev_annce_params->device_short_addr); ESP_LOGI(TAG, "New device commissioned or rejoined (short: 0x%04hx)", dev_annce_params->device_short_addr);
} break;
break;
default: default:
ESP_LOGI(TAG, "status: %d", status); ESP_LOGI(TAG, "status: %d", status);
break; break;
@ -112,7 +113,7 @@ void zboss_signal_handler(zb_bufid_t bufid)
} }
} }
void app_main() void app_main(void)
{ {
zb_ret_t zb_err_code; zb_ret_t zb_err_code;
zb_esp_platform_config_t config = { zb_esp_platform_config_t config = {

View File

@ -3,15 +3,4 @@ dependencies:
espressif/esp-zboss-lib: "~=0.0.4" espressif/esp-zboss-lib: "~=0.0.4"
## Required IDF version ## Required IDF version
idf: idf:
version: ">=4.1.0" version: ">=5.0.0"
# # Put list of dependencies here
# # For components maintained by Espressif:
# component: "~1.0.0"
# # For 3rd party components:
# username/component: ">=1.0.0,<2.0.0"
# username2/component2:
# version: "~1.0.0"
# # For transient dependencies `public` flag can be set.
# # `public` flag doesn't have an effect dependencies of the `main` component.
# # All dependencies of `main` are public by default.
# public: true

View File

@ -1,11 +1,5 @@
CONFIG_IDF_TARGET="esp32h2" CONFIG_IDF_TARGET="esp32h2"
#
# libsodium
#
CONFIG_LIBSODIUM_USE_MBEDTLS_SHA=y
# end of libsodium
# #
# Partition Table # Partition Table
# #

View File

@ -231,7 +231,7 @@ static void bdb_start_top_level_commissioning_cb(zb_uint8_t mode_mask)
* *
* @param bufid Zigbee zboss stack buffer id used to pass signal. * @param bufid Zigbee zboss stack buffer id used to pass signal.
*/ */
void zboss_signal_handler(zb_uint8_t bufid) void zboss_signal_handler(zb_bufid_t bufid)
{ {
zb_zdo_app_signal_hdr_t *p_sg_p = NULL; zb_zdo_app_signal_hdr_t *p_sg_p = NULL;
zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p); zb_zdo_app_signal_type_t sig = zb_get_app_signal(bufid, &p_sg_p);
@ -281,7 +281,7 @@ void zboss_signal_handler(zb_uint8_t bufid)
} }
} }
void app_main() void app_main(void)
{ {
zb_ret_t zb_err_code; zb_ret_t zb_err_code;
zb_esp_platform_config_t config = { zb_esp_platform_config_t config = {

View File

@ -3,15 +3,4 @@ dependencies:
espressif/esp-zboss-lib: "~=0.0.4" espressif/esp-zboss-lib: "~=0.0.4"
## Required IDF version ## Required IDF version
idf: idf:
version: ">=4.1.0" version: ">=5.0.0"
# # Put list of dependencies here
# # For components maintained by Espressif:
# component: "~1.0.0"
# # For 3rd party components:
# username/component: ">=1.0.0,<2.0.0"
# username2/component2:
# version: "~1.0.0"
# # For transient dependencies `public` flag can be set.
# # `public` flag doesn't have an effect dependencies of the `main` component.
# # All dependencies of `main` are public by default.
# public: true

View File

@ -1,11 +1,5 @@
CONFIG_IDF_TARGET="esp32h2" CONFIG_IDF_TARGET="esp32h2"
#
# libsodium
#
CONFIG_LIBSODIUM_USE_MBEDTLS_SHA=y
# end of libsodium
# #
# Partition Table # Partition Table
# #