Commit 649087fa authored by Marton Balint's avatar Marton Balint

avdevice/decklink_dec: unref packets on avpacket_queue_put error

Signed-off-by: 's avatarMarton Balint <cus@passwd.hu>
parent 75d1529c
...@@ -475,16 +475,19 @@ static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt) ...@@ -475,16 +475,19 @@ static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt)
// Drop Packet if queue size is > maximum queue size // Drop Packet if queue size is > maximum queue size
if (avpacket_queue_size(q) > (uint64_t)q->max_q_size) { if (avpacket_queue_size(q) > (uint64_t)q->max_q_size) {
av_packet_unref(pkt);
av_log(q->avctx, AV_LOG_WARNING, "Decklink input buffer overrun!\n"); av_log(q->avctx, AV_LOG_WARNING, "Decklink input buffer overrun!\n");
return -1; return -1;
} }
/* ensure the packet is reference counted */ /* ensure the packet is reference counted */
if (av_packet_make_refcounted(pkt) < 0) { if (av_packet_make_refcounted(pkt) < 0) {
av_packet_unref(pkt);
return -1; return -1;
} }
pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList)); pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList));
if (!pkt1) { if (!pkt1) {
av_packet_unref(pkt);
return -1; return -1;
} }
av_packet_move_ref(&pkt1->pkt, pkt); av_packet_move_ref(&pkt1->pkt, pkt);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment