Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: TYBLE16_simple_data_logger TYBLE16_MP3_Air
net_rpl.c File Reference
Router and Border Router RPL API. More...
Go to the source code of this file.
| Functions | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_init (int8_t interface_id, const uint8_t *dodag_id, const dodag_config_t *config, uint8_t instance_id, uint8_t flags) | 
| RPL DODAG root base allocate. | |
| int8_t | arm_nwk_6lowpan_rpl_memory_limit_set (size_t soft_limit, size_t hard_limit) | 
| RPL Global memory size limits. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_remove (int8_t interface_id) | 
| RPL DODAG remove by given interface ID. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_start (int8_t interface_id) | 
| Activate RPL DODAG by given Interface ID. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_route_update (int8_t interface_id, uint8_t *route_ptr, uint8_t prefix_len, uint8_t flags, uint32_t lifetime) | 
| RPL route information update. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_prefix_update (int8_t interface_id, uint8_t *prefix_ptr, uint8_t prefix_len, uint8_t flags, uint32_t lifetime) | 
| RPL prefix information update. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_poison (int8_t interface_id) | 
| RPL DODAG poison. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_dao_trig (int8_t interface_id) | 
| Trigger RPL DODAG DAO by DTSN increment. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_version_increment (int8_t interface_id) | 
| RPL DODAG version update. | |
| int8_t | arm_nwk_6lowpan_rpl_dodag_pref_set (int8_t interface_id, uint8_t preference) | 
| RPL DODAG preference set. | |
| uint8_t | rpl_instance_list_read (uint8_t *buffer_ptr, uint8_t buffer_size) | 
| Read RPL instance list of a node. | |
| uint8_t | rpl_read_dodag_info (rpl_dodag_info_t *dodag_ptr, uint8_t instance_id) | 
| Read DODAG information by given RPL instance ID. | |
Detailed Description
Router and Border Router RPL API.
Rough backwards compatibility being roughly preserved with old RPL system
Definition in file net_rpl.c.
Function Documentation
| int8_t arm_nwk_6lowpan_rpl_dodag_dao_trig | ( | int8_t | interface_id ) | 
| int8_t arm_nwk_6lowpan_rpl_dodag_init | ( | int8_t | interface_id, | 
| const uint8_t * | dodag_id, | ||
| const dodag_config_t * | config, | ||
| uint8_t | instance_id, | ||
| uint8_t | flags | ||
| ) | 
RPL DODAG root base allocate.
- Parameters:
- 
  interface_id Interface ID dodag_id A pointer to unique DODAGID. This must be the node's GP address in the ZigBeeIP network. config A pointer to the DODAG configure structure. instace_id Instance ID for RPL DODAG. flags Defines RPL MOP and DODAG pref. ZigBeeIP should use (BR_DODAG_MOP_NON_STORING | BR_DODAG_PREF_7). 
- Returns:
- 0, Allocate OK.
- -1, Allocate fail (The node is already connected to the same instance or the memory allocate fails).
- -2, DODAG configuration parameter failure.
| int8_t arm_nwk_6lowpan_rpl_dodag_poison | ( | int8_t | interface_id ) | 
RPL DODAG poison.
This function poisons the current RPL instance. After a few seconds arm_nwk_6lowpan_rpl_dodag_remove() can also clean the root.
- Parameters:
- 
  interface_id Interface ID that defines the RPL instance to be poisoned. 
- Returns:
- 0, Poison OK.
- <0, Poison fail.
| int8_t arm_nwk_6lowpan_rpl_dodag_pref_set | ( | int8_t | interface_id, | 
| uint8_t | preference | ||
| ) | 
| int8_t arm_nwk_6lowpan_rpl_dodag_prefix_update | ( | int8_t | interface_id, | 
| uint8_t * | prefix_ptr, | ||
| uint8_t | prefix_len, | ||
| uint8_t | flags, | ||
| uint32_t | lifetime | ||
| ) | 
RPL prefix information update.
- Parameters:
- 
  interface_id Root interface ID prefix_ptr A pointer to IPv6 prefix (16-bytes). prefix_len Prefix length (should be 64). flags Define R-flag (RPL_PREFIX_ROUTER_ADDRESS_FLAG), A-flag (RPL_PREFIX_AUTONOMOUS_ADDRESS_FLAG). lifetime Prefix lifetime. 
- Returns:
- 0, Update OK.
- <0, Update fail.
| int8_t arm_nwk_6lowpan_rpl_dodag_remove | ( | int8_t | interface_id ) | 
| int8_t arm_nwk_6lowpan_rpl_dodag_route_update | ( | int8_t | interface_id, | 
| uint8_t * | route_ptr, | ||
| uint8_t | prefix_len, | ||
| uint8_t | flags, | ||
| uint32_t | lifetime | ||
| ) | 
RPL route information update.
- Parameters:
- 
  interface_id Root interface ID. route_ptr A pointer to IPv6 prefix (16-bytes). prefix_len Prefix length (should be 64). flags Define R-flag (RPL_PREFIX_ROUTER_ADDRESS_FLAG). lifetime Route lifetime. 
- Returns:
- 0, Update OK.
- <0, Update fail.
| int8_t arm_nwk_6lowpan_rpl_dodag_start | ( | int8_t | interface_id ) | 
| int8_t arm_nwk_6lowpan_rpl_dodag_version_increment | ( | int8_t | interface_id ) | 
| int8_t arm_nwk_6lowpan_rpl_memory_limit_set | ( | size_t | soft_limit, | 
| size_t | hard_limit | ||
| ) | 
RPL Global memory size limits.
Calling this function you can update default memory limits. Soft default is 1024 and hard limit is 2048.
- Parameters:
- 
  soft_limit When RPL reach this state at total allocation it start cleaning unused data. hard_limit Total allocation limit. 0 means no limit and > 0 define hard limit. When hard limit > 0 soft_limit must be smaller than hard. 
- Returns:
- 0, Set OK.
- -1, Unsupported parameter
| uint8_t rpl_instance_list_read | ( | uint8_t * | buffer_ptr, | 
| uint8_t | buffer_size | ||
| ) | 
Read RPL instance list of a node.
Global instances are output as a single byte containing the instance ID; local instances are output as the instance ID followed by the 16-byte DODAG ID.
- Parameters:
- 
  buffer_ptr A pointer to the location of the instance IDs. buffer_size Instance list buffer size. 
- Returns:
- RPL instance count (not necessarily number of bytes, if local instances).
| uint8_t rpl_read_dodag_info | ( | rpl_dodag_info_t * | dodag_ptr, | 
| uint8_t | instance_id | ||
| ) | 
Generated on Tue Jul 12 2022 13:55:16 by
 1.7.2
 1.7.2