Fix a memory leak in CvCapture_FFMPEG::close
FFmpeg now requires that frames allocated with avcodec_alloc_frame are freed with avcodec_free_frame. (cherry picked from commit 77578d415f4d2b22a4ee1989ef0afda73c9d649b)
This commit is contained in:
parent
3f3ca85103
commit
c259590b26
@ -292,7 +292,15 @@ void CvCapture_FFMPEG::close()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( picture )
|
if( picture )
|
||||||
|
{
|
||||||
|
// FFmpeg and Libav added avcodec_free_frame in different versions.
|
||||||
|
#if LIBAVCODEC_BUILD >= (LIBAVCODEC_VERSION_MICRO >= 100 \
|
||||||
|
? CALC_FFMPEG_VERSION(54, 59, 100) : CALC_FFMPEG_VERSION(54, 28, 0))
|
||||||
|
avcodec_free_frame(&picture);
|
||||||
|
#else
|
||||||
av_free(picture);
|
av_free(picture);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
if( video_st )
|
if( video_st )
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user