/* * Copyright (C) 2015 Martine Lenders * * 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 net_gnrc_sixlowpan_frag * @{ * * @file * @internal * @brief 6LoWPAN reassembly buffer * * @author Martine Lenders */ #ifndef RBUF_H #define RBUF_H #include #include "net/gnrc/netif/hdr.h" #include "net/gnrc/pkt.h" #include "net/gnrc/sixlowpan/frag.h" #ifdef __cplusplus extern "C" { #endif #define RBUF_SIZE (4U) /**< size of the reassembly buffer */ #define RBUF_TIMEOUT (3U * US_PER_SEC) /**< timeout for reassembly in microseconds */ /** * @brief Fragment intervals to identify limits of fragments. * * @note Fragments MUST NOT overlap and overlapping fragments are to be * discarded * * @see * RFC 4944, section 5.3 * * * @internal */ typedef struct rbuf_int { struct rbuf_int *next; /**< next element in interval list */ uint16_t start; /**< start byte of interval */ uint16_t end; /**< end byte of interval */ } rbuf_int_t; /** * @brief Internal representation of the 6LoWPAN reassembly buffer. * * Additional members help with correct reassembly of the buffer. * * @internal * * @extends gnrc_sixlowpan_rbuf_t */ typedef struct { gnrc_sixlowpan_rbuf_t super; /**< exposed part of the reassembly buffer */ rbuf_int_t *ints; /**< intervals of the fragment */ uint32_t arrival; /**< time in microseconds of arrival of * last received fragment */ uint16_t cur_size; /**< the datagram's current size */ } rbuf_t; /** * @brief Adds a new fragment to the reassembly buffer. If the packet is * complete, dispatch the packet with the transmit information of * the last fragment. * * @param[in] netif_hdr The interface header of the fragment, with * gnrc_netif_hdr_t::if_pid and its source and * destination address set. * @param[in] frag The fragment to add. * @param[in] frag_size The fragment's size. * @param[in] offset The fragment's offset. * * @internal */ void rbuf_add(gnrc_netif_hdr_t *netif_hdr, gnrc_pktsnip_t *frag, size_t frag_size, size_t offset); /** * @brief Checks timeouts and removes entries if necessary */ void rbuf_gc(void); #ifdef __cplusplus } #endif #endif /* RBUF_H */ /** @} */