Stack Information
Ember Connect API for accessing and setting stack information. See Stack Information for documentation. More...
| Macros | |
| #define | EMBER_HIGH_PRIORITY_TASKS ( EMBER_OUTGOING_MESSAGES | EMBER_INCOMING_MESSAGES | EMBER_RADIO_IS_ON ) | 
| A mask of the tasks that prevent a device from sleeping.
         
          More... | |
| Handlers | |
| void | emberStackStatusHandler ( EmberStatus status) | 
| A callback invoked when the status of the stack changes.
         
          More... | |
| void | emberChildJoinHandler ( EmberNodeType nodeType, EmberNodeId nodeId) | 
| This handler is invoked at coordinator, range extender, or mac mode nodes when a new child has joined the device.
         
          More... | |
| void | emberStackIsrHandler (void) | 
| This handler is invoked in ISR context when certain stack-related ISR routines fire.
         
          More... | |
| bool | emberStackIdleHandler (uint32_t *idleTimeMs) | 
| A callback to allow the application to manage idling the MCU.
         
          More... | |
| void | emberRadioNeedsCalibratingHandler (void) | 
| The radio calibration callback function.
         
          More... | |
| APIs | |
| void | emberStackPowerDown (void) | 
| Immediately turns the radio power completely off.
         
          More... | |
| void | emberStackPowerUp (void) | 
| Powers up the radio. Typically called coming out of sleep.
         
          More... | |
| EmberNetworkStatus | emberNetworkState (void) | 
| Returns the current join status.
         
          More... | |
| bool | emberStackIsUp (void) | 
| Indicates whether the stack is currently up.
         
          More... | |
| EmberStatus | emberSetSecurityKey ( EmberKeyData *key) | 
| Sets the security key.
         
          More... | |
| EmberStatus | emberGetCounter ( EmberCounterType counterType, uint32_t *count) | 
| Retrieves the stack counter corresponding to the passed counter type.
         
          More... | |
| EmberStatus | emberSetRadioChannel (uint8_t channel) | 
| Sets the channel to use for sending and receiving messages on the current logical network. For a list of available radio channels, see the technical specification for the RF communication module in your Developer Kit.
         
          More... | |
| uint8_t | emberGetRadioChannel (void) | 
| Gets the radio channel, to which a node is set, on the current logical network. The possible return values depend on the radio in use. For a list of available radio channels, see the technical specification for the RF communication module in your Developer Kit.
         
          More... | |
| void | emberCalibrateCurrentChannel (void) | 
| Calibrates the current channel. The stack will notify the application of the need for channel calibration via the
         
          emberRadioNeedsCalibratingHandler()
         
         callback function during
         
          emberTick()
         
         . This function should only be called from within the context of the
         
          emberRadioNeedsCalibratingHandler()
         
         callback function. Note if this function is called when the radio is off, it will turn the radio on and leave it on.
         
          More... | |
| EmberStatus | emberSetRadioPower (int8_t power) | 
| Sets the radio output power at which a node is to operate for the current logical network. Ember radios have discrete power settings. For a list of available power settings, see the technical specification for the RF communication module in your Developer Kit. Note: Care should be taken when using this API on a running network, because it directly impacts the established link qualities neighboring nodes have with the node on which it is called. This can lead to disruption of existing routes and erratic network behavior. Note: If the requested power level is not available on a given radio, this function uses the next higher available power level.
         
          More... | |
| int8_t | emberGetRadioPower (void) | 
| Gets the radio output power of the current logical network at which a node is operating. Ember radios have discrete power settings. For a list of available power settings, see the technical specification for the RF communication module in your Developer Kit.
         
          More... | |
| EmberStatus | emberSetRadioPowerMode (bool radioOn) | 
| Allows the application to turn the radio on/off. This API is intended for use with direct devices only.
         
          More... | |
| EmberStatus | emberSetMacParams (bool checkCca, uint8_t maxCcaAttempts, uint8_t minBackoffExp, uint8_t maxBackoffExp, uint8_t maxRetries) | 
| Sets the MAC layer transmission parameters.
         
          More... | |
| EmberStatus | emberMacGetParentAddress ( EmberMacAddress *parentAddress) | 
| An API to retrieve the parent address. This API can be invoked only for nodes of
         
          EMBER_MAC_MODE_DEVICE
         
         or
         
          EMBER_MAC_MODE_SLEEPY_DEVICE
         
         type.
         
          More... | |
