mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
143 lines
4.7 KiB
C
143 lines
4.7 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 Centralized address storage interface for NHDP
|
|
*
|
|
* @author Fabian Nack <nack@inf.fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef NHDP_ADDRESS_H
|
|
#define NHDP_ADDRESS_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief NHDP address representation
|
|
*/
|
|
typedef struct nhdp_addr {
|
|
uint8_t *addr; /**< Pointer to the address data */
|
|
size_t addr_size; /**< Size in bytes of the address */
|
|
uint8_t addr_type; /**< AF type for the address */
|
|
uint8_t usg_count; /**< Usage count in information bases */
|
|
uint8_t in_tmp_table; /**< Signals usage in a writers temp table */
|
|
uint16_t tmp_metric_val; /**< Encoded metric value used during HELLO processing */
|
|
struct nhdp_addr *next; /**< Pointer to next address (used in central storage) */
|
|
} nhdp_addr_t;
|
|
|
|
/**
|
|
* @brief Container for NHDP address storage in a list
|
|
*/
|
|
typedef struct nhdp_addr_entry {
|
|
struct nhdp_addr *address; /**< Pointer to NHDP address storage entry */
|
|
struct nhdp_addr_entry *next; /**< Pointer to the next address list element */
|
|
} nhdp_addr_entry_t;
|
|
|
|
/**
|
|
* @name NHDP address temp usage helper macros
|
|
*
|
|
* @{
|
|
*/
|
|
#define NHDP_ADDR_TMP_NONE (0x00)
|
|
#define NHDP_ADDR_TMP_ANY (0x01)
|
|
#define NHDP_ADDR_TMP_SYM (0x03)
|
|
#define NHDP_ADDR_TMP_REM_LIST (0x04)
|
|
#define NHDP_ADDR_TMP_TH_REM_LIST (0x08)
|
|
#define NHDP_ADDR_TMP_TH_SYM_LIST (0x10)
|
|
#define NHDP_ADDR_TMP_NB_LIST (0x20)
|
|
#define NHDP_ADDR_TMP_SEND_LIST (0x60)
|
|
|
|
#define NHDP_ADDR_TMP_IN_ANY(addr) ((addr->in_tmp_table & 0x01))
|
|
#define NHDP_ADDR_TMP_IN_SYM(addr) ((addr->in_tmp_table & 0x02) >> 1)
|
|
#define NHDP_ADDR_TMP_IN_REM_LIST(addr) ((addr->in_tmp_table & 0x04) >> 2)
|
|
#define NHDP_ADDR_TMP_IN_TH_REM_LIST(addr) ((addr->in_tmp_table & 0x08) >> 3)
|
|
#define NHDP_ADDR_TMP_IN_TH_SYM_LIST(addr) ((addr->in_tmp_table & 0x10) >> 4)
|
|
#define NHDP_ADDR_TMP_IN_NB_LIST(addr) ((addr->in_tmp_table & 0x20) >> 5)
|
|
#define NHDP_ADDR_TMP_IN_SEND_LIST(addr) ((addr->in_tmp_table & 0x40) >> 6)
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief Get or create a NHDP address for the given address
|
|
*
|
|
* @param[in] addr Pointer to the given address
|
|
* @param[in] addr_size Length in bytes of the given address
|
|
* @param[in] addr_type AF type of the given address
|
|
*
|
|
* @return Pointer to the NHDP address representation of the given address
|
|
* @return NULL on error
|
|
*/
|
|
nhdp_addr_t *nhdp_addr_db_get_address(uint8_t *addr, size_t addr_size, uint8_t addr_type);
|
|
|
|
/**
|
|
* @brief Decrement the usage counter of a given NHDP address
|
|
*
|
|
* The NHDP address is deleted if the usage counter reaches zero.
|
|
*
|
|
* @param[in] addr Pointer to the NHDP address
|
|
*/
|
|
void nhdp_decrement_addr_usage(nhdp_addr_t *addr);
|
|
|
|
/**
|
|
* @brief Free the given address list
|
|
*
|
|
* This function frees every address list entry of the given address list.
|
|
*
|
|
* @param[in] list_head Pointer to the head of the address list to free
|
|
*/
|
|
void nhdp_free_addr_list(nhdp_addr_entry_t *list_head);
|
|
|
|
/**
|
|
* @brief Free the given address list entry
|
|
*
|
|
* Additionally to freeing the address entry, this function takes care that
|
|
* the usage counter of the list entry's address is decremented.
|
|
*
|
|
* @param[in] addr_entry Pointer to the address list entry to free
|
|
*/
|
|
void nhdp_free_addr_entry(nhdp_addr_entry_t *addr_entry);
|
|
|
|
/**
|
|
* @brief Construct an addr list containing all addresses with
|
|
* the given tmp_type
|
|
*
|
|
* @return Pointer to the head of the newly created address list
|
|
* @return NULL on error
|
|
*/
|
|
nhdp_addr_entry_t *nhdp_generate_addr_list_from_tmp(uint8_t tmp_type);
|
|
|
|
/**
|
|
* @brief Reset in_tmp_table flag of all NHDP addresses
|
|
*
|
|
* @note
|
|
* Must not be called from outside the NHDP writer's or reader's message creation process.
|
|
*
|
|
* @param[in] decr_usg Flag whether the usage counter of a resetted addr has to be decremented
|
|
*/
|
|
void nhdp_reset_addresses_tmp_usg(uint8_t decr_usg);
|
|
|
|
/**
|
|
* @brief Get a pointer to the head of the address storage list
|
|
*
|
|
* @return Pointer to the head of the central storage address list
|
|
* @return NULL if no addresses are registered
|
|
*/
|
|
nhdp_addr_t *nhdp_get_addr_db_head(void);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NHDP_ADDRESS_H */
|
|
/** @} */
|