1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "media/base/audio_decoder_config.h"
#include "base/logging.h"
#include "base/metrics/histogram.h"
#include "media/audio/sample_rates.h"
#include "media/base/limits.h"
namespace media {
AudioDecoderConfig::AudioDecoderConfig()
: codec_(kUnknownAudioCodec),
bits_per_channel_(0),
channel_layout_(CHANNEL_LAYOUT_UNSUPPORTED),
samples_per_second_(0),
extra_data_size_(0) {
}
AudioDecoderConfig::AudioDecoderConfig(AudioCodec codec,
int bits_per_channel,
ChannelLayout channel_layout,
int samples_per_second,
const uint8* extra_data,
size_t extra_data_size) {
Initialize(codec, bits_per_channel, channel_layout, samples_per_second,
extra_data, extra_data_size, true);
}
void AudioDecoderConfig::Initialize(AudioCodec codec,
int bits_per_channel,
ChannelLayout channel_layout,
int samples_per_second,
const uint8* extra_data,
size_t extra_data_size,
bool record_stats) {
CHECK((extra_data_size != 0) == (extra_data != NULL));
if (record_stats) {
UMA_HISTOGRAM_ENUMERATION("Media.AudioCodec", codec, kAudioCodecMax + 1);
// Fake enum histogram to get exact integral buckets. Expect to never see
// any values over 32 and even that is huge.
UMA_HISTOGRAM_ENUMERATION("Media.AudioBitsPerChannel", bits_per_channel,
40);
UMA_HISTOGRAM_ENUMERATION("Media.AudioChannelLayout", channel_layout,
CHANNEL_LAYOUT_MAX);
AudioSampleRate asr = media::AsAudioSampleRate(samples_per_second);
if (asr != kUnexpectedAudioSampleRate) {
UMA_HISTOGRAM_ENUMERATION("Media.AudioSamplesPerSecond", asr,
kUnexpectedAudioSampleRate);
} else {
UMA_HISTOGRAM_COUNTS(
"Media.AudioSamplesPerSecondUnexpected", samples_per_second);
}
}
codec_ = codec;
bits_per_channel_ = bits_per_channel;
channel_layout_ = channel_layout;
samples_per_second_ = samples_per_second;
extra_data_size_ = extra_data_size;
if (extra_data_size_ > 0) {
extra_data_.reset(new uint8[extra_data_size_]);
memcpy(extra_data_.get(), extra_data, extra_data_size_);
} else {
extra_data_.reset();
}
}
AudioDecoderConfig::~AudioDecoderConfig() {}
bool AudioDecoderConfig::IsValidConfig() const {
return codec_ != kUnknownAudioCodec &&
channel_layout_ != CHANNEL_LAYOUT_UNSUPPORTED &&
bits_per_channel_ > 0 &&
bits_per_channel_ <= limits::kMaxBitsPerSample &&
samples_per_second_ > 0 &&
samples_per_second_ <= limits::kMaxSampleRate;
}
void AudioDecoderConfig::CopyFrom(const AudioDecoderConfig& audio_config) {
Initialize(audio_config.codec(),
audio_config.bits_per_channel(),
audio_config.channel_layout(),
audio_config.samples_per_second(),
audio_config.extra_data(),
audio_config.extra_data_size(),
false);
}
AudioCodec AudioDecoderConfig::codec() const {
return codec_;
}
int AudioDecoderConfig::bits_per_channel() const {
return bits_per_channel_;
}
ChannelLayout AudioDecoderConfig::channel_layout() const {
return channel_layout_;
}
int AudioDecoderConfig::samples_per_second() const {
return samples_per_second_;
}
uint8* AudioDecoderConfig::extra_data() const {
return extra_data_.get();
}
size_t AudioDecoderConfig::extra_data_size() const {
return extra_data_size_;
}
} // namespace media
|