Zigbee SDK Version 8.2 Revision 2 (September 24, 2025) - Release Notes#
Simplicity SDK Version 2025.6.2
Silicon Labs is the vendor of choice for OEMs developing Zigbee networking into their products. The Silicon Labs Zigbee platform is the most integrated, complete, and feature-rich Zigbee solution available.
Silicon Labs EmberZNet SDK contains Silicon Labs’ implementation of the Zigbee stack specification.
Click here for earlier releases.
Release Summary#
Key Features | API Changes | Bug Fixes | Chip Enablement
Key Features#
- Updated filtering of InterPAN messages 
- GCC Link Time Optimization (LTO) 
- Added support for Tunneling functionality in Zigbee Direct. 
- Improved status notification for packet sent 
- Application Initialization Utilizing sl_main. 
Revision 1#
Added Common Token Manager integration.
API Changes#
- sl_zigbee_af_incoming_packet_filter_cb 
- sl_zigbee_af_outgoing_packet_filter_cb 
- sl_zigbee_send_raw_message_with_tag 
- sl_zigbee_af_zll_unset_factory_new 
- sl_zigbee_gp_clear_proxy_table 
- sl_zigbee_gp_proxy_table_remove_entry 
- sl_zigbee_af_green_power_cluster_gp_sink_close_commissioning_window 
- sl_zigbee_set_join_uses_install_code 
- sl_zigbee_get_join_uses_install_code 
- sl_zigbee_af_tc_link_key_update_now 
- sl_zigbee_af_gpep_incoming_message_cb 
- sl_zigbee_af_ncp_gpep_incoming_message_handler 
- sl_zigbee_gpep_incoming_message_handler 
- sl_zigbee_af_set_t_c_link_key_update_timer_milli_seconds 
Revision 2#
- sl_zigbee_af_mac_filter_match_message_cb 
- sl_zigbee_ezsp_mac_filter_match_message_handler 
- sl_802154_filter_match_message_handler 
Bug Fixes#
See Bug Fixes.
Chip Enablement#
- xGM260P PCB Module 
- xGM270S SiP Module 
- xG29 EFR32MG29B140F1024IM40 
Revision 2#
- SiXG301 SiLabs Series 3 chip and its radio boards. 
Key Features#
New Features | Enhancements | Removed Features | Deprecated Features
New Features#
- Updated filtering of InterPAN Messages - Updated the message filtering mechanism to allow the inter-pan messages to be available to the application. This required the following updates: - Added new packet type SL_ZIGBEE_PACKET_TYPE_INTERPAN macro for general inter-pan message identification. 
- The existing packet SL_ZIGBEE_ZIGBEE_PACKET_TYPE_INTERPAN has been renamed to SL_ZIGBEE_PACKET_TYPE_INTERPAN_ZLL, based on the usage in the code. 
- The following callback names have been changed to better reflect their role in the processing pipeline: - sl_zigbee_af_incoming_packet_filter_cb → sl_zigbee_pre_incoming_packet_filter_cb (privileged) 
- sl_zigbee_af_outgoing_packet_filter_cb → sl_zigbee_pre_outgoing_packet_filter_cb (privileged) 
 
- Two new callback functions have been introduced to provide a more comprehensive filtering framework: - sl_zigbee_post_incoming_packet_filter_cb() 
- sl_zigbee_post_outgoing_packet_filter_cb() 
 
- These functions are called over IPC after the packet has been received / sent and processed by the privileged pre-filter callback. It is meant to be informative for the application task and doesn't affect the packet handling, which has already occurred. 
 
- GCC Link Time Optimization (LTO) - Overview - Link Time Optimization (LTO) is now enabled for Zigbee applications in this release for GCC. LTO is a powerful compiler optimization technique that allows the compiler to perform whole-program analysis and optimization at link time, resulting in improved code performance and, in some cases, reduced binary size. 
- Usage - Installing the toolchain component toolchain_gcc_lto brings in the desired compiler and linker flags in a project. - In 2025.6.1, the zigbee gcc SOC libraries are built with desired compiler flags (-flto, -ffat-lto-objects) to be compatible with the linker to perform LTO at the final linking stage. The gcc linker flag -flto gets added to the linker options when toolchain_gcc_lto is installed in a project and when it is not installed the -fno-lto flags will be required to be added. The SLC CLI or Simplicity Studio generation automatically updates the generated or updated gcc makefile. User maintained makefile must consider these flags to be forward compatible. 
- Key Benefits - Improved Performance: LTO enables more aggressive inlining and cross-module optimizations, which can lead to faster execution of Zigbee stack and application code. 
- Potential Code Size Reduction: By eliminating redundant code and optimizing across module boundaries, LTO may reduce the overall firmware size in some scenarios. 
- Better Optimization Opportunities: The compiler can optimize function calls and data usage across all source files, not just within individual files. 
 
