Index: media/base/audio_decoder_config.cc |
diff --git a/media/base/audio_decoder_config.cc b/media/base/audio_decoder_config.cc |
index 38db05d3a54e1a7106da2d49a74b7085bdd5a05e..dfaf94a2682aef4d534a441a2740fda829724845 100644 |
--- a/media/base/audio_decoder_config.cc |
+++ b/media/base/audio_decoder_config.cc |
@@ -6,6 +6,7 @@ |
#include "base/logging.h" |
#include "base/metrics/histogram.h" |
+#include "base/time/time.h" |
#include "media/audio/sample_rates.h" |
#include "media/base/limits.h" |
#include "media/base/sample_format.h" |
@@ -30,7 +31,8 @@ AudioDecoderConfig::AudioDecoderConfig(AudioCodec codec, |
size_t extra_data_size, |
bool is_encrypted) { |
Initialize(codec, sample_format, channel_layout, samples_per_second, |
- extra_data, extra_data_size, is_encrypted, true); |
+ extra_data, extra_data_size, is_encrypted, true, |
+ base::TimeDelta(), base::TimeDelta()); |
} |
void AudioDecoderConfig::Initialize(AudioCodec codec, |
@@ -40,7 +42,9 @@ void AudioDecoderConfig::Initialize(AudioCodec codec, |
const uint8* extra_data, |
size_t extra_data_size, |
bool is_encrypted, |
- bool record_stats) { |
+ bool record_stats, |
+ base::TimeDelta seek_preroll, |
+ base::TimeDelta codec_delay) { |
CHECK((extra_data_size != 0) == (extra_data != NULL)); |
if (record_stats) { |
@@ -66,6 +70,8 @@ void AudioDecoderConfig::Initialize(AudioCodec codec, |
bytes_per_channel_ = SampleFormatToBytesPerChannel(sample_format); |
extra_data_.assign(extra_data, extra_data + extra_data_size); |
is_encrypted_ = is_encrypted; |
+ seek_preroll_ = seek_preroll; |
+ codec_delay_ = codec_delay; |
int channels = ChannelLayoutToChannelCount(channel_layout_); |
bytes_per_frame_ = channels * bytes_per_channel_; |
@@ -80,7 +86,9 @@ bool AudioDecoderConfig::IsValidConfig() const { |
bytes_per_channel_ <= limits::kMaxBytesPerSample && |
samples_per_second_ > 0 && |
samples_per_second_ <= limits::kMaxSampleRate && |
- sample_format_ != kUnknownSampleFormat; |
+ sample_format_ != kUnknownSampleFormat && |
+ seek_preroll_ >= base::TimeDelta() && |
+ codec_delay_ >= base::TimeDelta(); |
} |
bool AudioDecoderConfig::Matches(const AudioDecoderConfig& config) const { |
@@ -92,7 +100,9 @@ bool AudioDecoderConfig::Matches(const AudioDecoderConfig& config) const { |
(!extra_data() || !memcmp(extra_data(), config.extra_data(), |
extra_data_size())) && |
(is_encrypted() == config.is_encrypted()) && |
- (sample_format() == config.sample_format())); |
+ (sample_format() == config.sample_format()) && |
+ (seek_preroll() == config.seek_preroll()) && |
+ (codec_delay() == config.codec_delay())); |
} |
} // namespace media |