From 7ed8078bdbee11620e042aefccb08e7bbcb15804 Mon Sep 17 00:00:00 2001 From: Pirmin Walthert Date: Tue, 14 Apr 2020 17:48:07 +0200 Subject: [PATCH] res_rtp_asterisk: Resolve loop when receive buffer is flushed When the receive buffer was flushed by a received packet while it already contained a packet with the same sequence number, Asterisk never left the while loop which tried to order the packets. This change makes it so if the packet is in the receive buffer it is retrieved and freed allowing the buffer to empty. ASTERISK-28827 Change-Id: Idaa376101bc1ac880047c49feb6faee773e718b3 --- res/res_rtp_asterisk.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/res/res_rtp_asterisk.c b/res/res_rtp_asterisk.c index 5dd5d355f1..75be5610f0 100644 --- a/res/res_rtp_asterisk.c +++ b/res/res_rtp_asterisk.c @@ -7835,6 +7835,14 @@ static struct ast_frame *ast_rtp_read(struct ast_rtp_instance *instance, int rtc ast_debug(2, "Inserted just received packet with sequence number '%d' in correct order on RTP instance '%p'\n", seqno, instance); } + /* It is possible due to packet retransmission for this packet to also exist in the receive + * buffer so we explicitly remove it in case this occurs, otherwise the receive buffer will + * never be empty. + */ + payload = (struct ast_rtp_rtcp_nack_payload *)ast_data_buffer_remove(rtp->recv_buffer, seqno); + if (payload) { + ast_free(payload); + } rtp->expectedrxseqno++; if (rtp->expectedrxseqno == SEQNO_CYCLE_OVER) { rtp->expectedrxseqno = 0; -- 2.47.2