Backbone Router#
This module includes functions for the OpenThread Backbone Router Service.
Modules#
otBackboneRouterMulticastListenerInfo
Enumerations#
Represents the Backbone Router Status.
Represents the Multicast Listener events.
Represents the ND Proxy events.
Represents the Domain Prefix events.
Typedefs#
Represents Backbone Router configuration.
Pointer is called whenever the Multicast Listeners change.
Used to iterate through Multicast Listeners.
Represents a Backbone Router Multicast Listener info.
Pointer is called whenever the Nd Proxy changed.
Represents the Backbone Router ND Proxy info.
Pointer is called whenever the Domain Prefix changed.
Functions#
Gets the Primary Backbone Router information in the Thread Network.
Enables or disables Backbone functionality.
Gets the Backbone Router otBackboneRouterState.
Gets the local Backbone Router configuration.
Sets the local Backbone Router configuration otBackboneRouterConfig.
Explicitly registers local Backbone Router configuration.
Returns the Backbone Router registration jitter value.
Sets the Backbone Router registration jitter value.
Gets the local Domain Prefix configuration.
Configures response status for next DUA registration.
Configures the response status for the next Multicast Listener Registration.
Sets the Backbone Router Multicast Listener callback.
Clears the Multicast Listeners.
Adds a Multicast Listener with a timeout value, in seconds.
Gets the next Multicast Listener info (using an iterator).
Sets the Backbone Router ND Proxy callback.
Gets the Backbone Router ND Proxy info.
Sets the Backbone Router Domain Prefix callback.
Macros#
Initializer for otBackboneRouterMulticastListenerIterator.
Enumeration Documentation#
otBackboneRouterState#
otBackboneRouterState
Represents the Backbone Router Status.
| Enumerator | |
|---|---|
| OT_BACKBONE_ROUTER_STATE_DISABLED | Backbone function is disabled. | 
| OT_BACKBONE_ROUTER_STATE_SECONDARY | Secondary Backbone Router. | 
| OT_BACKBONE_ROUTER_STATE_PRIMARY | The Primary Backbone Router. | 
otBackboneRouterMulticastListenerEvent#
otBackboneRouterMulticastListenerEvent
Represents the Multicast Listener events.
| Enumerator | |
|---|---|
| OT_BACKBONE_ROUTER_MULTICAST_LISTENER_ADDED | Multicast Listener was added. | 
| OT_BACKBONE_ROUTER_MULTICAST_LISTENER_REMOVED | Multicast Listener was removed or expired. | 
otBackboneRouterNdProxyEvent#
otBackboneRouterNdProxyEvent
Represents the ND Proxy events.
| Enumerator | |
|---|---|
| OT_BACKBONE_ROUTER_NDPROXY_ADDED | ND Proxy was added. | 
| OT_BACKBONE_ROUTER_NDPROXY_REMOVED | ND Proxy was removed. | 
| OT_BACKBONE_ROUTER_NDPROXY_RENEWED | ND Proxy was renewed. | 
| OT_BACKBONE_ROUTER_NDPROXY_CLEARED | All ND Proxies were cleared. | 
otBackboneRouterDomainPrefixEvent#
otBackboneRouterDomainPrefixEvent
Represents the Domain Prefix events.
| Enumerator | |
|---|---|
| OT_BACKBONE_ROUTER_DOMAIN_PREFIX_ADDED | Domain Prefix was added. | 
| OT_BACKBONE_ROUTER_DOMAIN_PREFIX_REMOVED | Domain Prefix was removed. | 
| OT_BACKBONE_ROUTER_DOMAIN_PREFIX_CHANGED | Domain Prefix was changed. | 
Typedef Documentation#
otBackboneRouterConfig#
typedef struct otBackboneRouterConfig otBackboneRouterConfig
Represents Backbone Router configuration.
otBackboneRouterMulticastListenerCallback#
typedef void(* otBackboneRouterMulticastListenerCallback) (void *aContext, otBackboneRouterMulticastListenerEvent aEvent, const otIp6Address *aAddress) )(void *aContext, otBackboneRouterMulticastListenerEvent aEvent, const otIp6Address *aAddress)
Pointer is called whenever the Multicast Listeners change.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| [in] | aContext | The user context pointer. | |
| [in] | aEvent | The Multicast Listener event. | |
| [in] | aAddress | The IPv6 multicast address of the Multicast Listener. | 
otBackboneRouterMulticastListenerIterator#
typedef uint16_t otBackboneRouterMulticastListenerIterator
Used to iterate through Multicast Listeners.
otBackboneRouterMulticastListenerInfo#
typedef struct otBackboneRouterMulticastListenerInfo otBackboneRouterMulticastListenerInfo
Represents a Backbone Router Multicast Listener info.
otBackboneRouterNdProxyCallback#
typedef void(* otBackboneRouterNdProxyCallback) (void *aContext, otBackboneRouterNdProxyEvent aEvent, const otIp6Address *aDua) )(void *aContext, otBackboneRouterNdProxyEvent aEvent, const otIp6Address *aDua)
Pointer is called whenever the Nd Proxy changed.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| [in] | aContext | The user context pointer. | |
| [in] | aEvent | The ND Proxy event. | |
| [in] | aDua | The Domain Unicast Address of the ND Proxy, or  | 
otBackboneRouterNdProxyInfo#
typedef struct otBackboneRouterNdProxyInfo otBackboneRouterNdProxyInfo
Represents the Backbone Router ND Proxy info.
otBackboneRouterDomainPrefixCallback#
typedef void(* otBackboneRouterDomainPrefixCallback) (void *aContext, otBackboneRouterDomainPrefixEvent aEvent, const otIp6Prefix *aDomainPrefix) )(void *aContext, otBackboneRouterDomainPrefixEvent aEvent, const otIp6Prefix *aDomainPrefix)
Pointer is called whenever the Domain Prefix changed.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| [in] | aContext | The user context pointer. | |
| [in] | aEvent | The Domain Prefix event. | |
| [in] | aDomainPrefix | The new Domain Prefix if added or changed, nullptr otherwise. | 
Function Documentation#
otBackboneRouterGetPrimary#
otError otBackboneRouterGetPrimary (otInstance * aInstance, otBackboneRouterConfig * aConfig)
Gets the Primary Backbone Router information in the Thread Network.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterConfig * | [out] | aConfig | A pointer to where to put Primary Backbone Router information. | 
otBackboneRouterSetEnabled#
void otBackboneRouterSetEnabled (otInstance * aInstance, bool aEnable)
Enables or disables Backbone functionality.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| bool | [in] | aEnable | TRUE to enable Backbone functionality, FALSE otherwise. | 
If enabled, a Server Data Request message SRV_DATA.ntf is triggered for the attached device if there is no Backbone Router Service in the Thread Network Data.
If disabled, SRV_DATA.ntf is triggered if the Backbone Router is in the Primary state.
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE is enabled.
See Also
otBackboneRouterGetState#
otBackboneRouterState otBackboneRouterGetState (otInstance * aInstance)
Gets the Backbone Router otBackboneRouterState.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
See Also
otBackboneRouterGetConfig#
void otBackboneRouterGetConfig (otInstance * aInstance, otBackboneRouterConfig * aConfig)
Gets the local Backbone Router configuration.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterConfig * | [out] | aConfig | A pointer where to put local Backbone Router configuration. | 
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE is enabled.
See Also
otBackboneRouterSetConfig#
otError otBackboneRouterSetConfig (otInstance * aInstance, const otBackboneRouterConfig * aConfig)
Sets the local Backbone Router configuration otBackboneRouterConfig.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| const otBackboneRouterConfig * | [in] | aConfig | A pointer to the Backbone Router configuration to take effect. | 
A Server Data Request message SRV_DATA.ntf is initiated automatically if BBR Dataset changes for Primary Backbone Router.
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE is enabled.
See Also
otBackboneRouterRegister#
otError otBackboneRouterRegister (otInstance * aInstance)
Explicitly registers local Backbone Router configuration.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
A Server Data Request message SRV_DATA.ntf is triggered for the attached device.
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE is enabled.
See Also
otBackboneRouterGetRegistrationJitter#
uint8_t otBackboneRouterGetRegistrationJitter (otInstance * aInstance)
Returns the Backbone Router registration jitter value.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | N/A | aInstance | 
Returns
- The Backbone Router registration jitter value. 
See Also
otBackboneRouterSetRegistrationJitter#
void otBackboneRouterSetRegistrationJitter (otInstance * aInstance, uint8_t aJitter)
Sets the Backbone Router registration jitter value.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | the Backbone Router registration jitter value to set. | 
| uint8_t | N/A | aJitter | 
See Also
otBackboneRouterGetDomainPrefix#
otError otBackboneRouterGetDomainPrefix (otInstance * aInstance, otBorderRouterConfig * aConfig)
Gets the local Domain Prefix configuration.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBorderRouterConfig * | [out] | aConfig | A pointer to the Domain Prefix configuration. | 
otBackboneRouterConfigNextDuaRegistrationResponse#
void otBackboneRouterConfigNextDuaRegistrationResponse (otInstance * aInstance, const otIp6InterfaceIdentifier * aMlIid, uint8_t aStatus)
Configures response status for next DUA registration.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| const otIp6InterfaceIdentifier * | [in] | aMlIid | A pointer to the Mesh Local IID. If NULL, respond with  | 
| uint8_t | [in] | aStatus | The status to respond. | 
Note: available only when OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE is enabled. Only used for test and certification.
TODO: (DUA) support coap error code and corresponding process for certification purpose.
otBackboneRouterConfigNextMulticastListenerRegistrationResponse#
void otBackboneRouterConfigNextMulticastListenerRegistrationResponse (otInstance * aInstance, uint8_t aStatus)
Configures the response status for the next Multicast Listener Registration.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| uint8_t | [in] | aStatus | The status to respond. | 
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE, OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE, and OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE are enabled.
otBackboneRouterSetMulticastListenerCallback#
void otBackboneRouterSetMulticastListenerCallback (otInstance * aInstance, otBackboneRouterMulticastListenerCallback aCallback, void * aContext)
Sets the Backbone Router Multicast Listener callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterMulticastListenerCallback | [in] | aCallback | A pointer to the Multicast Listener callback. | 
| void * | [in] | aContext | A user context pointer. | 
otBackboneRouterMulticastListenerClear#
void otBackboneRouterMulticastListenerClear (otInstance * aInstance)
Clears the Multicast Listeners.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE, OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE, and OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE are enabled.
See Also
otBackboneRouterMulticastListenerAdd#
otError otBackboneRouterMulticastListenerAdd (otInstance * aInstance, const otIp6Address * aAddress, uint32_t aTimeout)
Adds a Multicast Listener with a timeout value, in seconds.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| const otIp6Address * | [in] | aAddress | The Multicast Listener address. | 
| uint32_t | [in] | aTimeout | The timeout (in seconds) of the Multicast Listener, or 0 to use the default MLR timeout. | 
Pass 0 to use the default MLR timeout.
Available when OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE, OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE, and OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE are enabled.
See Also
otBackboneRouterMulticastListenerGetNext#
otError otBackboneRouterMulticastListenerGetNext (otInstance * aInstance, otBackboneRouterMulticastListenerIterator * aIterator, otBackboneRouterMulticastListenerInfo * aListenerInfo)
Gets the next Multicast Listener info (using an iterator).
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterMulticastListenerIterator * | [inout] | aIterator | A pointer to the iterator. On success the iterator will be updated to point to next Multicast Listener. To get the first entry the iterator should be set to OT_BACKBONE_ROUTER_MULTICAST_LISTENER_ITERATOR_INIT. | 
| otBackboneRouterMulticastListenerInfo * | [out] | aListenerInfo | A pointer to an  | 
See Also
otBackboneRouterSetNdProxyCallback#
void otBackboneRouterSetNdProxyCallback (otInstance * aInstance, otBackboneRouterNdProxyCallback aCallback, void * aContext)
Sets the Backbone Router ND Proxy callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterNdProxyCallback | [in] | aCallback | A pointer to the ND Proxy callback. | 
| void * | [in] | aContext | A user context pointer. | 
otBackboneRouterGetNdProxyInfo#
otError otBackboneRouterGetNdProxyInfo (otInstance * aInstance, const otIp6Address * aDua, otBackboneRouterNdProxyInfo * aNdProxyInfo)
Gets the Backbone Router ND Proxy info.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| const otIp6Address * | [in] | aDua | The Domain Unicast Address. | 
| otBackboneRouterNdProxyInfo * | [out] | aNdProxyInfo | A pointer to the ND Proxy info. | 
otBackboneRouterSetDomainPrefixCallback#
void otBackboneRouterSetDomainPrefixCallback (otInstance * aInstance, otBackboneRouterDomainPrefixCallback aCallback, void * aContext)
Sets the Backbone Router Domain Prefix callback.
| Type | Direction | Argument Name | Description | 
|---|---|---|---|
| otInstance * | [in] | aInstance | A pointer to an OpenThread instance. | 
| otBackboneRouterDomainPrefixCallback | [in] | aCallback | A pointer to the Domain Prefix callback. | 
| void * | [in] | aContext | A user context pointer. |