| uint32_t | emberStackIdleTimeMs (uint16_t *currentStackTasks) | 
| Returns the time in milliseconds the stack could idle for.
         
          More... | |
| uint16_t | emberCurrentStackTasks (void) | 
| Returns a bitmask indicating the stack's current tasks.
         
          More... | |
| bool | emberOkToNap (void) | 
| Indicates whether the stack is currently in a state with no high-priority tasks and may sleep.
         
          More... | |
| bool | emberOkToHibernate (void) | 
| Indicates whether the stack currently has any pending tasks.
         
          More... | |
| EmberEUI64 | emberGetEui64 (void) | 
| Returns the EUI64 ID of the local node.
         
          More... | |
| bool | emberIsLocalEui64 ( EmberEUI64 eui64) | 
| Determines whether 
          eui64
         is the local node's EUI64 ID.
         
          More... | |
| EmberNodeId | emberGetNodeId (void) | 
| Returns the 16-bit node ID of local node on the current logical network.
         
          More... | |
| EmberPanId | emberGetPanId (void) | 
| Returns the local node's PAN ID of the current logical network.
         
          More... | |
| EmberNodeType | emberGetNodeType (void) | 
| Returns an
         
          EmberNodeType
         
         value indicating the type of the node.
         
          More... | |
| EmberNodeId | emberGetParentId (void) | 
| Returns the parent's node ID.
         
          More... | |
Detailed Description
Ember Connect API for accessing and setting stack information. See Stack Information 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.
      See
      
       stack-info.h
      
      for source code.
     
Macro Definition Documentation
| #define EMBER_HIGH_PRIORITY_TASKS ( EMBER_OUTGOING_MESSAGES | EMBER_INCOMING_MESSAGES | EMBER_RADIO_IS_ON ) | 
A mask of the tasks that prevent a device from sleeping.
        Definition at line
        
         27
        
        of file
        
         stack-info.h
        
        .
       
Function Documentation
| void emberCalibrateCurrentChannel | ( | void | 
            | ) | 
Calibrates the current channel. The stack will notify the application of the need for channel calibration via the emberRadioNeedsCalibratingHandler() callback function during emberTick() . This function should only be called from within the context of the emberRadioNeedsCalibratingHandler() callback function. Note if this function is called when the radio is off, it will turn the radio on and leave it on.
| void emberChildJoinHandler | ( | EmberNodeType | 
            nodeType,
            | 
| EmberNodeId | 
            nodeId
            | ||
| ) | 
This handler is invoked at coordinator, range extender, or mac mode nodes when a new child has joined the device.
- Parameters
- 
         [in] nodeTypeThe role of the joining device ( EMBER_STAR_RANGE_EXTENDER , EMBER_STAR_END_DEVICE , EMBER_STAR_SLEEPY_END_DEVICE , EMBER_MAC_MODE_DEVICE or EMBER_MAC_MODE_SLEEPY_DEVICE ). [in] nodeIdThe node ID of the joining device. 
| uint16_t emberCurrentStackTasks | ( | void | 
            | ) | 
Returns a bitmask indicating the stack's current tasks.
The mask EMBER_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 emberPollForData() to receive messages. Parents will hold messages for EMBER_INDIRECT_TRANSMISSION_TIMEOUT_MS milliseconds before discarding them.
- Returns
- A bitmask of the stack's active tasks.
| EmberStatus emberGetCounter | ( | EmberCounterType | 
            counterType,
            | 
| uint32_t * | 
            count
            | ||
| ) | 
Retrieves the stack counter corresponding to the passed counter type.
- Parameters
- 
         [in] counterTypeAn EmberCounterType value indicating the stack counter to be retrieved. 
- Returns
- An EmberStatus value of EMBER_SUCCESS if the stack counter was successfully retrieved. An EmberStatus value of EMBER_INVALID_CALL if the passed counterType is invalid. An EmberStatus value of EMBER_LIBRARY_NOT_PRESENT if the stack counter library is not present.
| EmberEUI64 emberGetEui64 | ( | void | 
            | ) | 
Returns the EUI64 ID of the local node.
- Returns
- The 64-bit ID.
| EmberNodeId emberGetNodeId | ( | void | 
            | ) | 
Returns the 16-bit node ID of local node on the current logical network.
- Returns
- The 16-bit ID.
| EmberNodeType emberGetNodeType | ( | void | 
            | ) | 
Returns an EmberNodeType value indicating the type of the node.
- Returns
- A PAN ID.
| EmberPanId emberGetPanId | ( | void | 
            | ) | 
