Commit f4168a07 authored by michael's avatar michael

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.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@20801 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 8547ed9a
...@@ -47,18 +47,20 @@ void av_init_packet(AVPacket *pkt) ...@@ -47,18 +47,20 @@ void av_init_packet(AVPacket *pkt)
int av_new_packet(AVPacket *pkt, int size) int av_new_packet(AVPacket *pkt, int size)
{ {
uint8_t *data; uint8_t *data= NULL;
if((unsigned)size > (unsigned)size + FF_INPUT_BUFFER_PADDING_SIZE) if((unsigned)size < (unsigned)size + FF_INPUT_BUFFER_PADDING_SIZE)
return AVERROR(ENOMEM);
data = av_malloc(size + FF_INPUT_BUFFER_PADDING_SIZE); data = av_malloc(size + FF_INPUT_BUFFER_PADDING_SIZE);
if (!data) if (data){
return AVERROR(ENOMEM);
memset(data + size, 0, FF_INPUT_BUFFER_PADDING_SIZE); memset(data + size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
}else
size=0;
av_init_packet(pkt); av_init_packet(pkt);
pkt->data = data; pkt->data = data;
pkt->size = size; pkt->size = size;
pkt->destruct = av_destruct_packet; pkt->destruct = av_destruct_packet;
if(!data)
return AVERROR(ENOMEM);
return 0; return 0;
} }
......
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