summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--DEPS2
-rw-r--r--media/ffmpeg/ffmpeg_common.h6
-rw-r--r--media/filters/audio_file_reader.cc24
-rw-r--r--media/filters/audio_file_reader.h1
-rw-r--r--media/filters/audio_file_reader_unittest.cc4
5 files changed, 28 insertions, 9 deletions
diff --git a/DEPS b/DEPS
index 349958a..d538181 100644
--- a/DEPS
+++ b/DEPS
@@ -215,7 +215,7 @@ deps = {
"src/third_party/ffmpeg":
Var("chromium_git") +
- "/chromium/third_party/ffmpeg.git@5c3de8094903dd2162232b8f1be916c46acdd8f5",
+ "/chromium/third_party/ffmpeg.git@f620cda6d1661f1b2f3214d17b9a254f5c89225f",
"src/third_party/libjingle/source/talk":
(Var("googlecode_url") % "webrtc") + "/trunk/talk@" +
diff --git a/media/ffmpeg/ffmpeg_common.h b/media/ffmpeg/ffmpeg_common.h
index ef1a7b6..d4e85c8 100644
--- a/media/ffmpeg/ffmpeg_common.h
+++ b/media/ffmpeg/ffmpeg_common.h
@@ -33,11 +33,11 @@ MSVC_PUSH_DISABLE_WARNING(4244);
#include <libavcodec/avcodec.h>
#include <libavformat/avformat.h>
#include <libavformat/avio.h>
-#include <libavutil/audioconvert.h>
#include <libavutil/avutil.h>
-#include <libavutil/mathematics.h>
-#include <libavutil/log.h>
#include <libavutil/imgutils.h>
+#include <libavutil/log.h>
+#include <libavutil/mathematics.h>
+#include <libavutil/opt.h>
MSVC_POP_WARNING();
} // extern "C"
diff --git a/media/filters/audio_file_reader.cc b/media/filters/audio_file_reader.cc
index cb8188e..3b14355 100644
--- a/media/filters/audio_file_reader.cc
+++ b/media/filters/audio_file_reader.cc
@@ -20,6 +20,7 @@ AudioFileReader::AudioFileReader(FFmpegURLProtocol* protocol)
protocol_(protocol),
channels_(0),
sample_rate_(0),
+ end_padding_(0),
av_sample_format_(0) {
}
@@ -59,9 +60,20 @@ bool AudioFileReader::OpenDemuxer() {
return false;
const int result = avformat_find_stream_info(format_context, NULL);
- DLOG_IF(WARNING, result < 0)
- << "AudioFileReader::Open() : error in avformat_find_stream_info()";
- return result >= 0;
+ if (result < 0) {
+ DLOG(WARNING)
+ << "AudioFileReader::Open() : error in avformat_find_stream_info()";
+ return false;
+ }
+
+ // Attempt to extract end padding for mp3 files.
+ if (strcmp(format_context->iformat->name, "mp3") == 0 &&
+ (av_opt_get_int(format_context->priv_data, "end_pad", 0, &end_padding_) <
+ 0 ||
+ end_padding_ < 0)) {
+ end_padding_ = 0;
+ }
+ return true;
}
bool AudioFileReader::OpenDecoder() {
@@ -221,6 +233,12 @@ int AudioFileReader::Read(AudioBus* audio_bus) {
av_free_packet(&packet);
}
+ // If decoding completed successfully try to strip end padding.
+ if (continue_decoding && end_padding_ <= current_frame) {
+ DCHECK_GE(end_padding_, 0);
+ current_frame -= end_padding_;
+ }
+
// Zero any remaining frames.
audio_bus->ZeroFramesPartial(
current_frame, audio_bus->frames() - current_frame);
diff --git a/media/filters/audio_file_reader.h b/media/filters/audio_file_reader.h
index c700b32..963baa7 100644
--- a/media/filters/audio_file_reader.h
+++ b/media/filters/audio_file_reader.h
@@ -87,6 +87,7 @@ class MEDIA_EXPORT AudioFileReader {
FFmpegURLProtocol* protocol_;
int channels_;
int sample_rate_;
+ int64_t end_padding_;
// AVSampleFormat initially requested; not Chrome's SampleFormat.
int av_sample_format_;
diff --git a/media/filters/audio_file_reader_unittest.cc b/media/filters/audio_file_reader_unittest.cc
index 4ce2ab6..ba264d6 100644
--- a/media/filters/audio_file_reader_unittest.cc
+++ b/media/filters/audio_file_reader_unittest.cc
@@ -195,12 +195,12 @@ TEST_F(AudioFileReaderTest, WaveF32LE) {
#if defined(USE_PROPRIETARY_CODECS)
TEST_F(AudioFileReaderTest, MP3) {
RunTest("sfx.mp3",
- "3.05,2.87,3.00,3.32,3.58,4.08,",
+ "5.59,7.11,6.63,6.23,5.58,5.22,",
1,
44100,
base::TimeDelta::FromMicroseconds(313470),
13825,
- 12719);
+ 10496);
}
TEST_F(AudioFileReaderTest, CorruptMP3) {