See End Devices for documentation.
License#
Copyright 2018 Silicon Laboratories Inc. www.silabs.com
The licensor of this software is Silicon Laboratories Inc. Your use of this software is governed by the terms of Silicon Labs Master Software License Agreement (MSLA) available at www.silabs.com/about-us/legal/master-software-license-agreement. This software is distributed to you in Source Code format and is governed by the sections of the MSLA applicable to Source Code.
/***************************************************************************/
#ifndef SILABS_CHILD_H
#define SILABS_CHILD_H
#include "stack/include/sl_zigbee_types.h"
#include "mac-child.h"
sl_802154_short_addr_t sl_zigbee_child_id(uint8_t childIndex);
int8_t sl_zigbee_child_power(uint8_t childIndex);
void sl_zigbee_set_child_power(uint8_t childIndex, int8_t newPower);
uint8_t sl_zigbee_child_index(sl_802154_short_addr_t childId);
sl_status_t sl_zigbee_get_child_data(uint8_t index,
                                     sl_zigbee_child_data_t *childData);
sl_status_t sl_zigbee_set_child_data(uint8_t index,
                                     const sl_zigbee_child_data_t *childData);
void sl_zigbee_child_join_handler(uint8_t index,
                                  bool joining,
                                  sl_802154_short_addr_t childId,
                                  sl_802154_long_addr_t childEui64,
                                  sl_zigbee_node_type_t childType);
sl_status_t sl_zigbee_set_keep_alive_mode(sl_zigbee_keep_alive_mode_t mode);
sl_zigbee_keep_alive_mode_t sl_zigbee_get_keep_alive_mode(void);
sl_status_t sl_zigbee_poll_for_data(void);
void sl_zigbee_set_mac_poll_failure_wait_time(uint32_t waitBeforeRetryIntervalMs);
void sl_zigbee_poll_complete_handler(sl_status_t status);
sl_status_t sl_zigbee_set_message_flag(sl_802154_short_addr_t childId);
sl_status_t sl_zigbee_clear_message_flag(sl_802154_short_addr_t childId);
void sl_zigbee_poll_handler(sl_802154_short_addr_t childId, bool transmitExpected);
sl_status_t sl_zigbee_add_child(sl_802154_short_addr_t shortId,
                                sl_802154_long_addr_t longId,
                                sl_zigbee_node_type_t nodeType);
sl_status_t sl_zigbee_remove_child(sl_802154_long_addr_t childEui64);
void sl_zigbee_remove_neighbor(sl_802154_short_addr_t shortId,
                               sl_802154_long_addr_t longId);
#ifdef DOXYGEN_SHOULD_SKIP_THIS
uint8_t sl_zigbee_child_count(void);
uint8_t sl_zigbee_router_child_count(void);
uint8_t sl_zigbee_max_child_count(void);
uint8_t sl_zigbee_max_router_child_count(void);
sl_802154_short_addr_t sl_zigbee_get_parent_node_id(void);
sl_802154_long_addr_t sl_zigbee_get_parent_eui64(void);
#else // Doxygen ignores the following
// A maximum for this node.
sl_status_t sl_zigbee_set_max_end_device_children(uint8_t max);
uint8_t sl_zigbee_get_max_end_device_children(void);
// The '+ 0' prevents anyone from accidentally assigning to these.
#define sl_zigbee_router_child_count()    0
#define sl_zigbee_max_child_count()       sl_zigbee_get_max_end_device_children()
#define sl_zigbee_max_router_child_count() 0
// Implemented in sl_zigbee_stack_common.c.
uint32_t sl_zigbee_get_parent_incoming_nwk_frame_counter(void);
sl_status_t sl_zigbee_set_parent_incoming_nwk_frame_counter(uint32_t value);
sl_802154_short_addr_t sl_zigbee_get_parent_node_id(void);
uint8_t* sl_zigbee_get_parent_eui64(void);
uint8_t sl_zigbee_child_count(void);
#endif
enum {
  SL_ZIGBEE_OUTGOING_MESSAGES = 0x0001,
  SL_ZIGBEE_INCOMING_MESSAGES = 0x0002,
  SL_ZIGBEE_RADIO_IS_ON = 0x0004,
  SL_ZIGBEE_TRANSPORT_ACTIVE = 0x0008,
  SL_ZIGBEE_APS_LAYER_ACTIVE = 0x0010,
  SL_ZIGBEE_ASSOCIATING = 0x0020,
  SL_ZIGBEE_ZLL_TOUCH_LINKING = 0x0040,
  SL_ZIGBEE_NETWORK_TIMEOUT_REQUEST = 0x0200,
  SL_ZIGBEE_SEND_ORPHAN_NOTIFICATION = 0x0400,
  SL_802154_DATA_POLL_SUPER_RETRY = 0x0800,
};
#define SL_ZIGBEE_HIGH_PRIORITY_TASKS \
  (SL_ZIGBEE_OUTGOING_MESSAGES | SL_ZIGBEE_INCOMING_MESSAGES | SL_ZIGBEE_RADIO_IS_ON)
