OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
42 ///////////////////////////////////////// | 42 ///////////////////////////////////////// |
43 // Sender | 43 // Sender |
44 // | 44 // |
45 | 45 |
46 // Can be called multiple times for Codec, CNG, RED. | 46 // Can be called multiple times for Codec, CNG, RED. |
47 int RegisterSendCodec(const CodecInst& send_codec) override; | 47 int RegisterSendCodec(const CodecInst& send_codec) override; |
48 | 48 |
49 void RegisterExternalSendCodec( | 49 void RegisterExternalSendCodec( |
50 AudioEncoder* external_speech_encoder) override; | 50 AudioEncoder* external_speech_encoder) override; |
51 | 51 |
| 52 void ModifyEncoder( |
| 53 FunctionView<void(std::unique_ptr<AudioEncoder>*)> modifier) override; |
| 54 |
52 // Get current send codec. | 55 // Get current send codec. |
53 rtc::Optional<CodecInst> SendCodec() const override; | 56 rtc::Optional<CodecInst> SendCodec() const override; |
54 | 57 |
55 // Get current send frequency. | 58 // Get current send frequency. |
56 int SendFrequency() const override; | 59 int SendFrequency() const override; |
57 | 60 |
58 // Sets the bitrate to the specified value in bits/sec. In case the codec does | 61 // Sets the bitrate to the specified value in bits/sec. In case the codec does |
59 // not support the requested value it will choose an appropriate value | 62 // not support the requested value it will choose an appropriate value |
60 // instead. | 63 // instead. |
61 void SetBitRate(int bitrate_bps) override; | 64 void SetBitRate(int bitrate_bps) override; |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
112 | 115 |
113 // Initialize receiver, resets codec database etc. | 116 // Initialize receiver, resets codec database etc. |
114 int InitializeReceiver() override; | 117 int InitializeReceiver() override; |
115 | 118 |
116 // Get current receive frequency. | 119 // Get current receive frequency. |
117 int ReceiveFrequency() const override; | 120 int ReceiveFrequency() const override; |
118 | 121 |
119 // Get current playout frequency. | 122 // Get current playout frequency. |
120 int PlayoutFrequency() const override; | 123 int PlayoutFrequency() const override; |
121 | 124 |
122 // Register possible receive codecs, can be called multiple times, | |
123 // for codecs, CNG, DTMF, RED. | |
124 int RegisterReceiveCodec(const CodecInst& receive_codec) override; | 125 int RegisterReceiveCodec(const CodecInst& receive_codec) override; |
| 126 int RegisterReceiveCodec( |
| 127 const CodecInst& receive_codec, |
| 128 FunctionView<std::unique_ptr<AudioDecoder>()> isac_factory) override; |
125 | 129 |
126 int RegisterExternalReceiveCodec(int rtp_payload_type, | 130 int RegisterExternalReceiveCodec(int rtp_payload_type, |
127 AudioDecoder* external_decoder, | 131 AudioDecoder* external_decoder, |
128 int sample_rate_hz, | 132 int sample_rate_hz, |
129 int num_channels, | 133 int num_channels, |
130 const std::string& name) override; | 134 const std::string& name) override; |
131 | 135 |
132 // Get current received codec. | 136 // Get current received codec. |
133 int ReceiveCodec(CodecInst* current_codec) const override; | 137 int ReceiveCodec(CodecInst* current_codec) const override; |
134 | 138 |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
206 // Logs the new value if it is different from the last logged value, or if | 210 // Logs the new value if it is different from the last logged value, or if |
207 // this is the first call. | 211 // this is the first call. |
208 void MaybeLog(int value); | 212 void MaybeLog(int value); |
209 | 213 |
210 private: | 214 private: |
211 int last_value_ = 0; | 215 int last_value_ = 0; |
212 int first_time_ = true; | 216 int first_time_ = true; |
213 const std::string histogram_name_; | 217 const std::string histogram_name_; |
214 }; | 218 }; |
215 | 219 |
| 220 int RegisterReceiveCodecUnlocked( |
| 221 const CodecInst& codec, |
| 222 FunctionView<std::unique_ptr<AudioDecoder>()> isac_factory) |
| 223 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); |
| 224 |
216 int Add10MsDataInternal(const AudioFrame& audio_frame, InputData* input_data) | 225 int Add10MsDataInternal(const AudioFrame& audio_frame, InputData* input_data) |
217 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); | 226 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); |
218 int Encode(const InputData& input_data) | 227 int Encode(const InputData& input_data) |
219 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); | 228 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); |
220 | 229 |
221 int InitializeReceiverSafe() EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); | 230 int InitializeReceiverSafe() EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); |
222 | 231 |
223 bool HaveValidEncoder(const char* caller_name) const | 232 bool HaveValidEncoder(const char* caller_name) const |
224 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); | 233 EXCLUSIVE_LOCKS_REQUIRED(acm_crit_sect_); |
225 | 234 |
(...skipping 25 matching lines...) Expand all Loading... |
251 AcmReceiver receiver_; // AcmReceiver has it's own internal lock. | 260 AcmReceiver receiver_; // AcmReceiver has it's own internal lock. |
252 ChangeLogger bitrate_logger_ GUARDED_BY(acm_crit_sect_); | 261 ChangeLogger bitrate_logger_ GUARDED_BY(acm_crit_sect_); |
253 | 262 |
254 std::unique_ptr<EncoderFactory> encoder_factory_ GUARDED_BY(acm_crit_sect_); | 263 std::unique_ptr<EncoderFactory> encoder_factory_ GUARDED_BY(acm_crit_sect_); |
255 | 264 |
256 // Current encoder stack, either obtained from | 265 // Current encoder stack, either obtained from |
257 // encoder_factory_->rent_a_codec.RentEncoderStack or provided by a call to | 266 // encoder_factory_->rent_a_codec.RentEncoderStack or provided by a call to |
258 // RegisterEncoder. | 267 // RegisterEncoder. |
259 std::unique_ptr<AudioEncoder> encoder_stack_ GUARDED_BY(acm_crit_sect_); | 268 std::unique_ptr<AudioEncoder> encoder_stack_ GUARDED_BY(acm_crit_sect_); |
260 | 269 |
| 270 std::unique_ptr<AudioDecoder> isac_decoder_ GUARDED_BY(acm_crit_sect_); |
| 271 |
261 // This is to keep track of CN instances where we can send DTMFs. | 272 // This is to keep track of CN instances where we can send DTMFs. |
262 uint8_t previous_pltype_ GUARDED_BY(acm_crit_sect_); | 273 uint8_t previous_pltype_ GUARDED_BY(acm_crit_sect_); |
263 | 274 |
264 // Used when payloads are pushed into ACM without any RTP info | 275 // Used when payloads are pushed into ACM without any RTP info |
265 // One example is when pre-encoded bit-stream is pushed from | 276 // One example is when pre-encoded bit-stream is pushed from |
266 // a file. | 277 // a file. |
267 // IMPORTANT: this variable is only used in IncomingPayload(), therefore, | 278 // IMPORTANT: this variable is only used in IncomingPayload(), therefore, |
268 // no lock acquired when interacting with this variable. If it is going to | 279 // no lock acquired when interacting with this variable. If it is going to |
269 // be used in other methods, locks need to be taken. | 280 // be used in other methods, locks need to be taken. |
270 std::unique_ptr<WebRtcRTPHeader> aux_rtp_header_; | 281 std::unique_ptr<WebRtcRTPHeader> aux_rtp_header_; |
(...skipping 10 matching lines...) Expand all Loading... |
281 rtc::CriticalSection callback_crit_sect_; | 292 rtc::CriticalSection callback_crit_sect_; |
282 AudioPacketizationCallback* packetization_callback_ | 293 AudioPacketizationCallback* packetization_callback_ |
283 GUARDED_BY(callback_crit_sect_); | 294 GUARDED_BY(callback_crit_sect_); |
284 ACMVADCallback* vad_callback_ GUARDED_BY(callback_crit_sect_); | 295 ACMVADCallback* vad_callback_ GUARDED_BY(callback_crit_sect_); |
285 }; | 296 }; |
286 | 297 |
287 } // namespace acm2 | 298 } // namespace acm2 |
288 } // namespace webrtc | 299 } // namespace webrtc |
289 | 300 |
290 #endif // WEBRTC_MODULES_AUDIO_CODING_ACM2_AUDIO_CODING_MODULE_IMPL_H_ | 301 #endif // WEBRTC_MODULES_AUDIO_CODING_ACM2_AUDIO_CODING_MODULE_IMPL_H_ |
OLD | NEW |