
With this change, the currently used encoder is held in a scoped_ptr. iSAC is a special case, since the encoder instance is also a decoder instance, so it may have to be available also if another send codec is used. This is accomplished by having a separate scoped_ptr for iSAC. Remove mirror ID from ACM codec database functions, and remove unused functions from the database. COAUTHOR=kwiberg@webrtc.org BUG=4228 R=tina.legrand@webrtc.org Review URL: https://webrtc-codereview.appspot.com/48729004 Cr-Commit-Position: refs/heads/master@{#8982}
101 lines
3.3 KiB
C++
101 lines
3.3 KiB
C++
/*
|
|
* Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef WEBRTC_MODULES_AUDIO_CODING_MAIN_ACM2_CODEC_MANAGER_H_
|
|
#define WEBRTC_MODULES_AUDIO_CODING_MAIN_ACM2_CODEC_MANAGER_H_
|
|
|
|
#include "webrtc/base/constructormagic.h"
|
|
#include "webrtc/base/thread_checker.h"
|
|
#include "webrtc/modules/audio_coding/main/acm2/acm_codec_database.h"
|
|
#include "webrtc/modules/audio_coding/main/interface/audio_coding_module_typedefs.h"
|
|
#include "webrtc/common_types.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class AudioDecoder;
|
|
|
|
namespace acm2 {
|
|
|
|
class ACMGenericCodec;
|
|
class AudioCodingModuleImpl;
|
|
|
|
class CodecManager final {
|
|
public:
|
|
explicit CodecManager(AudioCodingModuleImpl* acm);
|
|
~CodecManager();
|
|
|
|
int RegisterSendCodec(const CodecInst& send_codec);
|
|
|
|
int SendCodec(CodecInst* current_codec) const;
|
|
|
|
int RegisterReceiveCodec(const CodecInst& receive_codec);
|
|
|
|
bool SetCopyRed(bool enable);
|
|
|
|
int SetVAD(bool enable_dtx, bool enable_vad, ACMVADMode mode);
|
|
|
|
void VAD(bool* dtx_enabled, bool* vad_enabled, ACMVADMode* mode) const;
|
|
|
|
int SetCodecFEC(bool enable_codec_fec);
|
|
|
|
bool stereo_send() const { return stereo_send_; }
|
|
|
|
bool red_enabled() const { return red_enabled_; }
|
|
|
|
bool codec_fec_enabled() const { return codec_fec_enabled_; }
|
|
|
|
ACMGenericCodec* current_encoder() { return current_encoder_; }
|
|
|
|
const ACMGenericCodec* current_encoder() const { return current_encoder_; }
|
|
|
|
private:
|
|
void SetCngPayloadType(int sample_rate_hz, int payload_type);
|
|
|
|
void SetRedPayloadType(int sample_rate_hz, int payload_type);
|
|
|
|
// Get a pointer to AudioDecoder of the given codec. For some codecs, e.g.
|
|
// iSAC, encoding and decoding have to be performed on a shared
|
|
// codec-instance. By calling this method, we get the codec-instance that ACM
|
|
// owns, then pass that to NetEq. This way, we perform both encoding and
|
|
// decoding on the same codec-instance. Furthermore, ACM would have control
|
|
// over decoder functionality if required. If |codec| does not share an
|
|
// instance between encoder and decoder, the |*decoder| is set NULL.
|
|
// The field ACMCodecDB::CodecSettings.owns_decoder indicates that if a
|
|
// codec owns the decoder-instance. For such codecs |*decoder| should be a
|
|
// valid pointer, otherwise it will be NULL.
|
|
int GetAudioDecoder(const CodecInst& codec,
|
|
int codec_id,
|
|
AudioDecoder** decoder);
|
|
|
|
AudioCodingModuleImpl* acm_;
|
|
rtc::ThreadChecker thread_checker_;
|
|
uint8_t cng_nb_pltype_;
|
|
uint8_t cng_wb_pltype_;
|
|
uint8_t cng_swb_pltype_;
|
|
uint8_t cng_fb_pltype_;
|
|
uint8_t red_nb_pltype_;
|
|
bool stereo_send_;
|
|
bool vad_enabled_;
|
|
bool dtx_enabled_;
|
|
ACMVADMode vad_mode_;
|
|
ACMGenericCodec* current_encoder_;
|
|
CodecInst send_codec_inst_;
|
|
bool red_enabled_;
|
|
bool codec_fec_enabled_;
|
|
rtc::scoped_ptr<ACMGenericCodec> isac_enc_dec_;
|
|
rtc::scoped_ptr<ACMGenericCodec> encoder_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(CodecManager);
|
|
};
|
|
|
|
} // namespace acm2
|
|
} // namespace webrtc
|
|
#endif // WEBRTC_MODULES_AUDIO_CODING_MAIN_ACM2_CODEC_MANAGER_H_
|