- Considerations - Increased Stack and Heap Usage: Due to more aggressive inlining and function merging, LTO may increase stack and heap requirements. Stack sizes have been reviewed and updated in .slcp configuration files to ensure reliable operation under LTO. 
- Build Time: Enabling LTO may increase build times, as the linker performs more complex analysis and optimization. 
- Debugging: Debugging LTO-optimized binaries can be more challenging, as function boundaries and variable locations may change due to optimization. 
 
- Configuration Changes - The toolchain_gcc_lto component is now included in Zigbee NCP and related projects. - Stack size (SL_STACK_SIZE) configuration entries in .slcp files have been updated to ensure sufficient memory allocation for all combinations of LTO and RTOS usage. 
- Recommended Actions - Review and test your application for stack overflows or memory issues, especially if you have custom code or third-party libraries. - If you encounter issues related to stack or heap usage, consider adjusting the SL_STACK_SIZE and heap configuration values as needed. 
- Summary - LTO is now part of the default build configuration for Zigbee applications, providing enhanced optimization and performance. Please review the updated stack size settings and test your applications accordingly to ensure a smooth transition. 
 
- Application Initialization Utilizing sl_main. - sl_system is deprecated in 2025.6.1 and is being replaced with sl_main. This means the existing apps main.c is not compatible with the new sl_main component. Therefore, it is recommended that if you have your own version of main.c, make it compatible with the new main.c provided by the sl_main component. 
- Added support for Tunneling functionality in Zigbee Direct. 
- New Green Power application framework APIs for commissioning window and GP Proxy Table entries Networking: - To allow the management of green power proxy table directly by advanced users, two new public APIs are introduced: - void sl_zigbee_gp_clear_proxy_table(void); 
- void sl_zigbee_gp_proxy_table_remove_entry(uint8_t index); 
- Added following new Application framework API in green power server to close a commissioning session: 
 - bool sl_zigbee_af_green_power_cluster_gp_sink_close_commissioning_window(void); 
- Improved packet failure status - Updated the message sent by handler callback to report the status in case of error with more granularity. - Following new status codes are introduced: - #define SL_STATUS_ZIGBEE_ID_DISCOVERY_FAILED ((sl_status_t)0x0C1F) ///< Node ID discovery failed. 
 #define SL_STATUS_ZIGBEE_NO_APS_ACK ((sl_status_t)0x0C20) ///< Message was sent but no APS ACK received.
 #define SL_STATUS_ZIGBEE_APS_MESSAGE_CANCELED ((sl_status_t)0x0C21) ///< APS message was canceled.
 #define SL_STATUS_ZIGBEE_ID_DISCOVERY_NOT_ENABLED ((sl_status_t)0x0C22) ///< Node ID discovery not enabled.
 #define SL_STATUS_ZIGBEE_ID_DISCOVERY_UNDERWAY ((sl_status_t)0x0C23) ///< Message was not sent, Node ID discovery is underway.
 #define SL_STATUS_ZIGBEE_SEND_UNICAST_ROUTE_DISCOVERY_UNDERWAY ((sl_status_t)0x0C24) ///< The message was not sent because a route discovery is currently underway. There is no route to the target until the route discovery completes.
 #define SL_STATUS_ZIGBEE_SEND_UNICAST_FAILURE ((sl_status_t)0x0C25) ///< Radius is 0 or message has been dropped because route request failed or failed to submit message to tx queue.
 #define SL_STATUS_ZIGBEE_SEND_UNICAST_NO_ROUTE ((sl_status_t)0x0C26) ///< No active route to the destination.
 #define SL_STATUS_ZIGBEE_BROADCAST_TO_SLEEPY_CHILDREN_TIMEOUT ((sl_status_t)0x0C27) ///< Broadcast message timeout while waiting for sleepy children to poll.
 #define SL_STATUS_ZIGBEE_BROADCAST_RELAY_FAILED ((sl_status_t)0x0C28) ///< Expected a neighbor to relay the message, but none did.- The existing status codes that already get reported by the sent handler are listed here: - #define SL_STATUS_OK 
 #define SL_STATUS_FAIL
 #define SL_STATUS_MAC_NO_DATA
 #define SL_STATUS_CCA_FAILURE
 #define SL_STATUS_MAC_NO_ACK_RECEIVED
 #define SL_STATUS_TRANSMIT_INCOMPLETE
 #define SL_STATUS_ZIGBEE_DELIVERY_FAILED
 #define SL_STATUS_ZIGBEE_APS_ENCRYPTION_ERROR
 #define SL_STATUS_ALLOCATION_FAILED
 #define SL_STATUS_ZIGBEE_IEEE_ADDRESS_DISCOVERY_IN_PROGRESS
 #define SL_STATUS_ZIGBEE_KEY_NOT_AUTHORIZED
 #define SL_STATUS_NOT_FOUND
