[FFmpeg-cvslog] r22468 - trunk/libavformat/bink.c
pross
subversion
Thu Mar 11 13:29:02 CET 2010
Author: pross
Date: Thu Mar 11 13:29:02 2010
New Revision: 22468
Log:
Prevent memory leak introduced in r22389 in Bink demuxer: pass partial packets to decoder.
Modified:
trunk/libavformat/bink.c
Modified: trunk/libavformat/bink.c
==============================================================================
--- trunk/libavformat/bink.c Thu Mar 11 12:25:51 2010 (r22467)
+++ trunk/libavformat/bink.c Thu Mar 11 13:29:02 2010 (r22468)
@@ -212,15 +212,16 @@ static int read_packet(AVFormatContext *
bink->current_track++;
if (audio_size >= 4) {
/* get one audio packet per track */
- if ((ret = av_get_packet(pb, pkt, audio_size)) != audio_size)
- return ret < 0 ? ret : AVERROR(EIO);;
+ if ((ret = av_get_packet(pb, pkt, audio_size)) < 0)
+ return ret;
pkt->stream_index = bink->current_track;
pkt->pts = bink->audio_pts[bink->current_track - 1];
/* Each audio packet reports the number of decompressed samples
(in bytes). We use this value to calcuate the audio PTS */
- bink->audio_pts[bink->current_track -1] +=
- AV_RL32(pkt->data) / (2 * s->streams[bink->current_track]->codec->channels);
+ if (pkt->size >= 4)
+ bink->audio_pts[bink->current_track -1] +=
+ AV_RL32(pkt->data) / (2 * s->streams[bink->current_track]->codec->channels);
return 0;
} else {
url_fseek(pb, audio_size, SEEK_CUR);
@@ -228,9 +229,8 @@ static int read_packet(AVFormatContext *
}
/* get video packet */
- if ((ret = av_get_packet(pb, pkt, bink->remain_packet_size))
- != bink->remain_packet_size)
- return ret < 0 ? ret : AVERROR(EIO);
+ if ((ret = av_get_packet(pb, pkt, bink->remain_packet_size)) < 0)
+ return ret;
pkt->stream_index = 0;
pkt->pts = bink->video_pts++;
pkt->flags |= PKT_FLAG_KEY;
More information about the ffmpeg-cvslog
mailing list