Security
Headlines
HeadlinesLatestCVEs

Headline

CVE-2023-24819: gnrc_sixlowpan: Various hardening fixes [backport 2022.10] by miri64 · Pull Request #18820 · RIOT-OS/RIOT

RIOT-OS, an operating system that supports Internet of Things devices, contains a network stack with the ability to process 6LoWPAN frames. Prior to version 2022.10, an attacker can send a crafted frame to the device resulting in an out of bounds write in the packet buffer. The overflow can be used to corrupt other packets and the allocator metadata. Corrupting a pointer will easily lead to denial of service. While carefully manipulating the allocator metadata gives an attacker the possibility to write data to arbitrary locations and thus execute arbitrary code. Version 2022.10 fixes this issue. As a workaround, disable support for fragmented IP datagrams or apply the patches manually.

CVE
#dos

@@ -737,6 +737,12 @@ void gnrc_sixlowpan_iphc_recv(gnrc_pktsnip_t *sixlo, void *rbuf_ptr, if (rbuf != NULL) { ipv6 = rbuf->pkt; assert(ipv6 != NULL); if ((ipv6->size < sizeof(ipv6_hdr_t)) && (gnrc_pktbuf_realloc_data(ipv6, sizeof(ipv6_hdr_t)) != 0)) { DEBUG(“6lo iphc: no space to decompress IPHC\n”); _recv_error_release(sixlo, ipv6, rbuf); return; } } else { ipv6 = gnrc_pktbuf_add(NULL, NULL, sizeof(ipv6_hdr_t), @@ -828,7 +834,7 @@ void gnrc_sixlowpan_iphc_recv(gnrc_pktsnip_t *sixlo, void *rbuf_ptr, #endif /* MODULE_GNRC_SIXLOWPAN_FRAG_VRB */ } else { /* for a fragmented datagram we know the overall length already */ /* for a fragmented datagram we know the overall length already */ payload_len = (uint16_t)(rbuf->super.datagram_size - sizeof(ipv6_hdr_t)); } #ifdef MODULE_GNRC_SIXLOWPAN_FRAG_VRB @@ -872,13 +878,23 @@ void gnrc_sixlowpan_iphc_recv(gnrc_pktsnip_t *sixlo, void *rbuf_ptr, payload_len = (sixlo->size + uncomp_hdr_len - payload_offset - sizeof(ipv6_hdr_t)); } if ((rbuf == NULL) && if (rbuf == NULL) { /* (rbuf == NULL) => forwarding is not affected by this */ (gnrc_pktbuf_realloc_data(ipv6, uncomp_hdr_len + payload_len) != 0)) { DEBUG(“6lo iphc: no space left to copy payload\n”); _recv_error_release(sixlo, ipv6, rbuf); return; if (gnrc_pktbuf_realloc_data(ipv6, uncomp_hdr_len + payload_len) != 0) { DEBUG(“6lo iphc: no space left to copy payload\n”); _recv_error_release(sixlo, ipv6, rbuf); return; } } else { if (ipv6->size < (uncomp_hdr_len + (sixlo->size - payload_offset))) { DEBUG(“6lo iphc: not enough space to copy payload.\n”); DEBUG(“6lo iphc: potentially malicious datagram size received.\n”); _recv_error_release(sixlo, ipv6, rbuf); return; } }
/* re-assign IPv6 header in case realloc changed the address */ ipv6_hdr = ipv6->data; ipv6_hdr->len = byteorder_htons(payload_len);

CVE: Latest News

CVE-2023-50976: Transactions API Authorization by oleiman · Pull Request #14969 · redpanda-data/redpanda