The include file for all the types for Ember ApplicationFramework.
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_AF_API_TYPES
#define SILABS_AF_API_TYPES
#ifdef SL_COMPONENT_CATALOG_PRESENT
#include "sl_component_catalog.h"
#endif
#include "zap-type.h"
#include "app/framework/common/sl_zigbee_system_common.h"
#ifdef SL_CATALOG_ZIGBEE_MESSAGING_CLIENT_PRESENT
#include "messaging-client-config.h"
#endif // SL_CATALOG_ZIGBEE_MESSAGING_CLIENT_PRESENT
#ifdef EZSP_HOST
#include "app/util/ezsp/ezsp-enum.h"
#endif
typedef uint16_t sl_zigbee_af_profile_id_t;
typedef uint16_t sl_zigbee_af_attribute_id_t;
typedef uint16_t sl_zigbee_af_cluster_id_t;
typedef uint8_t sl_zigbee_af_attribute_type_t;
typedef uint8_t sl_zigbee_af_cluster_mask_t;
typedef uint8_t sl_zigbee_af_attribute_mask_t;
typedef void (*sl_zigbee_af_generic_cluster_function_t)(void);
typedef struct {
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_af_cluster_mask_t functionMask;
const sl_zigbee_af_generic_cluster_function_t functionPtr;
} sli_cluster_function_structure_t;
#define SL_ZIGBEE_AF_NULL_MANUFACTURER_CODE 0x0000u
#define SL_ZIGBEE_AF_INVALID_PROFILE_ID 0xFFFFu
typedef union {
uint8_t *ptrToDefaultValue;
uint16_t defaultValue;
} sl_zigbee_af_default_attribute_value_t;
typedef struct {
sl_zigbee_af_default_attribute_value_t defaultValue;
sl_zigbee_af_default_attribute_value_t minValue;
sl_zigbee_af_default_attribute_value_t maxValue;
} sl_zigbee_af_attribute_min_max_value_t;
typedef union {
uint8_t *ptrToDefaultValue;
uint16_t defaultValue;
sl_zigbee_af_attribute_min_max_value_t *ptrToMinMaxValue;
} sl_zigbee_af_default_or_min_max_attribute_value_t;
typedef struct {
sl_zigbee_af_attribute_id_t attributeId;
sl_zigbee_af_attribute_type_t attributeType;
uint8_t size;
sl_zigbee_af_attribute_mask_t mask;
sl_zigbee_af_default_or_min_max_attribute_value_t defaultValue;
} sl_zigbee_af_attribute_metadata_t;
typedef struct {
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_af_attribute_metadata_t *attributes;
uint16_t attributeCount;
uint16_t clusterSize;
sl_zigbee_af_cluster_mask_t mask;
const sl_zigbee_af_generic_cluster_function_t *functions;
} sl_zigbee_af_cluster_t;
typedef struct {
sl_zigbee_af_cluster_id_t zigbeeClusterId;
sl_zigbee_af_cluster_id_t zigbeeMfgClusterId;
sl_zigbee_af_cluster_id_t matterClusterId;
sl_zigbee_af_cluster_id_t matterMfgClusterId;
sl_zigbee_af_attribute_id_t zigbeeAttributeId;
sl_zigbee_af_attribute_id_t zigbeeMfgAttributeId;
sl_zigbee_af_attribute_type_t zigbeeAttributeType;
sl_zigbee_af_attribute_id_t matterAttributeId;
sl_zigbee_af_attribute_id_t matterMfgAttributeId;
sl_zigbee_af_attribute_type_t matterAttributeType;
} sl_zigbee_matter_af_multi_protocol_attribute_metadata_t;
typedef struct {
uint8_t endpoint;
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_af_cluster_mask_t clusterMask;
sl_zigbee_af_attribute_id_t attributeId;
uint16_t manufacturerCode;
} sl_zigbee_af_attribute_search_record_t;
typedef struct {
uint16_t index;
uint16_t manufacturerCode;
} sl_zigbee_af_manufacturer_code_entry_t;
typedef uint64_t sl_zigbee_af_difference_type_t;
typedef struct {
sl_zigbee_incoming_message_type_t type;
sl_zigbee_aps_frame_t* apsFrame;
uint8_t* message;
uint16_t msgLen;
uint16_t source;
uint8_t lastHopLqi;
int8_t lastHopRssi;
uint8_t bindingTableIndex;
uint8_t addressTableIndex;
uint8_t networkIndex;
} sl_zigbee_af_incoming_message_t;
typedef uint8_t sl_zigbee_af_interpan_message_type_t;
#define SL_ZIGBEE_AF_INTER_PAN_UNICAST 0x00u
#define SL_ZIGBEE_AF_INTER_PAN_BROADCAST 0x08u
#define SL_ZIGBEE_AF_INTER_PAN_MULTICAST 0x0Cu
// Legacy names
#define INTER_PAN_UNICAST SL_ZIGBEE_AF_INTER_PAN_UNICAST
#define INTER_PAN_BROADCAST SL_ZIGBEE_AF_INTER_PAN_BROADCAST
#define INTER_PAN_MULTICAST SL_ZIGBEE_AF_INTER_PAN_MULTICAST
#define SL_ZIGBEE_AF_INTERPAN_OPTION_NONE 0x0000u
#define SL_ZIGBEE_AF_INTERPAN_OPTION_APS_ENCRYPT 0x0001u
#define SL_ZIGBEE_AF_INTERPAN_OPTION_MAC_HAS_LONG_ADDRESS 0x0002u
typedef uint16_t sl_zigbee_af_interpan_options_t;
typedef struct {
sl_zigbee_af_interpan_message_type_t messageType;
sl_802154_long_addr_t longAddress;
sl_802154_short_addr_t shortAddress;
sl_802154_pan_id_t panId;
sl_zigbee_af_profile_id_t profileId;
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_multicast_id_t groupId;
sl_zigbee_af_interpan_options_t options;
} sl_zigbee_af_interpan_header_t;
// Legacy Name
#define sli_zigbee_interpan_header_t sl_zigbee_af_interpan_header_t
typedef uint8_t sl_zigbee_af_allowed_interpan_options_t;
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_CLIENT_TO_SERVER 0x01u
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_SERVER_TO_CLIENT 0x02u
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_BOTH 0x03u
#define SL_ZIGBEE_AF_INTERPAN_GLOBAL_COMMAND 0x04u
#define SL_ZIGBEE_AF_INTERPAN_MANUFACTURER_SPECIFIC 0x08u
typedef struct {
sl_zigbee_af_profile_id_t profileId;
sl_zigbee_af_cluster_id_t clusterId;
uint8_t commandId;
sl_zigbee_af_allowed_interpan_options_t options;
} sl_zigbee_af_allowed_inter_pan_message_t;
typedef struct {
sl_zigbee_aps_frame_t *apsFrame;
sl_zigbee_incoming_message_type_t type;
sl_802154_short_addr_t source;
uint8_t *buffer;
uint16_t bufLen;
bool clusterSpecific;
bool mfgSpecific;
uint16_t mfgCode;
uint8_t seqNum;
uint8_t commandId;
uint8_t payloadStartIndex;
uint8_t direction;
sl_zigbee_af_interpan_header_t *interPanHeader;
uint8_t networkIndex;
} sl_zigbee_af_cluster_command_t;
typedef struct {
sl_zigbee_af_cluster_t *cluster;
uint8_t clusterCount;
uint16_t endpointSize;
} sl_zigbee_af_endpoint_type_t;
#ifdef EZSP_HOST
typedef sl_zigbee_ezsp_decision_id_t sl_zigbee_af_tc_link_key_request_policy_t;
typedef sl_zigbee_ezsp_decision_id_t sl_zigbee_af_app_link_key_request_policy_t;
#define SL_ZIGBEE_AF_ALLOW_TC_KEY_REQUESTS SL_ZIGBEE_EZSP_ALLOW_TC_KEY_REQUESTS_AND_SEND_CURRENT_KEY
#define SL_ZIGBEE_AF_DENY_TC_KEY_REQUESTS SL_ZIGBEE_EZSP_DENY_TC_KEY_REQUESTS
#define SL_ZIGBEE_AF_ALLOW_APP_KEY_REQUESTS SL_ZIGBEE_EZSP_ALLOW_APP_KEY_REQUESTS
#define SL_ZIGBEE_AF_DENY_APP_KEY_REQUESTS SL_ZIGBEE_EZSP_DENY_APP_KEY_REQUESTS
#else
typedef sl_zigbee_tc_link_key_request_policy_t sl_zigbee_af_tc_link_key_request_policy_t;
typedef sl_zigbee_app_link_key_request_policy_t sl_zigbee_af_app_link_key_request_policy_t;
#define SL_ZIGBEE_AF_ALLOW_TC_KEY_REQUESTS SL_ZIGBEE_ALLOW_TC_LINK_KEY_REQUEST_AND_SEND_CURRENT_KEY
#define SL_ZIGBEE_AF_DENY_TC_KEY_REQUESTS SL_ZIGBEE_DENY_TC_LINK_KEY_REQUESTS
#define SL_ZIGBEE_AF_ALLOW_APP_KEY_REQUESTS SL_ZIGBEE_ALLOW_APP_LINK_KEY_REQUEST
#define SL_ZIGBEE_AF_DENY_APP_KEY_REQUESTS SL_ZIGBEE_DENY_APP_LINK_KEY_REQUESTS
#endif
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_security_profile_t
#else
typedef uint8_t sl_zigbee_af_security_profile_t;
enum
#endif
{
SL_ZIGBEE_AF_SECURITY_PROFILE_NONE = 0x00,
SL_ZIGBEE_AF_SECURITY_PROFILE_HA = 0x01,
SL_ZIGBEE_AF_SECURITY_PROFILE_HA12 = 0x02,
SL_ZIGBEE_AF_SECURITY_PROFILE_SE_TEST = 0x03,
SL_ZIGBEE_AF_SECURITY_PROFILE_SE_FULL = 0x04,
SL_ZIGBEE_AF_SECURITY_PROFILE_Z3 = 0x05,
SL_ZIGBEE_AF_SECURITY_PROFILE_CUSTOM = 0xFF,
};
typedef struct {
sl_zigbee_af_security_profile_t securityProfile;
uint16_t tcBitmask;
sl_zigbee_extended_security_bitmask_t tcExtendedBitmask;
uint16_t nodeBitmask;
sl_zigbee_extended_security_bitmask_t nodeExtendedBitmask;
sl_zigbee_af_tc_link_key_request_policy_t tcLinkKeyRequestPolicy;
sl_zigbee_af_app_link_key_request_policy_t appLinkKeyRequestPolicy;
sl_zigbee_key_data_t preconfiguredKey;
} sl_zigbee_af_security_profile_data_t;
#ifndef DOXYGEN_SHOULD_SKIP_THIS
typedef struct {
sl_zigbee_node_type_t nodeType;
sl_zigbee_af_security_profile_t securityProfile;
} sli_zigbee_af_zigbee_pro_network;
#endif
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_endpoint_bitmask_t;
#else
typedef uint8_t sl_zigbee_af_endpoint_bitmask_t;
enum
#endif
{
SL_ZIGBEE_AF_ENDPOINT_DISABLED = 0x00,
SL_ZIGBEE_AF_ENDPOINT_ENABLED = 0x01,
};
typedef struct {
uint8_t endpoint;
sl_zigbee_af_profile_id_t profileId;
uint16_t deviceId;
uint8_t deviceVersion;
sl_zigbee_af_endpoint_type_t *endpointType;
uint8_t networkIndex;
sl_zigbee_af_endpoint_bitmask_t bitmask;
} sl_zigbee_af_defined_endpoint_t;
// Cluster-specific types
#if (SL_ZIGBEE_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE <= 8)
typedef uint8_t sl_zigbee_af_plugin_esi_management_bitmask_t;
#elif (SL_ZIGBEE_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE <= 16)
typedef uint16_t sl_zigbee_af_plugin_esi_management_bitmask_t;
#elif (SL_ZIGBEE_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE <= 32)
typedef uint32_t sl_zigbee_af_plugin_esi_management_bitmask_t;
#else
#error "SL_ZIGBEE_AF_PLUGIN_ESI_MANAGEMENT_ESI_TABLE_SIZE cannot exceed 32"
#endif
typedef struct {
uint32_t eventId;
#if defined(EMBER_AF_PLUGIN_DRLC_SERVER) || defined(SL_CATALOG_ZIGBEE_DRLC_SERVER_PRESENT)
sl_802154_long_addr_t source;
uint8_t sourceEndpoint;
#endif //EMBER_AF_PLUGIN_DRLC_SERVER || SL_CATALOG_ZIGBEE_DRLC_SERVER_PRESENT
#if defined(EMBER_AF_PLUGIN_DRLC) || defined(SL_CATALOG_ZIGBEE_DRLC_PRESENT)
sl_zigbee_af_plugin_esi_management_bitmask_t esiBitmask;
#endif //EMBER_AF_PLUGIN_DRLC || SL_CATALOG_ZIGBEE_DRLC_PRESENT
uint8_t destinationEndpoint;
uint16_t deviceClass;
uint8_t utilityEnrollmentGroup;
uint32_t startTime;
uint16_t duration;
uint8_t criticalityLevel;
uint8_t coolingTempOffset;
uint8_t heatingTempOffset;
int16_t coolingTempSetPoint;
int16_t heatingTempSetPoint;
int8_t avgLoadPercentage;
uint8_t dutyCycle;
uint8_t eventControl;
uint32_t startRand;
uint32_t durationRand;
uint8_t optionControl;
} sl_zigbee_af_load_control_event_t;
typedef enum {
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE = 0x00,
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_RESPONSE_RECEIVED = 0x01,
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_TIMEOUT = 0x02,
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE = 0x03,
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE = 0x04,
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE = 0x05,
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE = 0x06,
} sl_zigbee_af_service_discovery_status_t;
#define EM_AF_DISCOVERY_RESPONSE_MASK (0x05u)
#define sl_zigbee_af_have_discovery_response_status(status) ((status) & EM_AF_DISCOVERY_RESPONSE_MASK)
typedef struct {
sl_zigbee_af_service_discovery_status_t status;
uint16_t zdoRequestClusterId;
sl_802154_short_addr_t matchAddress;
const void* responseData;
} sl_zigbee_af_service_discovery_result_t;
typedef struct {
uint8_t count;
const uint8_t* list;
} sl_zigbee_af_endpoint_list_t;
typedef struct {
uint8_t inClusterCount;
const uint16_t* inClusterList;
uint8_t outClusterCount;
const uint16_t* outClusterList;
sl_zigbee_af_profile_id_t profileId;
uint16_t deviceId;
uint8_t endpoint;
} sl_zigbee_af_cluster_list_t;
typedef void (sl_zigbee_af_service_discovery_callback_t)(const sl_zigbee_af_service_discovery_result_t* result);
typedef void (sl_zigbee_af_partner_link_key_exchange_callback_t)(bool success);
typedef enum {
SL_ZIGBEE_AF_LONG_POLL,
SL_ZIGBEE_AF_SHORT_POLL,
} sl_zigbee_af_event_poll_control_t;
typedef enum {
SL_ZIGBEE_AF_OK_TO_SLEEP,
SL_ZIGBEE_AF_OK_TO_HIBERNATE = SL_ZIGBEE_AF_OK_TO_SLEEP,
SL_ZIGBEE_AF_OK_TO_NAP,
SL_ZIGBEE_AF_STAY_AWAKE,
} sl_zigbee_af_event_sleep_control_t;
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_application_task_t
#else
typedef uint32_t sl_zigbee_af_application_task_t;
enum
#endif
{
// we may be able to remove these top two since they are
// handled by the stack on the SOC.
SL_ZIGBEE_AF_WAITING_FOR_DATA_ACK = 0x00000001, //not needed?
SL_ZIGBEE_AF_LAST_POLL_GOT_DATA = 0x00000002, //not needed?
SL_ZIGBEE_AF_WAITING_FOR_SERVICE_DISCOVERY = 0x00000004,
SL_ZIGBEE_AF_WAITING_FOR_ZDO_RESPONSE = 0x00000008,
SL_ZIGBEE_AF_WAITING_FOR_ZCL_RESPONSE = 0x00000010,
SL_ZIGBEE_AF_WAITING_FOR_REGISTRATION = 0x00000020,
SL_ZIGBEE_AF_WAITING_FOR_PARTNER_LINK_KEY_EXCHANGE = 0x00000040,
SL_ZIGBEE_AF_FORCE_SHORT_POLL = 0x00000080,
SL_ZIGBEE_AF_FRAGMENTATION_IN_PROGRESS = 0x00000100,
SL_ZIGBEE_AF_FORCE_SHORT_POLL_FOR_PARENT_CONNECTIVITY = 0x00000200,
SL_ZIGBEE_AF_WAITING_FOR_TC_KEY_UPDATE = 0x00000400,
};
typedef struct {
uint8_t endpoint;
sl_zigbee_af_cluster_id_t clusterId;
bool isClient;
sl_zigbee_af_event_poll_control_t pollControl;
sl_zigbee_af_event_sleep_control_t sleepControl;
sl_zigbee_event_control_t *eventControl;
} sl_zigbee_af_event_context;
// TODO: update doxygen
typedef struct {
uint8_t endpoint;
sl_zigbee_af_cluster_id_t clusterId;
bool isClient;
sl_zigbee_af_event_poll_control_t pollControl;
sl_zigbee_af_event_sleep_control_t sleepControl;
sli_zigbee_event_t *event;
} sl_zigbee_event_context_t;
typedef void (*sl_zigbee_af_network_event_handler_t)(void);
typedef void (*sl_zigbee_af_endpoint_event_handler_t)(uint8_t endpoint);
#define SL_ZIGBEE_AF_GROUP_TABLE_NULL_INDEX 0xFFu
#define SL_ZIGBEE_AF_GROUP_TABLE_UNUSED_ENDPOINT_ID 0x00u
#define ZCL_GROUPS_CLUSTER_MAXIMUM_NAME_LENGTH 16u
typedef struct {
uint8_t endpoint; // 0x00 when not in use
uint16_t groupId;
uint8_t bindingIndex;
#ifdef SL_ZIGBEE_AF_PLUGIN_GROUPS_SERVER_NAME_SUPPORT
uint8_t name[ZCL_GROUPS_CLUSTER_MAXIMUM_NAME_LENGTH + 1];
#endif
} sl_zigbee_af_group_table_entry_t;
#define SL_ZIGBEE_AF_SCENE_TABLE_NULL_INDEX 0xFFu
#define SL_ZIGBEE_AF_SCENE_TABLE_UNUSED_ENDPOINT_ID 0x00u
#define ZCL_SCENES_CLUSTER_MAXIMUM_NAME_LENGTH 16u
#define ZCL_SCENES_GLOBAL_SCENE_GROUP_ID 0x0000u
#define ZCL_SCENES_GLOBAL_SCENE_SCENE_ID 0x00u
// EMZIGBEE-6833: sl_zigbee_af_scene_table_entry_t declaration should be moved to the scenes component.
#ifdef SL_CATALOG_ZIGBEE_SCENES_PRESENT
#include "scenes-config.h"
#if (SL_ZIGBEE_AF_PLUGIN_SCENES_NAME_SUPPORT == 1)
#define SCENES_NAME_SUPPORT
#endif
#endif // SL_CATALOG_ZIGBEE_SCENES_PRESENT
typedef struct {
uint8_t endpoint; // 0x00 when this record is not in use
uint16_t groupId; // 0x0000 if not associated with a group
uint8_t sceneId;
#ifdef SCENES_NAME_SUPPORT
uint8_t name[ZCL_SCENES_CLUSTER_MAXIMUM_NAME_LENGTH + 1];
#endif
uint16_t transitionTime; // in seconds
uint8_t transitionTime100ms; // in tenths of a seconds
#ifdef ZCL_USING_ON_OFF_CLUSTER_SERVER
bool hasOnOffValue;
bool onOffValue;
#endif
#ifdef ZCL_USING_LEVEL_CONTROL_CLUSTER_SERVER
bool hasCurrentLevelValue;
uint8_t currentLevelValue;
#endif
#ifdef ZCL_USING_THERMOSTAT_CLUSTER_SERVER
bool hasOccupiedCoolingSetpointValue;
int16_t occupiedCoolingSetpointValue;
bool hasOccupiedHeatingSetpointValue;
int16_t occupiedHeatingSetpointValue;
bool hasSystemModeValue;
uint8_t systemModeValue;
#endif
#ifdef ZCL_USING_COLOR_CONTROL_CLUSTER_SERVER
bool hasCurrentXValue;
uint16_t currentXValue;
bool hasCurrentYValue;
uint16_t currentYValue;
bool hasEnhancedCurrentHueValue;
uint16_t enhancedCurrentHueValue;
bool hasCurrentSaturationValue;
uint8_t currentSaturationValue;
bool hasColorLoopActiveValue;
uint8_t colorLoopActiveValue;
bool hasColorLoopDirectionValue;
uint8_t colorLoopDirectionValue;
bool hasColorLoopTimeValue;
uint16_t colorLoopTimeValue;
bool hasColorTemperatureMiredsValue;
uint16_t colorTemperatureMiredsValue;
#endif //ZCL_USING_COLOR_CONTROL_CLUSTER_SERVER
#ifdef ZCL_USING_DOOR_LOCK_CLUSTER_SERVER
bool hasLockStateValue;
uint8_t lockStateValue;
#endif
#ifdef ZCL_USING_WINDOW_COVERING_CLUSTER_SERVER
bool hasCurrentPositionLiftPercentageValue;
uint8_t currentPositionLiftPercentageValue;
bool hasCurrentPositionTiltPercentageValue;
uint8_t currentPositionTiltPercentageValue;
#endif
} sl_zigbee_af_scene_table_entry_t;
#if !defined(EMBER_AF_PLUGIN_MESSAGING_CLIENT) && !defined(SL_CATALOG_ZIGBEE_MESSAGING_CLIENT_PRESENT)
// To forward declare callbacks regardless of whether the plugin
// is enabled, define all data structures. To define
// the messaging client data struct, declare this variable.
#define SL_ZIGBEE_AF_PLUGIN_MESSAGING_CLIENT_MESSAGE_SIZE 0
#endif
typedef struct {
bool valid;
bool active;
sl_zigbee_af_plugin_esi_management_bitmask_t esiBitmask;
uint8_t clientEndpoint;
uint32_t messageId;
uint8_t messageControl;
uint32_t startTime;
uint32_t endTime;
uint16_t durationInMinutes;
uint8_t message[SL_ZIGBEE_AF_PLUGIN_MESSAGING_CLIENT_MESSAGE_SIZE + 1];
} sl_zigbee_af_plugin_messaging_client_message_t;
#define ZCL_PRICE_CLUSTER_MAXIMUM_RATE_LABEL_LENGTH 11u
typedef struct {
bool valid;
bool active;
uint8_t clientEndpoint;
uint32_t providerId;
uint8_t rateLabel[ZCL_PRICE_CLUSTER_MAXIMUM_RATE_LABEL_LENGTH + 1];
uint32_t issuerEventId;
uint32_t currentTime;
uint8_t unitOfMeasure;
uint16_t currency;
uint8_t priceTrailingDigitAndPriceTier;
uint8_t numberOfPriceTiersAndRegisterTier;
uint32_t startTime;
uint32_t endTime;
uint16_t durationInMinutes;
uint32_t price;
uint8_t priceRatio;
uint32_t generationPrice;
uint8_t generationPriceRatio;
uint32_t alternateCostDelivered;
uint8_t alternateCostUnit;
uint8_t alternateCostTrailingDigit;
uint8_t numberOfBlockThresholds;
uint8_t priceControl;
} sl_zigbee_af_plugin_price_client_price_t;
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_plugin_price_cpp_auth_t
#else
typedef uint8_t sl_zigbee_af_plugin_price_cpp_auth_t;
enum
#endif
{
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_PENDING = 0,
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_ACCEPTED = 1,
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_REJECTED = 2,
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_FORCED = 3,
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_RESERVED = 4
};
#define SL_ZIGBEE_AF_PLUGIN_REPORTING_UNUSED_ENDPOINT_ID 0x00u
typedef struct {
sl_zigbee_af_reporting_direction_t direction;
uint8_t endpoint;
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_af_attribute_id_t attributeId;
uint8_t mask;
uint16_t manufacturerCode;
union {
struct {
uint16_t minInterval;
uint16_t maxInterval;
uint32_t reportableChange;
} reported;
struct {
sl_802154_short_addr_t source;
uint8_t endpoint;
uint16_t timeout;
} received;
} data;
} sl_zigbee_af_plugin_reporting_entry_t;
typedef enum {
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_SUCCESS = 0x00,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_BUSY = 0x01,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_NO_MORE_TUNNEL_IDS = 0x02,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_PROTOCOL_NOT_SUPPORTED = 0x03,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_FLOW_CONTROL_NOT_SUPPORTED = 0x04,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_IEEE_ADDRESS_REQUEST_FAILED = 0xF9,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_IEEE_ADDRESS_NOT_FOUND = 0xFA,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_ADDRESS_TABLE_FULL = 0xFB,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_LINK_KEY_EXCHANGE_REQUEST_FAILED = 0xFC,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_LINK_KEY_EXCHANGE_FAILED = 0xFD,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_REQUEST_TUNNEL_FAILED = 0xFE,
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_REQUEST_TUNNEL_TIMEOUT = 0xFF,
} sl_zigbee_af_plugin_tunneling_client_status_t;
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_zll_commissioning_status_t
#else
typedef uint8_t sl_zigbee_af_zll_commissioning_status_t;
enum
#endif
{
SL_ZIGBEE_AF_ZLL_ABORTED_BY_APPLICATION = 0x00,
SL_ZIGBEE_AF_ZLL_CHANNEL_CHANGE_FAILED = 0x01,
SL_ZIGBEE_AF_ZLL_JOINING_FAILED = 0x02,
SL_ZIGBEE_AF_ZLL_NO_NETWORKS_FOUND = 0x03,
SL_ZIGBEE_AF_ZLL_PREEMPTED_BY_STACK = 0x04,
SL_ZIGBEE_AF_ZLL_SENDING_START_JOIN_FAILED = 0x05,
SL_ZIGBEE_AF_ZLL_SENDING_DEVICE_INFORMATION_REQUEST_FAILED = 0x06,
SL_ZIGBEE_AF_ZLL_SENDING_IDENTIFY_REQUEST_FAILED = 0x07,
SL_ZIGBEE_AF_ZLL_SENDING_RESET_TO_FACTORY_NEW_REQUEST_FAILED = 0x08,
SL_ZIGBEE_AF_ZLL_NETWORK_FORMATION_FAILED = 0x09,
SL_ZIGBEE_AF_ZLL_NETWORK_UPDATE_OPERATION = 0x0A,
};
typedef struct {
sl_zigbee_multicast_id_t groupId;
uint8_t groupType;
} sl_zigbee_af_plugin_zll_commissioning_group_information_record_t;
typedef struct {
sl_802154_short_addr_t networkAddress;
uint8_t endpointId;
uint16_t profileId;
uint16_t deviceId;
uint8_t version;
} sl_zigbee_af_plugin_zll_commissioning_endpoint_information_record_t;
typedef struct {
uint16_t manufacturerId;
uint16_t imageTypeId;
uint32_t firmwareVersion;
uint8_t deviceSpecificFileEui64[EUI64_SIZE];
} sl_zigbee_af_ota_image_id_t;
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_image_block_request_options_t
#else
typedef uint8_t sl_zigbee_af_image_block_request_options_t;
enum
#endif
{
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_OPTIONS_NONE = 0x00,
// Client supports Min Block Request field
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_MIN_BLOCK_REQUEST_SUPPORTED_BY_CLIENT = 0x01,
// Server supports Min Block Request field
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_MIN_BLOCK_REQUEST_SUPPORTED_BY_SERVER = 0x02,
// The Image Block Request is actually simulated in place of an actually
// received Image Page Request
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_SIMULATED_FROM_PAGE_REQUEST = 0x04
};
typedef struct {
const sl_zigbee_af_ota_image_id_t* id;
uint32_t offset;
uint32_t waitTimeSecondsResponse;
sl_802154_short_addr_t source;
sl_802154_long_addr_t sourceEui; // optionally present in messages
// The minBlockRequestPeriod can be treated as milliseconds or seconds on the
// client. The OTA server plugin has optional support to probe clients and
// treat this field with appropriate units (ms or sec)
uint16_t minBlockRequestPeriod; // optionally present in messages
uint8_t maxDataSize;
uint8_t clientEndpoint;
sl_zigbee_af_image_block_request_options_t bitmask;
} sl_zigbee_af_image_block_request_callback_struct_t;
typedef enum {
SL_ZIGBEE_AF_OTA_STORAGE_SUCCESS = 0,
SL_ZIGBEE_AF_OTA_STORAGE_ERROR = 1,
SL_ZIGBEE_AF_OTA_STORAGE_RETURN_DATA_TOO_LONG = 2,
SL_ZIGBEE_AF_OTA_STORAGE_PARTIAL_FILE_FOUND = 3,
SL_ZIGBEE_AF_OTA_STORAGE_OPERATION_IN_PROGRESS = 4,
} sl_zigbee_af_ota_storage_status_t;
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_ota_download_result_t
#else
typedef uint8_t sl_zigbee_af_ota_download_result_t;
enum
#endif
{
SL_ZIGBEE_AF_OTA_DOWNLOAD_AND_VERIFY_SUCCESS = 0,
SL_ZIGBEE_AF_OTA_DOWNLOAD_TIME_OUT = 1,
SL_ZIGBEE_AF_OTA_VERIFY_FAILED = 2,
SL_ZIGBEE_AF_OTA_SERVER_ABORTED = 3,
SL_ZIGBEE_AF_OTA_CLIENT_ABORTED = 4,
SL_ZIGBEE_AF_OTA_ERASE_FAILED = 5,
};
#define SL_ZIGBEE_AF_OTA_MAX_HEADER_STRING_LENGTH 32u
#define UID_SIZE 32u
typedef struct {
// Magic Number omitted since it is always the same.
uint16_t headerVersion;
uint16_t headerLength;
uint16_t fieldControl;
uint16_t manufacturerId;
uint16_t imageTypeId; // a.k.a. Device ID
uint32_t firmwareVersion;
uint16_t zigbeeStackVersion;
uint8_t headerString[SL_ZIGBEE_AF_OTA_MAX_HEADER_STRING_LENGTH + 1];
uint32_t imageSize;
uint8_t securityCredentials;
union {
uint8_t EUI64[EUI64_SIZE];
uint8_t UID[UID_SIZE];
} upgradeFileDestination;
uint16_t minimumHardwareVersion;
uint16_t maximumHardwareVersion;
} sl_zigbee_af_ota_header_t;
typedef struct {
uint16_t id;
uint32_t length;
} sl_zigbee_af_tag_data_t;
typedef enum {
NO_APP_MESSAGE = 0,
RECEIVED_PARTNER_CERTIFICATE = 1,
GENERATING_EPHEMERAL_KEYS = 2,
GENERATING_SHARED_SECRET = 3,
KEY_GENERATION_DONE = 4,
GENERATE_SHARED_SECRET_DONE = 5,
LINK_KEY_ESTABLISHED = 6,
NO_LOCAL_RESOURCES = 7,
PARTNER_NO_RESOURCES = 8,
TIMEOUT_OCCURRED = 9,
INVALID_APP_COMMAND = 10,
MESSAGE_SEND_FAILURE = 11,
PARTNER_SENT_TERMINATE = 12,
INVALID_PARTNER_MESSAGE = 13,
PARTNER_SENT_DEFAULT_RESPONSE_ERROR = 14,
BAD_CERTIFICATE_ISSUER = 15,
KEY_CONFIRM_FAILURE = 16,
BAD_KEY_ESTABLISHMENT_SUITE = 17,
KEY_TABLE_FULL = 18,
NO_ESTABLISHMENT_ALLOWED = 19,
/* 283k1 certificates need to have valid key usage.
*/
INVALID_CERTIFICATE_KEY_USAGE = 20,
} sl_zigbee_af_key_establishment_notify_message_t;
#define APP_NOTIFY_ERROR_CODE_START NO_LOCAL_RESOURCES
#define APP_NOTIFY_MESSAGE_TEXT { \
"None", \
"Received Cert", \
"Generate keys", \
"Generate secret", \
"Key generate done", \
"Generate secret done", \
"Link key verified", \
\
/* Transient Error codes */ \
"No local resources", \
"Partner no resources", \
"Timeout", \
"Invalid app. command", \
"Message send failure", \
"Partner sent terminate", \
"Bad message", \
"Partner sent Default Rsp", \
\
/* Fatal errors */ \
"Bad cert issuer", \
"Key confirm failure", \
"Bad key est. suite", \
"Key table full", \
"Not allowed", \
"Invalid Key Usage", \
}
typedef enum {
SL_ZIGBEE_AF_IMAGE_GOOD = 0,
SL_ZIGBEE_AF_IMAGE_BAD = 1,
SL_ZIGBEE_AF_IMAGE_VERIFY_IN_PROGRESS = 2,
#ifndef DOXYGEN_SHOULD_SKIP_THIS
// Internal use only.
SL_ZIGBEE_AF_IMAGE_VERIFY_WAIT = 3,
SL_ZIGBEE_AF_IMAGE_VERIFY_ERROR = 4,
SL_ZIGBEE_AF_IMAGE_UNKNOWN = 5,
SL_ZIGBEE_AF_NO_IMAGE_VERIFY_SUPPORT = 6,
#endif
} sl_zigbee_af_image_verify_status_t;
typedef void (*sl_zigbee_af_tick_function_t)(uint8_t endpoint);
typedef void (*sl_zigbee_af_init_function_t)(uint8_t endpoint);
typedef void (*sl_zigbee_af_cluster_attribute_changed_callback_t)(uint8_t endpoint,
sl_zigbee_af_attribute_id_t attributeId);
typedef void (*sl_zigbee_af_manufacturer_specific_cluster_attribute_changed_callback_t)(uint8_t endpoint,
sl_zigbee_af_attribute_id_t attributeId,
uint16_t manufacturerCode);
typedef sl_zigbee_af_status_t (*sl_zigbee_af_cluster_pre_attribute_changed_callback_t)(uint8_t endpoint,
sl_zigbee_af_attribute_id_t attributeId,
sl_zigbee_af_attribute_type_t attributeType,
uint8_t size,
uint8_t *value);
typedef void (*sl_zigbee_af_default_response_function_t)(uint8_t endpoint,
uint8_t commandId,
sl_zigbee_af_status_t status);
typedef void (*sl_zigbee_af_message_sent_function_t)(sl_zigbee_outgoing_message_type_t type,
uint16_t indexOrDestination,
sl_zigbee_aps_frame_t *apsFrame,
uint16_t msgLen,
uint8_t *message,
sl_status_t status);
typedef struct {
sl_zigbee_af_message_sent_function_t callback;
sl_zigbee_aps_frame_t* apsFrame;
uint8_t* message;
uint16_t indexOrDestination;
uint16_t messageLength;
sl_zigbee_outgoing_message_type_t type;
bool broadcast;
} sl_zigbee_af_message_struct_t;
typedef struct {
sl_802154_long_addr_t deviceId;
sl_zigbee_key_data_t key;
} sl_zigbee_af_link_key_backup_data_t;
typedef struct {
sl_802154_long_addr_t extendedPanId;
uint8_t keyListLength;
uint8_t maxKeyListLength;
sl_zigbee_af_link_key_backup_data_t* keyList;
} sl_zigbee_af_trust_center_backup_data_t;
#define SL_ZIGBEE_AF_STANDALONE_BOOTLOADER_HARDWARE_TAG_LENGTH 16u
typedef struct {
uint8_t hardwareTag[SL_ZIGBEE_AF_STANDALONE_BOOTLOADER_HARDWARE_TAG_LENGTH];
uint8_t eui64[EUI64_SIZE];
uint16_t mfgId;
uint16_t bootloaderVersion;
uint8_t capabilities;
uint8_t platform;
uint8_t micro;
uint8_t phy;
bool bootloaderActive;
} sl_zigbee_af_standalone_bootloader_query_response_data_t;
typedef struct {
uint16_t clusterId;
uint8_t commandId;
uint8_t mask;
} sl_zigbee_af_command_metadata_t;
typedef struct {
uint16_t year;
uint8_t month;
uint8_t day;
uint8_t hours;
uint8_t minutes;
uint8_t seconds;
} sl_zigbee_af_time_struct_t;
typedef struct {
uint8_t year;
uint8_t month;
uint8_t dayOfMonth;
uint8_t dayOfWeek;
} sl_zigbee_af_date_t;
/* Simple Metering Server Test Code */
#define SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_ELECTRIC_METER 0
#define SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_GAS_METER 1
// Functional Notification Flags
// Also #defined in enums.h under slightly different names
#define SL_ZIGBEE_AF_METERING_FNF_NEW_OTA_FIRMWARE 0x00000001
#define SL_ZIGBEE_AF_METERING_FNF_CBKE_UPDATE_REQUEST 0x00000002
#define SL_ZIGBEE_AF_METERING_FNF_TIME_SYNC 0x00000004
#define SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_HAN 0x00000010
#define SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_WAN 0x00000020
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_METERING_DATA_ATTRIBUTE_SET 0x000001C0
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_PREPAYMENT_DATA_ATTRIBUTE_SET 0x00000E00
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_BASIC_CLUSTER 0x00001000
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_METERING_CLUSTER 0x00002000
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_PREPAYMENT_CLUSTER 0x00004000
#define SL_ZIGBEE_AF_METERING_FNF_NETWORK_KEY_ACTIVE 0x00008000
#define SL_ZIGBEE_AF_METERING_FNF_DISPLAY_MESSAGE 0x00010000
#define SL_ZIGBEE_AF_METERING_FNF_CANCEL_ALL_MESSAGES 0x00020000
#define SL_ZIGBEE_AF_METERING_FNF_CHANGE_SUPPLY 0x00040000
#define SL_ZIGBEE_AF_METERING_FNF_LOCAL_CHANGE_SUPPLY 0x00080000
#define SL_ZIGBEE_AF_METERING_FNF_SET_UNCONTROLLED_FLOW_THRESHOLD 0x00100000
#define SL_ZIGBEE_AF_METERING_FNF_TUNNEL_MESSAGE_PENDING 0x00200000
#define SL_ZIGBEE_AF_METERING_FNF_GET_SNAPSHOT 0x00400000
#define SL_ZIGBEE_AF_METERING_FNF_GET_SAMPLED_DATA 0x00800000
#define SL_ZIGBEE_AF_METERING_FNF_NEW_SUB_GHZ_CHANNEL_MASKS_AVAILABLE 0x01000000
#define SL_ZIGBEE_AF_METERING_FNF_ENERGY_SCAN_PENDING 0x02000000
#define SL_ZIGBEE_AF_METERING_FNF_CHANNEL_CHANGE_PENDING 0x04000000
// Notification Flags 2
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICE 0x00000001
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_PERIOD 0x00000002
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TARIFF_INFORMATION 0x00000004
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONVERSION_FACTOR 0x00000008
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CALORIFIC_VALUE 0x00000010
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CO2_VALUE 0x00000020
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BILLING_PERIOD 0x00000040
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONSOLIDATED_BILL 0x00000080
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICE_MATRIX 0x00000100
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_THRESHOLDS 0x00000200
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CURRENCY_CONVERSION 0x00000400
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CREDIT_PAYMENT_INFO 0x00001000
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CPP_EVENT 0x00002000
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TIER_LABELS 0x00004000
#define SL_ZIGBEE_AF_METERING_NF2_CANCEL_TARIFF 0x00008000
// Notification Flags 3
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_CALENDAR 0x00000001
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SPECIAL_DAYS 0x00000002
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SEASONS 0x00000004
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_WEEK 0x00000008
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_DAY 0x00000010
#define SL_ZIGBEE_AF_METERING_NF3_CANCEL_CALENDAR 0x00000020
// Notification Flags 4
#define SL_ZIGBEE_AF_METERING_NF4_SELECT_AVAILABLE_EMERGENCY_CREDIT 0x00000001
#define SL_ZIGBEE_AF_METERING_NF4_CHANGE_DEBT 0x00000002
#define SL_ZIGBEE_AF_METERING_NF4_EMERGENCY_CREDIT_SETUP 0x00000004
#define SL_ZIGBEE_AF_METERING_NF4_CONSUMER_TOP_UP 0x00000008
#define SL_ZIGBEE_AF_METERING_NF4_CREDIT_ADJUSTMENT 0x00000010
#define SL_ZIGBEE_AF_METERING_NF4_CHANGE_PAYMENT_MODE 0x00000020
#define SL_ZIGBEE_AF_METERING_NF4_GET_PREPAY_SNAPSHOT 0x00000040
#define SL_ZIGBEE_AF_METERING_NF4_GET_TOP_UP_LOG 0x00000080
#define SL_ZIGBEE_AF_METERING_NF4_SET_LOW_CREDIT_WARNING_LEVEL 0x00000100
#define SL_ZIGBEE_AF_METERING_NF4_GET_DEBT_REPAYMENT_LOG 0x00000200
#define SL_ZIGBEE_AF_METERING_NF4_SET_MAXIMUM_CREDIT_LIMIT 0x00000400
#define SL_ZIGBEE_AF_METERING_NF4_SET_OVERALL_DEBT_CAP 0x00000800
// Notification Flags 5
#define SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_TENANCY 0x00000001
#define SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_SUPPLIER 0x00000002
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_1_RESPONSE 0x00000004
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_2_RESPONSE 0x00000008
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_3_RESPONSE 0x00000010
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_4_RESPONSE 0x00000020
#define SL_ZIGBEE_AF_METERING_NF5_UPDATE_SITE_ID 0x00000040
#define SL_ZIGBEE_AF_METERING_NF5_RESET_BATTERY_COUNTER 0x00000080
#define SL_ZIGBEE_AF_METERING_NF5_UPDATE_CIN 0x00000100
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_cbke_key_establishment_suite_t
#else
typedef uint16_t sl_zigbee_af_cbke_key_establishment_suite_t;
enum
#endif
{
SL_ZIGBEE_AF_INVALID_KEY_ESTABLISHMENT_SUITE = 0x0000,
SL_ZIGBEE_AF_CBKE_KEY_ESTABLISHMENT_SUITE_163K1 = 0x0001,
SL_ZIGBEE_AF_CBKE_KEY_ESTABLISHMENT_SUITE_283K1 = 0x0002,
};
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_NAME_LENGTH (16u)
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_CONTACT_DETAILS_LENGTH (18u)
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_SITE_ID_LENGTH (32u)
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_CIN_LENGTH (24u)
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PASSWORD_LENGTH (10u)
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_device_management_password_type_t
#else
typedef uint16_t sl_zigbee_af_device_management_password_type_t;
enum
#endif
{
UNUSED_PASSWORD = 0x00,
SERVICE_PASSWORD = 0x01,
CONSUMER_PASSWORD = 0x02,
};
#ifdef DOXYGEN_SHOULD_SKIP_THIS
enum sl_zigbee_af_device_management_change_pending_flags_t
#else
typedef uint8_t sl_zigbee_af_device_management_change_pending_flags_t;
enum
#endif
{
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_CHANGE_OF_TENANCY_PENDING_MASK = 0x01,
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_CHANGE_OF_SUPPLIER_PENDING_MASK = 0x02,
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_SITE_ID_PENDING_MASK = 0x04,
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_CIN_PENDING_MASK = 0x08,
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_SERVICE_PASSWORD_PENDING_MASK = 0x10,
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_CONSUMER_PASSWORD_PENDING_MASK = 0x20,
};
typedef struct {
// Optional fields only used by Gas Proxy Function plugin.
uint32_t providerId;
uint32_t issuerEventId;
uint8_t tariffType;
// always used fields
uint32_t implementationDateTime;
uint32_t tenancy;
} sl_zigbee_af_device_management_tenancy_t;
typedef struct {
uint32_t proposedProviderId;
uint32_t implementationDateTime;
uint32_t providerChangeControl;
uint8_t proposedProviderName[SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_NAME_LENGTH + 1];
uint8_t proposedProviderContactDetails[SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_CONTACT_DETAILS_LENGTH + 1];
} sl_zigbee_af_device_management_supplier_t;
typedef struct {
uint32_t requestDateTime;
uint32_t implementationDateTime;
uint8_t supplyStatus;
uint8_t originatorIdSupplyControlBits;
} sl_zigbee_af_device_management_supply_t;
typedef struct {
uint8_t siteId[SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_SITE_ID_LENGTH + 1];
uint32_t implementationDateTime;
uint32_t issuerEventId;
} sl_zigbee_af_device_management_site_id_t;
typedef struct {
uint8_t cin[SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_CIN_LENGTH + 1];
uint32_t implementationDateTime;
uint32_t issuerEventId;
} sl_zigbee_af_device_management_c_i_n_t;
typedef struct {
bool supplyTamperState;
bool supplyDepletionState;
bool supplyUncontrolledFlowState;
bool loadLimitSupplyState;
} sl_zigbee_af_device_management_supply_status_flags_t;
typedef struct {
uint16_t uncontrolledFlowThreshold;
uint16_t multiplier;
uint16_t divisor;
uint16_t measurementPeriod;
uint8_t unitOfMeasure;
uint8_t stabilisationPeriod;
} sl_zigbee_af_device_management_uncontrolled_flow_threshold_t;
typedef struct {
uint32_t implementationDateTime;
uint8_t supplyStatus;
} sl_zigbee_af_device_management_supply_status_t;
typedef struct {
uint8_t password[SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PASSWORD_LENGTH + 1];
uint32_t implementationDateTime;
uint16_t durationInMinutes;
sl_zigbee_af_device_management_password_type_t passwordType;
} sl_zigbee_af_device_management_password_t;
typedef struct {
sl_zigbee_af_device_management_tenancy_t tenancy;
sl_zigbee_af_device_management_supplier_t supplier;
sl_zigbee_af_device_management_supply_t supply;
sl_zigbee_af_device_management_site_id_t siteId;
sl_zigbee_af_device_management_c_i_n_t cin;
sl_zigbee_af_device_management_supply_status_flags_t supplyStatusFlags;
sl_zigbee_af_device_management_supply_status_t supplyStatus;
//TODO: These passwords ought to be tokenized / hashed
sl_zigbee_af_device_management_password_t servicePassword;
sl_zigbee_af_device_management_password_t consumerPassword;
sl_zigbee_af_device_management_uncontrolled_flow_threshold_t threshold;
uint32_t providerId;
uint32_t issuerEventId;
uint8_t proposedLocalSupplyStatus;
sl_zigbee_af_tariff_type_t tariffType;
sl_zigbee_af_device_management_change_pending_flags_t pendingUpdates;
} sl_zigbee_af_device_management_info_t;
typedef struct {
uint8_t startIndex;
uint8_t endIndex;
} sl_zigbee_af_device_management_attribute_range_t;
// attrRange is a list of attributeId values in a cluster. It's needed to track contiguous
// segments of valid attributeId's with gaps in the middle.
// attributeSetId is the value of the upper byte in the attributeId. It ranges from 0x01(Price)
// to 0x08(OTA Event Configuration)
// Eg. {0x00,0x05} and {0x08,0x0A}
// We're betting that there isn't a list of cluster attributes that has more than 5 gaps.
typedef struct {
uint8_t attributeSetId;
sl_zigbee_af_device_management_attribute_range_t attributeRange[7];
} sl_zigbee_af_device_management_attribute_table_t;
typedef struct {
bool encryption;
uint8_t * plainPayload;
uint16_t plainPayloadLength;
uint8_t * encryptedPayload;
uint16_t encryptedPayloadLength;
} sl_zigbee_af_gbz_message_data_t;
typedef struct {
uint8_t * gbzCommands;
uint16_t gbzCommandsLength;
uint8_t * gbzCommandsResponse;
uint16_t gbzCommandsResponseLength;
uint16_t messageCode;
} sl_zigbee_af_gpf_message_t;
typedef uint16_t sl_zigbee_af_remote_cluster_type_t;
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_NONE 0x0000u
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_SERVER 0x0001u
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_CLIENT 0x0002u
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_INVALID 0xFFFFu
typedef struct {
sl_zigbee_af_cluster_id_t clusterId;
sl_zigbee_af_profile_id_t profileId;
uint16_t deviceId;
uint8_t endpoint;
sl_zigbee_af_remote_cluster_type_t type;
} sl_zigbee_af_remote_cluster_struct_t;
typedef struct {
sl_802154_long_addr_t targetEUI64;
uint8_t sourceEndpoint;
uint8_t destEndpoint;
uint16_t clusterId;
sl_802154_long_addr_t destEUI64;
sl_802154_long_addr_t sourceEUI64;
} sl_zigbee_af_remote_binding_struct_t;
typedef struct {
sl_zigbee_af_cluster_id_t clusterId;
bool server;
} sl_zigbee_af_cluster_info_t;
#ifdef SL_CATALOG_ZIGBEE_DEVICE_DATABASE_PRESENT
#include "device-database-config.h"
#else
#define SL_ZIGBEE_AF_MAX_CLUSTERS_PER_ENDPOINT 3u
#define SL_ZIGBEE_AF_MAX_ENDPOINTS_PER_DEVICE 1u
#endif
typedef struct {
sl_zigbee_af_cluster_info_t clusters[SL_ZIGBEE_AF_MAX_CLUSTERS_PER_ENDPOINT];
sl_zigbee_af_profile_id_t profileId;
uint16_t deviceId;
uint8_t endpoint;
uint8_t clusterCount;
} sl_zigbee_af_endpoint_info_struct_t;
// Although we treat this like a bitmap, only 1 bit is set at a time.
// We use the bitmap feature to allow us to find all devices
// with any in a set of status codes using
// sl_zigbee_af_device_database_find_device_by_status().
typedef enum {
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_NONE = 0x00,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_NEW = 0x01,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_ENDPOINTS = 0x02,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_CLUSTERS = 0x04,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_STACK_REVISION = 0x08,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_DONE = 0x40,
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FAILED = 0x80,
} sl_zigbee_af_device_discovery_status_t;
typedef struct {
sl_802154_long_addr_t eui64;
sl_zigbee_af_endpoint_info_struct_t endpoints[SL_ZIGBEE_AF_MAX_ENDPOINTS_PER_DEVICE];
sl_zigbee_af_device_discovery_status_t status;
uint8_t discoveryFailures;
uint8_t capabilities;
uint8_t endpointCount;
uint8_t stackRevision;
} sl_zigbee_af_device_info_t;
typedef struct {
uint16_t deviceIndex;
} sl_zigbee_af_device_database_iterator_t;
typedef struct {
sl_802154_short_addr_t sl_zigbee_node_id;
uint32_t timeStamp;
} sl_zigbee_af_joining_device_t;
#define SL_ZIGBEE_AF_INVALID_CLUSTER_ID 0xFFFFu
#define SL_ZIGBEE_AF_INVALID_ENDPOINT 0xFFu
#define SL_ZIGBEE_AF_INVALID_ENDPOINT_INDEX 0xFFu
#define SL_ZIGBEE_AF_INVALID_PAN_ID 0xFFFFu
#define SL_ZIGBEE_AF_PERMIT_JOIN_FOREVER 0xFFu
#define SL_ZIGBEE_AF_PERMIT_JOIN_MAX_TIMEOUT 0xFEu
#define SL_ZIGBEE_AF_ZDO_RESPONSE_OVERHEAD 2u
typedef uint32_t sl_zigbee_af_zcl_request_status_t;
#define SL_ZIGBEE_ZCL_STATUS_INTERNAL_COMMAND_HANDLED 0xFFFFFF00u
#endif // SILABS_AF_API_TYPES
Modules#
sli_cluster_function_structure_t
sl_zigbee_af_default_attribute_value_t
sl_zigbee_af_attribute_min_max_value_t
sl_zigbee_af_default_or_min_max_attribute_value_t
sl_zigbee_af_attribute_metadata_t
sl_zigbee_matter_af_multi_protocol_attribute_metadata_t
sl_zigbee_af_attribute_search_record_t
sl_zigbee_af_manufacturer_code_entry_t
sl_zigbee_af_incoming_message_t
sl_zigbee_af_interpan_header_t
sl_zigbee_af_allowed_inter_pan_message_t
sl_zigbee_af_cluster_command_t
sl_zigbee_af_security_profile_data_t
sl_zigbee_af_defined_endpoint_t
sl_zigbee_af_load_control_event_t
sl_zigbee_af_service_discovery_result_t
sl_zigbee_af_group_table_entry_t
sl_zigbee_af_scene_table_entry_t
sl_zigbee_af_plugin_messaging_client_message_t
sl_zigbee_af_plugin_price_client_price_t
sl_zigbee_af_plugin_reporting_entry_t
sl_zigbee_af_plugin_zll_commissioning_group_information_record_t
sl_zigbee_af_plugin_zll_commissioning_endpoint_information_record_t
sl_zigbee_af_image_block_request_callback_struct_t
sl_zigbee_af_link_key_backup_data_t
sl_zigbee_af_trust_center_backup_data_t
sl_zigbee_af_standalone_bootloader_query_response_data_t
sl_zigbee_af_command_metadata_t
sl_zigbee_af_device_management_tenancy_t
sl_zigbee_af_device_management_supplier_t
sl_zigbee_af_device_management_supply_t
sl_zigbee_af_device_management_site_id_t
sl_zigbee_af_device_management_c_i_n_t
sl_zigbee_af_device_management_supply_status_flags_t
sl_zigbee_af_device_management_uncontrolled_flow_threshold_t
sl_zigbee_af_device_management_supply_status_t
sl_zigbee_af_device_management_password_t
sl_zigbee_af_device_management_info_t
sl_zigbee_af_device_management_attribute_range_t
sl_zigbee_af_device_management_attribute_table_t
sl_zigbee_af_gbz_message_data_t
sl_zigbee_af_remote_cluster_struct_t
sl_zigbee_af_remote_binding_struct_t
sl_zigbee_af_endpoint_info_struct_t
sl_zigbee_af_device_database_iterator_t
Macros#
A distinguished manufacturer code that is used to indicate the absence of a manufacturer-specific profile, cluster, command, or attribute.
An invalid profile ID This is a reserved profileId.
A simple way to determine if the service discovery callback has a response.
Indicate the absence of a Group table entry.
Value used when setting or getting the endpoint in a Group table entry. It indicates that the entry is not in use.
Maximum length of Group names, not including the length byte.
Indicates the absence of a Scene table entry.
Value used when setting or getting the endpoint in a Scene table entry. It indicates that the entry is not in use.
Maximum length of Scene names, not including the length byte.
The group identifier for the global scene.
The scene identifier for the global scene.
Use when setting or getting the endpoint in a report table entry. It indicates that the entry is not in use.
The maximum size of the string that is present in the header of the Zigbee Over-the-air file format.
The length of the hardware tag in the Ember Bootloader Query Response.
Device Management plugin types.
Permit join times.
The overhead of the ZDO response. 1 byte for the sequence and 1 byte for the status code.
ZCL request handler status indicates a command was handled and no default response should be sent.
Enumerations#
Indicate the result of the service discovery. Unicast discoveries are completed as soon as a response is received. Broadcast discoveries wait a period of time for multiple responses to be received.
Control how the device will poll for a given active cluster-related event. When the event is scheduled, the application can pass a poll control value which will be stored along with the event. The processor is only allowed to poll according to the most restrictive value for all active event. For example, if two events are active, one with SL_ZIGBEE_AF_LONG_POLL and the other with SL_ZIGBEE_AF_SHORT_POLL, the processor will short poll until the second event is deactivated.
Control how the device will sleep for a given active cluster related event. When the event is scheduled, the scheduling code can pass a sleep control value which will be stored along with the event. The processor is only allowed to sleep according to the most restrictive sleep control value for any active event. For example, if two events are active, one with SL_ZIGBEE_AF_OK_TO_HIBERNATE and the other with SL_ZIGBEE_AF_OK_TO_NAP, the processor will only be allowed to sleep until the second event is deactivated.
Track tasks that the Application framework cares about. These are intended to be tasks that should keep the device out of hibernation like an application level request / response. If the response does not come in as a data ACK, the application needs to stay out of hibernation to wait and poll for it.
Specifies CPP Authorization values.
Status codes used by the ZLL Commissioning plugin.
The list of options possible for the image block request/response.
Contain the success or error code of an OTA storage device operation.
Contain the success or error code of an OTA download operation.
Indicate the state of an OTA bootload image undergoing verification. This is used both for cryptographic verification and manufacturer-specific verification.
CBKE Library types.
Typedefs#
Refer to the Zigbee application profile ID.
Refer to the ZCL attribute ID.
Refer to the ZCL cluster ID.
Refer to the ZCL attribute type.
User for the cluster mask.
User for the attribute mask.
Use for either of the cluster functions.
Interpan Message type: unicast, broadcast, or multicast.
The options for sending/receiving interpan messages.
The options for what interpan messages are allowed.
Bitmask data type for storing one bit of information for each ESI in the ESI table.
Define a callback where a code element or cluster can be informed as to the result of a service discovery they have requested. For each match, the callback is fired with all the resulting matches from that source. If the discovery was unicast to a specific device, the callback is only fired once with either MATCH_FOUND or COMPLETE (no matches found). If the discovery is broadcast, multiple callbacks may be fired with SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_RESPONSE_RECEIVED. After a few seconds, the callback is fired with SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE or SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE as the result.
Define a callback where a code element or cluster can be informed as to the result of a request to initiate a partner link key exchange. The callback will be triggered with success equal to true if the exchange completed successfully.
Refer to the handler for network events.
Refer to the handler for endpoint events.
Refer to the tick callback for cluster.
Refer to the init callback for cluster.
Refer to the attribute changed callback function.
Refer to the manufacturer-specific attribute changed callback function.
Refer to the pre-attribute changed callback function.
Refer to the default response callback function.
Refer to the message sent callback function.
Zigbee Internet Client/Server Remote Cluster Types.
return status for cluster request handlers - may be `sl_zigbee_af_status_t` or a special return status indicate special handling of the response by the request handler
Macro Definition Documentation#
SL_ZIGBEE_AF_NULL_MANUFACTURER_CODE#
#define SL_ZIGBEE_AF_NULL_MANUFACTURER_CODEValue:
0x0000u
A distinguished manufacturer code that is used to indicate the absence of a manufacturer-specific profile, cluster, command, or attribute.
95
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INVALID_PROFILE_ID#
#define SL_ZIGBEE_AF_INVALID_PROFILE_IDValue:
0xFFFFu
An invalid profile ID This is a reserved profileId.
101
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTER_PAN_UNICAST#
#define SL_ZIGBEE_AF_INTER_PAN_UNICASTValue:
0x00u
394
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTER_PAN_BROADCAST#
#define SL_ZIGBEE_AF_INTER_PAN_BROADCASTValue:
0x08u
395
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTER_PAN_MULTICAST#
#define SL_ZIGBEE_AF_INTER_PAN_MULTICASTValue:
0x0Cu
396
of file app/framework/include/af-types.h
INTER_PAN_UNICAST#
#define INTER_PAN_UNICASTValue:
SL_ZIGBEE_AF_INTER_PAN_UNICAST
399
of file app/framework/include/af-types.h
INTER_PAN_BROADCAST#
#define INTER_PAN_BROADCASTValue:
SL_ZIGBEE_AF_INTER_PAN_BROADCAST
400
of file app/framework/include/af-types.h
INTER_PAN_MULTICAST#
#define INTER_PAN_MULTICASTValue:
SL_ZIGBEE_AF_INTER_PAN_MULTICAST
401
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_OPTION_NONE#
#define SL_ZIGBEE_AF_INTERPAN_OPTION_NONEValue:
0x0000u
403
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_OPTION_APS_ENCRYPT#
#define SL_ZIGBEE_AF_INTERPAN_OPTION_APS_ENCRYPTValue:
0x0001u
404
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_OPTION_MAC_HAS_LONG_ADDRESS#
#define SL_ZIGBEE_AF_INTERPAN_OPTION_MAC_HAS_LONG_ADDRESSValue:
0x0002u
405
of file app/framework/include/af-types.h
sli_zigbee_interpan_header_t#
#define sli_zigbee_interpan_header_tValue:
sl_zigbee_af_interpan_header_t
442
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_DIRECTION_CLIENT_TO_SERVER#
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_CLIENT_TO_SERVERValue:
0x01u
449
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_DIRECTION_SERVER_TO_CLIENT#
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_SERVER_TO_CLIENTValue:
0x02u
450
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_DIRECTION_BOTH#
#define SL_ZIGBEE_AF_INTERPAN_DIRECTION_BOTHValue:
0x03u
451
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_GLOBAL_COMMAND#
#define SL_ZIGBEE_AF_INTERPAN_GLOBAL_COMMANDValue:
0x04u
452
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INTERPAN_MANUFACTURER_SPECIFIC#
#define SL_ZIGBEE_AF_INTERPAN_MANUFACTURER_SPECIFICValue:
0x08u
453
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_ALLOW_TC_KEY_REQUESTS#
#define SL_ZIGBEE_AF_ALLOW_TC_KEY_REQUESTSValue:
SL_ZIGBEE_ALLOW_TC_LINK_KEY_REQUEST_AND_SEND_CURRENT_KEY
523
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DENY_TC_KEY_REQUESTS#
#define SL_ZIGBEE_AF_DENY_TC_KEY_REQUESTSValue:
SL_ZIGBEE_DENY_TC_LINK_KEY_REQUESTS
524
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_ALLOW_APP_KEY_REQUESTS#
#define SL_ZIGBEE_AF_ALLOW_APP_KEY_REQUESTSValue:
SL_ZIGBEE_ALLOW_APP_LINK_KEY_REQUEST
525
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DENY_APP_KEY_REQUESTS#
#define SL_ZIGBEE_AF_DENY_APP_KEY_REQUESTSValue:
SL_ZIGBEE_DENY_APP_LINK_KEY_REQUESTS
526
of file app/framework/include/af-types.h
EM_AF_DISCOVERY_RESPONSE_MASK#
#define EM_AF_DISCOVERY_RESPONSE_MASKValue:
(0x05u)
682
of file app/framework/include/af-types.h
sl_zigbee_af_have_discovery_response_status#
#define sl_zigbee_af_have_discovery_response_statusValue:
(status)
A simple way to determine if the service discovery callback has a response.
688
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_GROUP_TABLE_NULL_INDEX#
#define SL_ZIGBEE_AF_GROUP_TABLE_NULL_INDEXValue:
0xFFu
Indicate the absence of a Group table entry.
948
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_GROUP_TABLE_UNUSED_ENDPOINT_ID#
#define SL_ZIGBEE_AF_GROUP_TABLE_UNUSED_ENDPOINT_IDValue:
0x00u
Value used when setting or getting the endpoint in a Group table entry. It indicates that the entry is not in use.
953
of file app/framework/include/af-types.h
ZCL_GROUPS_CLUSTER_MAXIMUM_NAME_LENGTH#
#define ZCL_GROUPS_CLUSTER_MAXIMUM_NAME_LENGTHValue:
16u
Maximum length of Group names, not including the length byte.
957
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_SCENE_TABLE_NULL_INDEX#
#define SL_ZIGBEE_AF_SCENE_TABLE_NULL_INDEXValue:
0xFFu
Indicates the absence of a Scene table entry.
975
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_SCENE_TABLE_UNUSED_ENDPOINT_ID#
#define SL_ZIGBEE_AF_SCENE_TABLE_UNUSED_ENDPOINT_IDValue:
0x00u
Value used when setting or getting the endpoint in a Scene table entry. It indicates that the entry is not in use.
980
of file app/framework/include/af-types.h
ZCL_SCENES_CLUSTER_MAXIMUM_NAME_LENGTH#
#define ZCL_SCENES_CLUSTER_MAXIMUM_NAME_LENGTHValue:
16u
Maximum length of Scene names, not including the length byte.
984
of file app/framework/include/af-types.h
ZCL_SCENES_GLOBAL_SCENE_GROUP_ID#
#define ZCL_SCENES_GLOBAL_SCENE_GROUP_IDValue:
0x0000u
The group identifier for the global scene.
988
of file app/framework/include/af-types.h
ZCL_SCENES_GLOBAL_SCENE_SCENE_ID#
#define ZCL_SCENES_GLOBAL_SCENE_SCENE_IDValue:
0x00u
The scene identifier for the global scene.
992
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PLUGIN_MESSAGING_CLIENT_MESSAGE_SIZE#
#define SL_ZIGBEE_AF_PLUGIN_MESSAGING_CLIENT_MESSAGE_SIZEValue:
0
1066
of file app/framework/include/af-types.h
ZCL_PRICE_CLUSTER_MAXIMUM_RATE_LABEL_LENGTH#
#define ZCL_PRICE_CLUSTER_MAXIMUM_RATE_LABEL_LENGTHValue:
11u
1082
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PLUGIN_REPORTING_UNUSED_ENDPOINT_ID#
#define SL_ZIGBEE_AF_PLUGIN_REPORTING_UNUSED_ENDPOINT_IDValue:
0x00u
Use when setting or getting the endpoint in a report table entry. It indicates that the entry is not in use.
1130
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_OTA_MAX_HEADER_STRING_LENGTH#
#define SL_ZIGBEE_AF_OTA_MAX_HEADER_STRING_LENGTHValue:
32u
The maximum size of the string that is present in the header of the Zigbee Over-the-air file format.
1336
of file app/framework/include/af-types.h
APP_NOTIFY_ERROR_CODE_START#
#define APP_NOTIFY_ERROR_CODE_STARTValue:
NO_LOCAL_RESOURCES
1439
of file app/framework/include/af-types.h
APP_NOTIFY_MESSAGE_TEXT#
#define APP_NOTIFY_MESSAGE_TEXTValue:
1440
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_STANDALONE_BOOTLOADER_HARDWARE_TAG_LENGTH#
#define SL_ZIGBEE_AF_STANDALONE_BOOTLOADER_HARDWARE_TAG_LENGTHValue:
16u
The length of the hardware tag in the Ember Bootloader Query Response.
1603
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_ELECTRIC_METER#
#define SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_ELECTRIC_METERValue:
0
1657
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_GAS_METER#
#define SL_ZIGBEE_AF_PLUGIN_SIMPLE_METERING_SERVER_GAS_METERValue:
1
1658
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_NEW_OTA_FIRMWARE#
#define SL_ZIGBEE_AF_METERING_FNF_NEW_OTA_FIRMWAREValue:
0x00000001
1662
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_CBKE_UPDATE_REQUEST#
#define SL_ZIGBEE_AF_METERING_FNF_CBKE_UPDATE_REQUESTValue:
0x00000002
1663
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_TIME_SYNC#
#define SL_ZIGBEE_AF_METERING_FNF_TIME_SYNCValue:
0x00000004
1664
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_HAN#
#define SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_HANValue:
0x00000010
1665
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_WAN#
#define SL_ZIGBEE_AF_METERING_FNF_STAY_AWAKE_REQUEST_WANValue:
0x00000020
1666
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_METERING_DATA_ATTRIBUTE_SET#
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_METERING_DATA_ATTRIBUTE_SETValue:
0x000001C0
1667
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_PREPAYMENT_DATA_ATTRIBUTE_SET#
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_HISTORICAL_PREPAYMENT_DATA_ATTRIBUTE_SETValue:
0x00000E00
1668
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_BASIC_CLUSTER#
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_BASIC_CLUSTERValue:
0x00001000
1669
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_METERING_CLUSTER#
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_METERING_CLUSTERValue:
0x00002000
1670
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_PREPAYMENT_CLUSTER#
#define SL_ZIGBEE_AF_METERING_FNF_PUSH_ALL_STATIC_DATA_PREPAYMENT_CLUSTERValue:
0x00004000
1671
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_NETWORK_KEY_ACTIVE#
#define SL_ZIGBEE_AF_METERING_FNF_NETWORK_KEY_ACTIVEValue:
0x00008000
1672
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_DISPLAY_MESSAGE#
#define SL_ZIGBEE_AF_METERING_FNF_DISPLAY_MESSAGEValue:
0x00010000
1673
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_CANCEL_ALL_MESSAGES#
#define SL_ZIGBEE_AF_METERING_FNF_CANCEL_ALL_MESSAGESValue:
0x00020000
1674
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_CHANGE_SUPPLY#
#define SL_ZIGBEE_AF_METERING_FNF_CHANGE_SUPPLYValue:
0x00040000
1675
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_LOCAL_CHANGE_SUPPLY#
#define SL_ZIGBEE_AF_METERING_FNF_LOCAL_CHANGE_SUPPLYValue:
0x00080000
1676
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_SET_UNCONTROLLED_FLOW_THRESHOLD#
#define SL_ZIGBEE_AF_METERING_FNF_SET_UNCONTROLLED_FLOW_THRESHOLDValue:
0x00100000
1677
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_TUNNEL_MESSAGE_PENDING#
#define SL_ZIGBEE_AF_METERING_FNF_TUNNEL_MESSAGE_PENDINGValue:
0x00200000
1678
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_GET_SNAPSHOT#
#define SL_ZIGBEE_AF_METERING_FNF_GET_SNAPSHOTValue:
0x00400000
1679
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_GET_SAMPLED_DATA#
#define SL_ZIGBEE_AF_METERING_FNF_GET_SAMPLED_DATAValue:
0x00800000
1680
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_NEW_SUB_GHZ_CHANNEL_MASKS_AVAILABLE#
#define SL_ZIGBEE_AF_METERING_FNF_NEW_SUB_GHZ_CHANNEL_MASKS_AVAILABLEValue:
0x01000000
1681
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_ENERGY_SCAN_PENDING#
#define SL_ZIGBEE_AF_METERING_FNF_ENERGY_SCAN_PENDINGValue:
0x02000000
1682
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_FNF_CHANNEL_CHANGE_PENDING#
#define SL_ZIGBEE_AF_METERING_FNF_CHANNEL_CHANGE_PENDINGValue:
0x04000000
1683
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICE#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICEValue:
0x00000001
1686
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_PERIOD#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_PERIODValue:
0x00000002
1687
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TARIFF_INFORMATION#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TARIFF_INFORMATIONValue:
0x00000004
1688
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONVERSION_FACTOR#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONVERSION_FACTORValue:
0x00000008
1689
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CALORIFIC_VALUE#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CALORIFIC_VALUEValue:
0x00000010
1690
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CO2_VALUE#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CO2_VALUEValue:
0x00000020
1691
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BILLING_PERIOD#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BILLING_PERIODValue:
0x00000040
1692
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONSOLIDATED_BILL#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CONSOLIDATED_BILLValue:
0x00000080
1693
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICE_MATRIX#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_PRICE_MATRIXValue:
0x00000100
1694
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_THRESHOLDS#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_BLOCK_THRESHOLDSValue:
0x00000200
1695
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CURRENCY_CONVERSION#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CURRENCY_CONVERSIONValue:
0x00000400
1696
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CREDIT_PAYMENT_INFO#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CREDIT_PAYMENT_INFOValue:
0x00001000
1697
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CPP_EVENT#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_CPP_EVENTValue:
0x00002000
1698
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TIER_LABELS#
#define SL_ZIGBEE_AF_METERING_NF2_PUBLISH_TIER_LABELSValue:
0x00004000
1699
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF2_CANCEL_TARIFF#
#define SL_ZIGBEE_AF_METERING_NF2_CANCEL_TARIFFValue:
0x00008000
1700
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_PUBLISH_CALENDAR#
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_CALENDARValue:
0x00000001
1703
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SPECIAL_DAYS#
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SPECIAL_DAYSValue:
0x00000002
1704
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SEASONS#
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_SEASONSValue:
0x00000004
1705
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_PUBLISH_WEEK#
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_WEEKValue:
0x00000008
1706
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_PUBLISH_DAY#
#define SL_ZIGBEE_AF_METERING_NF3_PUBLISH_DAYValue:
0x00000010
1707
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF3_CANCEL_CALENDAR#
#define SL_ZIGBEE_AF_METERING_NF3_CANCEL_CALENDARValue:
0x00000020
1708
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_SELECT_AVAILABLE_EMERGENCY_CREDIT#
#define SL_ZIGBEE_AF_METERING_NF4_SELECT_AVAILABLE_EMERGENCY_CREDITValue:
0x00000001
1711
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_CHANGE_DEBT#
#define SL_ZIGBEE_AF_METERING_NF4_CHANGE_DEBTValue:
0x00000002
1712
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_EMERGENCY_CREDIT_SETUP#
#define SL_ZIGBEE_AF_METERING_NF4_EMERGENCY_CREDIT_SETUPValue:
0x00000004
1713
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_CONSUMER_TOP_UP#
#define SL_ZIGBEE_AF_METERING_NF4_CONSUMER_TOP_UPValue:
0x00000008
1714
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_CREDIT_ADJUSTMENT#
#define SL_ZIGBEE_AF_METERING_NF4_CREDIT_ADJUSTMENTValue:
0x00000010
1715
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_CHANGE_PAYMENT_MODE#
#define SL_ZIGBEE_AF_METERING_NF4_CHANGE_PAYMENT_MODEValue:
0x00000020
1716
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_GET_PREPAY_SNAPSHOT#
#define SL_ZIGBEE_AF_METERING_NF4_GET_PREPAY_SNAPSHOTValue:
0x00000040
1717
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_GET_TOP_UP_LOG#
#define SL_ZIGBEE_AF_METERING_NF4_GET_TOP_UP_LOGValue:
0x00000080
1718
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_SET_LOW_CREDIT_WARNING_LEVEL#
#define SL_ZIGBEE_AF_METERING_NF4_SET_LOW_CREDIT_WARNING_LEVELValue:
0x00000100
1719
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_GET_DEBT_REPAYMENT_LOG#
#define SL_ZIGBEE_AF_METERING_NF4_GET_DEBT_REPAYMENT_LOGValue:
0x00000200
1720
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_SET_MAXIMUM_CREDIT_LIMIT#
#define SL_ZIGBEE_AF_METERING_NF4_SET_MAXIMUM_CREDIT_LIMITValue:
0x00000400
1721
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF4_SET_OVERALL_DEBT_CAP#
#define SL_ZIGBEE_AF_METERING_NF4_SET_OVERALL_DEBT_CAPValue:
0x00000800
1722
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_TENANCY#
#define SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_TENANCYValue:
0x00000001
1725
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_SUPPLIER#
#define SL_ZIGBEE_AF_METERING_NF5_PUBLISH_CHANGE_OF_SUPPLIERValue:
0x00000002
1726
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_1_RESPONSE#
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_1_RESPONSEValue:
0x00000004
1727
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_2_RESPONSE#
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_2_RESPONSEValue:
0x00000008
1728
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_3_RESPONSE#
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_3_RESPONSEValue:
0x00000010
1729
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_4_RESPONSE#
#define SL_ZIGBEE_AF_METERING_NF5_REQUEST_NEW_PASSWORD_4_RESPONSEValue:
0x00000020
1730
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_UPDATE_SITE_ID#
#define SL_ZIGBEE_AF_METERING_NF5_UPDATE_SITE_IDValue:
0x00000040
1731
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_RESET_BATTERY_COUNTER#
#define SL_ZIGBEE_AF_METERING_NF5_RESET_BATTERY_COUNTERValue:
0x00000080
1732
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_METERING_NF5_UPDATE_CIN#
#define SL_ZIGBEE_AF_METERING_NF5_UPDATE_CINValue:
0x00000100
1733
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_NAME_LENGTH#
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_NAME_LENGTHValue:
(16u)
Device Management plugin types.
1754
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_CONTACT_DETAILS_LENGTH#
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PROPOSED_PROVIDER_CONTACT_DETAILS_LENGTHValue:
(18u)
1755
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_SITE_ID_LENGTH#
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_SITE_ID_LENGTHValue:
(32u)
1756
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_CIN_LENGTH#
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_CIN_LENGTHValue:
(24u)
1757
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PASSWORD_LENGTH#
#define SL_ZIGBEE_AF_DEVICE_MANAGEMENT_MAXIMUM_PASSWORD_LENGTHValue:
(10u)
1758
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_NONE#
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_NONEValue:
0x0000u
1911
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_SERVER#
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_SERVERValue:
0x0001u
1912
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_CLIENT#
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_CLIENTValue:
0x0002u
1913
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_INVALID#
#define SL_ZIGBEE_AF_REMOTE_CLUSTER_TYPE_INVALIDValue:
0xFFFFu
1914
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_MAX_CLUSTERS_PER_ENDPOINT#
#define SL_ZIGBEE_AF_MAX_CLUSTERS_PER_ENDPOINTValue:
3u
1947
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_MAX_ENDPOINTS_PER_DEVICE#
#define SL_ZIGBEE_AF_MAX_ENDPOINTS_PER_DEVICEValue:
1u
1948
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INVALID_CLUSTER_ID#
#define SL_ZIGBEE_AF_INVALID_CLUSTER_IDValue:
0xFFFFu
1998
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INVALID_ENDPOINT#
#define SL_ZIGBEE_AF_INVALID_ENDPOINTValue:
0xFFu
2000
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INVALID_ENDPOINT_INDEX#
#define SL_ZIGBEE_AF_INVALID_ENDPOINT_INDEXValue:
0xFFu
2002
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_INVALID_PAN_ID#
#define SL_ZIGBEE_AF_INVALID_PAN_IDValue:
0xFFFFu
2004
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PERMIT_JOIN_FOREVER#
#define SL_ZIGBEE_AF_PERMIT_JOIN_FOREVERValue:
0xFFu
Permit join times.
2009
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_PERMIT_JOIN_MAX_TIMEOUT#
#define SL_ZIGBEE_AF_PERMIT_JOIN_MAX_TIMEOUTValue:
0xFEu
2010
of file app/framework/include/af-types.h
SL_ZIGBEE_AF_ZDO_RESPONSE_OVERHEAD#
#define SL_ZIGBEE_AF_ZDO_RESPONSE_OVERHEADValue:
2u
The overhead of the ZDO response. 1 byte for the sequence and 1 byte for the status code.
2016
of file app/framework/include/af-types.h
SL_ZIGBEE_ZCL_STATUS_INTERNAL_COMMAND_HANDLED#
#define SL_ZIGBEE_ZCL_STATUS_INTERNAL_COMMAND_HANDLEDValue:
0xFFFFFF00u
ZCL request handler status indicates a command was handled and no default response should be sent.
2027
of file app/framework/include/af-types.h
Enumeration Documentation#
sl_zigbee_af_security_profile_t#
sl_zigbee_af_security_profile_t
Enumerator | |
---|---|
SL_ZIGBEE_AF_SECURITY_PROFILE_NONE | |
SL_ZIGBEE_AF_SECURITY_PROFILE_HA | |
SL_ZIGBEE_AF_SECURITY_PROFILE_HA12 | |
SL_ZIGBEE_AF_SECURITY_PROFILE_SE_TEST | |
SL_ZIGBEE_AF_SECURITY_PROFILE_SE_FULL | |
SL_ZIGBEE_AF_SECURITY_PROFILE_Z3 | |
SL_ZIGBEE_AF_SECURITY_PROFILE_CUSTOM |
530
of file app/framework/include/af-types.h
sl_zigbee_af_service_discovery_status_t#
sl_zigbee_af_service_discovery_status_t
Indicate the result of the service discovery. Unicast discoveries are completed as soon as a response is received. Broadcast discoveries wait a period of time for multiple responses to be received.
Enumerator | |
---|---|
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE | |
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_RESPONSE_RECEIVED | |
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_TIMEOUT | |
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE | |
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE | |
SL_ZIGBEE_AF_UNICAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE | |
SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE |
672
of file app/framework/include/af-types.h
sl_zigbee_af_event_poll_control_t#
sl_zigbee_af_event_poll_control_t
Control how the device will poll for a given active cluster-related event. When the event is scheduled, the application can pass a poll control value which will be stored along with the event. The processor is only allowed to poll according to the most restrictive value for all active event. For example, if two events are active, one with SL_ZIGBEE_AF_LONG_POLL and the other with SL_ZIGBEE_AF_SHORT_POLL, the processor will short poll until the second event is deactivated.
Enumerator | |
---|---|
SL_ZIGBEE_AF_LONG_POLL | |
SL_ZIGBEE_AF_SHORT_POLL |
782
of file app/framework/include/af-types.h
sl_zigbee_af_event_sleep_control_t#
sl_zigbee_af_event_sleep_control_t
Control how the device will sleep for a given active cluster related event. When the event is scheduled, the scheduling code can pass a sleep control value which will be stored along with the event. The processor is only allowed to sleep according to the most restrictive sleep control value for any active event. For example, if two events are active, one with SL_ZIGBEE_AF_OK_TO_HIBERNATE and the other with SL_ZIGBEE_AF_OK_TO_NAP, the processor will only be allowed to sleep until the second event is deactivated.
Enumerator | |
---|---|
SL_ZIGBEE_AF_OK_TO_SLEEP | |
SL_ZIGBEE_AF_OK_TO_HIBERNATE | Deprecated |
SL_ZIGBEE_AF_OK_TO_NAP | Deprecated |
SL_ZIGBEE_AF_STAY_AWAKE |
800
of file app/framework/include/af-types.h
sl_zigbee_af_application_task_t#
sl_zigbee_af_application_task_t
Track tasks that the Application framework cares about. These are intended to be tasks that should keep the device out of hibernation like an application level request / response. If the response does not come in as a data ACK, the application needs to stay out of hibernation to wait and poll for it.
Some tasks do not necessarily have a response. For example, a ZDO request may or may not have a response. In this case, the application framework cannot rely on the fact that a response will come in to end the wake cycle, so the Application framework must time out the wake cycle if no expected response is received or no other event can be relied upon to end the wake cycle.
Add these types of tasks to the wake timeout mask by calling sl_zigbee_af_set_wake_timeout_bitmask_cb so that they can be governed by a timeout instead of a request / response.
The current tasks bitmask is an uint32_t bitmask used to track which tasks are active at any given time. The bottom 16 bits, values 0x01 - 0x8000 are reserved for Ember's use. The top 16 bits are reserved for the customer, values 0x10000 - 0x80000000
Enumerator | |
---|---|
SL_ZIGBEE_AF_WAITING_FOR_DATA_ACK | |
SL_ZIGBEE_AF_LAST_POLL_GOT_DATA | |
SL_ZIGBEE_AF_WAITING_FOR_SERVICE_DISCOVERY | |
SL_ZIGBEE_AF_WAITING_FOR_ZDO_RESPONSE | |
SL_ZIGBEE_AF_WAITING_FOR_ZCL_RESPONSE | |
SL_ZIGBEE_AF_WAITING_FOR_REGISTRATION | |
SL_ZIGBEE_AF_WAITING_FOR_PARTNER_LINK_KEY_EXCHANGE | |
SL_ZIGBEE_AF_FORCE_SHORT_POLL | |
SL_ZIGBEE_AF_FRAGMENTATION_IN_PROGRESS | |
SL_ZIGBEE_AF_FORCE_SHORT_POLL_FOR_PARENT_CONNECTIVITY | |
SL_ZIGBEE_AF_WAITING_FOR_TC_KEY_UPDATE |
836
of file app/framework/include/af-types.h
sl_zigbee_af_plugin_price_cpp_auth_t#
sl_zigbee_af_plugin_price_cpp_auth_t
Specifies CPP Authorization values.
Enumerator | |
---|---|
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_PENDING | |
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_ACCEPTED | |
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_REJECTED | |
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_FORCED | |
SL_ZIGBEE_AF_PLUGIN_PRICE_CPP_AUTH_RESERVED |
1113
of file app/framework/include/af-types.h
sl_zigbee_af_plugin_tunneling_client_status_t#
sl_zigbee_af_plugin_tunneling_client_status_t
Enumerator | |
---|---|
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_SUCCESS | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_BUSY | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_NO_MORE_TUNNEL_IDS | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_PROTOCOL_NOT_SUPPORTED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_FLOW_CONTROL_NOT_SUPPORTED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_IEEE_ADDRESS_REQUEST_FAILED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_IEEE_ADDRESS_NOT_FOUND | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_ADDRESS_TABLE_FULL | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_LINK_KEY_EXCHANGE_REQUEST_FAILED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_LINK_KEY_EXCHANGE_FAILED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_REQUEST_TUNNEL_FAILED | |
SL_ZIGBEE_AF_PLUGIN_TUNNELING_CLIENT_REQUEST_TUNNEL_TIMEOUT |
1184
of file app/framework/include/af-types.h
sl_zigbee_af_zll_commissioning_status_t#
sl_zigbee_af_zll_commissioning_status_t
Status codes used by the ZLL Commissioning plugin.
Enumerator | |
---|---|
SL_ZIGBEE_AF_ZLL_ABORTED_BY_APPLICATION | |
SL_ZIGBEE_AF_ZLL_CHANNEL_CHANGE_FAILED | |
SL_ZIGBEE_AF_ZLL_JOINING_FAILED | |
SL_ZIGBEE_AF_ZLL_NO_NETWORKS_FOUND | |
SL_ZIGBEE_AF_ZLL_PREEMPTED_BY_STACK | |
SL_ZIGBEE_AF_ZLL_SENDING_START_JOIN_FAILED | |
SL_ZIGBEE_AF_ZLL_SENDING_DEVICE_INFORMATION_REQUEST_FAILED | |
SL_ZIGBEE_AF_ZLL_SENDING_IDENTIFY_REQUEST_FAILED | |
SL_ZIGBEE_AF_ZLL_SENDING_RESET_TO_FACTORY_NEW_REQUEST_FAILED | |
SL_ZIGBEE_AF_ZLL_NETWORK_FORMATION_FAILED | |
SL_ZIGBEE_AF_ZLL_NETWORK_UPDATE_OPERATION |
1203
of file app/framework/include/af-types.h
sl_zigbee_af_image_block_request_options_t#
sl_zigbee_af_image_block_request_options_t
The list of options possible for the image block request/response.
Enumerator | |
---|---|
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_OPTIONS_NONE | |
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_MIN_BLOCK_REQUEST_SUPPORTED_BY_CLIENT | |
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_MIN_BLOCK_REQUEST_SUPPORTED_BY_SERVER | |
SL_ZIGBEE_AF_IMAGE_BLOCK_REQUEST_SIMULATED_FROM_PAGE_REQUEST |
1266
of file app/framework/include/af-types.h
sl_zigbee_af_ota_storage_status_t#
sl_zigbee_af_ota_storage_status_t
Contain the success or error code of an OTA storage device operation.
Enumerator | |
---|---|
SL_ZIGBEE_AF_OTA_STORAGE_SUCCESS | |
SL_ZIGBEE_AF_OTA_STORAGE_ERROR | |
SL_ZIGBEE_AF_OTA_STORAGE_RETURN_DATA_TOO_LONG | |
SL_ZIGBEE_AF_OTA_STORAGE_PARTIAL_FILE_FOUND | |
SL_ZIGBEE_AF_OTA_STORAGE_OPERATION_IN_PROGRESS |
1305
of file app/framework/include/af-types.h
sl_zigbee_af_ota_download_result_t#
sl_zigbee_af_ota_download_result_t
Contain the success or error code of an OTA download operation.
Enumerator | |
---|---|
SL_ZIGBEE_AF_OTA_DOWNLOAD_AND_VERIFY_SUCCESS | |
SL_ZIGBEE_AF_OTA_DOWNLOAD_TIME_OUT | |
SL_ZIGBEE_AF_OTA_VERIFY_FAILED | |
SL_ZIGBEE_AF_OTA_SERVER_ABORTED | |
SL_ZIGBEE_AF_OTA_CLIENT_ABORTED | |
SL_ZIGBEE_AF_OTA_ERASE_FAILED |
1318
of file app/framework/include/af-types.h
sl_zigbee_af_key_establishment_notify_message_t#
sl_zigbee_af_key_establishment_notify_message_t
Enumerator | |
---|---|
NO_APP_MESSAGE | |
RECEIVED_PARTNER_CERTIFICATE | |
GENERATING_EPHEMERAL_KEYS | |
GENERATING_SHARED_SECRET | |
KEY_GENERATION_DONE | |
GENERATE_SHARED_SECRET_DONE | |
LINK_KEY_ESTABLISHED | LINK_KEY_ESTABLISHED indicates Success, key establishment done. |
NO_LOCAL_RESOURCES | Error codes: Transient failures where Key Establishment could be retried. |
PARTNER_NO_RESOURCES | |
TIMEOUT_OCCURRED | |
INVALID_APP_COMMAND | |
MESSAGE_SEND_FAILURE | |
PARTNER_SENT_TERMINATE | |
INVALID_PARTNER_MESSAGE | |
PARTNER_SENT_DEFAULT_RESPONSE_ERROR | |
BAD_CERTIFICATE_ISSUER | Fatal Errors: These results are not worth retrying because the outcome will not change. |
KEY_CONFIRM_FAILURE | |
BAD_KEY_ESTABLISHMENT_SUITE | |
KEY_TABLE_FULL | |
NO_ESTABLISHMENT_ALLOWED | Neither initiator nor responder is an ESP/TC so the key establishment is not allowed per the spec. |
INVALID_CERTIFICATE_KEY_USAGE |
1390
of file app/framework/include/af-types.h
sl_zigbee_af_image_verify_status_t#
sl_zigbee_af_image_verify_status_t
Indicate the state of an OTA bootload image undergoing verification. This is used both for cryptographic verification and manufacturer-specific verification.
Enumerator | |
---|---|
SL_ZIGBEE_AF_IMAGE_GOOD | |
SL_ZIGBEE_AF_IMAGE_BAD | |
SL_ZIGBEE_AF_IMAGE_VERIFY_IN_PROGRESS |
1473
of file app/framework/include/af-types.h
sl_zigbee_af_cbke_key_establishment_suite_t#
sl_zigbee_af_cbke_key_establishment_suite_t
CBKE Library types.
Enumerator | |
---|---|
SL_ZIGBEE_AF_INVALID_KEY_ESTABLISHMENT_SUITE | |
SL_ZIGBEE_AF_CBKE_KEY_ESTABLISHMENT_SUITE_163K1 | |
SL_ZIGBEE_AF_CBKE_KEY_ESTABLISHMENT_SUITE_283K1 |
1739
of file app/framework/include/af-types.h
sl_zigbee_af_device_management_password_type_t#
sl_zigbee_af_device_management_password_type_t
Enumerator | |
---|---|
UNUSED_PASSWORD | |
SERVICE_PASSWORD | |
CONSUMER_PASSWORD |
1761
of file app/framework/include/af-types.h
sl_zigbee_af_device_management_change_pending_flags_t#
sl_zigbee_af_device_management_change_pending_flags_t
Enumerator | |
---|---|
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_CHANGE_OF_TENANCY_PENDING_MASK | |
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_CHANGE_OF_SUPPLIER_PENDING_MASK | |
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_SITE_ID_PENDING_MASK | |
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_CIN_PENDING_MASK | |
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_SERVICE_PASSWORD_PENDING_MASK | |
SL_ZIGBEE_AF_DEVICE_MANAGEMENT_UPDATE_CONSUMER_PASSWORD_PENDING_MASK |
1773
of file app/framework/include/af-types.h
sl_zigbee_af_device_discovery_status_t#
sl_zigbee_af_device_discovery_status_t
Enumerator | |
---|---|
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_NONE | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_NEW | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_ENDPOINTS | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_CLUSTERS | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FIND_STACK_REVISION | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_DONE | |
SL_ZIGBEE_AF_DEVICE_DISCOVERY_STATUS_FAILED |
1965
of file app/framework/include/af-types.h
Typedef Documentation#
sl_zigbee_af_profile_id_t#
typedef uint16_t sl_zigbee_af_profile_id_t
Refer to the Zigbee application profile ID.
43
of file app/framework/include/af-types.h
sl_zigbee_af_attribute_id_t#
typedef uint16_t sl_zigbee_af_attribute_id_t
Refer to the ZCL attribute ID.
48
of file app/framework/include/af-types.h
sl_zigbee_af_cluster_id_t#
typedef uint16_t sl_zigbee_af_cluster_id_t
Refer to the ZCL cluster ID.
53
of file app/framework/include/af-types.h
sl_zigbee_af_attribute_type_t#
typedef uint8_t sl_zigbee_af_attribute_type_t
Refer to the ZCL attribute type.
58
of file app/framework/include/af-types.h
sl_zigbee_af_cluster_mask_t#
typedef uint8_t sl_zigbee_af_cluster_mask_t
User for the cluster mask.
63
of file app/framework/include/af-types.h
sl_zigbee_af_attribute_mask_t#
typedef uint8_t sl_zigbee_af_attribute_mask_t
User for the attribute mask.
68
of file app/framework/include/af-types.h
sl_zigbee_af_generic_cluster_function_t#
typedef void(* sl_zigbee_af_generic_cluster_function_t) (void) )(void)
Use for either of the cluster functions.
This type is used for the array of the cluster functions and should always be cast into one of the specific functions before being called.
76
of file app/framework/include/af-types.h
sl_zigbee_af_difference_type_t#
typedef uint64_t sl_zigbee_af_difference_type_t
Compare two ZCL attribute values. The size of this data type depends on the platform.
337
of file app/framework/include/af-types.h
sl_zigbee_af_interpan_message_type_t#
typedef uint8_t sl_zigbee_af_interpan_message_type_t
Interpan Message type: unicast, broadcast, or multicast.
393
of file app/framework/include/af-types.h
sl_zigbee_af_interpan_options_t#
typedef uint16_t sl_zigbee_af_interpan_options_t
The options for sending/receiving interpan messages.
410
of file app/framework/include/af-types.h
sl_zigbee_af_allowed_interpan_options_t#
typedef uint8_t sl_zigbee_af_allowed_interpan_options_t
The options for what interpan messages are allowed.
447
of file app/framework/include/af-types.h
sl_zigbee_af_tc_link_key_request_policy_t#
typedef sl_zigbee_tc_link_key_request_policy_t sl_zigbee_af_tc_link_key_request_policy_t
521
of file app/framework/include/af-types.h
sl_zigbee_af_app_link_key_request_policy_t#
typedef sl_zigbee_app_link_key_request_policy_t sl_zigbee_af_app_link_key_request_policy_t
522
of file app/framework/include/af-types.h
sl_zigbee_af_plugin_esi_management_bitmask_t#
typedef uint8_t sl_zigbee_af_plugin_esi_management_bitmask_t
Bitmask data type for storing one bit of information for each ESI in the ESI table.
616
of file app/framework/include/af-types.h
sl_zigbee_af_service_discovery_callback_t#
typedef void() sl_zigbee_af_service_discovery_callback_t(const sl_zigbee_af_service_discovery_result_t *result) (const sl_zigbee_af_service_discovery_result_t *result)
Define a callback where a code element or cluster can be informed as to the result of a service discovery they have requested. For each match, the callback is fired with all the resulting matches from that source. If the discovery was unicast to a specific device, the callback is only fired once with either MATCH_FOUND or COMPLETE (no matches found). If the discovery is broadcast, multiple callbacks may be fired with SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_RESPONSE_RECEIVED. After a few seconds, the callback is fired with SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_RESPONSE or SL_ZIGBEE_AF_BROADCAST_SERVICE_DISCOVERY_COMPLETE_WITH_EMPTY_RESPONSE as the result.
763
of file app/framework/include/af-types.h
sl_zigbee_af_partner_link_key_exchange_callback_t#
typedef void() sl_zigbee_af_partner_link_key_exchange_callback_t(bool success) (bool success)
Define a callback where a code element or cluster can be informed as to the result of a request to initiate a partner link key exchange. The callback will be triggered with success equal to true if the exchange completed successfully.
771
of file app/framework/include/af-types.h
sl_zigbee_af_network_event_handler_t#
typedef void(* sl_zigbee_af_network_event_handler_t) (void) )(void)
Refer to the handler for network events.
938
of file app/framework/include/af-types.h
sl_zigbee_af_endpoint_event_handler_t#
typedef void(* sl_zigbee_af_endpoint_event_handler_t) (uint8_t endpoint) )(uint8_t endpoint)
Refer to the handler for endpoint events.
943
of file app/framework/include/af-types.h
sl_zigbee_af_tick_function_t#
typedef void(* sl_zigbee_af_tick_function_t) (uint8_t endpoint) )(uint8_t endpoint)
Refer to the tick callback for cluster.
Tick function will be called once for each tick for each endpoint in the cluster. The rate of tick is determined by the metadata of the cluster.
1494
of file app/framework/include/af-types.h
sl_zigbee_af_init_function_t#
typedef void(* sl_zigbee_af_init_function_t) (uint8_t endpoint) )(uint8_t endpoint)
Refer to the init callback for cluster.
Init function is called when the application starts up, once for each cluster/endpoint combination.
1502
of file app/framework/include/af-types.h
sl_zigbee_af_cluster_attribute_changed_callback_t#
typedef void(* sl_zigbee_af_cluster_attribute_changed_callback_t) (uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId) )(uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId)
Refer to the attribute changed callback function.
This function is called just after an attribute changes.
1509
of file app/framework/include/af-types.h
sl_zigbee_af_manufacturer_specific_cluster_attribute_changed_callback_t#
typedef void(* sl_zigbee_af_manufacturer_specific_cluster_attribute_changed_callback_t) (uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId, uint16_t manufacturerCode) )(uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId, uint16_t manufacturerCode)
Refer to the manufacturer-specific attribute changed callback function.
This function is called just after a manufacturer-specific attribute changes.
1518
of file app/framework/include/af-types.h
sl_zigbee_af_cluster_pre_attribute_changed_callback_t#
typedef sl_zigbee_af_status_t(* sl_zigbee_af_cluster_pre_attribute_changed_callback_t) (uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId, sl_zigbee_af_attribute_type_t attributeType, uint8_t size, uint8_t *value) )(uint8_t endpoint, sl_zigbee_af_attribute_id_t attributeId, sl_zigbee_af_attribute_type_t attributeType, uint8_t size, uint8_t *value)
Refer to the pre-attribute changed callback function.
This function is called before an attribute changes.
1527
of file app/framework/include/af-types.h
sl_zigbee_af_default_response_function_t#
typedef void(* sl_zigbee_af_default_response_function_t) (uint8_t endpoint, uint8_t commandId, sl_zigbee_af_status_t status) )(uint8_t endpoint, uint8_t commandId, sl_zigbee_af_status_t status)
Refer to the default response callback function.
This function is called when default response is received, before the global callback. Global callback is called immediately afterwards.
1539
of file app/framework/include/af-types.h
sl_zigbee_af_message_sent_function_t#
typedef void(* sl_zigbee_af_message_sent_function_t) (sl_zigbee_outgoing_message_type_t type, uint16_t indexOrDestination, sl_zigbee_aps_frame_t *apsFrame, uint16_t msgLen, uint8_t *message, sl_status_t status) )(sl_zigbee_outgoing_message_type_t type, uint16_t indexOrDestination, sl_zigbee_aps_frame_t *apsFrame, uint16_t msgLen, uint8_t *message, sl_status_t status)
Refer to the message sent callback function.
This function is called when a message is sent.
1548
of file app/framework/include/af-types.h
sl_zigbee_af_remote_cluster_type_t#
typedef uint16_t sl_zigbee_af_remote_cluster_type_t
Zigbee Internet Client/Server Remote Cluster Types.
1909
of file app/framework/include/af-types.h
sl_zigbee_af_zcl_request_status_t#
typedef uint32_t sl_zigbee_af_zcl_request_status_t
return status for cluster request handlers - may be `sl_zigbee_af_status_t` or a special return status indicate special handling of the response by the request handler
2022
of file app/framework/include/af-types.h