/* * Copyright (C) 2015 Martine Lenders * * 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_ndp_internal Internal functions for neighbor discovery. * @ingroup net_gnrc_ndp * @brief Internal functions for neighbor discovery. * @internal * @note Only for use with a neighbor discovery implementations. * @{ * * @file * @brief Internal neighbor discovery functions for neighbor discovery. * * @author Martine Lenders */ #ifndef GNRC_NDP_INTERNAL_H_ #define GNRC_NDP_INTERNAL_H_ #include "net/ipv6/addr.h" #include "net/ipv6/hdr.h" #include "net/ndp.h" #ifdef __cplusplus extern "C" { #endif /** * @brief Get best match from default router list. * * @internal * * @see * RFC 4861, section 6.3.6 * * * @return Address to a default router. * @return NULL, if the default router list is empty. */ ipv6_addr_t *gnrc_ndp_internal_default_router(void); /** * @brief Sets state of a neighbor cache entry and triggers required actions. * * @internal * * @param[in] nc_entry A neighbor cache entry. * @param[in] state The new state for the neighbor cache entry. */ void gnrc_ndp_internal_set_state(gnrc_ipv6_nc_t *nc_entry, uint8_t state); /** * @brief Send precompiled neighbor solicitation. * * @internal * * @param[in] iface Interface to send over. May not be KERNEL_PID_UNDEF. * @param[in] tgt Target address for the neighbor solicitation. May not be * NULL. * @param[in] dst Destination address for neighbor solicitation. May not be * NULL. */ void gnrc_ndp_internal_send_nbr_sol(kernel_pid_t iface, ipv6_addr_t *tgt, ipv6_addr_t *dst); /** * @brief Send precompiled neighbor advertisement. * * @internal * * @param[in] iface Interface to send over. May not be KERNEL_PID_UNDEF. * @param[in] tgt Target address for the neighbor solicitation. May * not be NULL. * @param[in] dst Destination address for neighbor solicitation. May * not be NULL. * @param[in] supply_tl2a Add target link-layer address option to neighbor * advertisement if link-layer has addresses. * @param[in] ext_opts External options for the neighbor advertisement. Leave NULL for none. * **Warning:** these are not tested if they are suitable for a * neighbor advertisement so be sure to check that. * **Will be released** in an error case. */ void gnrc_ndp_internal_send_nbr_adv(kernel_pid_t iface, ipv6_addr_t *tgt, ipv6_addr_t *dst, bool supply_tl2a, gnrc_pktsnip_t *ext_opts); /** * @brief Handles a SL2A option. * * @param[in] pkt Packet the option was received in. * @param[in] ipv6 IPv6 header of @p pkt * @param[in] icmpv6_type ICMPv6 type of the message carrying the option. * @param[in] tl2a_opt The TL2A option. * @param[out] l2addr The L2 address carried in the SL2A option. * * @return length of the L2 address, on success. * @return -EINVAL, if SL2A was not valid. * @return -ENOTSUP, if node should silently ignore the option. */ int gnrc_ndp_internal_sl2a_opt_handle(gnrc_pktsnip_t *pkt, ipv6_hdr_t *ipv6, uint8_t icmpv6_type, ndp_opt_t *sl2a_opt, uint8_t *l2addr); /** * @brief Handles a TL2A option. * * @param[in] pkt Packet the option was received in. * @param[in] ipv6 IPv6 header of @p pkt * @param[in] icmpv6_type ICMPv6 type of the message carrying the option. * @param[in] tl2a_opt The TL2A option. * @param[out] l2addr The L2 address carried in the TL2A option. * * @return length of the L2 address, on success. * @return -EINVAL, if TL2A was not valid. * @return -ENOTSUP, if node should silently ignore the option. */ int gnrc_ndp_internal_tl2a_opt_handle(gnrc_pktsnip_t *pkt, ipv6_hdr_t *ipv6, uint8_t icmpv6_type, ndp_opt_t *tl2a_opt, uint8_t *l2addr); #ifdef __cplusplus } #endif #endif /* GNRC_NDP_INTERNAL_H_ */ /** @} */