blob: eaf0f4f8c5ec63f78760bb6844ec12ff0b79a46e [file] [log] [blame]
#include <stdint.h>
#include "lwip/ip6_addr.h"
#include "lwip/netif.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Route table entry
*
*/
typedef struct
{
ip6_addr_t prefix;
uint8_t prefix_length;
ip6_addr_t gateway;
int8_t preference;
uint32_t lifetime_seconds;
struct netif * netif;
} bl_route_entry_t;
/**
* @brief Adds an entry to the route table
*
* @param[in] route_entry The route entry to be added
*
* @return
* - The pointer to the added route entry on success
* - NULL on failure
*
*/
bl_route_entry_t * bl_route_table_add_route_entry(const bl_route_entry_t * route_entry);
/**
* @brief Removes an entry from the route table
*
* @param[in] route_entry The route entry to be removed
*
* @return
* - 0
* - -1 The provided route_entry is not in the route table.
*
*/
int8_t bl_route_table_remove_route_entry(bl_route_entry_t * route_entry);
/**
* @brief The lwIP ip6 route hook, called by the lwIP function ip6_route when sending packets.
*
* @param[in] src The source address
* @param[in] dest The destination address
*
* @return
* - The target interface when route found
* - NULL when route not found
*
*/
struct netif * lwip_hook_ip6_route(const ip6_addr_t * src, const ip6_addr_t * dest);
/**
* @brief The lwIP gateway hook, called by the lwIP when deciding next hop.
*
* @param[in] netif The output network interface
* @param[in] dest The destination address
*
* @return
* - The gateway address when route found
* - NULL when route not found
*
*/
const ip6_addr_t * lwip_hook_nd6_get_gw(struct netif * netif, const ip6_addr_t * dest);
#ifdef __cplusplus
}
#endif