Adding a payload type to AudioEncoder objects

The type is set in the Config struct and is provided in the EncodedInfo
output struct from each Encode() call. The audio_decoder_unittest is
updated to verify correct propagation of the payload type.

BUG=3926
R=kwiberg@webrtc.org

Review URL: https://webrtc-codereview.appspot.com/27299004

git-svn-id: http://webrtc.googlecode.com/svn/trunk@7780 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
henrik.lundin@webrtc.org 2014-12-02 12:08:39 +00:00
parent 0cd5558f2b
commit 7f1dfa5b61
8 changed files with 37 additions and 3 deletions

View File

@ -24,6 +24,7 @@ class AudioEncoder {
public: public:
struct EncodedInfo { struct EncodedInfo {
uint32_t encoded_timestamp; uint32_t encoded_timestamp;
int payload_type;
}; };
virtual ~AudioEncoder() {} virtual ~AudioEncoder() {}

View File

@ -29,6 +29,7 @@ int16_t NumSamplesPerFrame(int num_channels,
AudioEncoderPcm::AudioEncoderPcm(const Config& config) AudioEncoderPcm::AudioEncoderPcm(const Config& config)
: num_channels_(config.num_channels), : num_channels_(config.num_channels),
payload_type_(config.payload_type),
num_10ms_frames_per_packet_(config.frame_size_ms / 10), num_10ms_frames_per_packet_(config.frame_size_ms / 10),
full_frame_samples_(NumSamplesPerFrame(num_channels_, full_frame_samples_(NumSamplesPerFrame(num_channels_,
config.frame_size_ms, config.frame_size_ms,
@ -73,6 +74,7 @@ bool AudioEncoderPcm::Encode(uint32_t timestamp,
int16_t ret = EncodeCall(&speech_buffer_[0], full_frame_samples_, encoded); int16_t ret = EncodeCall(&speech_buffer_[0], full_frame_samples_, encoded);
speech_buffer_.clear(); speech_buffer_.clear();
info->encoded_timestamp = first_timestamp_in_buffer_; info->encoded_timestamp = first_timestamp_in_buffer_;
info->payload_type = payload_type_;
if (ret < 0) if (ret < 0)
return false; return false;
*encoded_bytes = static_cast<size_t>(ret); *encoded_bytes = static_cast<size_t>(ret);

View File

@ -20,10 +20,14 @@ namespace webrtc {
class AudioEncoderPcm : public AudioEncoder { class AudioEncoderPcm : public AudioEncoder {
public: public:
struct Config { struct Config {
Config() : frame_size_ms(20), num_channels(1) {} public:
int frame_size_ms; int frame_size_ms;
int num_channels; int num_channels;
int payload_type;
protected:
explicit Config(int pt)
: frame_size_ms(20), num_channels(1), payload_type(pt) {}
}; };
explicit AudioEncoderPcm(const Config& config); explicit AudioEncoderPcm(const Config& config);
@ -49,6 +53,7 @@ class AudioEncoderPcm : public AudioEncoder {
private: private:
static const int kSampleRateHz = 8000; static const int kSampleRateHz = 8000;
const int num_channels_; const int num_channels_;
const int payload_type_;
const int num_10ms_frames_per_packet_; const int num_10ms_frames_per_packet_;
const int16_t full_frame_samples_; const int16_t full_frame_samples_;
std::vector<int16_t> speech_buffer_; std::vector<int16_t> speech_buffer_;
@ -57,6 +62,10 @@ class AudioEncoderPcm : public AudioEncoder {
class AudioEncoderPcmA : public AudioEncoderPcm { class AudioEncoderPcmA : public AudioEncoderPcm {
public: public:
struct Config : public AudioEncoderPcm::Config {
Config() : AudioEncoderPcm::Config(8) {}
};
explicit AudioEncoderPcmA(const Config& config) : AudioEncoderPcm(config) {} explicit AudioEncoderPcmA(const Config& config) : AudioEncoderPcm(config) {}
protected: protected:
@ -67,6 +76,10 @@ class AudioEncoderPcmA : public AudioEncoderPcm {
class AudioEncoderPcmU : public AudioEncoderPcm { class AudioEncoderPcmU : public AudioEncoderPcm {
public: public:
struct Config : public AudioEncoderPcm::Config {
Config() : AudioEncoderPcm::Config(0) {}
};
explicit AudioEncoderPcmU(const Config& config) : AudioEncoderPcm(config) {} explicit AudioEncoderPcmU(const Config& config) : AudioEncoderPcm(config) {}
protected: protected:

View File

@ -33,6 +33,7 @@ AudioEncoderG722::EncoderState::~EncoderState() {
AudioEncoderG722::AudioEncoderG722(const Config& config) AudioEncoderG722::AudioEncoderG722(const Config& config)
: num_channels_(config.num_channels), : num_channels_(config.num_channels),
payload_type_(config.payload_type),
num_10ms_frames_per_packet_(config.frame_size_ms / 10), num_10ms_frames_per_packet_(config.frame_size_ms / 10),
num_10ms_frames_buffered_(0), num_10ms_frames_buffered_(0),
first_timestamp_in_buffer_(0), first_timestamp_in_buffer_(0),
@ -113,6 +114,7 @@ bool AudioEncoderG722::Encode(uint32_t timestamp,
} }
*encoded_bytes = samples_per_channel / 2 * num_channels_; *encoded_bytes = samples_per_channel / 2 * num_channels_;
info->encoded_timestamp = first_timestamp_in_buffer_; info->encoded_timestamp = first_timestamp_in_buffer_;
info->payload_type = payload_type_;
return true; return true;
} }

View File

@ -53,6 +53,7 @@ class AudioEncoderG722 : public AudioEncoder {
}; };
const int num_channels_; const int num_channels_;
const int payload_type_;
const int num_10ms_frames_per_packet_; const int num_10ms_frames_per_packet_;
int num_10ms_frames_buffered_; int num_10ms_frames_buffered_;
uint32_t first_timestamp_in_buffer_; uint32_t first_timestamp_in_buffer_;

View File

@ -36,7 +36,9 @@ int16_t CastInt16(size_t x) {
} // namespace } // namespace
AudioEncoderOpus::Config::Config() : frame_size_ms(20), num_channels(1) {} AudioEncoderOpus::Config::Config()
: frame_size_ms(20), num_channels(1), payload_type(120) {
}
bool AudioEncoderOpus::Config::IsOk() const { bool AudioEncoderOpus::Config::IsOk() const {
if (frame_size_ms <= 0 || frame_size_ms % 10 != 0) if (frame_size_ms <= 0 || frame_size_ms % 10 != 0)
@ -49,6 +51,7 @@ bool AudioEncoderOpus::Config::IsOk() const {
AudioEncoderOpus::AudioEncoderOpus(const Config& config) AudioEncoderOpus::AudioEncoderOpus(const Config& config)
: num_10ms_frames_per_packet_(DivExact(config.frame_size_ms, 10)), : num_10ms_frames_per_packet_(DivExact(config.frame_size_ms, 10)),
num_channels_(config.num_channels), num_channels_(config.num_channels),
payload_type_(config.payload_type),
samples_per_10ms_frame_(DivExact(kSampleRateHz, 100) * num_channels_) { samples_per_10ms_frame_(DivExact(kSampleRateHz, 100) * num_channels_) {
CHECK(config.IsOk()); CHECK(config.IsOk());
input_buffer_.reserve(num_10ms_frames_per_packet_ * samples_per_10ms_frame_); input_buffer_.reserve(num_10ms_frames_per_packet_ * samples_per_10ms_frame_);
@ -98,6 +101,7 @@ bool AudioEncoderOpus::Encode(uint32_t timestamp,
return false; return false;
*encoded_bytes = r; *encoded_bytes = r;
info->encoded_timestamp = first_timestamp_in_buffer_; info->encoded_timestamp = first_timestamp_in_buffer_;
info->payload_type = payload_type_;
return true; return true;
} }

View File

@ -25,6 +25,7 @@ class AudioEncoderOpus : public AudioEncoder {
bool IsOk() const; bool IsOk() const;
int frame_size_ms; int frame_size_ms;
int num_channels; int num_channels;
int payload_type;
}; };
explicit AudioEncoderOpus(const Config& config); explicit AudioEncoderOpus(const Config& config);
@ -45,6 +46,7 @@ class AudioEncoderOpus : public AudioEncoder {
private: private:
const int num_10ms_frames_per_packet_; const int num_10ms_frames_per_packet_;
const int num_channels_; const int num_channels_;
const int payload_type_;
const int samples_per_10ms_frame_; const int samples_per_10ms_frame_;
std::vector<int16_t> input_buffer_; std::vector<int16_t> input_buffer_;
OpusEncInst* inst_; OpusEncInst* inst_;

View File

@ -102,6 +102,7 @@ class AudioDecoderTest : public ::testing::Test {
data_length_(0), data_length_(0),
encoded_bytes_(0), encoded_bytes_(0),
channels_(1), channels_(1),
payload_type_(17),
decoder_(NULL) {} decoder_(NULL) {}
virtual ~AudioDecoderTest() {} virtual ~AudioDecoderTest() {}
@ -153,6 +154,7 @@ class AudioDecoderTest : public ::testing::Test {
0, interleaved_input.get(), audio_encoder_->sample_rate_hz() / 100, 0, interleaved_input.get(), audio_encoder_->sample_rate_hz() / 100,
data_length_ * 2, output, &enc_len_bytes, &encoded_info_)); data_length_ * 2, output, &enc_len_bytes, &encoded_info_));
} }
EXPECT_EQ(payload_type_, encoded_info_.payload_type);
return static_cast<int>(enc_len_bytes); return static_cast<int>(enc_len_bytes);
} }
@ -262,6 +264,7 @@ class AudioDecoderTest : public ::testing::Test {
size_t data_length_; size_t data_length_;
size_t encoded_bytes_; size_t encoded_bytes_;
size_t channels_; size_t channels_;
const int payload_type_;
AudioEncoder::EncodedInfo encoded_info_; AudioEncoder::EncodedInfo encoded_info_;
AudioDecoder* decoder_; AudioDecoder* decoder_;
scoped_ptr<AudioEncoder> audio_encoder_; scoped_ptr<AudioEncoder> audio_encoder_;
@ -275,6 +278,7 @@ class AudioDecoderPcmUTest : public AudioDecoderTest {
decoder_ = new AudioDecoderPcmU; decoder_ = new AudioDecoderPcmU;
AudioEncoderPcmU::Config config; AudioEncoderPcmU::Config config;
config.frame_size_ms = static_cast<int>(frame_size_ / 8); config.frame_size_ms = static_cast<int>(frame_size_ / 8);
config.payload_type = payload_type_;
audio_encoder_.reset(new AudioEncoderPcmU(config)); audio_encoder_.reset(new AudioEncoderPcmU(config));
} }
}; };
@ -287,6 +291,7 @@ class AudioDecoderPcmATest : public AudioDecoderTest {
decoder_ = new AudioDecoderPcmA; decoder_ = new AudioDecoderPcmA;
AudioEncoderPcmA::Config config; AudioEncoderPcmA::Config config;
config.frame_size_ms = static_cast<int>(frame_size_ / 8); config.frame_size_ms = static_cast<int>(frame_size_ / 8);
config.payload_type = payload_type_;
audio_encoder_.reset(new AudioEncoderPcmA(config)); audio_encoder_.reset(new AudioEncoderPcmA(config));
} }
}; };
@ -485,6 +490,7 @@ class AudioDecoderG722Test : public AudioDecoderTest {
assert(decoder_); assert(decoder_);
AudioEncoderG722::Config config; AudioEncoderG722::Config config;
config.frame_size_ms = 10; config.frame_size_ms = 10;
config.payload_type = payload_type_;
config.num_channels = 1; config.num_channels = 1;
audio_encoder_.reset(new AudioEncoderG722(config)); audio_encoder_.reset(new AudioEncoderG722(config));
} }
@ -501,6 +507,7 @@ class AudioDecoderG722StereoTest : public AudioDecoderTest {
assert(decoder_); assert(decoder_);
AudioEncoderG722::Config config; AudioEncoderG722::Config config;
config.frame_size_ms = 10; config.frame_size_ms = 10;
config.payload_type = payload_type_;
config.num_channels = 2; config.num_channels = 2;
audio_encoder_.reset(new AudioEncoderG722(config)); audio_encoder_.reset(new AudioEncoderG722(config));
} }
@ -586,6 +593,7 @@ class AudioDecoderOpusTest : public AudioDecoderTest {
decoder_ = new AudioDecoderOpus(1); decoder_ = new AudioDecoderOpus(1);
AudioEncoderOpus::Config config; AudioEncoderOpus::Config config;
config.frame_size_ms = static_cast<int>(frame_size_) / 48; config.frame_size_ms = static_cast<int>(frame_size_) / 48;
config.payload_type = payload_type_;
audio_encoder_.reset(new AudioEncoderOpus(config)); audio_encoder_.reset(new AudioEncoderOpus(config));
} }
}; };
@ -599,6 +607,7 @@ class AudioDecoderOpusStereoTest : public AudioDecoderOpusTest {
AudioEncoderOpus::Config config; AudioEncoderOpus::Config config;
config.frame_size_ms = static_cast<int>(frame_size_) / 48; config.frame_size_ms = static_cast<int>(frame_size_) / 48;
config.num_channels = 2; config.num_channels = 2;
config.payload_type = payload_type_;
audio_encoder_.reset(new AudioEncoderOpus(config)); audio_encoder_.reset(new AudioEncoderOpus(config));
} }
}; };