- Added new plugin feature: zigbee_memory_usage and zigbee_memory_usage_cli - This component provides APIs and CLI commands for monitoring heap memory usage in Zigbee and Multiprotocol SoC and NCP applications. It allows applications to query the total heap size, current used heap size, and high watermark values both at runtime and immediately after initialization. This enables developers to track memory usage trends and optimize resource allocation. The CLI prints current and initialization-time heap statistics, while the API exposes functions for programmatic access to these metrics. 
Revision 1#
- Added Common Token Manager integration - In the 2025.6.1 SDK release, a new platform component has been added called the Common Token Manager (CTM). This component is meant to eventually replace the longstanding legacy Token Manager that the Zigbee stack has used for years. Users are encouraged to read AN1154 for information on how tokens work. AN1154 also explains the use of the legacy Token Manager, as well as the new Common Token Manager and its impact to user applications. - The Zigbee stack libraries and source code have been updated to conform with the new Common Token Manager. As such, users will notice that calls to legacy routines in source code have been replaced by calls to new routines which are defined by the CTM. For example, the following calls have been removed in Zigbee sample code shipped in the SDK: - halCommonGetToken() 
- halCommonSetToken() 
- halCommonGetMfgToken() 
- halInternalSetMfgTokenData() 
 - These routines have been replaced with calls to the new CTM module: - sl_token_manager_get_data() 
- sl_token_manager_set_data() 
 - The calls to the legacy APIs have been replaced, but the definitions have been left in place in order to keep user applications compiling. The new APIs handle reading and writing of all tokens, both dynamic tokens and manufacturing tokens. In alignment with these changes, sample applications in Zigbee have been updated to only include the Common Token Manager set of components, since only the new routines are called from sample applications in the SDK. The legacy Token Manager component is not included in the 2025.6.1 sample applications for Zigbee, since no sample code calls the legacy APIs. - In order to maintain functionality for user applications upgrading into SDK 2025.6.1, user applications will automatically be upgraded to include both the legacy Token Manager and the new Common Token Manager components. This action allows an application to continue to use the legacy APIs to read and write tokens, while the stack uses the new APIs to read and write its tokens. Users are strongly encouraged to migrate their calls over to the new APIs. The legacy component, labeled as the Token Manager component in Simplicity Studio, is marked as deprecated and will eventually be removed in a future release, at which point legacy APIs will no longer be supported. - A note on token initialization 
 - Unlike the legacy Token Manager, which had user code define a token before it could be read or written to, the Common Token Manager does not have a creation or initialization routine. Users may simply call the sl_token_manager_set_data() API to write any token. Calling sl_token_manager_get_data() will return an error code for a token that has never been written to before. While the Common Token Manager does not expose nor require a token initialization call, the Zigbee stack does provide a set of token initialization APIs. These APIs are required for the following cases: - The user application is using the new Common Token Manager, and 
- The user application is not using the legacy Token Manager and, thus, is not defining tokens using the legacy Token Manager (using the DEFINE_BASIC_TOKEN set of macros), and 
- One of the following is true: - The user is building a host application, which stores its tokens in a file on disk. 
- The user is building zigbeed, or the Zigbee daemon, which interacts with the RCP, and stores its token on disk. 
- The user is building a NCP image with the Stack Token Interface component, which allows a host application to extract tokens from the NCP. This is used to allow the host to backup and replace the NCP device, for example. 
 
 - Zigbee stack libraries and sample code already initialize their own tokens. Users finding themselves needing to initialize tokens can do so with the following Zigbee APIs: - sl_zigbee_initialize_basic_token() 
- sl_zigbee_initialize_counter_token() 
- sl_zigbee_initialize_index_token() 
 - The Zigbee initialization APIs may be removed in a future SDK release, at which point users will not need to initialize tokens for Zigbee images. - Failure to initialize tokens on host or zigbeed applications will result in runtime errors and possible assertions when those tokens are read or written to. Failure to initialize tokens on NCP applications that include the Stack Token Interface component will result in the host being unable to retrieve those tokens using the host-side Stack Token Interface routines. - Known issues 
 - At this time, deleting a token for a host application is unsupported. This will be addressed in a future SDK release. 
