Miscellaneous#
API for the Miscellaneous functionality in the Application Framework.
Miscellaneous description.
API#
This variable defines an invalid image ID. It is used to determine if a returned sl_zigbee_af_ota_image_id_t is valid or not by passing the data to the function sl_zigbee_af_is_ota_image_id_valid().
Set the Zigbee stack task to ready when running on an OS.
Enable/disable endpoints.
Determine if an endpoint at the specified index is enabled or disabled.
Return true if a given ZCL data type is a string type.
Return true if the given attribute type is a string.
Return true if the given attribute type is a long string.
Increment the ZCL sequence number and return the value.
Retrieve the last sequence number that was used.
Compare two values of known length as integers.Simple integer comparison function. Signed integer comparison are supported for numbers with length of 4 (bytes) or less. The integers are in native endianness.
Populate the passed EUI64 with the local EUI64 MAC address.
Return the node ID of the local node.
Generate a random key (link, network, or master).
Return the PAN ID of the local node.
Return the radioChannel of the current network.
Return the current network state. This call caches the results on the host to prevent frequent EZSP transactions.
Return the current network parameters.
Return the current node type.
Enable local permit join and optionally broadcast the ZDO Mgmt_Permit_Join_req message. This API can be called from any device type and still return SL_STATUS_OK. If the API is called from an end device, the permit association bit will just be left off.
Enable local permit join and broadcast the ZDO Mgmt_Permit_Join_req message. This API can be called from any device type and still return SL_STATUS_OK. If the API is called from an end device, the permit association bit will just be left off.
Acquire the app framework mutex (for RTOS builds). This should be done if code run from outside of the app framework (callback) context in RTOS builds needs to call app framework APIs, as interactions between app framework and other application tasks are not otherwise designed to be thread-safe. Note that APIs relating to app framework events are included in this category of app framework APIs (so thread-safe interactions with the event queue from other tasks require the acquisition of this lock).
Release the app framework mutex (for RTOS builds), allowing other application tasks (like the app framework task) waiting on this mutex to run. This should be done once the application code has finished its calls to app framework data or APIs.
Indicate a new image verification is taking place.
Indicate the continuation of an image verification already in progress.
The mask applied by sl_zigbee_af_next_sequence when generating ZCL sequence numbers.
The mask applied to generated message tags used by the framework when sending messages via EZSP. Customers who call ezspSend functions directly must use message tags outside this mask.
Return true if the cluster is in the manufacturer-specific range.
Return true if the cluster is in the manufacturer-specific range.
Return true if the cluster is in the manufacturer-specific range.
Return true if the cluster is in the manufacturer-specific range.
Return true if the cluster is in the manufacturer-specific range.
Return true if the cluster is in the manufacturer-specific range.
API Documentation#
sl_zigbee_af_invalid_image_id#
const sl_zigbee_af_ota_image_id_t sl_zigbee_af_invalid_image_id
This variable defines an invalid image ID. It is used to determine if a returned sl_zigbee_af_ota_image_id_t is valid or not by passing the data to the function sl_zigbee_af_is_ota_image_id_valid().
sl_zigbee_wakeup_common_task#
void sl_zigbee_wakeup_common_task (void )
Set the Zigbee stack task to ready when running on an OS.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_endpoint_enable_disable#
bool sl_zigbee_af_endpoint_enable_disable (uint8_t endpoint, bool enable)
Enable/disable endpoints.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | endpoint | |
| bool | N/A | enable | 
sl_zigbee_af_endpoint_index_is_enabled#
bool sl_zigbee_af_endpoint_index_is_enabled (uint8_t index)
Determine if an endpoint at the specified index is enabled or disabled.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | index | 
sl_zigbee_af_is_this_data_type_a_string_type#
bool sl_zigbee_af_is_this_data_type_a_string_type (sl_zigbee_af_attribute_type_t dataType)
Return true if a given ZCL data type is a string type.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_af_attribute_type_t | N/A | dataType | 
Use this function to perform a different memory operation on a certain attribute because it is a string type. Since ZCL strings carry length as the first byte(s), it is often required to treat them differently than regular data types.
Returns
- true if data type is a string. 
sl_zigbee_af_is_string_attribute_type#
bool sl_zigbee_af_is_string_attribute_type (sl_zigbee_af_attribute_type_t attributeType)
Return true if the given attribute type is a string.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_af_attribute_type_t | N/A | attributeType | 
sl_zigbee_af_is_long_string_attribute_type#
bool sl_zigbee_af_is_long_string_attribute_type (sl_zigbee_af_attribute_type_t attributeType)
Return true if the given attribute type is a long string.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_af_attribute_type_t | N/A | attributeType | 
sl_zigbee_af_next_sequence#
uint8_t sl_zigbee_af_next_sequence (void )
Increment the ZCL sequence number and return the value.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
ZCL messages have sequence numbers so that they can be matched up with other messages in the transaction. To avoid conflicts with sequence numbers generated independently by the application, this API returns sequence numbers with the high bit clear. If the application generates its own sequence numbers, it should use numbers with the high bit set.
Returns
- The next ZCL sequence number. 
sl_zigbee_af_get_last_sequence_number#
uint8_t sl_zigbee_af_get_last_sequence_number (void )
Retrieve the last sequence number that was used.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_compare_values#
int8_t sl_zigbee_af_compare_values (uint8_t * val1, uint8_t * val2, uint8_t len, bool signedNumber)
Compare two values of known length as integers.Simple integer comparison function. Signed integer comparison are supported for numbers with length of 4 (bytes) or less. The integers are in native endianness.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t * | N/A | val1 | |
| uint8_t * | N/A | val2 | |
| uint8_t | N/A | len | |
| bool | N/A | signedNumber | 
Returns
- -1, if val1 is smaller 0, if they are the same or if two negative numbers with length greater than 4 is being compared 1, if val2 is smaller. 
sl_zigbee_af_get_eui64#
void sl_zigbee_af_get_eui64 (sl_802154_long_addr_t returnEui64)
Populate the passed EUI64 with the local EUI64 MAC address.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_long_addr_t | N/A | returnEui64 | 
sl_zigbee_af_get_node_id#
sl_802154_short_addr_t sl_zigbee_af_get_node_id (void )
Return the node ID of the local node.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_generate_random_key#
sl_status_t sl_zigbee_af_generate_random_key (sl_zigbee_key_data_t * result)
Generate a random key (link, network, or master).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_key_data_t * | N/A | result | 
sl_zigbee_af_get_pan_id#
sl_802154_pan_id_t sl_zigbee_af_get_pan_id (void )
Return the PAN ID of the local node.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_get_radio_channel#
uint8_t sl_zigbee_af_get_radio_channel (void )
Return the radioChannel of the current network.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_network_state#
sl_zigbee_network_status_t sl_zigbee_af_network_state (void )
Return the current network state. This call caches the results on the host to prevent frequent EZSP transactions.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_get_network_parameters#
sl_status_t sl_zigbee_af_get_network_parameters (sl_zigbee_node_type_t * nodeType, sl_zigbee_network_parameters_t * parameters)
Return the current network parameters.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_node_type_t * | N/A | nodeType | |
| sl_zigbee_network_parameters_t * | N/A | parameters | 
sl_zigbee_af_get_node_type#
sl_status_t sl_zigbee_af_get_node_type (sl_zigbee_node_type_t * nodeType)
Return the current node type.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_node_type_t * | N/A | nodeType | 
sl_zigbee_af_permit_join#
sl_status_t sl_zigbee_af_permit_join (uint8_t duration, bool broadcastMgmtPermitJoin)
Enable local permit join and optionally broadcast the ZDO Mgmt_Permit_Join_req message. This API can be called from any device type and still return SL_STATUS_OK. If the API is called from an end device, the permit association bit will just be left off.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | duration | The duration that the permit join bit will remain on and other devices will be able to join the current network. | 
| bool | N/A | broadcastMgmtPermitJoin | whether or not to broadcast the ZDO Mgmt_Permit_Join_req message. | 
Returns
- status of whether or not permit join was enabled. 
sl_zigbee_af_broadcast_permit_join#
sl_status_t sl_zigbee_af_broadcast_permit_join (uint8_t duration)
Enable local permit join and broadcast the ZDO Mgmt_Permit_Join_req message. This API can be called from any device type and still return SL_STATUS_OK. If the API is called from an end device, the permit association bit will just be left off.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | duration | The duration that the permit join bit will remain on and other devices will be able to join the current network. | 
Returns
- status of whether or not permit join was enabled. 
sl_zigbee_af_acquire_lock#
void sl_zigbee_af_acquire_lock (void )
Acquire the app framework mutex (for RTOS builds). This should be done if code run from outside of the app framework (callback) context in RTOS builds needs to call app framework APIs, as interactions between app framework and other application tasks are not otherwise designed to be thread-safe. Note that APIs relating to app framework events are included in this category of app framework APIs (so thread-safe interactions with the event queue from other tasks require the acquisition of this lock).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_af_release_lock#
void sl_zigbee_af_release_lock (void )
Release the app framework mutex (for RTOS builds), allowing other application tasks (like the app framework task) waiting on this mutex to run. This should be done once the application code has finished its calls to app framework data or APIs.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A |