2015-05-22 21:47:37 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 INRIA.
|
|
|
|
* Copyright (C) 2015 Cenk Gündoğan <cnkgndgn@gmail.com>
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-08-17 15:41:29 +02:00
|
|
|
* @ingroup net_gnrc_rpl
|
2015-05-22 21:47:37 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief DODAG-related functions for RPL
|
|
|
|
*
|
|
|
|
* Header file, which defines all public known DODAG-related functions for RPL.
|
|
|
|
*
|
|
|
|
* @author Eric Engel <eric.engel@fu-berlin.de>
|
|
|
|
* @author Cenk Gündoğan <cnkgndgn@gmail.com>
|
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef NET_GNRC_RPL_DODAG_H
|
|
|
|
#define NET_GNRC_RPL_DODAG_H
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#include "net/ipv6/addr.h"
|
2015-05-22 21:47:37 +02:00
|
|
|
#include "trickle.h"
|
2015-08-17 15:41:29 +02:00
|
|
|
#include "net/gnrc/rpl.h"
|
|
|
|
#include "net/gnrc/rpl/structs.h"
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of RPL instances
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_RPL_INSTANCES_NUMOF
|
2015-11-09 13:07:10 +01:00
|
|
|
#define GNRC_RPL_INSTANCES_NUMOF (1)
|
2015-05-22 21:47:37 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of RPL parents
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_RPL_PARENTS_NUMOF
|
2015-11-09 13:07:10 +01:00
|
|
|
#define GNRC_RPL_PARENTS_NUMOF (3)
|
2015-05-22 21:47:37 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RPL instance table
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
extern gnrc_rpl_instance_t gnrc_rpl_instances[GNRC_RPL_INSTANCES_NUMOF];
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RPL parent table
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
extern gnrc_rpl_parent_t gnrc_rpl_parents[GNRC_RPL_PARENTS_NUMOF];
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Add a new RPL instance with the id @p instance_id.
|
|
|
|
*
|
|
|
|
* @param[in] instance_id The instance id of the new RPL instance.
|
|
|
|
* @param[out] inst Pointer to an existing or new instance. Otherwise NULL.
|
|
|
|
*
|
|
|
|
* @return true, if instance could be created.
|
|
|
|
* @return false, if instance could not be created or exists already.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
bool gnrc_rpl_instance_add(uint8_t instance_id, gnrc_rpl_instance_t **inst);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Remove a RPL instance with the id @p instance_id.
|
|
|
|
*
|
|
|
|
* @param[in] instance_id The instance id of the RPL instance to remove.
|
|
|
|
*
|
|
|
|
* @return true, on success.
|
|
|
|
* @return false, otherwise.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
bool gnrc_rpl_instance_remove_by_id(uint8_t instance_id);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Remove a RPL instance with the pointer @p inst.
|
|
|
|
*
|
|
|
|
* @param[in] inst Pointer to the the RPL instance to remove.
|
|
|
|
*
|
|
|
|
* @return true, on success.
|
|
|
|
* @return false, otherwise.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
bool gnrc_rpl_instance_remove(gnrc_rpl_instance_t *inst);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the RPL instance with the id @p instance_id.
|
|
|
|
*
|
|
|
|
* @param[in] instance_id The instance id of the RPL instance to get.
|
|
|
|
*
|
|
|
|
* @return Pointer to the RPL instance, on success.
|
|
|
|
* @return NULL, otherwise.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_rpl_instance_t *gnrc_rpl_instance_get(uint8_t instance_id);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
2015-08-27 22:29:08 +02:00
|
|
|
* @brief Initialize a new RPL DODAG with the id @p dodag_id for the instance @p instance.
|
2015-05-22 21:47:37 +02:00
|
|
|
*
|
|
|
|
* @param[in] instance Pointer to the instance to add the DODAG to
|
|
|
|
* @param[in] dodag_id The DODAG-ID of the new DODAG
|
2016-03-22 14:58:23 +01:00
|
|
|
* @param[in] iface Interface PID where the DODAG operates
|
2015-05-22 21:47:37 +02:00
|
|
|
*
|
|
|
|
* @return true, if DODAG could be created.
|
|
|
|
* @return false, if DODAG could not be created or exists already.
|
|
|
|
*/
|
2021-07-28 14:47:20 +02:00
|
|
|
bool gnrc_rpl_dodag_init(gnrc_rpl_instance_t *instance, const ipv6_addr_t *dodag_id,
|
|
|
|
kernel_pid_t iface);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Remove all parents from the @p dodag.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the dodag.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
void gnrc_rpl_dodag_remove_all_parents(gnrc_rpl_dodag_t *dodag);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Add a new parent with the IPv6 address @p addr to the @p dodag.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
* @param[in] addr IPV6 address of the parent
|
|
|
|
* @param[out] parent Pointer to an existing or new parent. Otherwise NULL.
|
|
|
|
*
|
|
|
|
* @return true. if parent could be created.
|
|
|
|
* @return false, if parent could not be created or exists already.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
bool gnrc_rpl_parent_add_by_addr(gnrc_rpl_dodag_t *dodag, ipv6_addr_t *addr,
|
|
|
|
gnrc_rpl_parent_t **parent);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Remove the @p parent from its DODAG.
|
|
|
|
*
|
|
|
|
* @param[in] parent Pointer to the parent.
|
|
|
|
*
|
|
|
|
* @return true, on success.
|
|
|
|
* @return false, otherwise.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
bool gnrc_rpl_parent_remove(gnrc_rpl_parent_t *parent);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Update a @p parent of the @p dodag.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
* @param[in] parent Pointer to the parent
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
void gnrc_rpl_parent_update(gnrc_rpl_dodag_t *dodag, gnrc_rpl_parent_t *parent);
|
2015-05-22 21:47:37 +02:00
|
|
|
|
2020-02-14 11:41:30 +01:00
|
|
|
/**
|
|
|
|
* @brief Removes the dodag state of @p dodag after
|
2020-04-23 10:36:08 +02:00
|
|
|
* CONFIG_GNRC_RPL_CLEANUP_TIME milliseconds
|
2020-02-14 11:41:30 +01:00
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
*/
|
|
|
|
void gnrc_rpl_cleanup_start(gnrc_rpl_dodag_t *dodag);
|
|
|
|
|
2015-05-22 21:47:37 +02:00
|
|
|
/**
|
|
|
|
* @brief Start a local repair.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
void gnrc_rpl_local_repair(gnrc_rpl_dodag_t *dodag);
|
2015-08-22 09:19:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Operate as leaf.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
*/
|
|
|
|
void gnrc_rpl_leaf_operation(gnrc_rpl_dodag_t *dodag);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Operate as router.
|
|
|
|
*
|
|
|
|
* @param[in] dodag Pointer to the DODAG
|
|
|
|
*/
|
|
|
|
void gnrc_rpl_router_operation(gnrc_rpl_dodag_t *dodag);
|
2015-05-22 21:47:37 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* NET_GNRC_RPL_DODAG_H */
|
2015-05-22 21:47:37 +02:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|