Revision 2#
- Updated zigbee_token_interface and zigbee_trust_center_backup usage. - This revision adds the Silabs series 3 radio micro controllers that have the following updates and limitations regarding zigbee_token_interface and zigbee_trust_center_backup usage for applications using series 2 and 3 controllers. zigbee_token_interface and zigbee_trust_center_backup components require projects to be generated with the token_manager (legacy) component. Series 2 apps built with zigbee_token_interface and/or zigbee_trust_center_backup MUST include token_manager component explicitly. Series 3 apps can not use zigbee_token_interface or zigbee_trust_center_backup in this revision due to their reliance on token_manager APIs, which are not available for series 3. 
- Updated filter match for InterPAN messages. - Updated Filtering of InterPAN message to support multiple filters matching regardless of whether ZLL or Custom filters match. The matched filter value will be passed up to the application using sli_802154_stack_filter_match_message_handler(). 
- The following APIs, struct, and enums have been updated as part of this feature. 
- The following APIs have new signatures: - sl_zigbee_af_mac_filter_match_message_cb() 
- sl_zigbee_ezsp_mac_filter_match_message_handler() 
- sl_802154_filter_match_message_handler() 
- All of the above APIs that subscribe to the mac_filter_match_message callback have been updated. They now pass filterValueMatch instead of filterIndexMatch. 
 
- Structure changes. - sl_zigbee_mac_filter_match_struct_t: - Removed fields legacyPassthroughType and filterIndexMatch. 
- Added field filterValueMatch. 
 
 
- Enumeration changes. - sl_zigbee_mac_passthrough_type_t: - EM_MAC_PASSTHROUGH_INTERNAL_ZLL renamed to SL_802154_PASSTHROUGH_INTERNAL_ZLL. 
- EM_MAC_PASSTHROUGH_INTERNAL_GP renamed to SL_802154_PASSTHROUGH_INTERNAL_GP. 
 
 
 
- FreeRTOS support for Zigbee NCP applications. - Added FreeRTOS support for Zigbee UART NCP applications. 
 
- IAR toolchain support. - Users are reminded that applications intended for series 3 parts are not supported with the IAR toolchain in this release. 
 
Enhancements#
- Enhanced Multi Rail Demo Component initialization - The initialization of the Multirail Demo component initialization is enhanced to check presence of BLE component in the application project and allocate the third RAIL state buffer, if available, to be used by the multi rail demo plugin. That way it always leaves the second RAIL state buffer for BLE and as the 1st state buffer is always consumed by Zigbee stack in a Zigbee-BLE DMP application. 
- Added CLI commands in zigbee_network_creator_security.slcc to toggle Allow TC Rejoin With Wellknown Key - Added commands to control allowing of Trust Center rejoin with well-known key, along with a timeout. 
- Added command to toggle RequireInstallCodesOrPresetPassphrase - Added command to toggle TC require install code policy and introduced new stack APIs sl_zigbee_set_join_uses_install_code and sl_zigbee_get_join_uses_install_code. 
- Two new applications have been added - Zigbee - NCP CPC over UART link (zigbee_ncp_cpc_uart.slcp) and Zigbee - NCP CPC over SPI link (zigbee_ncp_cpc_spi.slcp). - These are single protocol zigbee applications that connect to the NCP over a CPC connection. 
- Enhancements to ZLL initialization for Zigbee Matter Light joining matter fabric - ZLL initialization causes long delays in Zigbee Matter Light reconnecting to Matter Fabric. The sl_zigbee_af_zll_unset_factory_new() API has been added to allow applications to unset a Zigbee node from the default factory new state when necessary. A callback, sl_rail_mux_invalid_rx_channel_detected_cb(), has been added to Zigbee+OT applications. This callback notifies the application when there has been an attempted RX on two different channels while concurrent listening is not enabled. The application can then implement its own logic to handle this situation. 
- Enhancements to Zigbee packages structure - SLC "package" field values for components related to Zigbee and OpenThread have been adjusted in preparation for an upcoming SDK release format change in future. 
- Enhancements to Network creator - The Network Creator component has been updated to perform an energy scan followed by an active scan when determining a channel and PAN ID on which to form a network. 
- Enhancements to network steering - The VERIFY_TCLK state has been removed from the Network Steering plugin. This state was made obsolete, since the entire Trust Center Link Key update procedure as described in Zigbee 3.0, which comprises of the Node Descriptor, Request Key, and Verify Key exchanges, is handled by the stack. The end result of the TCLK exchange is handled by Network Steering via additional sl_zigbee_af_update_tc_link_key_status_cb invocations. 
- Zigbee Direct enhancements - Re-enabled the support for Curve 25519 in Zigbee Direct Device Light application. 
 Legacy Network functionality for Zigbee Direct Device is now supported.
 Increased zigbee AF task stack and BT event handler stack size to fix device crash issue.- Implement decryption of Tunnel command frame contents using the well-known global key for centralized security networks. An underlying bug, where the entire contents of input to sl_zigbee_sec_man_aes_ccm_extended was not copied over IPC was fixed. The API expects length+mic_length bytes of input to be copied over in the case of decryption. The doxygen for the API reflects to show this change. 
