diff mbox

[FFmpeg-devel,2/2] avdevice/decklink_dec: unref packets on avpacket_queue_put error

Message ID 20180422211822.12870-2-cus@passwd.hu
State Accepted
Commit 649087fa83a50e04a4ddd7f2f5f740a18ac28902
Headers show

Commit Message

Marton Balint April 22, 2018, 9:18 p.m. UTC
Signed-off-by: Marton Balint <cus@passwd.hu>
---
 libavdevice/decklink_dec.cpp | 3 +++
 1 file changed, 3 insertions(+)

Comments

James Almer April 30, 2018, 9:54 p.m. UTC | #1
On 4/22/2018 6:18 PM, Marton Balint wrote:
> Signed-off-by: Marton Balint <cus@passwd.hu>
> ---
>  libavdevice/decklink_dec.cpp | 3 +++
>  1 file changed, 3 insertions(+)
> 
> diff --git a/libavdevice/decklink_dec.cpp b/libavdevice/decklink_dec.cpp
> index 10535dc388..510637676c 100644
> --- a/libavdevice/decklink_dec.cpp
> +++ b/libavdevice/decklink_dec.cpp
> @@ -475,16 +475,19 @@ static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt)
>  
>      // Drop Packet if queue size is > maximum queue 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");
>          return -1;
>      }
>      /* ensure the packet is reference counted */
>      if (av_packet_make_refcounted(pkt) < 0) {
> +        av_packet_unref(pkt);
>          return -1;
>      }
>  
>      pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList));
>      if (!pkt1) {
> +        av_packet_unref(pkt);
>          return -1;
>      }
>      av_packet_move_ref(&pkt1->pkt, pkt);

This should be backported. Strictly speaking the last unref(), since pkt
will always be reference counted at this point even before patch 1/2 of
this series because of the make_refcounted() call above.
Marton Balint May 1, 2018, 7:53 p.m. UTC | #2
On Mon, 30 Apr 2018, James Almer wrote:

> On 4/22/2018 6:18 PM, Marton Balint wrote:
>> Signed-off-by: Marton Balint <cus@passwd.hu>
>> ---
>>  libavdevice/decklink_dec.cpp | 3 +++
>>  1 file changed, 3 insertions(+)
>> 
>> diff --git a/libavdevice/decklink_dec.cpp b/libavdevice/decklink_dec.cpp
>> index 10535dc388..510637676c 100644
>> --- a/libavdevice/decklink_dec.cpp
>> +++ b/libavdevice/decklink_dec.cpp
>> @@ -475,16 +475,19 @@ static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt)
>>
>>      // Drop Packet if queue size is > maximum queue 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");
>>          return -1;
>>      }
>>      /* ensure the packet is reference counted */
>>      if (av_packet_make_refcounted(pkt) < 0) {
>> +        av_packet_unref(pkt);
>>          return -1;
>>      }
>>
>>      pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList));
>>      if (!pkt1) {
>> +        av_packet_unref(pkt);
>>          return -1;
>>      }
>>      av_packet_move_ref(&pkt1->pkt, pkt);
>
> This should be backported. Strictly speaking the last unref(), since pkt
> will always be reference counted at this point even before patch 1/2 of
> this series because of the make_refcounted() call above.

Indeed, backported.

Thanks,
Marton
diff mbox

Patch

diff --git a/libavdevice/decklink_dec.cpp b/libavdevice/decklink_dec.cpp
index 10535dc388..510637676c 100644
--- a/libavdevice/decklink_dec.cpp
+++ b/libavdevice/decklink_dec.cpp
@@ -475,16 +475,19 @@  static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt)
 
     // Drop Packet if queue size is > maximum queue 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");
         return -1;
     }
     /* ensure the packet is reference counted */
     if (av_packet_make_refcounted(pkt) < 0) {
+        av_packet_unref(pkt);
         return -1;
     }
 
     pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList));
     if (!pkt1) {
+        av_packet_unref(pkt);
         return -1;
     }
     av_packet_move_ref(&pkt1->pkt, pkt);