mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-17 04:52:59 +01:00
Merge pull request #20984 from benpicco/gnrc_pktsnip_t-shrink
sys/net/gnrc/pkt: use `uint8_t` for user count
This commit is contained in:
commit
aee4c1ef9c
@ -110,17 +110,18 @@ typedef struct gnrc_pktsnip {
|
|||||||
struct gnrc_pktsnip *next; /**< next snip in the packet */
|
struct gnrc_pktsnip *next; /**< next snip in the packet */
|
||||||
void *data; /**< pointer to the data of the snip */
|
void *data; /**< pointer to the data of the snip */
|
||||||
size_t size; /**< the length of the snip in byte */
|
size_t size; /**< the length of the snip in byte */
|
||||||
|
/* end of iolist_t */
|
||||||
|
#ifdef MODULE_GNRC_NETERR
|
||||||
|
kernel_pid_t err_sub; /**< subscriber to errors related to this
|
||||||
|
* packet snip */
|
||||||
|
#endif
|
||||||
|
gnrc_nettype_t type; /**< protocol of the packet snip */
|
||||||
/**
|
/**
|
||||||
* @brief Counter of threads currently having control over this packet.
|
* @brief Counter of threads currently having control over this packet.
|
||||||
*
|
*
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
unsigned int users;
|
uint8_t users;
|
||||||
gnrc_nettype_t type; /**< protocol of the packet snip */
|
|
||||||
#ifdef MODULE_GNRC_NETERR
|
|
||||||
kernel_pid_t err_sub; /**< subscriber to errors related to this
|
|
||||||
* packet snip */
|
|
||||||
#endif
|
|
||||||
} gnrc_pktsnip_t;
|
} gnrc_pktsnip_t;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -92,6 +92,7 @@ int gnrc_netapi_dispatch(gnrc_nettype_t type, uint32_t demux_ctx,
|
|||||||
if (numof != 0) {
|
if (numof != 0) {
|
||||||
gnrc_netreg_entry_t *sendto = gnrc_netreg_lookup(type, demux_ctx);
|
gnrc_netreg_entry_t *sendto = gnrc_netreg_lookup(type, demux_ctx);
|
||||||
|
|
||||||
|
/* the packet is replicated over all interfaces that is's being sent on */
|
||||||
gnrc_pktbuf_hold(pkt, numof - 1);
|
gnrc_pktbuf_hold(pkt, numof - 1);
|
||||||
|
|
||||||
while (sendto) {
|
while (sendto) {
|
||||||
|
@ -576,7 +576,7 @@ static void _send_multicast(gnrc_pktsnip_t *pkt, bool prep_hdr,
|
|||||||
if (!gnrc_netif_highlander()) {
|
if (!gnrc_netif_highlander()) {
|
||||||
/* interface not given: send over all interfaces */
|
/* interface not given: send over all interfaces */
|
||||||
if (netif == NULL) {
|
if (netif == NULL) {
|
||||||
/* send packet to link layer */
|
/* the packet is replicated over all interfaces that is's being sent on */
|
||||||
gnrc_pktbuf_hold(pkt, ifnum - 1);
|
gnrc_pktbuf_hold(pkt, ifnum - 1);
|
||||||
|
|
||||||
while ((netif = gnrc_netif_iter(netif))) {
|
while ((netif = gnrc_netif_iter(netif))) {
|
||||||
|
@ -210,6 +210,7 @@ void gnrc_pktbuf_hold(gnrc_pktsnip_t *pkt, unsigned int num)
|
|||||||
{
|
{
|
||||||
mutex_lock(&gnrc_pktbuf_mutex);
|
mutex_lock(&gnrc_pktbuf_mutex);
|
||||||
while (pkt) {
|
while (pkt) {
|
||||||
|
assert(pkt->users + num <= 0xff);
|
||||||
pkt->users += num;
|
pkt->users += num;
|
||||||
pkt = pkt->next;
|
pkt = pkt->next;
|
||||||
}
|
}
|
||||||
|
@ -213,6 +213,7 @@ void gnrc_pktbuf_hold(gnrc_pktsnip_t *pkt, unsigned int num)
|
|||||||
{
|
{
|
||||||
mutex_lock(&gnrc_pktbuf_mutex);
|
mutex_lock(&gnrc_pktbuf_mutex);
|
||||||
while (pkt) {
|
while (pkt) {
|
||||||
|
assert(pkt->users + num <= 0xff);
|
||||||
pkt->users += num;
|
pkt->users += num;
|
||||||
pkt = pkt->next;
|
pkt = pkt->next;
|
||||||
}
|
}
|
||||||
|
@ -325,7 +325,10 @@ static void test_pktbuf_mark__pkt_NOT_NULL__size_greater_than_pkt_size(void)
|
|||||||
|
|
||||||
static void test_pktbuf_mark__pkt_NOT_NULL__pkt_data_NULL(void)
|
static void test_pktbuf_mark__pkt_NOT_NULL__pkt_data_NULL(void)
|
||||||
{
|
{
|
||||||
gnrc_pktsnip_t pkt = { NULL, NULL, sizeof(TEST_STRING16), 1, GNRC_NETTYPE_TEST };
|
gnrc_pktsnip_t pkt = { .size = sizeof(TEST_STRING16),
|
||||||
|
.type = GNRC_NETTYPE_TEST,
|
||||||
|
.users = 1,
|
||||||
|
};
|
||||||
|
|
||||||
TEST_ASSERT_NULL(gnrc_pktbuf_mark(&pkt, sizeof(TEST_STRING16) - 1,
|
TEST_ASSERT_NULL(gnrc_pktbuf_mark(&pkt, sizeof(TEST_STRING16) - 1,
|
||||||
GNRC_NETTYPE_TEST));
|
GNRC_NETTYPE_TEST));
|
||||||
|
@ -21,8 +21,8 @@
|
|||||||
#include "unittests-constants.h"
|
#include "unittests-constants.h"
|
||||||
#include "tests-pktqueue.h"
|
#include "tests-pktqueue.h"
|
||||||
|
|
||||||
#define PKT_INIT_ELEM(len, data, next) \
|
#define PKT_INIT_ELEM(len, ptr, nxt) \
|
||||||
{ (next), (void *)(data), (len), 1, GNRC_NETTYPE_UNDEF }
|
{ .next = (nxt), .data = (void *)(ptr), .size = (len), .users = 1, .type = GNRC_NETTYPE_UNDEF }
|
||||||
#define PKT_INIT_ELEM_STATIC_DATA(data, next) PKT_INIT_ELEM(sizeof(data), (void *)(data), (next))
|
#define PKT_INIT_ELEM_STATIC_DATA(data, next) PKT_INIT_ELEM(sizeof(data), (void *)(data), (next))
|
||||||
#define PKTQUEUE_INIT_ELEM(pkt) { NULL, pkt }
|
#define PKTQUEUE_INIT_ELEM(pkt) { NULL, pkt }
|
||||||
|
|
||||||
|
@ -22,8 +22,8 @@
|
|||||||
#include "unittests-constants.h"
|
#include "unittests-constants.h"
|
||||||
#include "tests-priority_pktqueue.h"
|
#include "tests-priority_pktqueue.h"
|
||||||
|
|
||||||
#define PKT_INIT_ELEM(len, data, next) \
|
#define PKT_INIT_ELEM(len, ptr, nxt) \
|
||||||
{ (next), (void *)(data), (len), 1, GNRC_NETTYPE_UNDEF }
|
{ .next = (nxt), .data = (void *)(ptr), .size = (len), .users = 1, .type = GNRC_NETTYPE_UNDEF }
|
||||||
#define PKT_INIT_ELEM_STATIC_DATA(data, next) PKT_INIT_ELEM(sizeof(data), (void *)(data), (next))
|
#define PKT_INIT_ELEM_STATIC_DATA(data, next) PKT_INIT_ELEM(sizeof(data), (void *)(data), (next))
|
||||||
#define PKTQUEUE_INIT_ELEM(pkt) { NULL, pkt }
|
#define PKTQUEUE_INIT_ELEM(pkt) { NULL, pkt }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user