- Zigbee Throughput component enhancements - An optional uint8_t argument is added to the start command of the Zigbee Throughput component to configure its behavior regarding clearing counters. Calling "plugin throughput start 0" will leave counters uncleared, so testing that involves checking these values will work as intended in cases where counting may begin before the test starts. 
Revision 2#
- Enhanced validation for end device type application. - The End Device Support component is now enforced when a user creates an end device or sleepy end device application. Note that this component is always required but has always been enabled at the project level in previous releases. 
Removed Features#
None.
Deprecated Features#
| Deprecated Feature | Planned Removal Date | 
|---|---|
| The Zigbee Classic Key Storage component will be removed in a future release. This component handles storing encryption keys in plaintext NVM3 tokens. Future versions of software will instead use the Zigbee Secure Key Storage component, where keys are stored in PSA storage. See AN1311 for more information on PSA storage. Users will note that there already exists a Zigbee Secure Key Storage Upgrade component to move keys from classic key storage (NVM3 tokens) to secure key storage (PSA). | June 21, 2026 | 
API Changes#
New APIs | Modified APIs | Removed APIs | Deprecated APIs
New APIs#
| New API Signature | Deprecated API replaced by this (if any) | 
|---|---|
| sl_status_t sl_zigbee_send_raw_message_with_tag(const uint8_t *message, uint8_t message_length, sl_zigbee_transmit_priority_t priority, bool useCca, uint8_t messageTag); This is similar to sl_zigbee_send_raw_message, but accepts a messageTag for outgoing message and the same tag referred in the message sent callback. | |
| sl_zigbee_af_zll_unset_factory_new() API has been added to allow applications to unset a Zigbee node from the default factory new state when necessary. | |
| sl_zigbee_gp_clear_proxy_table(void); void sl_zigbee_gp_proxy_table_remove_entry(uint8_t index); To allow the management of green power proxy table directly by an advanced users two new public APIs are introduced void | |
| bool sl_zigbee_af_green_power_cluster_gp_sink_close_commissioning_window(void); Added following new Application framework API in green power server to close a commissioning session. | |
| void sl_zigbee_set_join_uses_install_code(bool enable); Enables/Disables TC to allow joining of a device through install code only. | |
| bool sl_zigbee_get_join_uses_install_code(void); Return true if the TC only allows joining of a device through install code. | |
| sl_status_t sl_zigbee_af_tc_link_key_update_now(void); | 
Modified APIs#
| Old API | Modified | 
|---|---|
| sl_zigbee_af_gpep_incoming_message_cb(GP_PARAMS) | sl_zigbee_af_gpep_incoming_message_cb(sl_zigbee_gp_params_t *param) | 
| sl_zigbee_af_ncp_gpep_incoming_message_handler(GP_PARAMS) | sl_zigbee_af_ncp_gpep_incoming_message_handler(sl_zigbee_gp_params_t *param) | 
| sl_zigbee_gpep_incoming_message_handler(GP_PARAMS) | sl_zigbee_gpep_incoming_message_handler(sl_zigbee_gp_params_t *param) | 
| sl_zigbee_af_set_t_c_link_key_update_timer_milli_seconds | sl_zigbee_af_set_tc_link_key_update_timer_ms | 
Revision 2#
| Old API | Modified | 
|---|---|
| sl_zigbee_af_mac_filter_match_message_cb() | Input argument 1 changed to sl_zigbee_mac_filter_match_data_t filterValueMatch from uint8_t filterIndexMatch | 
| sl_zigbee_ezsp_mac_filter_match_message_handler() | Input argument 1 changed to sl_zigbee_mac_filter_match_data_t filterValueMatch from uint8_t filterIndexMatch | 
| sl_802154_filter_match_message_handler() | Input argument 1 changed to sl_zigbee_mac_filter_match_data_t filterValueMatch from uint8_t filterIndexMatch | 
Removed APIs#
None.
Deprecated APIs#
None.
Bug Fixes#
| ID | Issue Description | GitHub / Salesforce Reference (if any) | Affected Software Variants, Hardware, Modes, Host Interfaces | 
|---|---|---|---|
| 1312098 | Fixed an issue where certain packets with invalid data regarding the APS frame size could cause the Zigbee stack to assert if received. | None | All variants | 
| 1369186 | Allow users to configure Address Table Size (macro SL_ZIGBEE_ADDRESS_TABLE_SIZE) via zigbee_pro_stack component inside Simplicity Studio. | None | All variants | 
| 1376690 | An issue was fixed where uninitialized values in Zigbee IPC commands carry garbage values. | None | All variants | 
| 1377518 | Fixed a CPC EZSP buffer TX/RX memory leak issue on NCP when running using zigbee_ncp_cpc component. | None | NCP, CPC | 
| 1377754 | Fixed a race condition issue where Zigbee IPC commands returned before the Zigbee task woke up and executed the current IPC command. This led to unexpected behavior due to using incorrect IPC command results. | None | All variants | 
| 1379738 | Fixed a memory alignment issue for CSL Tx Buffer. | None | All variants | 
| 1381092 | Fixed the gateway prompt string gets truncated when executing a command on the host. Fixed intermittent failure on command input truncation. | None | All variants | 
| 1383925 | Fixed an issue to remove the children immediately from the source route table of its parent after it left the network. | None | All variants | 
| 1385096 | Fixed an assertion issue on CPC NCP when the Host tried to connect to it multiple times. | None | All variants | 
| 1385689 | Fixed an issue that caused the network steering to call network_found infinitely when too many beacons are present. This was achieved by clearing the scan state appropriately. | None | All variants | 
| 1385996 | Fixed a compiler warnings in throughput.c. | None | All variants | 
| 1390107 | Fixed Multi network didn't work when using Zigbee IPC component. | None | All variants | 
| 1393842 | By increasing SL_BT_RTOS_EVENT_HANDLER_STACK_SIZE the Zigbee BLE - DirectDeviceLight doesn't crash anymore. So the config option SL_MBEDTLS_PSA_ASSUME_EXCLUSIVE_BUFFERS was disabled. | None | All variants | 
| 1407954 | Fixed an issue that caused the watchdog reset while rebooting applications that are configured with a large proxy table size. | None | All variants | 
| 1408816 | Fixed the missing restriction issue in Time Server cluster implementation. | None | All variants | 
| 1409453 | Removed Simple LED component from dependency list of Zigbee Identify Feedback. | None | All variants | 
| 1409871 | Fixed an issue that caused an assert during execution of level control cluster Step command. The issue was caused mainly because the updated temporary value for each step was not stored and read back correctly during step iteration and the minimum level should 0 instead of 1. | None | All variants | 
| 1410670 | An issue has been fixed where the Slot Manager component failed to compile if the application did not include CLI. | None | All variants | 
| 1412141 | Fixed some warnings showing up when enabling lto flag. | None | All variants | 
| 1412866 | An issue has been fixed where a Zigbee 3.0 joining device would fail to successfully update its Trust Center Link Key with the trust center. | None | All variants | 
| 1413451 | Fixed an issue that caused wrong format in GP Pairing Configuration packet. | None | All variants | 
| 1415014 | Fixed an issue that caused redundant bytes after Status field in Routing table Response packet when it's not supported. | None | All variants | 
| 1420830 | An issue exposed when using the Multi-Network feature in conjunction with the Sleepy-to-sleepy feature has been fixed. The issue resulted in s2s target not responding after joining successfully on secondary network. | None | All variants | 
| 1421368 | Fixed an issue that caused incorrect behavior in copying message payload in sli_zigbee_stack_raw_transmit_complete_handler when RTOS is used. | None | All variants | 
| 1424260 | Added brd4194a to backlist for SleepyToSleepyShades app. | None | All variants | 
| 1424600 | Fixed an issue where OTA client fetched the same image again and again when Delete Failed Downloads option set to false. | None | All variants | 
| 1426766 | Fixed an issue by increasing the waiting time to 5000 msec to allow receiving RSTACK frame after NCP resets. | None | All variants | 
| 1426899 | An issue exposed when using the Multi-Network feature in conjunction with the Sleepy-to-sleepy feature has been fixed. The issue resulted in network decryption failures on one of the networks when attempting to bring up the second network. | None | All variants | 
| 1430460 | Fixed issue where S2S shades was not able to receive data from target on primary network if the secondary network on the shades failed to join another network. | None | All variants | 
| 1431513 | Fixed null terminated string when using info command. | None | All variants | 
| 1434650 | This fixed the issue of sink's handling the pairing configuration command with action remove pairing - groupcast receiving from a proxy. | None | All variants | 
| 1435112 | Fixed an issue where sl_zigbee_gp_proxy_table_process_gp_pairing did not appear to be IPC-safe. | None | All variants | 
| 1442296 | Fixed duplicate APIs declaration when enabling green power adapter. | None | All variants | 
| 1442317 | Fixed an issue where the host app crashed when trying to leave network. The Green Power NCP was configurated with a large number of GP table size. | None | All variants | 
| 1442467 | Added upgrade rule to replace zigbee_pro_stack_rail_mux by zigbee_pro_stack. | None | All variants | 
| 1446979 | SL_ZIGBEE_ZIGBEE_PACKET_TYPE_INTERPAN has been renamed to SL_ZIGBEE_PACKET_TYPE_INTERPAN_ZLL. Added new SL_ZIGBEE_PACKET_TYPE_INTERPAN macro for general interpan message identification. | None | All variants | 
| 1446980 | The following callback names have been changed: sl_zigbee_af_incoming_packet_filter_cb → sl_zigbee_pre_incoming_packet_filter_cb (privileged); sl_zigbee_af_outgoing_packet_filter_cb → sl_zigbee_pre_outgoing_packet_filter_cb (privileged) | None | All variants | 
| 1446981 | Two new callback functions have been introduced: sl_zigbee_post_incoming_packet_filter_cb() and sl_zigbee_post_outgoing_packet_filter_cb(). These are called over IPC after the packet has been processed. | None | All variants | 
| 1453733 | Fixed an issue where builds using the zigbee_force_sleep_and_wakeup component would fail to compile with RTOS enabled. | None | All variants | 
Revision 1#
| ID | Issue Description | GitHub / Salesforce Reference (if any) | Affected Software Variants, Hardware, Modes, Host Interfaces | 
|---|---|---|---|
| 1473402 | Fixed issue where zigbee_ble_sleepy_to_sleepy_shades triggers bus fault when commands are received from a second controller. | None | All variants | 
| 1476331 | Fixed potential stack memory corruption when calling sl_zigbee_ezsp_get_configuration_value() | None | All variants | 
| 1477113 | Fixed an issue where APS Duplicate Rejection feature did not work properly. | None | All variants | 
Revision 2#
| ID | Issue Description | GitHub / Salesforce Reference (if any) | Affected Software Variants, Hardware, Modes, Host Interfaces | 
|---|---|---|---|
| 1510077 | An issue has been fixed where projects upgrading to Simplicity SDK 2025.6.1 would fail to resolve token symbols, such as TOKEN_ definitions and halCommonGetToken routines. This issue is resolved for users that migrate their applications to 2025.6.2 and future versions of the SDK. Users on 2025.6.1 not wishing to upgrade should manually add the Legacy Token Manager component to their applications. | None | All | 
| 1490483 | Updated EZSP user guide for the member radius in structure sl_zigbee_aps_frame_t. Note that in the use of this in a send API, it gets updated internally based on message type and radius supplied in the API. | None | EZSP Document | 
| 1482909 | The NVM3 override feature, documented in section 3.6 of AN1154: Using Tokens for Non-Volatile Data Storage, is now supported for Zigbee manufacturing tokens. The stack will now read override tokens held in NVM3, if present. | None | All variants | 
| 1404835 | Updated the EZSP document highlighting the ezsp set configuration for CTUNE value command return type. Note setting this parameter using ezsp API for setting configuration value invokes internal manufacturer library function call, mfglibInternalSetCtune, unlike a zigbee stack call, and hence the return value of the ezsp set API should be interpreted as type sl_status_t type. | None | EZSP Document | 
| 1477116 | Fixed an issue where a router device may end up rejoining its old PANId (with its extended PANId) instead of the updated network when both the network beacons are present during a secure rejoin attempt. | None | All variants | 
| 1474508 | Fixed issue Zigbee OTA fails when GCC LTO is enabled. | None | All variants | 
Chip Enablement#
| Chip Family | OPNs / Boards / OPN Combinations | Supported Software Variants (if applicable) | Supported Modes | Supported Host Interfaces | 
|---|---|---|---|---|
| xGM26 | xGM260P PCB Module | NA | 
 | UART | 
