Commit 1149d734 authored by michael's avatar michael

Fix memleak of header in error returns.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16831 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 5f03ddcb
...@@ -121,8 +121,10 @@ static int fourxm_read_header(AVFormatContext *s, ...@@ -121,8 +121,10 @@ static int fourxm_read_header(AVFormatContext *s,
header = av_malloc(header_size); header = av_malloc(header_size);
if (!header) if (!header)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
if (get_buffer(pb, header, header_size) != header_size) if (get_buffer(pb, header, header_size) != header_size){
av_free(header);
return AVERROR(EIO); return AVERROR(EIO);
}
/* take the lazy approach and search for any and all vtrk and strk chunks */ /* take the lazy approach and search for any and all vtrk and strk chunks */
for (i = 0; i < header_size - 8; i++) { for (i = 0; i < header_size - 8; i++) {
...@@ -142,8 +144,10 @@ static int fourxm_read_header(AVFormatContext *s, ...@@ -142,8 +144,10 @@ static int fourxm_read_header(AVFormatContext *s,
/* allocate a new AVStream */ /* allocate a new AVStream */
st = av_new_stream(s, 0); st = av_new_stream(s, 0);
if (!st) if (!st){
av_free(header);
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
}
av_set_pts_info(st, 60, 1, fourxm->fps); av_set_pts_info(st, 60, 1, fourxm->fps);
fourxm->video_stream_index = st->index; fourxm->video_stream_index = st->index;
...@@ -166,8 +170,10 @@ static int fourxm_read_header(AVFormatContext *s, ...@@ -166,8 +170,10 @@ static int fourxm_read_header(AVFormatContext *s,
current_track = AV_RL32(&header[i + 8]); current_track = AV_RL32(&header[i + 8]);
if (current_track + 1 > fourxm->track_count) { if (current_track + 1 > fourxm->track_count) {
fourxm->track_count = current_track + 1; fourxm->track_count = current_track + 1;
if((unsigned)fourxm->track_count >= UINT_MAX / sizeof(AudioTrack)) if((unsigned)fourxm->track_count >= UINT_MAX / sizeof(AudioTrack)){
av_free(header);
return -1; return -1;
}
fourxm->tracks = av_realloc(fourxm->tracks, fourxm->tracks = av_realloc(fourxm->tracks,
fourxm->track_count * sizeof(AudioTrack)); fourxm->track_count * sizeof(AudioTrack));
if (!fourxm->tracks) { if (!fourxm->tracks) {
...@@ -183,8 +189,10 @@ static int fourxm_read_header(AVFormatContext *s, ...@@ -183,8 +189,10 @@ static int fourxm_read_header(AVFormatContext *s,
/* allocate a new AVStream */ /* allocate a new AVStream */
st = av_new_stream(s, current_track); st = av_new_stream(s, current_track);
if (!st) if (!st){
av_free(header);
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
}
av_set_pts_info(st, 60, 1, fourxm->tracks[current_track].sample_rate); av_set_pts_info(st, 60, 1, fourxm->tracks[current_track].sample_rate);
......
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