1
0
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:
benpicco 2024-11-17 17:29:16 +00:00 committed by GitHub
commit aee4c1ef9c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 19 additions and 12 deletions

View File

@ -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;
/** /**

View File

@ -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) {

View File

@ -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))) {

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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));

View File

@ -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 }

View File

@ -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 }