| xGM27 | xGM270S SiP Module | NA | 
 | UART | 
| xG29 | EFR32MG29B140F1024IM40 | NA | 
 | 
 | 
Revision 2#
| Chip Family | OPNs / Boards / OPN Combinations | Supported Software Variants (if applicable) | Supported Modes | Supported Host Interfaces | 
|---|---|---|---|---|
| Series 3 | SiXG30x | NA | 
 | 
 | 
Application Example Changes#
New Examples | Modified Examples | Removed Examples | Deprecated Examples
New Examples#
| Example Name | Description | Supported Software Variants (if applicable) | Supported Modes | Supported OPNs / Boards / OPN Combinations | Supported Host Interfaces | 
|---|---|---|---|---|---|
| Zigbee - NCP CPC over UART link (zigbee_ncp_cpc_uart.slcp). See readme here | These are single protocol Zigbee applications that connect to the NCP over a CPC connection. | All NCP Variants. | NCP | All supported | UART | 
| Zigbee - NCP CPC over SPI link (zigbee_ncp_cpc_spi.slcp). See readme here | These are single protocol Zigbee applications that connect to the NCP over a CPC connection. | All NCP Variants. | NCP | All supported | SPI | 
Modified Examples#
None.
Removed Examples#
None.
Deprecated Examples#
None.
Known Issues and Limitations#
| ID | Issue or Limitation Description | GitHub / Salesforce Reference (if any) | Workaround (if any) | Affected Software Variants, Hardware, Modes, Host Interfaces | 
|---|---|---|---|---|
| 1503910 | For Series 3 parts, the boot time is inconsistent because of the NVM3 repack invoked during initialisation. To optimize application performance, it is recommended for users to implement user NVM3 repacks periodically during application downtime. | None | Please refer to the NVM3 documentation regarding implementing the user triggered repack functional. A code example to call the user repack is provided below this table. | Series 3 | 
| 1507499 | Applications utilizing direct SPI access (that is, without the use of CPC) are currently not working for series 3 hardware. This includes the "Zigbee - NCP ncp-spi" and "Zigbee - NCP MpNcpSpi" applications, as well as any application that brings in the "NCP SPI" component. Generations of such applications will fail, indicating unmet dependencies or incompatible dependencies. | None | None | Series 3 NCP | 
| 1446942 | sl_zigbee_af_get_command_aps_frame() is currently not thread safe. Users may notice that subsequent calls to any of the sl_zigbee_af_send_command_* APIs result in incorrect APS frames being transmitted. This issue will be fixed in a future release. | None | None | All variants | 
| 1064370 | The Z3Switch sample application has one button(btn1 instance) that leads to button description does not match the operation out of box. Workaround: Install the btn0 instance manually during Z3Switch project creation. | None | Install btn0 instance manually during Z3Switch project creation. | Z3Switch | 
| 1474962 | Nwk Update Request updates nwkUpdateID incorrectly. | None | None | All variants | 
| 1477680 | There are following two issues present related to sleepy to sleepy application. 
 | None | 
 | Zigbee BLE Sleepy To Sleepy Apps | 
