mirror of https://git.ffmpeg.org/ffmpeg.git
Add missing checks in avfilter_default_get_video_buffer().
Originally committed as revision 24809 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
4f9ce3c4c7
commit
65d4cab562
|
@ -35,9 +35,12 @@ static void avfilter_default_free_buffer(AVFilterBuffer *ptr)
|
|||
AVFilterBufferRef *avfilter_default_get_video_buffer(AVFilterLink *link, int perms, int w, int h)
|
||||
{
|
||||
AVFilterBuffer *pic = av_mallocz(sizeof(AVFilterBuffer));
|
||||
AVFilterBufferRef *ref = av_mallocz(sizeof(AVFilterBufferRef));
|
||||
AVFilterBufferRef *ref = NULL;
|
||||
int i, tempsize;
|
||||
char *buf;
|
||||
char *buf = NULL;
|
||||
|
||||
if (!pic || !(ref = av_mallocz(sizeof(AVFilterBufferRef))))
|
||||
goto fail;
|
||||
|
||||
ref->buf = pic;
|
||||
ref->video = av_mallocz(sizeof(AVFilterBufferRefVideoProps));
|
||||
|
@ -58,12 +61,22 @@ AVFilterBufferRef *avfilter_default_get_video_buffer(AVFilterLink *link, int per
|
|||
tempsize = av_fill_image_pointers(pic->data, ref->format, ref->video->h, NULL, pic->linesize);
|
||||
buf = av_malloc(tempsize + 16); // +2 is needed for swscaler, +16 to be
|
||||
// SIMD-friendly
|
||||
if (!buf)
|
||||
goto fail;
|
||||
av_fill_image_pointers(pic->data, ref->format, ref->video->h, buf, pic->linesize);
|
||||
|
||||
memcpy(ref->data, pic->data, sizeof(ref->data));
|
||||
memcpy(ref->linesize, pic->linesize, sizeof(ref->linesize));
|
||||
|
||||
return ref;
|
||||
|
||||
fail:
|
||||
av_free(buf);
|
||||
if (ref && ref->video)
|
||||
av_free(ref->video);
|
||||
av_free(ref);
|
||||
av_free(pic);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void avfilter_default_start_frame(AVFilterLink *link, AVFilterBufferRef *picref)
|
||||
|
|
Loading…
Reference in New Issue