2014-09-05 18:21:58 +02:00
|
|
|
/*
|
2015-01-30 15:41:14 +01:00
|
|
|
* Copyright (C) 2014, 2015 Martine Lenders <mlenders@inf.fu-berlin.de>
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
|
|
|
* 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_pktqueue Packet Queue
|
2014-10-13 19:30:12 +02:00
|
|
|
* @brief Packet wrapper for the Priority Queue
|
2014-10-11 08:20:50 +02:00
|
|
|
* @ingroup net
|
2014-09-05 18:21:58 +02:00
|
|
|
* @{
|
|
|
|
*
|
2015-01-30 15:41:14 +01:00
|
|
|
* @file
|
2015-08-17 15:41:29 +02:00
|
|
|
* @brief gnrc_pktsnip_t-centric wrapper for @ref priority_queue_t
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
|
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_PKTQUEUE_H_
|
|
|
|
#define GNRC_PKTQUEUE_H_
|
2014-09-05 18:21:58 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#include "net/gnrc/pkt.h"
|
2015-06-22 17:55:07 +02:00
|
|
|
#include "utlist.h"
|
2014-09-05 18:21:58 +02:00
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-09-05 18:21:58 +02:00
|
|
|
/**
|
|
|
|
* @brief data type for packet queue nodes
|
|
|
|
*
|
|
|
|
* @extends priority_queue_node_t
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
typedef struct gnrc_pktqueue {
|
|
|
|
struct gnrc_pktqueue *next; /**< next node in queue */
|
|
|
|
gnrc_pktsnip_t *pkt; /**< pointer to the packet */
|
|
|
|
} gnrc_pktqueue_t;
|
2014-09-05 18:21:58 +02:00
|
|
|
|
|
|
|
/**
|
2015-06-22 17:55:07 +02:00
|
|
|
* @brief add @p node into @p queue based on its priority
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
2015-06-22 17:55:07 +02:00
|
|
|
* @details The new node will be appended after objects with the same
|
|
|
|
* priority.
|
|
|
|
*
|
|
|
|
* @param[in,out] queue the queue, may not be NULL
|
|
|
|
* @param[in] node the node to add.
|
2014-09-05 18:21:58 +02:00
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
static inline void gnrc_pktqueue_add(gnrc_pktqueue_t **queue, gnrc_pktqueue_t *node)
|
2014-09-05 18:21:58 +02:00
|
|
|
{
|
2015-06-22 17:55:07 +02:00
|
|
|
LL_APPEND(*queue, node);
|
2014-09-05 18:21:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-22 17:55:07 +02:00
|
|
|
* @brief remove @p node from @p queue
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
2015-06-22 17:55:07 +02:00
|
|
|
* @param[in] queue the queue, may not be NULL
|
|
|
|
* @param[in] node the node to remove
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
2015-06-22 17:55:07 +02:00
|
|
|
* @return @p node.
|
2014-09-05 18:21:58 +02:00
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
static inline gnrc_pktqueue_t *gnrc_pktqueue_remove(gnrc_pktqueue_t **queue, gnrc_pktqueue_t *node)
|
2014-09-05 18:21:58 +02:00
|
|
|
{
|
2015-06-22 17:55:07 +02:00
|
|
|
if (node) {
|
|
|
|
LL_DELETE(*queue, node);
|
|
|
|
node->next = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return node;
|
2014-09-05 18:21:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief remove the packet queue's head
|
|
|
|
*
|
2015-06-22 17:55:07 +02:00
|
|
|
* @param[in] queue the queue, may not be NULL
|
2014-09-05 18:21:58 +02:00
|
|
|
*
|
|
|
|
* @return the old head
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
static inline gnrc_pktqueue_t *gnrc_pktqueue_remove_head(gnrc_pktqueue_t **queue)
|
2014-09-05 18:21:58 +02:00
|
|
|
{
|
2015-08-17 15:41:29 +02:00
|
|
|
return gnrc_pktqueue_remove(queue, *queue);
|
2014-09-05 18:21:58 +02:00
|
|
|
}
|
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#endif /* GNRC_PKTQUEUE_H_ */
|
2014-09-05 18:21:58 +02:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|