uint16_t sl_zigbee_current_stack_tasks(void);
#ifdef DOXYGEN_SHOULD_SKIP_THIS
bool sl_zigbee_ok_to_nap(void);
#else
#define sl_zigbee_ok_to_nap() \
  (!(sl_zigbee_current_stack_tasks() & SL_ZIGBEE_HIGH_PRIORITY_TASKS))
#endif
bool sl_zigbee_parent_token_set(void);
#ifdef DOXYGEN_SHOULD_SKIP_THIS
bool sl_zigbee_ok_to_hibernate(void);
#else
#define sl_zigbee_ok_to_hibernate() (!sl_zigbee_current_stack_tasks())
#endif
#ifdef DOXYGEN_SHOULD_SKIP_THIS
bool sl_zigbee_ok_to_long_poll(void);
#else
#define sl_zigbee_ok_to_long_poll() (!sl_zigbee_pending_acked_messages())
#endif
void sl_zigbee_stack_power_down(void);
void sl_zigbee_stack_power_up(void);
// @} END Power Management
// @} END addtogroup
sl_status_t sl_zigbee_send_link_power_delta_request (void);
int8_t sl_zigbee_get_avg_parent_rssi(void);
sl_802154_short_addr_t sl_zigbee_get_parent_id(void);
sl_status_t sl_zigbee_set_child_timeout_option_mask(uint16_t mask);
#endif // SILABS_CHILD_H
Power Management#
A mask of the tasks that prevent a device from sleeping.
Define tasks that are taken into account when dealing with sleep related behavior.
Return a bitmask indicating the stack's current tasks.
Indicate whether the stack is currently in a state where there are no high-priority tasks, allowing the device to sleep.
Indicate whether the parent token has been set by association.
Indicate whether the stack currently has any tasks pending.
Indicate whether the stack is currently in a state that does not require the application to periodically poll.
Immediately turn the radio power completely off.
Initialize the radio. Typically called coming out of deep sleep.
Send a link power delta request to the parent.
Accessor function for recent average RSSI value between this device and the parent (SoC only).
Accessor function for the parent's node ID if applicable (SoC only).
: Bit mask that decides which timeout values are acceptable for a child. It defaults to 0xFFFF which covers all the following 15 options:
Functions#
Convert a child index to a node ID.
Return radio power value of the child from the given childIndex.
Set the radio power value for a given child index.
Convert a node ID to a child index.
Get the EUI64 and node type of the child at the provided index. If there is no child at 'index', it returns ::SL_STATUS_NOT_JOINED. Possible child indexes run from zero to sl_zigbee_max_child_count() - 1.
Sets the EUI64, node ID, and node type of the child at the provided index in nonvolatile memory. No other data from the childData argument is used or copied. The user is responsible for rebooting the device after calling this API in order to initialize RAM-based child data. Possible child indexes run from zero to sl_zigbee_max_child_count() - 1.
Called by the stack when a child joins or leaves. 'Joining' is true if the child is joining and false if leaving.
Request any pending data from the parent node. This function allows an end device to query its parent for any pending data.
Set a flag to indicate that a message is pending for a child. The next time that the child polls, it will be informed that it has a pending message. The message is sent from sl_zigbee_poll_handler, which is called when the child requests data.
Clear a flag to indicate that there are no more messages for a child. The next time the child polls, it will be informed that it does not have any pending messages.
Called to allow the application to send a message in response to a poll from a child.
Add a child to the child/neighbor table only on SoC, allowing direct manipulation of these tables by the application. This can affect the network functionality, and needs to be used wisely. If used appropriately, the application can maintain more than the maximum of children provided by the stack.
Remove a node from child/neighbor table only on SoC, allowing direct manipulation of these tables by the application. This can affect the network functionality, and needs to be used wisely.
Remove a neighbor from neighbor table only on SoC, allowing direct manipulation of neighbor table by the application. This can affect the network functionality, and needs to be used wisely.
Return the number of children the node currently has.
Return the number of router children that the node currently has.
Return the maximum number of children for this node. The return value is undefined for nodes that are not joined to a network.
Return the maximum number of router children for this node. The return value is undefined for nodes that are not joined to a network.
Return the parent's node ID. The return value is undefined for nodes without parents (coordinators and nodes that are not joined to a network).
Return the parent's EUI64. The return value is undefined for nodes without parents (coordinators and nodes that are not joined to a network).
Power Management Documentation#
@5#
@5
Define tasks that are taken into account when dealing with sleep related behavior.
As opposed to its subset of SL_ZIGBEE_HIGH_PRIORITY_TASKS, these tasks do not necessarily prevent the device from going to sleep. However, they are taken into account when calculating how long we can sleep until the next event.
| Enumerator | |
|---|---|
| SL_ZIGBEE_OUTGOING_MESSAGES | Messages are waiting for transmission. | 
| SL_ZIGBEE_INCOMING_MESSAGES | One or more incoming messages are being processed. | 
| SL_ZIGBEE_RADIO_IS_ON | The radio is currently powered on. On sleepy devices, the radio is turned off when not in use. On non-sleepy devices (SL_ZIGBEE_COORDINATOR, SL_ZIGBEE_ROUTER, or SL_ZIGBEE_END_DEVICE), the radio is always on. | 
| SL_ZIGBEE_TRANSPORT_ACTIVE | The transport layer has messages awaiting an ACK. | 
| SL_ZIGBEE_APS_LAYER_ACTIVE | The ZigBee APS layer has messages awaiting an ACK. | 
| SL_ZIGBEE_ASSOCIATING | The node is currently trying to associate with a ZigBee PRO network. | 
| SL_ZIGBEE_ZLL_TOUCH_LINKING | The node is currently touch linking. | 
| SL_ZIGBEE_NETWORK_TIMEOUT_REQUEST | Network Timeout Request Event. | 
| SL_ZIGBEE_SEND_ORPHAN_NOTIFICATION | Sending Orphan Notification Event. | 
| SL_802154_DATA_POLL_SUPER_RETRY | MAC Data Poll Super Retry Event . | 
sl_zigbee_current_stack_tasks#
uint16_t sl_zigbee_current_stack_tasks (void )
Return a bitmask indicating the stack's current tasks.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
The mask SL_ZIGBEE_HIGH_PRIORITY_TASKS defines which tasks are high priority. Devices should not sleep if any high priority tasks are active. Active tasks that are not high priority are waiting for messages to arrive from other devices. If there are active tasks, but no high priority ones, the device may sleep but should periodically wake up and call sl_zigbee_poll_for_data() in order to receive messages. Parents will hold messages for SL_ZIGBEE_INDIRECT_TRANSMISSION_TIMEOUT milliseconds before discarding them.
Returns
- A bitmask of the stack's active tasks. 
sl_zigbee_ok_to_nap#
bool sl_zigbee_ok_to_nap (void )
Indicate whether the stack is currently in a state where there are no high-priority tasks, allowing the device to sleep.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
There may be tasks expecting incoming messages, in which case the device should periodically wake up and call sl_zigbee_poll_for_data() in order to receive messages. This function can only be called when the node type is SL_ZIGBEE_SLEEPY_END_DEVICE
Returns
- True if the application may sleep but the stack may be expecting incoming messages. 
sl_zigbee_parent_token_set#
bool sl_zigbee_parent_token_set (void )
Indicate whether the parent token has been set by association.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- True if the parent token has been set. 
sl_zigbee_ok_to_hibernate#
bool sl_zigbee_ok_to_hibernate (void )
Indicate whether the stack currently has any tasks pending.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
If no tasks are pending, sl_zigbee_tick() does not need to be called until the next time a stack API function is called. This function can only be called when the node type is SL_ZIGBEE_SLEEPY_END_DEVICE or
Returns
- True if the application may sleep for as long as it wishes. 
sl_zigbee_ok_to_long_poll#
bool sl_zigbee_ok_to_long_poll (void )
Indicate whether the stack is currently in a state that does not require the application to periodically poll.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- True if the application may stop polling periodically. 
sl_zigbee_stack_power_down#
void sl_zigbee_stack_power_down (void )
Immediately turn the radio power completely off.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Calling this function will render all other stack functions except sl_zigbee_stack_power_up() non-functional until the radio is powered back on.
sl_zigbee_stack_power_up#
void sl_zigbee_stack_power_up (void )
Initialize the radio. Typically called coming out of deep sleep.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
For non-sleepy devices, also turns the radio on and leaves it in RX mode.
sl_zigbee_send_link_power_delta_request#
sl_status_t sl_zigbee_send_link_power_delta_request (void )
Send a link power delta request to the parent.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_get_avg_parent_rssi#
int8_t sl_zigbee_get_avg_parent_rssi (void )
Accessor function for recent average RSSI value between this device and the parent (SoC only).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_get_parent_id#
sl_802154_short_addr_t sl_zigbee_get_parent_id (void )
Accessor function for the parent's node ID if applicable (SoC only).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
sl_zigbee_set_child_timeout_option_mask#
sl_status_t sl_zigbee_set_child_timeout_option_mask (uint16_t mask)
: Bit mask that decides which timeout values are acceptable for a child. It defaults to 0xFFFF which covers all the following 15 options:
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint16_t | N/A | mask | 
#define SECONDS_10 0 #define MINUTES_2 1 #define MINUTES_4 2 #define MINUTES_8 3 #define MINUTES_16 4 #define MINUTES_32 5 #define MINUTES_64 6 #define MINUTES_128 7 #define MINUTES_256 8 #define MINUTES_512 9 #define MINUTES_1024 10 #define MINUTES_2048 11 #define MINUTES_4096 12 #define MINUTES_8192 13 #define MINUTES_16384 14 // ~11 days
Function Documentation#
sl_zigbee_child_id#
sl_802154_short_addr_t sl_zigbee_child_id (uint8_t childIndex)
Convert a child index to a node ID.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | childIndex | The index. | 
Returns
- The node ID of the child or SL_ZIGBEE_NULL_NODE_ID if there isn't a child at the childIndex specified. 
sl_zigbee_child_power#
int8_t sl_zigbee_child_power (uint8_t childIndex)
Return radio power value of the child from the given childIndex.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | childIndex | The index. | 
Returns
- The power of the child or maximum radio power, which is the power value provided by the user while forming/joining a network if there isn't a child at the childIndex specified. 
sl_zigbee_set_child_power#
void sl_zigbee_set_child_power (uint8_t childIndex, int8_t newPower)
Set the radio power value for a given child index.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | childIndex | The index. | 
| int8_t | N/A | newPower | The new power value. | 
sl_zigbee_child_index#
uint8_t sl_zigbee_child_index (sl_802154_short_addr_t childId)
Convert a node ID to a child index.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | childId | The node ID of the child. | 
Returns
- The child index or 0xFF if the node ID does not belong to a child. 
sl_zigbee_get_child_data#
sl_status_t sl_zigbee_get_child_data (uint8_t index, sl_zigbee_child_data_t * childData)
Get the EUI64 and node type of the child at the provided index. If there is no child at 'index', it returns ::SL_STATUS_NOT_JOINED. Possible child indexes run from zero to sl_zigbee_max_child_count() - 1.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | index | The index of the child of interest. | 
| sl_zigbee_child_data_t * | N/A | childData | The child's data is copied here. | 
Returns
- Returns ::SL_STATUS_OK if a child is found at that index, ::SL_STATUS_NOT_JOINED if not. 
sl_zigbee_set_child_data#
sl_status_t sl_zigbee_set_child_data (uint8_t index, const sl_zigbee_child_data_t * childData)
Sets the EUI64, node ID, and node type of the child at the provided index in nonvolatile memory. No other data from the childData argument is used or copied. The user is responsible for rebooting the device after calling this API in order to initialize RAM-based child data. Possible child indexes run from zero to sl_zigbee_max_child_count() - 1.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | index | The index of the child. | 
| const sl_zigbee_child_data_t * | N/A | childData | The child's data. | 
Returns
- Returns ::SL_STATUS_OK if successfully setting child at that index, ::SL_STATUS_INVALID_INDEX if provided index is out of range. 
Note
- This API only sets the child data to nonvolatile memory. A reboot is required after calling this API to read the nonvolatile child data and set it to RAM structures. This API does not set other child RAM data, such as power and timeout values. 
sl_zigbee_child_join_handler#
void sl_zigbee_child_join_handler (uint8_t index, bool joining, sl_802154_short_addr_t childId, sl_802154_long_addr_t childEui64, sl_zigbee_node_type_t childType)
Called by the stack when a child joins or leaves. 'Joining' is true if the child is joining and false if leaving.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | index | The index of the child of interest. | 
| bool | N/A | joining | True if the child is joining, false if the child is leaving. | 
| sl_802154_short_addr_t | N/A | childId | Node ID of the child. | 
| sl_802154_long_addr_t | N/A | childEui64 | The EUI64 of the child. | 
| sl_zigbee_node_type_t | N/A | childType | Node type of the child. | 
The index is the same as the value that should be passed to sl_zigbee_get_child_data() to get this child's data. Note that if the child is leaving, sl_zigbee_get_child_data() will return ::SL_STATUS_NOT_JOINED if called with this index. If the application includes sl_zigbee_child_join_handler(), it must define SL_ZIGBEE_APPLICATION_HAS_CHILD_JOIN_HANDLER in its CONFIGURATION_HEADER
sl_zigbee_set_keep_alive_mode#
sl_status_t sl_zigbee_set_keep_alive_mode (sl_zigbee_keep_alive_mode_t mode)
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_zigbee_keep_alive_mode_t | N/A | mode | One of the four configurations in the sl_zigbee_keep_alive_mode_t. | 
@ brief Set the keep alive mode.
sl_zigbee_get_keep_alive_mode#
sl_zigbee_keep_alive_mode_t sl_zigbee_get_keep_alive_mode (void )
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
@ brief Get the keep alive mode.
Returns
- mode One of the four configurations in the sl_zigbee_keep_alive_mode_t. 
sl_zigbee_poll_for_data#
sl_status_t sl_zigbee_poll_for_data (void )
Request any pending data from the parent node. This function allows an end device to query its parent for any pending data.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
End devices must call this function periodically to maintain contact with their parent. The parent will remove a child if it has not received a poll from it within the configured timeout.
If the end device has lost contact with its parent, sl_zigbee_poll_for_data() calls ::emberRejoinNetwork(true) and returns ::SL_STATUS_FAIL.
The default values for the timeouts are set in config/sl_zigbee_configuration_defaults.h and can be overridden in the application's configuration header.
Returns
- An sl_status_t value: - ::SL_STATUS_OK - The poll message has been submitted for transmission. 
- ::SL_STATUS_INVALID_STATE - The node is not an end device. 
- ::SL_STATUS_NOT_JOINED - The node is not part of a network. 
- ::SL_STATUS_MAC_TRANSMIT_QUEUE_FULL - The MAC layer transmit queue is full. 
- ::SL_STATUS_ALLOCATION_FAILED - No buffers available to create the data poll message. 
- ::SL_STATUS_FAIL - Too much time has elapsed since the last successful poll. A rejoin attempt has been initiated. This error is not "fatal". The command can be retried until successful. 
 
