Sub GHz Server#
Callbacks for Sub GHz Server Component.
Callbacks#
Incoming ZDO message handler.
Callback to let the application handle the incoming Mgmt_NWK_Unsolicited_Enhanced_Update_notify command.
Duty cycle state change callback for the use with the Sub-GHz plugin.
Get the suspend ZCL messages status.
Callbacks Documentation#
sli_zigbee_af_sub_ghz_server_zdo_message_received_callback#
void sli_zigbee_af_sub_ghz_server_zdo_message_received_callback (sl_802154_short_addr_t sender, const uint8_t * message, uint16_t length)
Incoming ZDO message handler.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| sl_802154_short_addr_t | N/A | sender | |
| const uint8_t * | N/A | message | |
| uint16_t | N/A | length | 
Used to handle the incoming Mgmt_NWK_Unsolicited_Enhanced_Update_notify command. Calls the user's sl_zigbee_af_sub_ghz_unsolicited_enhanced_update_notify_cb in response.
sl_zigbee_af_sub_ghz_unsolicited_enhanced_update_notify_cb#
void sl_zigbee_af_sub_ghz_unsolicited_enhanced_update_notify_cb (uint8_t channelPage, uint8_t channel, uint16_t macTxUcastTotal, uint16_t macTxUcastFailures, uint16_t macTxUcastRetries, uint8_t period)
Callback to let the application handle the incoming Mgmt_NWK_Unsolicited_Enhanced_Update_notify command.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | channelPage | ........ current channel page | 
| uint8_t | N/A | channel | ............ current channel | 
| uint16_t | N/A | macTxUcastTotal | .... total number of Mac Tx transaction attempts | 
| uint16_t | N/A | macTxUcastFailures | . total number of Mac Tx transaction failures | 
| uint16_t | N/A | macTxUcastRetries | .. total number of Mac Tx transaction retries | 
| uint8_t | N/A | period | ............. time in minutes over which macTxUcastXxx were measured | 
'Mgmt_NWK_Unsolicited_Enhanced_Update_notify' is a client command. The client sends it to notify the server about the poor link quality. The server should determine whether a channel change is necessary and change the channel if so. There is no default action performed by the application framework. If not handled by the application, no action is taken.
sl_zigbee_af_sub_ghz_duty_cycle_cb#
bool sl_zigbee_af_sub_ghz_duty_cycle_cb (uint8_t channelPage, uint8_t channel, sl_zigbee_duty_cycle_state_t oldState, sl_zigbee_duty_cycle_state_t newState)
Duty cycle state change callback for the use with the Sub-GHz plugin.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| uint8_t | N/A | channelPage | the channel that registered a Duty Cycle state change | 
| uint8_t | N/A | channel | current Duty Cycle mode | 
| sl_zigbee_duty_cycle_state_t | N/A | oldState | the previous Duty Cycle state | 
| sl_zigbee_duty_cycle_state_t | N/A | newState | the current Duty Cycle state | 
The Sub-GHz plugin monitors the duty cycle and calls this callback every time the duty cycle state changes.
Returns
- true to handle in the application, false for default behaviour 
The default response is sending the 'Suspend ZCL Messages' command, either by unicast to the most offending client of a broadcast to all clients, depending on the old and new duty cycle state.
sl_zigbee_af_sub_ghz_get_suspend_zcl_messages_status_cb#
bool sl_zigbee_af_sub_ghz_get_suspend_zcl_messages_status_cb (void )
Get the suspend ZCL messages status.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| void | N/A | 
'Get Suspend ZCL Messages Status' is a client command. The client can send it to the server to query the status instead of waiting for the 'Suspend ZCL Messages' command.
The server's default action is sending the 'Suspend ZCL Messages' command with the parameter indicating the remaining suspend time in minutes.
Returns
- True to indicate the callback has been handled by the application, false to keep the default behavior