From 2ed3990cc97ddeff4d421320c50000ecde14982f Mon Sep 17 00:00:00 2001 From: Green Sky Date: Tue, 17 Sep 2024 15:46:33 +0200 Subject: [PATCH] fix: toxav rtp temp buffer allocation size was too large and cast from 32bit to 16bit, causing a overflow and making the allocated size too small --- toxav/rtp.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/toxav/rtp.c b/toxav/rtp.c index 8ad4ce670e9..49c91a02ce9 100644 --- a/toxav/rtp.c +++ b/toxav/rtp.c @@ -805,7 +805,7 @@ int rtp_send_data(RTPSession *session, const uint8_t *data, uint32_t length, header.flags |= RTP_KEY_FRAME; } - const uint16_t rdata_size = length + RTP_HEADER_SIZE + 1; + const uint16_t rdata_size = min_u32(length + RTP_HEADER_SIZE + 1, MAX_CRYPTO_DATA_SIZE); VLA(uint8_t, rdata, rdata_size); memset(rdata, 0, rdata_size); rdata[0] = session->payload_type; // packet id == payload_type