Returns the local node's PAN ID of the current logical network.
- Returns
- A PAN ID.
| EmberNodeId emberGetParentId | ( | void | 
            | ) | 
Returns the parent's node ID.
- Returns
- The parent's node ID.
| uint8_t emberGetRadioChannel | ( | void | 
            | ) | 
Gets the radio channel, to which a node is set, on the current logical network. The possible return values depend on the radio in use. For a list of available radio channels, see the technical specification for the RF communication module in your Developer Kit.
- Returns
- The current radio channel.
| int8_t emberGetRadioPower | ( | void | 
            | ) | 
Gets the radio output power of the current logical network at which a node is operating. Ember radios have discrete power settings. For a list of available power settings, see the technical specification for the RF communication module in your Developer Kit.
- Returns
- Current radio output power, in dBm.
| bool emberIsLocalEui64 | ( | EmberEUI64 | 
            eui64
            | ) | 
        Determines whether
        
         eui64
        
        is the local node's EUI64 ID.
       
- Parameters
- 
         [in] eui64An EUI64 ID. 
- Returns
- 
         TRUE if
         eui64is the local node's ID, otherwise FALSE.
| EmberStatus emberMacGetParentAddress | ( | EmberMacAddress * | 
            parentAddress
            | ) | 
An API to retrieve the parent address. This API can be invoked only for nodes of EMBER_MAC_MODE_DEVICE or EMBER_MAC_MODE_SLEEPY_DEVICE type.
- Returns
- An EmberStatus value of EMBER_SUCCESS if the parent address was successfully retrieved, otherwise an EmberStatus value indicating the reason of failure.
| EmberNetworkStatus emberNetworkState | ( | void | 
            | ) | 
Returns the current join status.
Returns a value indicating whether the node is joining, joined to, or leaving a network.
- Returns
- An EmberNetworkStatus value indicating the current join status.
| bool emberOkToHibernate | ( | void | 
            | ) | 
Indicates whether the stack currently has any pending tasks.
If no tasks are pending , emberTick() does not need to be called until next stack API function is called. This function can only be called when the node type is EMBER_STAR_SLEEPY_END_DEVICE .
- Returns
- TRUE if the application may sleep for as long as it wishes.
| bool emberOkToNap | ( | void | 
            | ) | 
Indicates whether the stack is currently in a state with no high-priority tasks and may sleep.
There may be tasks expecting incoming messages, in which case the device should periodically wake up and call emberPollForData() to receive messages. This function can only be called when the node type is EMBER_STAR_SLEEPY_END_DEVICE .
- Returns
- TRUE if the application may sleep but the stack may be expecting incoming messages.
| void emberRadioNeedsCalibratingHandler | ( | void | 
            | ) | 
The radio calibration callback function.
This handler is invoked by the stack upon receiving a "calibration needed" event from the radio to inform the application that it should perform calibration of the current channel as soon as possible using the emberCalibrateCurrentChannel() API. While calibration only takes tens of microseconds, the application can failsafe any critical processes or peripherals before calling emberCalibrateCurrentChannel() . The application must call emberCalibrateCurrentChannel() in response to this callback to maintain expected radio performance.
| EmberStatus emberSetMacParams | ( | bool | 
            checkCca,
            | 
| uint8_t | 
            maxCcaAttempts,
            | ||
| uint8_t | 
            minBackoffExp,
            | ||
| uint8_t | 
            maxBackoffExp,
            | ||
| uint8_t | 
            maxRetries
            | ||
| ) | 
Sets the MAC layer transmission parameters.
- Parameters
- 
         [in] checkCcaIf set to TRUE, the node performs a clear channel assessment prior to transmit a packet. If the channel is not clear, a random backoff is performed. If this is set to FALSE, no clear channel assessment is performed and the packet is transmitted immediately. This parameter is by default set to TRUE. [in] maxCcaAttemptsThe maximum number of clear channel assessment attempts that are performed prior to fail to transmit a packet with EMBER_PHY_TX_CCA_FAIL status. This parameter is set by default to 4. Note: this is meaningful only if the checkCca parameter is set to TRUE. [in] minBackoffExpThe backoff exponent used if the initial channel clear assessment fails. This parameter is set by default to 3. Note: this is meaningful only if the checkCca parameter is set to TRUE. [in] maxBackoffExpThe backoff exponent used if the final channel clear assessment fails. This parameter is set by default to 5. Note: this is meaningful only if the checkCca parameter is set to TRUE. [in] maxRetriesThe number of transmission retries that is performed if no acknowledgement was received. This parameter is set by default to 3 (which means that a total of 4 transmission attempts will be performed). 
