diff options
author | wm4 <nfxjfg@googlemail.com> | 2014-09-21 12:51:41 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-09-21 14:57:12 +0200 |
commit | 6c7f1155bb648eced8e5aa08b1fd490df2f8b325 (patch) | |
tree | 607abb626c790b71c3a55e0597fe501b21499240 /libavformat/mp3dec.c | |
parent | 36bf549b2706bd10014556a84a33ed6daf5d5373 (diff) | |
download | ffmpeg-6c7f1155bb648eced8e5aa08b1fd490df2f8b325.tar.gz |
avformat/mp3dec: avoid early EOF with concatenated gapless mp3s
Consider a file created with something like:
cat file1.mp3 file2.mp3 > result.mp3
Then if file2.mp3 has gapless information, result.mp3 would stop playing
something in the middle. This happens because the gapless info directs
the decoder to discard all samples after a certain position. To make
matters worse, the gapless info of file2.mp3 will be used when playing
the file1.mp3 part, because the gapless info is located at the end of
the file.
While handling concatenated gapless files correctly would be insane and
a lot of effort (especially without scanning the whole file on opening),
it's easy to prevent at least early EOF. Playback will happen to work,
even if it's slightly broken.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/mp3dec.c')
-rw-r--r-- | libavformat/mp3dec.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libavformat/mp3dec.c b/libavformat/mp3dec.c index 639c78d405..8745f209d3 100644 --- a/libavformat/mp3dec.c +++ b/libavformat/mp3dec.c @@ -219,8 +219,10 @@ static void mp3_parse_info_tag(AVFormatContext *s, AVStream *st, mp3->start_pad = v>>12; mp3-> end_pad = v&4095; st->skip_samples = mp3->start_pad + 528 + 1; - if (mp3->frames) - st->end_discard_sample = -mp3->end_pad + 528 + 1 + mp3->frames * (int64_t)spf; + if (mp3->frames) { + st->first_discard_sample = -mp3->end_pad + 528 + 1 + mp3->frames * (int64_t)spf; + st->last_discard_sample = mp3->frames * (int64_t)spf; + } if (!st->start_time) st->start_time = av_rescale_q(st->skip_samples, (AVRational){1, c->sample_rate}, |