mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
8c3dc66ad8
The name `fragment_msg` or `frag_msg`/`msg_frag` always to me was a bit misplaced, as it basically implements an asynchronous fragmentation buffer and doesn't necessarily have anything to do with messages. This change 1. changes the name to `fb` (for fragmentation buffer) 2. factors its code out to its own sub-module so it can be re-used by other 6LoWPAN fragmentation schemes like [Selective Fragment Recovery] [Selective Fragment Recovery]: https://tools.ietf.org/html/draft-ietf-6lo-fragment-recovery-05
116 lines
2.9 KiB
C
116 lines
2.9 KiB
C
/*
|
|
* Copyright (C) 2019 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.
|
|
*/
|
|
|
|
/**
|
|
* @defgroup net_gnrc_sixlowpan_frag_fb 6LoWPAN fragmentation buffer
|
|
* @ingroup net_gnrc_sixlowpan_frag
|
|
* @brief Buffer for asynchronous 6LoWPAN fragmentation
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Fragmentation buffer definitions
|
|
*
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
*/
|
|
#ifndef NET_GNRC_SIXLOWPAN_FRAG_FB_H
|
|
#define NET_GNRC_SIXLOWPAN_FRAG_FB_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
|
|
#include "msg.h"
|
|
#include "net/gnrc/pkt.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Message type for passing one 6LoWPAN fragment down the network stack
|
|
*/
|
|
#define GNRC_SIXLOWPAN_FRAG_FB_SND_MSG (0x0225)
|
|
|
|
/**
|
|
* @brief 6LoWPAN fragmentation buffer entry.
|
|
*/
|
|
typedef struct {
|
|
gnrc_pktsnip_t *pkt; /**< Pointer to the IPv6 packet to be fragmented */
|
|
uint16_t datagram_size; /**< Length of just the (uncompressed) IPv6 packet to be fragmented */
|
|
uint16_t tag; /**< Tag used for the fragment */
|
|
uint16_t offset; /**< Offset of the Nth fragment from the beginning of the
|
|
* payload datagram */
|
|
#ifdef MODULE_GNRC_SIXLOWPAN_FRAG_HINT
|
|
/**
|
|
* @brief Hint for the size (smaller than link-layer PDU) for the next
|
|
* fragment to sent
|
|
*/
|
|
gnrc_sixlowpan_frag_hint_t hint;
|
|
#endif /* MODULE_GNRC_SIXLOWPAN_FRAG_HINT */
|
|
} gnrc_sixlowpan_frag_fb_t;
|
|
|
|
#ifdef TEST_SUITES
|
|
/**
|
|
* @brief Reset fragmentation buffer
|
|
*
|
|
* @note Only available with test
|
|
*/
|
|
void gnrc_sixlowpan_frag_fb_reset(void);
|
|
#endif
|
|
|
|
/**
|
|
* @brief Allocates a fragmentation buffer entry
|
|
*
|
|
* @return A fragmentation buffer entry if available
|
|
* @return NULL, otherwise
|
|
*/
|
|
gnrc_sixlowpan_frag_fb_t *gnrc_sixlowpan_frag_fb_get(void);
|
|
|
|
/**
|
|
* @brief Generate a new datagram tag for sending
|
|
*
|
|
* @return A new datagram tag.
|
|
*/
|
|
uint16_t gnrc_sixlowpan_frag_fb_next_tag(void);
|
|
|
|
#if defined(TEST_SUITES) && !defined(DOXYGEN)
|
|
#include "kernel_types.h"
|
|
|
|
/* can't include `net/sixlowpan.h` as this would create a cyclical include */
|
|
extern kernel_pid_t gnrc_sixlowpan_get_pid(void);
|
|
#endif
|
|
|
|
/**
|
|
* @brief Sends a message to pass a further fragment down the network stack
|
|
*
|
|
* @see GNRC_SIXLOWPAN_MSG_FRAG_SND
|
|
*
|
|
* @param[in] fbuf A fragmentation buffer entry
|
|
*]
|
|
* @return true, when the message was sent
|
|
* @return false when sending the message failed.
|
|
*/
|
|
static inline bool gnrc_sixlowpan_frag_fb_send(gnrc_sixlowpan_frag_fb_t *fbuf)
|
|
{
|
|
msg_t msg;
|
|
|
|
msg.content.ptr = fbuf;
|
|
msg.type = GNRC_SIXLOWPAN_FRAG_FB_SND_MSG;
|
|
#ifdef TEST_SUITES
|
|
return (msg_try_send(&msg, gnrc_sixlowpan_get_pid()) > 0);
|
|
#else
|
|
return (msg_send_to_self(&msg) != 0);
|
|
#endif
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NET_GNRC_SIXLOWPAN_FRAG_FB_H */
|
|
/** @} */
|