2017-06-28 19:18:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup net_gnrc_ipv6_nib_abr Authoritative border router list
|
|
|
|
* @ingroup net_gnrc_ipv6_nib
|
|
|
|
* @brief Authoritative border router list component of neighbor
|
|
|
|
* information base
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Authoritative border router list definitions
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
#ifndef NET_GNRC_IPV6_NIB_ABR_H
|
|
|
|
#define NET_GNRC_IPV6_NIB_ABR_H
|
|
|
|
|
2020-03-11 17:38:03 +01:00
|
|
|
#include <kernel_defines.h>
|
|
|
|
|
2017-06-28 19:18:48 +02:00
|
|
|
#include "net/ipv6/addr.h"
|
|
|
|
#include "net/gnrc/ipv6/nib/conf.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-02-05 11:02:18 +01:00
|
|
|
/**
|
|
|
|
* @brief Authoritative border router list entry view on NIB
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
ipv6_addr_t addr; /**< The address of the border router */
|
|
|
|
uint32_t version; /**< last received version */
|
|
|
|
uint32_t valid_until; /**< timestamp (in minutes) until which the
|
|
|
|
* information is valid */
|
|
|
|
} gnrc_ipv6_nib_abr_t;
|
|
|
|
|
|
|
|
#if GNRC_IPV6_NIB_CONF_MULTIHOP_P6C || defined(DOXYGEN)
|
2020-03-11 17:38:03 +01:00
|
|
|
#if IS_ACTIVE(CONFIG_GNRC_IPV6_NIB_6LBR) || defined(DOXYGEN)
|
2017-06-28 19:18:48 +02:00
|
|
|
/**
|
|
|
|
* @brief Adds the address of an authoritative border router to the NIB
|
|
|
|
*
|
|
|
|
* @param[in] addr The address of an authoritative border router.
|
|
|
|
*
|
|
|
|
* @return 0 on success.
|
|
|
|
* @return -ENOMEM, if no space is left in the neighbor cache.
|
2020-03-11 17:38:03 +01:00
|
|
|
* @return -ENOTSUP, if @ref CONFIG_GNRC_IPV6_NIB_6LBR or
|
2019-02-05 11:02:18 +01:00
|
|
|
* @ref GNRC_IPV6_NIB_CONF_MULTIHOP_P6C is not defined
|
2017-06-28 19:18:48 +02:00
|
|
|
*/
|
|
|
|
int gnrc_ipv6_nib_abr_add(const ipv6_addr_t *addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Removes an authoritative border router from the NIB
|
|
|
|
*
|
|
|
|
* @param[in] addr The address of an authoritative border router.
|
|
|
|
*/
|
|
|
|
void gnrc_ipv6_nib_abr_del(const ipv6_addr_t *addr);
|
2020-03-11 17:38:03 +01:00
|
|
|
#else /* CONFIG_GNRC_IPV6_NIB_6LBR || defined(DOXYGEN) */
|
2019-02-05 11:02:18 +01:00
|
|
|
#define gnrc_ipv6_nib_abr_add(addr) (-ENOTSUP)
|
|
|
|
#define gnrc_ipv6_nib_abr_del(addr) (void)(addr)
|
2020-03-11 17:38:03 +01:00
|
|
|
#endif /* CONFIG_GNRC_IPV6_NIB_6LBR || defined(DOXYGEN) */
|
2019-02-05 11:02:18 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Iterates over all authoritative border router in the NIB
|
|
|
|
*
|
|
|
|
* @pre `(state != NULL) && (abr != NULL)`
|
|
|
|
*
|
|
|
|
* @param[in,out] state Iteration state of the authoritative border router list.
|
|
|
|
* Must point to NULL pointer to start iteration
|
|
|
|
* @param[out] abr The next authoritative border router list entry.
|
|
|
|
*
|
|
|
|
* Usage example:
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.c}
|
|
|
|
* #include "net/gnrc/ipv6/nib/abr.h"
|
|
|
|
*
|
|
|
|
* int main(void) {
|
|
|
|
* void *state = NULL;
|
|
|
|
* gnrc_ipv6_nib_abr_t abr;
|
|
|
|
*
|
|
|
|
* puts("My border routers:");
|
|
|
|
* while (gnrc_ipv6_nib_abr_iter(&state, &abr)) {
|
|
|
|
* gnrc_ipv6_nib_abr_print(&abr);
|
|
|
|
* }
|
|
|
|
* return 0;
|
|
|
|
* }
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*
|
|
|
|
* @note The list may change during iteration.
|
|
|
|
*
|
|
|
|
* @return true, if iteration can be continued.
|
|
|
|
* @return false, if @p abr is the last authoritative border router entry in
|
|
|
|
* the NIB.
|
|
|
|
*/
|
|
|
|
bool gnrc_ipv6_nib_abr_iter(void **state, gnrc_ipv6_nib_abr_t *abr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Prints an authoritative border router list entry
|
|
|
|
*
|
|
|
|
* @pre `abr != NULL`
|
|
|
|
*
|
|
|
|
* @param[in] abr An authoritative border router list entry
|
|
|
|
*/
|
|
|
|
void gnrc_ipv6_nib_abr_print(gnrc_ipv6_nib_abr_t *abr);
|
|
|
|
#else /* GNRC_IPV6_NIB_CONF_MULTIHOP_P6C || defined(DOXYGEN) */
|
|
|
|
#define gnrc_ipv6_nib_abr_add(addr) (-ENOTSUP)
|
|
|
|
#define gnrc_ipv6_nib_abr_del(addr) (void)(addr)
|
|
|
|
#define gnrc_ipv6_nib_abr_iter(state, abr) (false)
|
|
|
|
#define gnrc_ipv6_nib_abr_print(abr) (void)(abr)
|
|
|
|
#endif /* GNRC_IPV6_NIB_CONF_MULTIHOP_P6C || defined(DOXYGEN) */
|
2017-06-28 19:18:48 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* NET_GNRC_IPV6_NIB_ABR_H */
|
|
|
|
/** @} */
|