/* * 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_ft Forwarding table * @ingroup net_gnrc_ipv6_nib * @brief * @{ * * @file * @brief Forwarding table definitions * * @author Martine Lenders */ #ifndef NET_GNRC_IPV6_NIB_FT_H #define NET_GNRC_IPV6_NIB_FT_H #include #include "net/gnrc/pkt.h" #include "net/ipv6/addr.h" #ifdef __cplusplus extern "C" { #endif /** * @brief Forwarding table entry view on NIB */ typedef struct { ipv6_addr_t dst; /**< destination or prefix */ ipv6_addr_t next_hop; /**< next hop to gnrc_ipv6_nib_ft_t::dst */ uint8_t dst_len; /**< prefix-length in bits of * gnrc_ipv6_nib_ft_t::dst */ uint8_t primary; /**< != 0 if gnrc_ipv6_nib_ft_t::dst is preferred * default route */ uint16_t iface; /**< interface to gnrc_ipv6_nib_ft_t::next_hop */ } gnrc_ipv6_nib_ft_t; /** * @brief Gets the best matching forwarding table entry to a destination * * @pre `(dst != NULL) && (fte != NULL)` * * @param[in] dst The destination. * @param[in] pkt Packet that is supposed to go to that destination * (is handed over to a reactive routing protocol if one exists * on the interface found and no route is found) * @param[out] fte The resulting forwarding table entry. * * @return 0, on success. * @return -ENETUNREACH, if no route was found. */ int gnrc_ipv6_nib_ft_get(const ipv6_addr_t *dst, gnrc_pktsnip_t *pkt, gnrc_ipv6_nib_ft_t *fte); /** * @brief Adds a new route to the forwarding table * * @param[in] dst The destination to the route. May be NULL or `::` for * default route. * @param[in] dst_len The prefix length of @p dst in bits. May be 0 for * default route. * @param[in] next_hop The next hop to @p dst/@p dst_len. May be NULL, if * @p dst/@p dst_len is no the default route. * @param[in] iface The interface to @p next_hop. May not be 0. * * @return 0, on success. * @return -EINVAL, if a parameter was of invalid value. * @return -ENOMEM, if there was no space left in forwarding table. */ int gnrc_ipv6_nib_ft_add(const ipv6_addr_t *dst, unsigned dst_len, const ipv6_addr_t *next_hop, unsigned iface); /** * @brief Deletes a route from forwarding table. * * @param[in] dst The destination of the route. May be NULL or `::` for * default route. * @param[in] dst_len The prefix length of @p dst in bits. May be 0 for * default route. */ void gnrc_ipv6_nib_ft_del(const ipv6_addr_t *dst, unsigned dst_len); /** * @brief Iterates over all forwarding table entries in the NIB * * @pre `(state != NULL) && (fte != NULL)` * * @param[in] next_hop Restrict iteration to entries to this next hop. NULL * for any next hop. Can be used to build a source * routing tree. * @param[in] iface Restrict iteration to entries on this interface. * 0 for any interface. * @param[in,out] state Iteration state of the forwarding table. Must point * to a NULL pointer to start iteration. * @param[out] fte The next forwarding table entry. * * The iteration over all forwarding table entries in the NIB includes all * entries added via @p gnrc_ipv6_nib_ft_add() and entries that are currently * in the Destination Cache, in the Prefix List, and in the Default Router List. * * Usage example: * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.c} * #include "net/gnrc/ipv6/nib/ft.h" * * int main(void) { * void *state = NULL; * gnrc_ipv6_nib_ft_t fte; * * puts("My neighbors:"); * while (gnrc_ipv6_nib_ft_iter(NULL, 0, &state, &fte)) { * gnrc_ipv6_nib_ft_print(&fte); * } * return 0; * } * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * @note The list may change during iteration. * * @return true, if iteration can be continued. * @return false, if @p fte is the last neighbor cache entry in the NIB. */ bool gnrc_ipv6_nib_ft_iter(const ipv6_addr_t *next_hop, unsigned iface, void **state, gnrc_ipv6_nib_ft_t *fte); /** * @brief Prints a forwarding table entry * * @pre `fce != NULL` * * @param[in] fte A forwarding table entry. */ void gnrc_ipv6_nib_ft_print(const gnrc_ipv6_nib_ft_t *fte); #ifdef __cplusplus } #endif #endif /* NET_GNRC_IPV6_NIB_FT_H */ /** @} */