sl_zigbee_set_mac_poll_failure_wait_time#
void sl_zigbee_set_mac_poll_failure_wait_time (uint32_t waitBeforeRetryIntervalMs)
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint32_t | N/A | waitBeforeRetryIntervalMs | Time in milliseconds the device waits before retrying a data poll when a MAC level data poll fails for any reason. The retry feature can be disabled by setting this value to zero. | 
@ brief Set the retry interval (in milliseconds) for mac data poll. This function is useful for sleepy end devices. The retry interval is the time in milliseconds the device waits before retrying a data poll when a MAC level data poll fails for any reason. The retry feature can be disabled by setting the retry interval to zero.
sl_zigbee_poll_complete_handler#
void sl_zigbee_poll_complete_handler (sl_status_t status)
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_status_t | N/A | status | An  
 | 
@ brief Called by the stack when a data poll to the parent is complete.
If the application includes sl_zigbee_poll_complete_handler(), it must define SL_ZIGBEE_APPLICATION_HAS_POLL_COMPLETE_HANDLER within its CONFIGURATION_HEADER
sl_zigbee_set_message_flag#
sl_status_t sl_zigbee_set_message_flag (sl_802154_short_addr_t childId)
Set a flag to indicate that a message is pending for a child. The next time that the child polls, it will be informed that it has a pending message. The message is sent from sl_zigbee_poll_handler, which is called when the child requests data.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | childId | The ID of the child that just polled for data. | 
Returns
- An ::sl_status_t value. - ::SL_STATUS_OK - The next time that the child polls, it will be informed that it has pending data. 
- ::SL_STATUS_NOT_JOINED - The child identified by childId is not our child. 
 