| 1479979 | The zigbee daemon (zigbeed) has an issue where it exits spontaneously when installed using 32-bit Debian packages. | None | Users may use the Docker-based zigbeed to circumvent the issue until a fix is provided in a future SDK release. | Zigbeed CMP | 
Code example for Known Issue 1503910:
 // Set the user repack threshold
                static uint32_t user_repack_threshold = 1024;
                /***************************************************************************//**
                * Perform a user-triggered repack with a configurable threshold.
                *
                * This function sets the number of bytes (threshold) that must remain free
                * before a forced repack is triggered. It performs repack operations until
                * the threshold is satisfied or no further memory can be freed.
                ******************************************************************************/
                void nvm3_repack_with_threshold(void)
                {
                  sl_status_t sta;
                  nvm3_MemInfo_t memInfo;
                  size_t initMemInfo;  // Get available memory
                  if (nvm3_getMemInfo(nvm3_defaultHandle, &memInfo) != SL_STATUS_OK) {
                    printf("Get memory info failed at startup\r\n");
                    return;
                  }  // Set the repack headroom to user threshold
                  nvm3_defaultInit->repackHeadroom = user_repack_threshold;
                  sta = nvm3_open(nvm3_defaultHandle, nvm3_defaultInit);
                  if (sta != SL_STATUS_OK) {
                    printf("NVM3 re-open with increased headroom failed: %lu\r\n", sta);
                    return;
                  }
                  initMemInfo = memInfo.availableMemory;
                  int repack =0;
                  while (user_repack_threshold > memInfo.availableMemory) {
                    repack++;
                    sta = nvm3_repack(nvm3_defaultHandle);
                    if (sta != SL_STATUS_OK) {
                      printf("ERROR: NVM3 repack failed! Status: %lu\r\n", sta);
                      EFM_ASSERT(sta == SL_STATUS_OK);
                      break;
                    }
                    nvm3_getMemInfo(nvm3_defaultHandle, &memInfo);
                  }
                  return;
                }