summaryrefslogtreecommitdiff
path: root/libavdevice
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2017-10-02 13:08:39 -0300
committerJames Almer <jamrial@gmail.com>2017-10-02 15:12:01 -0300
commite91f0c4f8b3e81bc63838cc67370a7b13c8d9e78 (patch)
tree7c4e30073a9dd4c75166342ef09a0d31a2a6b511 /libavdevice
parent0c1ffd0aa55c6cef6dffe2b736786c6cb86d8a3d (diff)
avdevice/decklink_dec: remove av_dup_packet() usage
Reviewed-by: Marton Balint <cus@passwd.hu> Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavdevice')
-rw-r--r--libavdevice/decklink_dec.cpp14
1 files changed, 8 insertions, 6 deletions
diff --git a/libavdevice/decklink_dec.cpp b/libavdevice/decklink_dec.cpp
index 9d12d0fed0..53ff576ec5 100644
--- a/libavdevice/decklink_dec.cpp
+++ b/libavdevice/decklink_dec.cpp
@@ -450,22 +450,24 @@ static unsigned long long avpacket_queue_size(AVPacketQueue *q)
static int avpacket_queue_put(AVPacketQueue *q, AVPacket *pkt)
{
AVPacketList *pkt1;
+ int ret;
// Drop Packet if queue size is > maximum queue size
if (avpacket_queue_size(q) > (uint64_t)q->max_q_size) {
av_log(q->avctx, AV_LOG_WARNING, "Decklink input buffer overrun!\n");
return -1;
}
- /* duplicate the packet */
- if (av_dup_packet(pkt) < 0) {
- return -1;
- }
- pkt1 = (AVPacketList *)av_malloc(sizeof(AVPacketList));
+ pkt1 = (AVPacketList *)av_mallocz(sizeof(AVPacketList));
if (!pkt1) {
return -1;
}
- pkt1->pkt = *pkt;
+ ret = av_packet_ref(&pkt1->pkt, pkt);
+ av_packet_unref(pkt);
+ if (ret < 0) {
+ av_free(pkt1);
+ return -1;
+ }
pkt1->next = NULL;
pthread_mutex_lock(&q->mutex);