1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/net/routing/aodvv2/routingtable.h
Lotte Steenbrink 0c67c02047 Add the AODVv2 Routing Protocol
This PR depends on #1766.

It contains a minimal implementation of the AODVv2 routing protocol.
*Not* implemented are:

	- AckReqs
	- alternate metrics
	- multiple interfaces
	- clients and Client Networks
	- buffering
	- all addresses, TLVs, and features that are marked as optional

An example application can be found at https://github.com/Lotterleben/RIOT-AODVv2/tree/master/aodvv2_demo.

The implementation relies heavily on a functioning Neighbor Discovery Protocol.
It might be necessary to fill the neighbor cache manually with the current state
of RIOTs NDP implementation.

The value of AODVV2_MAX_UNREACHABLE_NODES has been chosen arbitrarily and will be subject to
future improvement.

Please note that based on my experience, with the default transceiver
buffer size (3) of the native port, about 2/3 of the route discoveries
will fail. This has been addressed in issue #1747. It is advised to increase
the transceiver buffer size when using AODVv2 as a routing protocol.
2014-11-27 03:50:20 -08:00

164 lines
5.9 KiB
C

/*
* Copyright (C) 2014 Freie Universität Berlin
* Copyright (C) 2014 Lotte Steenbrink <lotte.steenbrink@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.
*/
/**
* @ingroup aodvv2
* @{
*
* @file routingtable.h
* @brief Cobbled-together routing table.
*
* @author Lotte Steenbrink <lotte.steenbrink@fu-berlin.de>
*/
#ifndef AODVV2_ROUTINGTABLE_H_
#define AODVV2_ROUTINGTABLE_H_
#include <string.h>
#include "common/netaddr.h"
#include "aodvv2/types.h"
#include "constants.h"
#include "seqnum.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* A route table entry (i.e., a route) may be in one of the following states:
*/
enum aodvv2_routing_states
{
ROUTE_STATE_ACTIVE,
ROUTE_STATE_IDLE,
ROUTE_STATE_EXPIRED,
ROUTE_STATE_BROKEN,
ROUTE_STATE_TIMED
};
/**
* all fields of a routing table entry
*/
struct aodvv2_routing_entry_t
{
struct netaddr addr; /**< IP address of this route's destination */
aodvv2_seqnum_t seqnum; /**< The Sequence Number obtained from the
* last packet that updated the entry */
struct netaddr nextHopAddr; /**< IP address of the the next hop towards
* the destination */
timex_t lastUsed; /**< IP address of this route's destination */
timex_t expirationTime; /**< Time at which this route expires */
aodvv2_metric_t metricType; /**< Metric type of this route */
uint8_t metric; /**< Metric value of this route*/
uint8_t state; /**< State of this route
* (i.e. one of aodvv2_routing_states) */
};
/**
* @brief Initialize routing table.
*/
void routingtable_init(void);
/**
* @brief Get next hop towards dest.
* Returns NULL if dest is not in routing table.
*
* @param[in] dest Destination of the packet
* @param[in] metricType Metric Type of the desired route
* @return next hop towards dest if it exists, NULL otherwise
*/
struct netaddr *routingtable_get_next_hop(struct netaddr *dest, aodvv2_metric_t metricType);
/**
* @brief Add new entry to routing table, if there is no other entry
* to the same destination.
*
* @param[in] entry The routing table entry to add
*/
void routingtable_add_entry(struct aodvv2_routing_entry_t *entry);
/**
* @brief Retrieve pointer to a routing table entry.
* To edit, simply follow the pointer.
* Returns NULL if addr is not in routing table.
*
* @param[in] addr The address towards which the route should point
* @param[in] metricType Metric Type of the desired route
* @return Routing table entry if it exists, NULL otherwise
*/
struct aodvv2_routing_entry_t *routingtable_get_entry(struct netaddr *addr, aodvv2_metric_t metricType);
/**
* @brief Delete routing table entry towards addr with metric type MetricType,
* if it exists.
*
* @param[in] addr The address towards which the route should point
* @param[in] metricType Metric Type of the desired route
*/
void routingtable_delete_entry(struct netaddr *addr, aodvv2_metric_t metricType);
/**
* Find all routing table entries that use hop as their nextHopAddress, mark them
* as broken, write the active one into unreachable_nodes[] and increment len
* accordingly. (Sorry about the Name.)
*
* @param hop Address of the newly unreachable next hop
* @param unreachable_nodes[] array of newlu unreachable nodes to be filled.
* should be empty.
* @param len size_t* which will contain the length of
* unreachable_nodes[] after execution
*/
void routingtable_break_and_get_all_hopping_over(struct netaddr *hop,
struct unreachable_node unreachable_nodes[],
size_t *len);
/**
* Check if the data of a RREQ or RREP offers improvement for an existing routing
* table entry.
* @param rt_entry the routing table entry to check
* @param node_data The data to check against. When handling a RREQ,
* the OrigNode's information (i.e. packet_data.origNode)
* must be passed. When handling a RREP, the
* TargNode's data (i.e. packet_data.targNode) must
* be passed.
*/
bool routingtable_offers_improvement(struct aodvv2_routing_entry_t *rt_entry,
struct node_data *node_data);
/**
* Fills a routing table entry with the data of a RREQ.
* @param packet_data the RREQ's data
* @param rt_entry the routing table entry to fill
* @param link_cost the link cost for this RREQ
*/
void routingtable_fill_routing_entry_t_rreq(struct aodvv2_packet_data *packet_data,
struct aodvv2_routing_entry_t *rt_entry,
uint8_t link_cost);
/**
* Fills a routing table entry with the data of a RREP.
* @param packet_data the RREP's data
* @param rt_entry the routing table entry to fill
* @param link_cost the link cost for this RREP
*/
void routingtable_fill_routing_entry_t_rrep(struct aodvv2_packet_data *packet_data,
struct aodvv2_routing_entry_t *rt_entry,
uint8_t link_cost);
void print_routingtable(void);
void print_routingtable_entry(struct aodvv2_routing_entry_t *rt_entry);
#ifdef __cplusplus
}
#endif
#endif /* AODVV2_ROUTINGTABLE_H_*/