summaryrefslogtreecommitdiff
path: root/libavcodec/avpacket.c
diff options
context:
space:
mode:
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>2010-11-21 10:21:06 +0000
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>2010-11-21 10:21:06 +0000
commita08d918e680266f66f85ddaf232946f7147b74a8 (patch)
treef427f57cfd5f17122ba3a9cf71a27d19cea1887c /libavcodec/avpacket.c
parent1a68e7ed15b351fdb273906643224d2cf8142114 (diff)
Add a av_grow_packet function, to be used by code that merges
palette and video data packets to get rid of PaletteControl. Originally committed as revision 25776 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/avpacket.c')
-rw-r--r--libavcodec/avpacket.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/libavcodec/avpacket.c b/libavcodec/avpacket.c
index c51260face..82890c3676 100644
--- a/libavcodec/avpacket.c
+++ b/libavcodec/avpacket.c
@@ -20,6 +20,7 @@
*/
#include "avcodec.h"
+#include "libavutil/avassert.h"
void av_destruct_packet_nofree(AVPacket *pkt)
@@ -71,6 +72,23 @@ void av_shrink_packet(AVPacket *pkt, int size)
memset(pkt->data + size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
}
+int av_grow_packet(AVPacket *pkt, int grow_by)
+{
+ void *new_ptr;
+ av_assert0((unsigned)pkt->size <= INT_MAX - FF_INPUT_BUFFER_PADDING_SIZE);
+ if (!pkt->size)
+ return av_new_packet(pkt, grow_by);
+ if ((unsigned)grow_by > INT_MAX - (pkt->size + FF_INPUT_BUFFER_PADDING_SIZE))
+ return -1;
+ new_ptr = av_realloc(pkt->data, pkt->size + grow_by + FF_INPUT_BUFFER_PADDING_SIZE);
+ if (!new_ptr)
+ return AVERROR(ENOMEM);
+ pkt->data = new_ptr;
+ pkt->size += grow_by;
+ memset(pkt->data + pkt->size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
+ return 0;
+}
+
int av_dup_packet(AVPacket *pkt)
{
if (((pkt->destruct == av_destruct_packet_nofree) || (pkt->destruct == NULL)) && pkt->data) {