mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
4a31f94cfc
Signed-off-by: Francois Berder <18538310+francois-berder@users.noreply.github.com>
407 lines
14 KiB
C
407 lines
14 KiB
C
/*
|
|
* 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 Neighbor Information Base for IPv6
|
|
* @ingroup net_gnrc_ipv6
|
|
* @brief Neighbor Information Base (NIB) for IPv6
|
|
*
|
|
* @todo Add detailed description
|
|
* @todo Implement multihop DAD
|
|
* @todo Implement classic SLAAC
|
|
* @todo Implement MLD
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief NIB definitions
|
|
*
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
*/
|
|
#ifndef NET_GNRC_IPV6_NIB_H
|
|
#define NET_GNRC_IPV6_NIB_H
|
|
|
|
#include "net/gnrc/ipv6/nib/abr.h"
|
|
#include "net/gnrc/ipv6/nib/ft.h"
|
|
#include "net/gnrc/ipv6/nib/nc.h"
|
|
#include "net/gnrc/ipv6/nib/pl.h"
|
|
|
|
#include "net/icmpv6.h"
|
|
#include "net/ipv6/addr.h"
|
|
#include "net/ipv6/hdr.h"
|
|
#include "net/gnrc/ipv6/nib/nc.h"
|
|
#include "net/gnrc/netif.h"
|
|
#include "net/gnrc/pkt.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name Timer event message types
|
|
* @anchor net_gnrc_ipv6_nib_msg
|
|
* @{
|
|
*/
|
|
/**
|
|
* @brief (Re-)transmit unicast Neighbor Solicitation event.
|
|
*
|
|
* This message type is for the event of (re-)transmitting of unicast Neighbor
|
|
* Solicitation. The expected message context is a pointer to a valid on-link
|
|
* entry representing the neighbor to which the Neighbor Solicitation is
|
|
* supposed to be sent.
|
|
*/
|
|
#define GNRC_IPV6_NIB_SND_UC_NS (0x4fc0U)
|
|
|
|
/**
|
|
* @brief (Re-)transmit multicast Neighbor Solicitation event.
|
|
*
|
|
* This message type is for the event of (re-)transmitting of multicast Neighbor
|
|
* Solicitation. The expected message context is a pointer to a valid on-link
|
|
* entry representing the neighbor to which [solicited
|
|
* nodes](https://tools.ietf.org/html/rfc4291#section-2.7.1) group
|
|
* the Neighbor Solicitation is supposed to be sent.
|
|
*/
|
|
#define GNRC_IPV6_NIB_SND_MC_NS (0x4fc1U)
|
|
|
|
/**
|
|
* @brief Send delayed Neighbor Advertisement event.
|
|
*
|
|
* This message type is for the event of sending delayed Neighbor
|
|
* Advertisements. The expected message context is a pointer to a valid
|
|
* [packet snip](@ref gnrc_pktsnip_t) in *sending order*, representing the
|
|
* Neighbor Advertisement.
|
|
*/
|
|
#define GNRC_IPV6_NIB_SND_NA (0x4fc2U)
|
|
|
|
/**
|
|
* @brief Search router event.
|
|
*
|
|
* This message type is for the event of searching a (new) router (which
|
|
* implies sending a multicast Router Solicitation). The expected message
|
|
* context is a pointer to a valid interface behind which the router is
|
|
* searched.
|
|
*/
|
|
#define GNRC_IPV6_NIB_SEARCH_RTR (0x4fc3U)
|
|
|
|
/**
|
|
* @brief Reply Router Solicitation event.
|
|
*
|
|
* This message type is for the event of the delayed reply to a Router
|
|
* Solicitaion with a Router Advertisement. The expected message context is a
|
|
* pointer to a valid on-link entry representing the neighbor that sent the
|
|
* Router Solicitation.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ROUTER != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_REPLY_RS (0x4fc5U)
|
|
|
|
/**
|
|
* @brief (Re-)transmit multicast Router Advertisement event.
|
|
*
|
|
* This message type is for the event of (Re)transmit Advertisements
|
|
* event. The expected message context is a pointer to a valid interface over
|
|
* which the Router Advertisement will be sent and by which parameters it will
|
|
* be configured.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ROUTER != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_SND_MC_RA (0x4fc6U)
|
|
|
|
/**
|
|
* @brief Reachability timeout event.
|
|
*
|
|
* This message type is for the event of a REACHABLE state timeout.
|
|
* The expected message context is a pointer to a valid on-link entry
|
|
* representing the neighbor cache entry that faces a state change.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ARSM != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_REACH_TIMEOUT (0x4fc7U)
|
|
|
|
/**
|
|
* @brief Delay timeout event.
|
|
*
|
|
* This message type is for the event of the DELAY state timeout.
|
|
* The expected message context is a pointer to a valid on-link entry
|
|
* representing the neighbor cache entry that faces a state change.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ARSM != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_DELAY_TIMEOUT (0x4fc8U)
|
|
|
|
/**
|
|
* @brief Address registration timeout event.
|
|
*
|
|
* This message type is for the event of a 6LoWPAN address registration state
|
|
* timeout. The expected message context is a pointer to a valid on-link entry
|
|
* representing the neighbor which faces a timeout of its address registration.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_6LR != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_ADDR_REG_TIMEOUT (0x4fc9U)
|
|
|
|
/**
|
|
* @brief Authoritative border router timeout event.
|
|
*
|
|
* This message type is for the event of an Authoritative border router timeout.
|
|
* The expected message context is the NIB-internal state of the authoritative
|
|
* border router.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_MULTIHOP_P6C != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_ABR_TIMEOUT (0x4fcbU)
|
|
|
|
/**
|
|
* @brief Prefix timeout event.
|
|
*
|
|
* This message type is for the event of a prefix timeout. The expected message
|
|
* context is a valid off-link entry representing the prefix.
|
|
*/
|
|
#define GNRC_IPV6_NIB_PFX_TIMEOUT (0x4fccU)
|
|
|
|
/**
|
|
* @brief Router timeout event.
|
|
*
|
|
* This message type is for the event of a router timeout. The expected message
|
|
* context is a valid default router entry representing the router.
|
|
*/
|
|
#define GNRC_IPV6_NIB_RTR_TIMEOUT (0x4fcdU)
|
|
|
|
/**
|
|
* @brief Recalculate reachability timeout time.
|
|
*
|
|
* This message type is for the event of recalculating the reachability timeout
|
|
* time. The expected message context is a valid
|
|
* [interface](@ref net_gnrc_netif).
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ARSM != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_RECALC_REACH_TIME (0x4fceU)
|
|
|
|
/**
|
|
* @brief Reregister address.
|
|
*
|
|
* This message type is for the event of reregistering an IPv6 address to the
|
|
* upstream router. The expected message context is an IPv6 address assigned to
|
|
* one of the nodes interfaces.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_6LN != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_REREG_ADDRESS (0x4fcfU)
|
|
|
|
/**
|
|
* @brief Route timeout event.
|
|
*
|
|
* This message type is for the event of a route timeout. The expected message
|
|
* context is a valid off-link entry representing the route.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_ROUTER != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_ROUTE_TIMEOUT (0x4fd0U)
|
|
|
|
/**
|
|
* @brief Perform DAD event.
|
|
*
|
|
* This message type is for performing DAD for a given address. The expected
|
|
* message context is a TENTATIVE IPv6 address.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_SLAAC != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_DAD (0x4fd1U)
|
|
|
|
/**
|
|
* @brief Validate a tentative address event.
|
|
*
|
|
* Moves a TENTATIVE address to VALID state. The expected message context is a
|
|
* TENTATIVE IPv6 address.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_SLAAC != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_VALID_ADDR (0x4fd2U)
|
|
|
|
/**
|
|
* @brief Recursive DNS server timeout
|
|
*
|
|
* This message type is for the event of a recursive DNS server timeout.
|
|
* The expected message context is the [UDP end point](@ref sock_udp_ep_t)
|
|
* representing the DNS server.
|
|
*
|
|
* @note Only handled with @ref GNRC_IPV6_NIB_CONF_DNS != 0
|
|
*/
|
|
#define GNRC_IPV6_NIB_RDNSS_TIMEOUT (0x4fd3U)
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief Types for gnrc_netif_ipv6_t::route_info_cb
|
|
* @anchor net_gnrc_ipv6_nib_route_info_type
|
|
*/
|
|
enum {
|
|
GNRC_IPV6_NIB_ROUTE_INFO_TYPE_UNDEF = 0, /**< undefined */
|
|
/**
|
|
* @brief reactive routing query
|
|
*
|
|
* A reactive routing query is issued when a route is unknown to the NIB.
|
|
* A reactive routing protocol can use this call to search for a route in a
|
|
* reactive manner.
|
|
*
|
|
* The `ctx_addr` will be the destination address of the unknown route,
|
|
* `ctx` a pointer to the packet as `gnrc_pktsnip_t` that caused the route
|
|
* look-up (to possibly queue it for later sending).
|
|
*/
|
|
GNRC_IPV6_NIB_ROUTE_INFO_TYPE_RRQ,
|
|
|
|
/**
|
|
* @brief route notification
|
|
*
|
|
* A route notification is issued when an already established route is
|
|
* taken. A routing protocol can use this call to update its information on
|
|
* the route.
|
|
*
|
|
* The `ctx_addr` is the prefix of the route, `ctx` is set to a value equal
|
|
* to the length of the prefix in bits.
|
|
*/
|
|
GNRC_IPV6_NIB_ROUTE_INFO_TYPE_RN,
|
|
|
|
/**
|
|
* @brief neighbor state change
|
|
*
|
|
* A neighbor state change is issued when ever the NUD state of a neighbor
|
|
* changes. A routing protocol can use this call to update its information
|
|
* on routes via this neighbor.
|
|
*
|
|
* The `ctx_addr` is the address of the neighbor, `ctx` is a value equal
|
|
* to the new NUD state as defined in [the NC info flags](@ref
|
|
* net_gnrc_ipv6_nib_nc_info). If the entry is deleted, `ctx` will be set
|
|
* to @ref GNRC_IPV6_NIB_NC_INFO_NUD_STATE_UNREACHABLE (except if it was
|
|
* already in the `UNREACHABLE` state). This does not include cache-outs,
|
|
* since they give no information about the neighbor's reachability (you
|
|
* might however get an INCOMPLETE or STALE notification due to that, as
|
|
* soon as the neighbor enters the neighbor cache again).
|
|
*
|
|
* Be advised to only use `ctx_addr` in the context of the callback, since
|
|
* it might be overwritten, after the callback was left.
|
|
*/
|
|
GNRC_IPV6_NIB_ROUTE_INFO_TYPE_NSC,
|
|
};
|
|
|
|
/**
|
|
* @brief Initialize NIB
|
|
*/
|
|
void gnrc_ipv6_nib_init(void);
|
|
|
|
/**
|
|
* @brief Adds an interface to be managed by the NIB.
|
|
*
|
|
* @pre `netif != NULL`
|
|
*
|
|
* @param[in,out] netif The interface to be managed by the NIB
|
|
*/
|
|
void gnrc_ipv6_nib_init_iface(gnrc_netif_t *netif);
|
|
|
|
/**
|
|
* @brief Gets link-layer address of next hop to a destination address
|
|
*
|
|
* @pre `(dst != NULL) && (nce != NULL)`
|
|
*
|
|
* @param[in] dst Destination address of a packet.
|
|
* @param[in] netif Restrict search to this interface. May be `NULL` for any
|
|
* interface.
|
|
* @param[in] pkt The IPv6 packet in sending order for which the next hop
|
|
* is searched. Needed for queuing for with reactive
|
|
* routing or address resolution. May be `NULL`.
|
|
* Will be released properly on error.
|
|
* @param[out] nce The neighbor cache entry of the next hop to @p dst.
|
|
*
|
|
* @return 0, on success.
|
|
* @return -ENETUNREACH if there is no route to host.
|
|
* @return -EHOSTUNREACH if the next hop is not reachable or if @p dst was
|
|
* link-local, but @p iface was @ref KERNEL_PID_UNDEF (no neighbor
|
|
* cache entry will be created in this case and no neighbor
|
|
* solicitation sent).
|
|
*/
|
|
int gnrc_ipv6_nib_get_next_hop_l2addr(const ipv6_addr_t *dst,
|
|
gnrc_netif_t *netif, gnrc_pktsnip_t *pkt,
|
|
gnrc_ipv6_nib_nc_t *nce);
|
|
|
|
/**
|
|
* @brief Handles a received ICMPv6 packet
|
|
*
|
|
* @pre `netif != NULL`
|
|
* @pre `ipv6 != NULL`
|
|
* @pre `icmpv6 != NULL`
|
|
* @pre `icmpv6_len > sizeof(icmpv6_hdr_t)`
|
|
*
|
|
* @attention The ICMPv6 checksum is supposed to be checked externally!
|
|
*
|
|
* @note @p ipv6 is just used for the addresses and hop limit. The next
|
|
* header field will not be checked for correctness (but should be
|
|
* @ref PROTNUM_ICMPV6)
|
|
*
|
|
* @see [RFC 4861, section 6.1](https://tools.ietf.org/html/rfc4861#section-6.1)
|
|
* @see [RFC 4861, section 6.2.6](https://tools.ietf.org/html/rfc4861#section-6.2.6)
|
|
* @see [RFC 4861, section 6.3.4](https://tools.ietf.org/html/rfc4861#section-6.3.4)
|
|
* @see [RFC 4861, section 7.1](https://tools.ietf.org/html/rfc4861#section-7.1)
|
|
* @see [RFC 4861, section 7.2.3](https://tools.ietf.org/html/rfc4861#section-7.2.3)
|
|
* @see [RFC 4861, section 7.2.5](https://tools.ietf.org/html/rfc4861#section-7.2.5)
|
|
* @see [RFC 4861, section 8.1](https://tools.ietf.org/html/rfc4861#section-8.1)
|
|
* @see [RFC 4861, section 8.3](https://tools.ietf.org/html/rfc4861#section-8.3)
|
|
* @see [RFC 4862, section 5.4.3](https://tools.ietf.org/html/rfc4862#section-5.4.3)
|
|
* @see [RFC 4862, section 5.4.4](https://tools.ietf.org/html/rfc4862#section-5.4.4)
|
|
* @see [RFC 4862, section 5.5.3](https://tools.ietf.org/html/rfc4862#section-5.5.3)
|
|
* @see [RFC 6775, section 5.5.2](https://tools.ietf.org/html/rfc6775#section-5.5.2)
|
|
* @see [RFC 6775, section 5.4](https://tools.ietf.org/html/rfc6775#section-5.4)
|
|
* @see [RFC 6775, section 6.3](https://tools.ietf.org/html/rfc6775#section-6.3)
|
|
* @see [RFC 6775, section 6.5](https://tools.ietf.org/html/rfc6775#section-6.5)
|
|
* @see [RFC 6775, section 8.1.3](https://tools.ietf.org/html/rfc6775#section-8.1.3)
|
|
* @see [RFC 6775, section 8.2.1](https://tools.ietf.org/html/rfc6775#section-8.2.1)
|
|
* @see [RFC 6775, section 8.2.4](https://tools.ietf.org/html/rfc6775#section-8.2.4)
|
|
* @see [RFC 6775, section 8.2.5](https://tools.ietf.org/html/rfc6775#section-8.2.5)
|
|
*
|
|
* @param[in] netif The interface the packet came over.
|
|
* @param[in] ipv6 The IPv6 header of the received packet.
|
|
* @param[in] icmpv6 The ICMPv6 header and payload of the received
|
|
* packet.
|
|
* @param[in] icmpv6_len The number of bytes at @p icmpv6.
|
|
*/
|
|
void gnrc_ipv6_nib_handle_pkt(gnrc_netif_t *netif, const ipv6_hdr_t *ipv6,
|
|
const icmpv6_hdr_t *icmpv6, size_t icmpv6_len);
|
|
|
|
/**
|
|
* @brief Handles a timer event
|
|
*
|
|
* @param[in] ctx Context of the timer event.
|
|
* @param[in] type Type of the timer event (see [timer event
|
|
* types](@ref net_gnrc_ipv6_nib_msg))
|
|
*/
|
|
void gnrc_ipv6_nib_handle_timer_event(void *ctx, uint16_t type);
|
|
|
|
#if GNRC_IPV6_NIB_CONF_ROUTER || defined(DOXYGEN)
|
|
/**
|
|
* @brief Changes the state if an interface advertises itself as a router
|
|
* or not
|
|
*
|
|
* @param[in] netif The interface for which the state should be changed.
|
|
* @param[in] enable `true`, to enable advertising the interface as a router.
|
|
* `false`, to disable advertising the interface as a
|
|
* router.
|
|
*/
|
|
void gnrc_ipv6_nib_change_rtr_adv_iface(gnrc_netif_t *netif, bool enable);
|
|
#else
|
|
/**
|
|
* @brief Optimization to NOP for non-routers
|
|
*/
|
|
#define gnrc_ipv6_nib_change_rtr_adv_iface(netif, enable) \
|
|
(void)netif; (void)enable
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NET_GNRC_IPV6_NIB_H */
|
|
/** @} */
|