Browse Source

free Track and unset priv_data to avoid double free, fix memleak

Originally committed as revision 18836 to svn://svn.ffmpeg.org/ffmpeg/trunk
tags/v0.6
Baptiste Coudurier 16 years ago
parent
commit
8be080aebb
1 changed files with 4 additions and 3 deletions
  1. +4
    -3
      libavformat/mxfdec.c

+ 4
- 3
libavformat/mxfdec.c View File

@@ -943,6 +943,10 @@ static int mxf_read_close(AVFormatContext *s)
int i;

av_freep(&mxf->packages_refs);

for (i = 0; i < s->nb_streams; i++)
s->streams[i]->priv_data = NULL;

for (i = 0; i < mxf->metadata_sets_count; i++) {
switch (mxf->metadata_sets[i]->type) {
case MultipleDescriptor:
@@ -955,9 +959,6 @@ static int mxf_read_close(AVFormatContext *s)
case MaterialPackage:
av_freep(&((MXFPackage *)mxf->metadata_sets[i])->tracks_refs);
break;
case Track:
mxf->metadata_sets[i] = NULL; /* will be freed later */
break;
default:
break;
}


Loading…
Cancel
Save