sl_zigbee_clear_message_flag#
sl_status_t sl_zigbee_clear_message_flag (sl_802154_short_addr_t childId)
Clear a flag to indicate that there are no more messages for a child. The next time the child polls, it will be informed that it does not have any pending messages.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | childId | The ID of the child that no longer has pending messages. | 
Returns
- An ::sl_status_t value. - ::SL_STATUS_OK - The next time that the child polls, it will be informed that it does not have any pending messages. 
- ::SL_STATUS_NOT_JOINED - The child identified by childId is not our child. 
 
sl_zigbee_poll_handler#
void sl_zigbee_poll_handler (sl_802154_short_addr_t childId, bool transmitExpected)
Called to allow the application to send a message in response to a poll from a child.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | childId | The ID of the child that is requesting data. | 
| bool | N/A | transmitExpected | True if the child is expecting an application- supplied data message. False otherwise. | 
This function is called when a child polls, provided that the pending message flag is set for that child (see sl_zigbee_set_message_flag(). The message should be sent to the child using sl_zigbee_send_unicast() with the SL_ZIGBEE_APS_OPTION_POLL_RESPONSE option.
If the application includes ::emberPollHanlder(), it must define SL_ZIGBEE_APPLICATION_HAS_POLL_HANDLER in its CONFIGURATION_HEADER.
sl_zigbee_add_child#
sl_status_t sl_zigbee_add_child (sl_802154_short_addr_t shortId, sl_802154_long_addr_t longId, sl_zigbee_node_type_t nodeType)
Add a child to the child/neighbor table only on SoC, allowing direct manipulation of these tables by the application. This can affect the network functionality, and needs to be used wisely. If used appropriately, the application can maintain more than the maximum of children provided by the stack.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | shortId | The preferred short ID of the node. | 
| sl_802154_long_addr_t | N/A | longId | The long ID of the node. | 
| sl_zigbee_node_type_t | N/A | nodeType | The nodetype e.g., SL_ZIGBEE_ROUTER defining, if this would be added to the child table or neighbor table. | 
Returns
- An ::sl_status_t value. - ::SL_STATUS_OK - This node has been successfully added. 
- ::SL_STATUS_FAIL - The child was not added to the child/neighbor table. 
 
sl_zigbee_remove_child#
sl_status_t sl_zigbee_remove_child (sl_802154_long_addr_t childEui64)
Remove a node from child/neighbor table only on SoC, allowing direct manipulation of these tables by the application. This can affect the network functionality, and needs to be used wisely.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_long_addr_t | N/A | childEui64 | The long ID of the node. | 
Returns
- An ::sl_status_t value. - ::SL_STATUS_OK - This node has been successfully removed. 
- ::SL_STATUS_FAIL - The node was not found in either of the child or neighbor tables. 
 
sl_zigbee_remove_neighbor#
void sl_zigbee_remove_neighbor (sl_802154_short_addr_t shortId, sl_802154_long_addr_t longId)
Remove a neighbor from neighbor table only on SoC, allowing direct manipulation of neighbor table by the application. This can affect the network functionality, and needs to be used wisely.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | shortId | The short ID of the neighbor. | 
| sl_802154_long_addr_t | N/A | longId | The long ID of the neighbor. | 
sl_zigbee_child_count#
uint8_t sl_zigbee_child_count (void )
Return the number of children the node currently has.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The number of children. 
sl_zigbee_router_child_count#
uint8_t sl_zigbee_router_child_count (void )
Return the number of router children that the node currently has.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The number of router children. 
sl_zigbee_max_child_count#
uint8_t sl_zigbee_max_child_count (void )
Return the maximum number of children for this node. The return value is undefined for nodes that are not joined to a network.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The maximum number of children. 
sl_zigbee_max_router_child_count#
uint8_t sl_zigbee_max_router_child_count (void )
Return the maximum number of router children for this node. The return value is undefined for nodes that are not joined to a network.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The maximum number of router children. 
sl_zigbee_get_parent_node_id#
sl_802154_short_addr_t sl_zigbee_get_parent_node_id (void )
Return the parent's node ID. The return value is undefined for nodes without parents (coordinators and nodes that are not joined to a network).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The parent's node ID. 
sl_zigbee_get_parent_eui64#
sl_802154_long_addr_t sl_zigbee_get_parent_eui64 (void )
Return the parent's EUI64. The return value is undefined for nodes without parents (coordinators and nodes that are not joined to a network).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
Returns
- The parent's EUI64.