2015-04-10 12:02:55 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Martine Lenders <mlenders@inf.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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-08-17 15:41:29 +02:00
|
|
|
* @defgroup net_gnrc_sixlowpan_ctx Contexts for 6LoWPAN address compression
|
|
|
|
* @ingroup net_gnrc_sixlowpan
|
2015-04-10 12:02:55 +02:00
|
|
|
* @brief Context buffer for stateful 6LoWPAN address compression
|
|
|
|
* @see <a href="https://tools.ietf.org/html/rfc6282#section-3.1.2">
|
|
|
|
* RFC 6282, section 3.1.2
|
|
|
|
* </a>
|
|
|
|
* @see <a href="http://tools.ietf.org/html/rfc6775#section-4.2">
|
|
|
|
* RFC 6775, section 4.2
|
|
|
|
* </a>
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Context buffer definitions
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
*/
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef NET_GNRC_SIXLOWPAN_CTX_H
|
|
|
|
#define NET_GNRC_SIXLOWPAN_CTX_H
|
2015-04-10 12:02:55 +02:00
|
|
|
|
|
|
|
#include <inttypes.h>
|
2015-06-02 17:21:36 +02:00
|
|
|
#include <stdbool.h>
|
2015-04-10 12:02:55 +02:00
|
|
|
|
2015-08-10 00:26:36 +02:00
|
|
|
#include "net/ipv6/addr.h"
|
2021-07-22 16:59:08 +02:00
|
|
|
#include "timex.h"
|
2022-11-11 18:47:30 +01:00
|
|
|
#include "modules.h"
|
2015-04-10 12:02:55 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_SIXLOWPAN_CTX_SIZE (16) /**< maximum number of entries in
|
2015-04-10 12:02:55 +02:00
|
|
|
* context buffer */
|
|
|
|
|
2015-06-02 17:21:36 +02:00
|
|
|
/**
|
|
|
|
* @{
|
|
|
|
* @name Context flags.
|
2015-08-17 15:41:29 +02:00
|
|
|
* @brief Flags to set in gnrc_sixlowpan_ctx_t::flags_id.
|
2015-06-02 17:21:36 +02:00
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_SIXLOWPAN_CTX_FLAGS_CID_MASK (0x0f) /**< mask for the Context ID. */
|
|
|
|
#define GNRC_SIXLOWPAN_CTX_FLAGS_COMP (0x10) /**< Use context for compression */
|
2015-06-02 17:21:36 +02:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2015-04-11 08:52:24 +02:00
|
|
|
/**
|
|
|
|
* @brief Entry in the 6LoWPAN context buffer.
|
|
|
|
*/
|
2015-04-10 12:02:55 +02:00
|
|
|
typedef struct {
|
2015-08-10 00:26:36 +02:00
|
|
|
ipv6_addr_t prefix; /**< The prefix associated to this context. */
|
2015-08-17 15:41:29 +02:00
|
|
|
uint8_t prefix_len; /**< Length of gnrc_sixlowpan_ctx_t::prefix in bit. */
|
2015-04-10 12:02:55 +02:00
|
|
|
/**
|
2015-06-02 17:21:36 +02:00
|
|
|
* @brief 4-bit flags, 4-bit Context ID.
|
2015-04-10 12:02:55 +02:00
|
|
|
*
|
|
|
|
* @note This needs to be here to easily translate prefixes to
|
|
|
|
* ID.
|
2015-06-02 17:21:36 +02:00
|
|
|
*
|
|
|
|
* @details The flags are defined as above.
|
2015-04-10 12:02:55 +02:00
|
|
|
*/
|
2015-06-02 17:21:36 +02:00
|
|
|
uint8_t flags_id;
|
2015-04-10 12:02:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Lifetime in minutes this context is valid.
|
|
|
|
*
|
|
|
|
* @see <a href="http://tools.ietf.org/html/rfc6775#section-4.2">
|
|
|
|
* 6LoWPAN Context Option
|
|
|
|
* </a>
|
|
|
|
*/
|
|
|
|
uint16_t ltime;
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_sixlowpan_ctx_t;
|
2015-04-10 12:02:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets a context matching the given IPv6 address best with its prefix.
|
|
|
|
*
|
|
|
|
* @param[in] addr An IPv6 address.
|
|
|
|
*
|
|
|
|
* @return The context associated with the best prefix for @p addr.
|
|
|
|
* @return NULL if there is no such context.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_sixlowpan_ctx_t *gnrc_sixlowpan_ctx_lookup_addr(const ipv6_addr_t *addr);
|
2015-04-10 12:02:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets context by ID.
|
|
|
|
*
|
|
|
|
* @param[in] id A context ID.
|
|
|
|
*
|
|
|
|
* @return The context associated with @p id.
|
|
|
|
* @return NULL if there is no such context.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_sixlowpan_ctx_t *gnrc_sixlowpan_ctx_lookup_id(uint8_t id);
|
2015-04-10 12:02:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Updates (or adds if currently not registered) a context
|
|
|
|
*
|
|
|
|
* @param[in] id The ID for the context.
|
2015-08-17 15:41:29 +02:00
|
|
|
* Must be < @ref GNRC_SIXLOWPAN_CTX_SIZE.
|
2015-04-10 12:02:55 +02:00
|
|
|
* @param[in] prefix The prefix for the context.
|
2015-06-02 17:21:36 +02:00
|
|
|
* @param[in] prefix_len Length of @p prefix in bits. Must be > 0.
|
|
|
|
* @param[in] ltime New lifetime of the context. @p comp will be
|
|
|
|
* implicitly set to `false` if @p ltime == 0.
|
|
|
|
* @param[in] comp Use for compression if true, do not use for
|
|
|
|
* compression, but still for decompression if false.
|
2015-04-10 12:02:55 +02:00
|
|
|
*
|
|
|
|
* @return The new context on success.
|
|
|
|
* @return NULL, on error or on removal.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_sixlowpan_ctx_t *gnrc_sixlowpan_ctx_update(uint8_t id, const ipv6_addr_t *prefix,
|
|
|
|
uint8_t prefix_len, uint16_t ltime,
|
|
|
|
bool comp);
|
2015-04-10 12:02:55 +02:00
|
|
|
|
2015-06-02 17:21:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Removes context.
|
|
|
|
*
|
|
|
|
* @param[in] id A context ID.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
static inline void gnrc_sixlowpan_ctx_remove(uint8_t id)
|
2015-06-02 17:21:36 +02:00
|
|
|
{
|
2021-07-22 16:59:08 +02:00
|
|
|
if (IS_USED(MODULE_GNRC_SIXLOWPAN_CTX)) {
|
|
|
|
gnrc_sixlowpan_ctx_lookup_id(id)->prefix_len = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Check if a prefix matches a compression context
|
|
|
|
*
|
|
|
|
* @param[in] ctx The compression context
|
|
|
|
* @param[in] prefix IPv6 prefix
|
|
|
|
* @param[in] prefix_len Length of the IPv6 prefix
|
|
|
|
*
|
|
|
|
* @return true if the prefix matches the compression context.
|
|
|
|
*/
|
|
|
|
static inline bool gnrc_sixlowpan_ctx_match(const gnrc_sixlowpan_ctx_t *ctx,
|
|
|
|
const ipv6_addr_t *prefix, uint8_t prefix_len)
|
|
|
|
{
|
|
|
|
return (ctx != NULL) &&
|
|
|
|
(ctx->prefix_len == prefix_len) &&
|
|
|
|
(ipv6_addr_match_prefix(&ctx->prefix, prefix) >= prefix_len);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Create or update a compression context
|
|
|
|
*
|
|
|
|
* @param[in] prefix IPv6 prefix of the compression context
|
|
|
|
* @param[in] prefix_len Length of the IPv6 prefix
|
|
|
|
* @param[in] valid Lifetime of the prefix in seconds
|
|
|
|
*
|
|
|
|
* @return true if a new compression context was created or an existing context
|
|
|
|
* was updated.
|
|
|
|
* false if no new context could be added
|
|
|
|
*/
|
|
|
|
static inline bool gnrc_sixlowpan_ctx_update_6ctx(const ipv6_addr_t *prefix, uint8_t prefix_len,
|
|
|
|
uint32_t valid)
|
|
|
|
{
|
|
|
|
if (!IS_USED(MODULE_GNRC_SIXLOWPAN_CTX)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
gnrc_sixlowpan_ctx_t *ctx = gnrc_sixlowpan_ctx_lookup_addr(prefix);
|
|
|
|
uint8_t cid = 0;
|
|
|
|
|
|
|
|
if (!gnrc_sixlowpan_ctx_match(ctx, prefix, prefix_len)) {
|
|
|
|
/* While the context is a prefix match, the defined prefix within the
|
|
|
|
* context does not match => use new context */
|
|
|
|
ctx = NULL;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
cid = ctx->flags_id & GNRC_SIXLOWPAN_CTX_FLAGS_CID_MASK;
|
|
|
|
}
|
|
|
|
/* find first free context ID */
|
|
|
|
if (ctx == NULL) {
|
|
|
|
while (((ctx = gnrc_sixlowpan_ctx_lookup_id(cid)) != NULL) &&
|
|
|
|
!gnrc_sixlowpan_ctx_match(ctx, prefix, prefix_len)) {
|
|
|
|
cid++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (cid < GNRC_SIXLOWPAN_CTX_SIZE) {
|
|
|
|
return gnrc_sixlowpan_ctx_update(cid, (ipv6_addr_t *)prefix, prefix_len,
|
|
|
|
valid / (60 * MS_PER_SEC),
|
|
|
|
true);
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2015-06-02 17:21:36 +02:00
|
|
|
}
|
2015-04-10 12:02:55 +02:00
|
|
|
|
2015-04-11 08:52:24 +02:00
|
|
|
#ifdef TEST_SUITES
|
|
|
|
/**
|
|
|
|
* @brief Resets the whole context buffer.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
void gnrc_sixlowpan_ctx_reset(void);
|
2015-04-11 08:52:24 +02:00
|
|
|
#endif
|
|
|
|
|
2015-04-10 12:02:55 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* NET_GNRC_SIXLOWPAN_CTX_H */
|
2015-04-10 12:02:55 +02:00
|
|
|
/** @} */
|