]> granicus.if.org Git - libx264/commitdiff
Fix memory leak in lavf demuxer.
authorSteven Walters <kemuri9@gmail.com>
Sun, 9 Jan 2011 21:01:04 +0000 (16:01 -0500)
committerFiona Glaser <fiona@x264.com>
Mon, 10 Jan 2011 04:10:37 +0000 (20:10 -0800)
Leak only occurred with input files that have more than one video stream.

input/lavf.c

index 56bfa29ca3d0d80a6543a713307fa60df725f20c..45faec4b97d58e9b0fdc6ca92219389b3f116fba 100644 (file)
@@ -39,6 +39,12 @@ typedef struct
     cli_pic_t *first_pic;
 } lavf_hnd_t;
 
+#define x264_free_packet( pkt )\
+{\
+    av_free_packet( pkt );\
+    av_init_packet( pkt );\
+}
+
 static int read_frame_internal( cli_pic_t *p_pic, lavf_hnd_t *h, int i_frame, video_info_t *info )
 {
     if( h->first_pic && !info )
@@ -81,6 +87,9 @@ static int read_frame_internal( cli_pic_t *p_pic, lavf_hnd_t *h, int i_frame, vi
                 if( avcodec_decode_video2( c, &frame, &finished, pkt ) < 0 )
                     x264_cli_log( "lavf", X264_LOG_WARNING, "video decoding failed on frame %d\n", h->next_frame );
             }
+            /* if the packet successfully decoded but the data from it is not desired, free it */
+            else if( ret >= 0 )
+                x264_free_packet( pkt );
         } while( !finished && ret >= 0 );
 
         if( !finished )
@@ -203,8 +212,7 @@ static int read_frame( cli_pic_t *pic, hnd_t handle, int i_frame )
 
 static int release_frame( cli_pic_t *pic, hnd_t handle )
 {
-    av_free_packet( pic->opaque );
-    av_init_packet( pic->opaque );
+    x264_free_packet( pic->opaque );
     return 0;
 }