1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/net/ng_pkt.h

119 lines
4.4 KiB
C
Raw Normal View History

2015-01-22 15:30:27 +01:00
/*
* Copyright (C) 2014, 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-02-13 12:27:34 +01:00
* @defgroup net_ng_pkt Packet
2015-01-22 15:30:27 +01:00
* @brief Network packet abstraction types
* @ingroup net
* @{
*
* @file
* @brief General definitions for network packets
*
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
*/
#ifndef NG_PKT_H_
#define NG_PKT_H_
#include <inttypes.h>
#include <stdlib.h>
#include "net/ng_nettype.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Type to represent snips (or parts,
* snip == (packet header || packet payload)) of a network packet
* @details The idea behind the packet snips is that they either can represent
* protocol-specific headers or payload. A packet can be comprised of
2015-02-13 12:27:34 +01:00
* @f$ n @f$ pktsnip_t elements, where the first element represents the
* header of the lowest available network layer and the @f$ (n - 1) @f$-st
2015-01-22 15:30:27 +01:00
* element represents the payload of the highest available layer.
* Use @ref sys_ut to operate on this.
*
* Example:
*
* buffer
* +---------------------------+ +------+
* | size = 14 | data +-------------->| |
2015-02-13 12:27:34 +01:00
* | type = NETTYPE_ETHERNET |------+ +------+
2015-01-22 15:30:27 +01:00
* +---------------------------+ +----------->| |
* | next | | |
* v | | |
* +---------------------------+ | +------+
* | size = 40 | data | +-------->| |
2015-02-13 12:27:34 +01:00
* | type = NETTYPE_IPV6 |---------+ | +------+
2015-01-22 15:30:27 +01:00
* +---------------------------+ | +----->| |
* | next | | +------+
* v | | +-->| |
* +---------------------------+ | | | | |
* | size = 8 | data | | | . .
2015-02-13 12:27:34 +01:00
* | type = NETTYPE_UDP |------------+ | | . .
2015-01-22 15:30:27 +01:00
* +---------------------------+ | |
* | next | |
* v | |
* +---------------------------+ | |
* | size = 5 | data | |
2015-02-13 12:27:34 +01:00
* | type = NETTYPE_COAP |---------------+ |
2015-01-22 15:30:27 +01:00
* +---------------------------+ |
* | next |
* v |
* +---------------------------+ |
* | size = 54 | data |
2015-02-13 12:27:34 +01:00
* | type = NETTYPE_UNKNOWN |------------------+
2015-01-22 15:30:27 +01:00
* +---------------------------+
*
*
* @note This type implements its own list implementation because of the way
* it is stored in the packet buffer.
2014-12-11 10:58:56 +01:00
* @note This type has no initializer on purpose. Please use @ref net_ng_pktbuf
2015-01-22 15:30:27 +01:00
* as factory.
*/
2015-02-13 12:27:34 +01:00
/* packed to be aligned correctly in the static packet buffer */
typedef struct __attribute__((packed)) ng_pktsnip {
2014-12-11 10:58:56 +01:00
/**
* @brief Counter of threads currently having control over this packet.
*
* @internal
*/
unsigned int users;
2015-01-22 15:30:27 +01:00
struct ng_pktsnip *next; /**< next snip in the packet */
void *data; /**< pointer to the data of the snip */
size_t size; /**< the length of the snip in byte */
ng_nettype_t type; /**< protocol of the packet snip */
} ng_pktsnip_t;
/**
* @brief Calculates length of a packet in byte.
*
* @param[in] pkt list of packet snips.
*
* @return length of the list of headers.
*/
static inline size_t ng_pkt_len(ng_pktsnip_t *pkt)
{
size_t len = 0;
while (pkt) {
len += pkt->size;
pkt = pkt->next;
}
return len;
}
#ifdef __cplusplus
}
#endif
#endif /* NG_PKT_H_ */
/** @} */