From 8eef1c117086170d7d227c3818ee9f16db0a653e Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Wed, 13 Nov 2024 15:40:36 +0100 Subject: [PATCH] sys/net/gnrc/netif: don't release snip with netdev_new_api --- sys/net/gnrc/netif/gnrc_netif_raw.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/sys/net/gnrc/netif/gnrc_netif_raw.c b/sys/net/gnrc/netif/gnrc_netif_raw.c index 0ba358fd177b..f8a475be0054 100644 --- a/sys/net/gnrc/netif/gnrc_netif_raw.c +++ b/sys/net/gnrc/netif/gnrc_netif_raw.c @@ -104,13 +104,24 @@ static gnrc_pktsnip_t *_recv(gnrc_netif_t *netif) return pkt; } +static gnrc_pktsnip_t *_skip_pkt_head(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt) +{ + if (gnrc_netif_netdev_legacy_api(netif)) { + /* we don't need the netif snip: remove it */ + return gnrc_pktbuf_remove_snip(pkt, pkt); + } + else { + /* _tx_done() will free the entire list */ + return pkt->next; + } +} + static int _send(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt) { int res = -ENOBUFS; if (pkt->type == GNRC_NETTYPE_NETIF) { - /* we don't need the netif snip: remove it */ - pkt = gnrc_pktbuf_remove_snip(pkt, pkt); + pkt = _skip_pkt_head(netif, pkt); } netdev_t *dev = netif->dev;