mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
165 lines
5.2 KiB
C
165 lines
5.2 KiB
C
|
/*
|
||
|
* Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.de>
|
||
|
*
|
||
|
* 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 gnrc_sixlowpan_nd_router Router-part of 6LoWPAN-ND
|
||
|
* @ingroup gnrc_sixlowpan_nd
|
||
|
* @brief Router-part of 6LoWPAN-ND
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Router-definitions for 6LoWPAN-ND.
|
||
|
*
|
||
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
||
|
*/
|
||
|
#ifndef GNRC_SIXLOWPAN_ND_ROUTER_H_
|
||
|
#define GNRC_SIXLOWPAN_ND_ROUTER_H_
|
||
|
|
||
|
#include <stdbool.h>
|
||
|
|
||
|
#include "bitfield.h"
|
||
|
#include "net/gnrc/sixlowpan/ctx.h"
|
||
|
#include "net/gnrc/ipv6/netif.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief Number of registerable border routers
|
||
|
*
|
||
|
* @note More than one border routers require some way of synchronization
|
||
|
* of the context information (see
|
||
|
* [RFC 6775, section 8.1](https://tools.ietf.org/html/rfc6775#section-8.1))
|
||
|
*/
|
||
|
#ifndef GNRC_SIXLOWPAN_ND_ROUTER_ABR_NUMOF
|
||
|
#define GNRC_SIXLOWPAN_ND_ROUTER_ABR_NUMOF (1)
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief The number of non-link-local prefixes associated with border routers
|
||
|
* at maximum.
|
||
|
*/
|
||
|
#ifndef GNRC_SIXLOWPAN_ND_ROUTER_ABR_PRF_NUMOF
|
||
|
#define GNRC_SIXLOWPAN_ND_ROUTER_ABR_PRF_NUMOF (GNRC_SIXLOWPAN_ND_ROUTER_ABR_NUMOF)
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief Representation for prefixes coming from a router
|
||
|
*/
|
||
|
typedef struct gnrc_sixlowpan_nd_router_prf {
|
||
|
struct gnrc_sixlowpan_nd_router_prf *next; /**< next prefix */
|
||
|
gnrc_ipv6_netif_t *iface; /**< interface the prefix is registered too */
|
||
|
gnrc_ipv6_netif_addr_t *prefix; /**< prefix on the interface/in the prefix list */
|
||
|
} gnrc_sixlowpan_nd_router_prf_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Abstract representation of a border router on all (border) routers.
|
||
|
*/
|
||
|
typedef struct {
|
||
|
ipv6_addr_t addr; /**< the IPv6 address of the border router (BR) */
|
||
|
uint32_t version; /**< version of the information dissiminated by the
|
||
|
* BR */
|
||
|
uint16_t ltime; /**< the time in minutes until deletion */
|
||
|
BITFIELD(ctxs, GNRC_SIXLOWPAN_CTX_SIZE);/**< contexts associated with BR */
|
||
|
gnrc_sixlowpan_nd_router_prf_t *prfs; /**< prefixes associated with BR */
|
||
|
vtimer_t ltimer; /**< timer for deletion */
|
||
|
} gnrc_sixlowpan_nd_router_abr_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Removes tentetative neighbor cache entries or sets registered ones to
|
||
|
* garbage-collectible.
|
||
|
*
|
||
|
* @param[in] nc_entry A neighbor cache entry.
|
||
|
*/
|
||
|
static inline void gnrc_sixlowpan_nd_router_gc_nc(gnrc_ipv6_nc_t *nc_entry)
|
||
|
{
|
||
|
switch (gnrc_ipv6_nc_get_type(nc_entry)) {
|
||
|
case GNRC_IPV6_NC_TYPE_TENTATIVE:
|
||
|
case GNRC_IPV6_NC_TYPE_REGISTERED:
|
||
|
gnrc_ipv6_nc_remove(nc_entry->iface, &nc_entry->ipv6_addr);
|
||
|
break;
|
||
|
default:
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Set @p netif to router mode.
|
||
|
*
|
||
|
* @details This sets/unsets the GNRC_IPV6_NETIF_FLAGS_ROUTER and initializes or ceases router
|
||
|
* behavior for 6LoWPAN neighbor discovery.
|
||
|
*
|
||
|
* @param[in] netif An IPv6 interface. Must not be NULL.
|
||
|
* @param[in] enable Status for the GNRC_IPV6_NETIF_FLAGS_ROUTER flag.
|
||
|
*/
|
||
|
static inline void gnrc_sixlowpan_nd_router_set_router(gnrc_ipv6_netif_t *netif, bool enable)
|
||
|
{
|
||
|
if (enable) {
|
||
|
netif->flags |= GNRC_IPV6_NETIF_FLAGS_ROUTER;
|
||
|
}
|
||
|
else {
|
||
|
netif->flags &= ~GNRC_IPV6_NETIF_FLAGS_ROUTER;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Set/Unset GNRC_IPV6_NETIF_FLAGS_RTR_ADV flag for @p netif.
|
||
|
*
|
||
|
* @details GNRC_IPV6_NETIF_FLAGS_RTR_ADV and initializes or ceases
|
||
|
* periodic router advertising behavior for neighbor discovery.
|
||
|
*
|
||
|
* @param[in] netif An IPv6 interface. Must not be NULL.
|
||
|
* @param[in] enable Status for the GNRC_IPV6_NETIF_FLAGS_RTR_ADV flag.
|
||
|
*/
|
||
|
static inline void gnrc_sixlowpan_nd_router_set_rtr_adv(gnrc_ipv6_netif_t *netif, bool enable)
|
||
|
{
|
||
|
if (enable) {
|
||
|
netif->flags |= GNRC_IPV6_NETIF_FLAGS_RTR_ADV;
|
||
|
}
|
||
|
else {
|
||
|
netif->flags &= ~GNRC_IPV6_NETIF_FLAGS_RTR_ADV;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Get's the border router for this router.
|
||
|
*
|
||
|
* @return The border router, if one is specified.
|
||
|
* @return NULL, otherwise.
|
||
|
*/
|
||
|
gnrc_sixlowpan_nd_router_abr_t *gnrc_sixlowpan_nd_router_abr_get(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Checks if the version data @p abr_opt is older than the version of the currently
|
||
|
* registered border router.
|
||
|
*
|
||
|
* @param[in] abr_opt An authoritative border router option containing potentially new
|
||
|
* information on the currently registered border router.
|
||
|
*
|
||
|
* @return true, if the information in @p abr_opt is newer.
|
||
|
* @return false, if the information in @p abr_opt is older.
|
||
|
*/
|
||
|
bool gnrc_sixlowpan_nd_router_abr_older(sixlowpan_nd_opt_abr_t *abr_opt);
|
||
|
|
||
|
/**
|
||
|
* @brief Removes the border router and all the prefixes and contexts it disseminated through
|
||
|
* the network for this node.
|
||
|
*
|
||
|
* @param[in] abr The border router.
|
||
|
*/
|
||
|
void gnrc_sixlowpan_nd_router_abr_remove(gnrc_sixlowpan_nd_router_abr_t *abr);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* GNRC_SIXLOWPAN_ND_ROUTER_H_ */
|
||
|
/** @} */
|