- Returns
- An EmberStatus value indicating whether the MAC parameters were successfully set or the reason of failure.
| EmberStatus emberSetRadioChannel | ( | uint8_t | 
            channel
            | ) | 
Sets the channel to use for sending and receiving messages on the current logical network. For a list of available radio channels, see the technical specification for the RF communication module in your Developer Kit.
Note: Care should be taken when using this API. All devices on a network must use the same channel. Each call triggers a token write. Excessive usage might cause flash to wear-out.
- Parameters
- 
         [in] channelA desired radio channel. 
- Returns
- 
         An
         
          EmberStatus
         
         value of:
         - EMBER_SUCCESS if the stack accepted the channel change.
- EMBER_INVALID_CALL if the node is currently performing frequency hopping.
- EMBER_PHY_INVALID_CHANNEL if the passed channel is invalid.
- EMBER_MAC_BUSY if the MAC is currently performing a high priority task.
 
| EmberStatus emberSetRadioPower | ( | int8_t | 
            power
            | ) | 
Sets the radio output power at which a node is to operate for the current logical network. Ember radios have discrete power settings. For a list of available power settings, see the technical specification for the RF communication module in your Developer Kit. Note: Care should be taken when using this API on a running network, because it directly impacts the established link qualities neighboring nodes have with the node on which it is called. This can lead to disruption of existing routes and erratic network behavior. Note: If the requested power level is not available on a given radio, this function uses the next higher available power level.
- Parameters
- 
         [in] powerDesired radio output power, in dBm. 
- Returns
- An EmberStatus value indicating the success or failure of the command. Failure indicates that the requested power level is out of range.
| EmberStatus emberSetRadioPowerMode | ( | bool | 
            radioOn
            | ) | 
Allows the application to turn the radio on/off. This API is intended for use with direct devices only.
- Parameters
- 
         [in] radioOnIf this parameter is true, the radio is turned on, otherwise it's turned off. 
- Returns
- An EmberStatus value indicating the success or failure of the command. Failure indicates that the node type is a type other than EMBER_DIRECT_DEVICE .
| EmberStatus emberSetSecurityKey | ( | EmberKeyData * | 
            key
            | ) | 
Sets the security key.
- Parameters
- 
         [out] keyAn EmberKeyData value containing the security key to be set. 
- Returns
- An EmberStatus value of EMBER_SUCCESS if the key was successfully set. Otherwise, it returns an EmberStatus value of EMBER_INVALID_CALL .
| bool emberStackIdleHandler | ( | uint32_t * | 
            idleTimeMs
            | ) | 
A callback to allow the application to manage idling the MCU.
- Parameters
- 
         [in,out] idleTimeMsA pointer to the time in millisecond the stack is allowed to idle. If the application decides to manage idling the MCU, it should update the passed value with the actual time the MCU was idled. 
- Returns
- true if the application is managing idling the MCU, false otherise. If this function returns false, the stack will manage idling the MCU.
| uint32_t emberStackIdleTimeMs | ( | uint16_t * | 
            currentStackTasks
            | ) | 
Returns the time in milliseconds the stack could idle for.
- Parameters
- 
         [in] currentStackTasksA pointer to an integer that is written with the active stack tasks at the time of the API call. 
- Returns
- Allowed idle time in milliseconds.
| void emberStackIsrHandler | ( | void | 
            | ) | 
This handler is invoked in ISR context when certain stack-related ISR routines fire.
| bool emberStackIsUp | ( | void | 
            | ) | 
Indicates whether the stack is currently up.
Returns true if the stack is joined to a network and ready to send and receive messages. This reflects only the state of the local node and does not indicate whether or not other nodes are able to communicate with this node.
- Returns
- TRUE if the stack is up, false otherwise.
| void emberStackPowerDown | ( | void | 
            | ) | 
Immediately turns the radio power completely off.
After calling this function, do not call any other stack function except emberStackPowerUp() because all other stack functions require that the radio is powered to operate properly.
| void emberStackPowerUp | ( | void | 
            | ) | 
Powers up the radio. Typically called coming out of sleep.
For non-sleepy devices, also turns the radio on and leaves it in rx mode.
| void emberStackStatusHandler | ( | EmberStatus | 
            status
            | ) | 
A callback invoked when the status of the stack changes.
The application is free to begin messaging once it receives the EMBER_NETWORK_UP status.
- Parameters
- 
         [in] statusStack status. One of the following: