mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
152 lines
5.5 KiB
C
152 lines
5.5 KiB
C
/*
|
|
* Copyright (C) 2014 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.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup nhdp
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Interface Information Base interface for NHDP
|
|
*
|
|
* @author Fabian Nack <nack@inf.fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef IIB_TABLE_H_
|
|
#define IIB_TABLE_H_
|
|
|
|
#include "timex.h"
|
|
#include "kernel_types.h"
|
|
|
|
#include "nib_table.h"
|
|
#include "nhdp_address.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Possible L_STATUS values of a link tuple
|
|
*/
|
|
typedef enum iib_link_tuple_status_t {
|
|
IIB_LT_STATUS_PENDING,
|
|
IIB_LT_STATUS_LOST,
|
|
IIB_LT_STATUS_HEARD,
|
|
IIB_LT_STATUS_SYM,
|
|
IIB_LT_STATUS_UNKNOWN
|
|
} iib_link_tuple_status_t;
|
|
|
|
/**
|
|
* @brief Link Set entry (link tuple)
|
|
*/
|
|
typedef struct iib_link_set_entry_t {
|
|
nhdp_addr_entry_t *address_list_head; /**< Pointer to head of this tuple's addresses */
|
|
timex_t heard_time; /**< Time at which entry leaves heard status */
|
|
timex_t sym_time; /**< Time at which entry leaves symmetry status */
|
|
uint8_t pending; /**< Flag whether link is pending */
|
|
uint8_t lost; /**< Flag whether link is lost */
|
|
timex_t exp_time; /**< Time at which entry expires */
|
|
nib_entry_t *nb_elt; /**< Pointer to corresponding nb tuple */
|
|
enum iib_link_tuple_status_t last_status; /**< Last processed status of link tuple */
|
|
struct iib_link_set_entry_t *next; /**< Pointer to next list entry */
|
|
} iib_link_set_entry_t;
|
|
|
|
/**
|
|
* @brief 2-Hop Set entry (2-Hop tuple)
|
|
*/
|
|
typedef struct iib_two_hop_set_entry_t {
|
|
struct iib_link_set_entry_t *ls_elt; /**< Pointer to corresponding link tuple */
|
|
nhdp_addr_t *th_nb_addr; /**< Address of symmetric 2-hop neighbor */
|
|
timex_t exp_time; /**< Time at which entry expires */
|
|
struct iib_two_hop_set_entry_t *next; /**< Pointer to next list entry */
|
|
} iib_two_hop_set_entry_t;
|
|
|
|
/**
|
|
* @brief Link set for a registered interface
|
|
*/
|
|
typedef struct iib_base_entry_t {
|
|
kernel_pid_t if_pid; /**< PID of the interface */
|
|
struct iib_link_set_entry_t *link_set_head; /**< Pointer to this if's link tuples */
|
|
struct iib_two_hop_set_entry_t *two_hop_set_head; /**< Pointer to this if's 2-hop tuples */
|
|
struct iib_base_entry_t *next; /**< Pointer to next list entry */
|
|
} iib_base_entry_t;
|
|
|
|
/**
|
|
* @brief Register a new interface in the IIB
|
|
*
|
|
* This function creates a new empty Link Set and a new empty 2-Hop Set for the
|
|
* given interface.
|
|
*
|
|
* @param[in] pid PID of the interface
|
|
*
|
|
* @return 0 on success
|
|
* @return -1 on error
|
|
*/
|
|
int iib_register_if(kernel_pid_t pid);
|
|
|
|
/**
|
|
* @brief Process a received HELLO message in the IIB
|
|
*
|
|
* @note
|
|
* Must not be called from outside the NHDP reader's message processing.
|
|
*
|
|
* @param[in] if_pid PID of the interface the message was received on
|
|
* @param[in] nb_elt Pointer to the Neighbor Tuple for the message originator
|
|
* @param[in] send_list Pointer to the Sending Address List from the received HELLO
|
|
* @param[in] th_sym_list Pointer to the Addr List of the originator's symmetric 2-Hop neighbors
|
|
* @param[in] th_rem_list Pointer to the Addr List of the originator's lost 2-Hop neighbors
|
|
* @param[in] rem_list Pointer to the Removed Address List
|
|
* @param[in] validity_time Validity time in milliseconds for the originator's information
|
|
* @param[in] is_sym_nb Flag whether the link to the originator is symmetric
|
|
* @param[in] is_lost Flag whether the originator marked this link as lost
|
|
*
|
|
* @return 0 on success
|
|
*/
|
|
int iib_process_hello(kernel_pid_t if_pid, nib_entry_t *nb_elt, nhdp_addr_entry_t *send_list,
|
|
nhdp_addr_entry_t *th_sym_list, nhdp_addr_entry_t *th_rem_list,
|
|
nhdp_addr_entry_t *rem_list, uint64_t validity_time, uint8_t is_sym_nb,
|
|
uint8_t is_lost);
|
|
|
|
/**
|
|
* @brief Add addresses to the currently constructed HELLO message
|
|
*
|
|
* @note
|
|
* Must not be called from outside the NHDP writer's message creation process.
|
|
*
|
|
* @param[in] if_pid PID of the interface the message is constructed for
|
|
* @param[in] wr The NHDP writer used for message construction
|
|
*/
|
|
void iib_fill_wr_addresses(kernel_pid_t if_pid, struct rfc5444_writer *wr);
|
|
|
|
/**
|
|
* @brief Update L_STATUS of all existing Link Tuples
|
|
*
|
|
* @note
|
|
* If a status change appears the steps described in section 13 of RFC 6130 are executed.
|
|
*
|
|
* @param[in] now Pointer to current time timex representation
|
|
*/
|
|
void iib_update_lt_status(timex_t *now);
|
|
|
|
/**
|
|
* @brief Exchange the corresponding Neighbor Tuple of existing Link Tuples
|
|
*
|
|
* This function exchanges the corresponding Neighbor Tuple of every Link Tuple that
|
|
* was assigned to old_entry. Primarily used on Neighbor Tuple deletion of old_entry.
|
|
*
|
|
* @param[in] old_entry Pointer to the old corresponding Neighbor Tuple
|
|
* @param[in] new_entry Pointer to the new corresponding Neighbor Tuple
|
|
*/
|
|
void iib_propagate_nb_entry_change(nib_entry_t *old_entry, nib_entry_t *new_entry);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* IIB_TABLE_H_ */
|
|
/** @} */
|