aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2009-12-11 21:49:30 +0000
committerMichael Niedermayer <michaelni@gmx.at>2009-12-11 21:49:30 +0000
commita0b468f5db92daf1854c49d920169ed39e9cfb1b (patch)
treec00848c82b6780ddcf51dc095f591f8b0fddebe8
parent15a316c0146106ac627fa67ddaa639f75a4eccce (diff)
downloadffmpeg-a0b468f5db92daf1854c49d920169ed39e9cfb1b.tar.gz
Make sure av_new_packet() initializes the data and destruct pointers.
Some code does call av_free_packet() on failed av_new_packets(), this prevents the freeing of uninitialized pointers. Originally committed as revision 20801 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavcodec/avpacket.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/libavcodec/avpacket.c b/libavcodec/avpacket.c
index 5bea639d66..5a80325388 100644
--- a/libavcodec/avpacket.c
+++ b/libavcodec/avpacket.c
@@ -47,18 +47,20 @@ void av_init_packet(AVPacket *pkt)
int av_new_packet(AVPacket *pkt, int size)
{
- uint8_t *data;
- if((unsigned)size > (unsigned)size + FF_INPUT_BUFFER_PADDING_SIZE)
- return AVERROR(ENOMEM);
+ uint8_t *data= NULL;
+ if((unsigned)size < (unsigned)size + FF_INPUT_BUFFER_PADDING_SIZE)
data = av_malloc(size + FF_INPUT_BUFFER_PADDING_SIZE);
- if (!data)
- return AVERROR(ENOMEM);
+ if (data){
memset(data + size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
+ }else
+ size=0;
av_init_packet(pkt);
pkt->data = data;
pkt->size = size;
pkt->destruct = av_destruct_packet;
+ if(!data)
+ return AVERROR(ENOMEM);
return 0;
}