Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * libjingle | 2 * libjingle |
| 3 * Copyright 2004 Google Inc. | 3 * Copyright 2004 Google Inc. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions are met: | 6 * modification, are permitted provided that the following conditions are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright notice, | 8 * 1. Redistributions of source code must retain the above copyright notice, |
| 9 * this list of conditions and the following disclaimer. | 9 * this list of conditions and the following disclaimer. |
| 10 * 2. Redistributions in binary form must reproduce the above copyright notice, | 10 * 2. Redistributions in binary form must reproduce the above copyright notice, |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 30 | 30 |
| 31 #include <map> | 31 #include <map> |
| 32 #include <set> | 32 #include <set> |
| 33 #include <string> | 33 #include <string> |
| 34 #include <vector> | 34 #include <vector> |
| 35 | 35 |
| 36 #include "talk/media/base/rtputils.h" | 36 #include "talk/media/base/rtputils.h" |
| 37 #include "talk/media/webrtc/webrtccommon.h" | 37 #include "talk/media/webrtc/webrtccommon.h" |
| 38 #include "talk/media/webrtc/webrtcvoe.h" | 38 #include "talk/media/webrtc/webrtcvoe.h" |
| 39 #include "talk/session/media/channel.h" | 39 #include "talk/session/media/channel.h" |
| 40 #include "webrtc/audio_state.h" | |
| 40 #include "webrtc/base/buffer.h" | 41 #include "webrtc/base/buffer.h" |
| 41 #include "webrtc/base/byteorder.h" | 42 #include "webrtc/base/byteorder.h" |
| 42 #include "webrtc/base/logging.h" | 43 #include "webrtc/base/logging.h" |
| 43 #include "webrtc/base/scoped_ptr.h" | 44 #include "webrtc/base/scoped_ptr.h" |
| 44 #include "webrtc/base/stream.h" | 45 #include "webrtc/base/stream.h" |
| 45 #include "webrtc/base/thread_checker.h" | 46 #include "webrtc/base/thread_checker.h" |
| 46 #include "webrtc/call.h" | 47 #include "webrtc/call.h" |
| 47 #include "webrtc/common.h" | 48 #include "webrtc/common.h" |
| 48 #include "webrtc/config.h" | 49 #include "webrtc/config.h" |
| 49 | 50 |
| 50 namespace cricket { | 51 namespace cricket { |
| 51 | 52 |
| 52 class AudioDeviceModule; | 53 class AudioDeviceModule; |
| 53 class AudioRenderer; | 54 class AudioRenderer; |
| 54 class VoETraceWrapper; | 55 class VoETraceWrapper; |
| 55 class VoEWrapper; | 56 class VoEWrapper; |
| 56 class WebRtcVoiceMediaChannel; | 57 class WebRtcVoiceMediaChannel; |
| 57 | 58 |
| 58 // WebRtcVoiceEngine is a class to be used with CompositeMediaEngine. | 59 // WebRtcVoiceEngine is a class to be used with CompositeMediaEngine. |
| 59 // It uses the WebRtc VoiceEngine library for audio handling. | 60 // It uses the WebRtc VoiceEngine library for audio handling. |
| 60 class WebRtcVoiceEngine | 61 class WebRtcVoiceEngine final : public webrtc::TraceCallback { |
| 61 : public webrtc::VoiceEngineObserver, | |
| 62 public webrtc::TraceCallback { | |
| 63 friend class WebRtcVoiceMediaChannel; | 62 friend class WebRtcVoiceMediaChannel; |
| 64 | 63 |
| 65 public: | 64 public: |
| 66 WebRtcVoiceEngine(); | 65 WebRtcVoiceEngine(); |
| 67 // Dependency injection for testing. | 66 // Dependency injection for testing. |
| 68 WebRtcVoiceEngine(VoEWrapper* voe_wrapper, VoETraceWrapper* tracing); | 67 WebRtcVoiceEngine(VoEWrapper* voe_wrapper, |
| 68 VoETraceWrapper* tracing, | |
| 69 webrtc::AudioState* audio_state); | |
|
tommi
2015/11/02 13:46:53
if we were using linked_ptr, we'd have to pass tha
the sun
2015/11/03 12:41:07
Indeed. Turns out we don't need the AudioState for
| |
| 69 ~WebRtcVoiceEngine(); | 70 ~WebRtcVoiceEngine(); |
| 70 bool Init(rtc::Thread* worker_thread); | 71 bool Init(rtc::Thread* worker_thread); |
| 71 void Terminate(); | 72 void Terminate(); |
| 72 | 73 |
| 73 webrtc::VoiceEngine* GetVoE() { return voe()->engine(); } | 74 rtc::linked_ptr<webrtc::AudioState> GetAudioState() const { |
|
tommi
2015/11/02 13:46:53
It would be nice to have a thread check here.
or c
the sun
2015/11/03 12:41:07
No, it has the same life span as WVoE and VoE. Nev
| |
| 75 return audio_state_; | |
| 76 } | |
| 74 VoiceMediaChannel* CreateChannel(webrtc::Call* call, | 77 VoiceMediaChannel* CreateChannel(webrtc::Call* call, |
| 75 const AudioOptions& options); | 78 const AudioOptions& options); |
| 76 | 79 |
| 77 AudioOptions GetOptions() const { return options_; } | 80 AudioOptions GetOptions() const { return options_; } |
| 78 bool SetOptions(const AudioOptions& options); | 81 bool SetOptions(const AudioOptions& options); |
| 79 bool SetDevices(const Device* in_device, const Device* out_device); | 82 bool SetDevices(const Device* in_device, const Device* out_device); |
| 80 bool GetOutputVolume(int* level); | 83 bool GetOutputVolume(int* level); |
| 81 bool SetOutputVolume(int level); | 84 bool SetOutputVolume(int level); |
| 82 int GetInputLevel(); | 85 int GetInputLevel(); |
| 83 | 86 |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 126 void SetTraceFilter(int filter); | 129 void SetTraceFilter(int filter); |
| 127 void SetTraceOptions(const std::string& options); | 130 void SetTraceOptions(const std::string& options); |
| 128 // Every option that is "set" will be applied. Every option not "set" will be | 131 // Every option that is "set" will be applied. Every option not "set" will be |
| 129 // ignored. This allows us to selectively turn on and off different options | 132 // ignored. This allows us to selectively turn on and off different options |
| 130 // easily at any time. | 133 // easily at any time. |
| 131 bool ApplyOptions(const AudioOptions& options); | 134 bool ApplyOptions(const AudioOptions& options); |
| 132 | 135 |
| 133 // webrtc::TraceCallback: | 136 // webrtc::TraceCallback: |
| 134 void Print(webrtc::TraceLevel level, const char* trace, int length) override; | 137 void Print(webrtc::TraceLevel level, const char* trace, int length) override; |
| 135 | 138 |
| 136 // webrtc::VoiceEngineObserver: | |
| 137 void CallbackOnError(int channel_id, int errCode) override; | |
| 138 | |
| 139 // Given the device type, name, and id, find device id. Return true and | 139 // Given the device type, name, and id, find device id. Return true and |
| 140 // set the output parameter rtc_id if successful. | 140 // set the output parameter rtc_id if successful. |
| 141 bool FindWebRtcAudioDeviceId( | 141 bool FindWebRtcAudioDeviceId( |
| 142 bool is_input, const std::string& dev_name, int dev_id, int* rtc_id); | 142 bool is_input, const std::string& dev_name, int dev_id, int* rtc_id); |
| 143 | 143 |
| 144 void StartAecDump(const std::string& filename); | 144 void StartAecDump(const std::string& filename); |
| 145 int CreateVoEChannel(); | 145 int CreateVoEChannel(); |
| 146 | 146 |
| 147 static const int kDefaultLogSeverity = rtc::LS_WARNING; | 147 static const int kDefaultLogSeverity = rtc::LS_WARNING; |
| 148 | 148 |
| 149 // The primary instance of WebRtc VoiceEngine. | 149 // The primary instance of WebRtc VoiceEngine. |
| 150 rtc::scoped_ptr<VoEWrapper> voe_wrapper_; | 150 rtc::scoped_ptr<VoEWrapper> voe_wrapper_; |
| 151 rtc::scoped_ptr<VoETraceWrapper> tracing_; | 151 rtc::scoped_ptr<VoETraceWrapper> tracing_; |
| 152 rtc::linked_ptr<webrtc::AudioState> audio_state_; | |
| 152 // The external audio device manager | 153 // The external audio device manager |
| 153 webrtc::AudioDeviceModule* adm_; | 154 webrtc::AudioDeviceModule* adm_ = nullptr; |
| 154 int log_filter_; | 155 int log_filter_; |
| 155 std::string log_options_; | 156 std::string log_options_; |
| 156 bool is_dumping_aec_; | 157 bool is_dumping_aec_ = false; |
| 157 std::vector<AudioCodec> codecs_; | 158 std::vector<AudioCodec> codecs_; |
| 158 std::vector<RtpHeaderExtension> rtp_header_extensions_; | 159 std::vector<RtpHeaderExtension> rtp_header_extensions_; |
| 159 std::vector<WebRtcVoiceMediaChannel*> channels_; | 160 std::vector<WebRtcVoiceMediaChannel*> channels_; |
| 160 // channels_ can be read from WebRtc callback thread. We need a lock on that | |
| 161 // callback as well as the RegisterChannel/UnregisterChannel. | |
| 162 rtc::CriticalSection channels_cs_; | |
| 163 webrtc::AgcConfig default_agc_config_; | 161 webrtc::AgcConfig default_agc_config_; |
| 164 | 162 |
| 165 webrtc::Config voe_config_; | 163 webrtc::Config voe_config_; |
| 166 | 164 |
| 167 bool initialized_; | 165 bool initialized_ = false; |
| 168 AudioOptions options_; | 166 AudioOptions options_; |
| 169 | 167 |
| 170 // Cache received extended_filter_aec, delay_agnostic_aec and experimental_ns | 168 // Cache received extended_filter_aec, delay_agnostic_aec and experimental_ns |
| 171 // values, and apply them in case they are missing in the audio options. We | 169 // values, and apply them in case they are missing in the audio options. We |
| 172 // need to do this because SetExtraOptions() will revert to defaults for | 170 // need to do this because SetExtraOptions() will revert to defaults for |
| 173 // options which are not provided. | 171 // options which are not provided. |
| 174 Settable<bool> extended_filter_aec_; | 172 Settable<bool> extended_filter_aec_; |
| 175 Settable<bool> delay_agnostic_aec_; | 173 Settable<bool> delay_agnostic_aec_; |
| 176 Settable<bool> experimental_ns_; | 174 Settable<bool> experimental_ns_; |
| 177 | 175 |
| 178 RTC_DISALLOW_COPY_AND_ASSIGN(WebRtcVoiceEngine); | 176 RTC_DISALLOW_COPY_AND_ASSIGN(WebRtcVoiceEngine); |
| 179 }; | 177 }; |
| 180 | 178 |
| 181 // WebRtcVoiceMediaChannel is an implementation of VoiceMediaChannel that uses | 179 // WebRtcVoiceMediaChannel is an implementation of VoiceMediaChannel that uses |
| 182 // WebRtc Voice Engine. | 180 // WebRtc Voice Engine. |
| 183 class WebRtcVoiceMediaChannel : public VoiceMediaChannel, | 181 class WebRtcVoiceMediaChannel final : public VoiceMediaChannel, |
| 184 public webrtc::Transport { | 182 public webrtc::Transport { |
| 185 public: | 183 public: |
| 186 WebRtcVoiceMediaChannel(WebRtcVoiceEngine* engine, | 184 WebRtcVoiceMediaChannel(WebRtcVoiceEngine* engine, |
| 187 const AudioOptions& options, | 185 const AudioOptions& options, |
| 188 webrtc::Call* call); | 186 webrtc::Call* call); |
| 189 ~WebRtcVoiceMediaChannel() override; | 187 ~WebRtcVoiceMediaChannel() override; |
| 190 | 188 |
| 191 const AudioOptions& options() const { return options_; } | 189 const AudioOptions& options() const { return options_; } |
| 192 | 190 |
| 193 bool SetSendParameters(const AudioSendParameters& params) override; | 191 bool SetSendParameters(const AudioSendParameters& params) override; |
| 194 bool SetRecvParameters(const AudioRecvParameters& params) override; | 192 bool SetRecvParameters(const AudioRecvParameters& params) override; |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 236 rtc_options.packet_id = options.packet_id; | 234 rtc_options.packet_id = options.packet_id; |
| 237 return VoiceMediaChannel::SendPacket(&packet, rtc_options); | 235 return VoiceMediaChannel::SendPacket(&packet, rtc_options); |
| 238 } | 236 } |
| 239 | 237 |
| 240 bool SendRtcp(const uint8_t* data, size_t len) override { | 238 bool SendRtcp(const uint8_t* data, size_t len) override { |
| 241 rtc::Buffer packet(reinterpret_cast<const uint8_t*>(data), len, | 239 rtc::Buffer packet(reinterpret_cast<const uint8_t*>(data), len, |
| 242 kMaxRtpPacketLen); | 240 kMaxRtpPacketLen); |
| 243 return VoiceMediaChannel::SendRtcp(&packet, rtc::PacketOptions()); | 241 return VoiceMediaChannel::SendRtcp(&packet, rtc::PacketOptions()); |
| 244 } | 242 } |
| 245 | 243 |
| 246 void OnError(int error); | |
| 247 | |
| 248 int GetReceiveChannelId(uint32_t ssrc) const; | 244 int GetReceiveChannelId(uint32_t ssrc) const; |
| 249 int GetSendChannelId(uint32_t ssrc) const; | 245 int GetSendChannelId(uint32_t ssrc) const; |
| 250 | 246 |
| 251 private: | 247 private: |
| 252 bool SetSendCodecs(const std::vector<AudioCodec>& codecs); | 248 bool SetSendCodecs(const std::vector<AudioCodec>& codecs); |
| 253 bool SetSendRtpHeaderExtensions( | 249 bool SetSendRtpHeaderExtensions( |
| 254 const std::vector<RtpHeaderExtension>& extensions); | 250 const std::vector<RtpHeaderExtension>& extensions); |
| 255 bool SetOptions(const AudioOptions& options); | 251 bool SetOptions(const AudioOptions& options); |
| 256 bool SetMaxSendBandwidth(int bps); | 252 bool SetMaxSendBandwidth(int bps); |
| 257 bool SetRecvCodecs(const std::vector<AudioCodec>& codecs); | 253 bool SetRecvCodecs(const std::vector<AudioCodec>& codecs); |
| 258 bool SetRecvRtpHeaderExtensions( | 254 bool SetRecvRtpHeaderExtensions( |
| 259 const std::vector<RtpHeaderExtension>& extensions); | 255 const std::vector<RtpHeaderExtension>& extensions); |
| 260 bool SetLocalRenderer(uint32_t ssrc, AudioRenderer* renderer); | 256 bool SetLocalRenderer(uint32_t ssrc, AudioRenderer* renderer); |
| 261 bool MuteStream(uint32_t ssrc, bool mute); | 257 bool MuteStream(uint32_t ssrc, bool mute); |
| 262 | 258 |
| 263 WebRtcVoiceEngine* engine() { return engine_; } | 259 WebRtcVoiceEngine* engine() { return engine_; } |
| 264 int GetLastEngineError() { return engine()->GetLastEngineError(); } | 260 int GetLastEngineError() { return engine()->GetLastEngineError(); } |
| 265 int GetOutputLevel(int channel); | 261 int GetOutputLevel(int channel); |
| 266 bool GetRedSendCodec(const AudioCodec& red_codec, | 262 bool GetRedSendCodec(const AudioCodec& red_codec, |
| 267 const std::vector<AudioCodec>& all_codecs, | 263 const std::vector<AudioCodec>& all_codecs, |
| 268 webrtc::CodecInst* send_codec); | 264 webrtc::CodecInst* send_codec); |
| 269 bool SetPlayout(int channel, bool playout); | 265 bool SetPlayout(int channel, bool playout); |
| 270 static Error WebRtcErrorToChannelError(int err_code); | |
| 271 | 266 |
| 272 typedef int (webrtc::VoERTP_RTCP::* ExtensionSetterFunction)(int, bool, | 267 typedef int (webrtc::VoERTP_RTCP::* ExtensionSetterFunction)(int, bool, |
| 273 unsigned char); | 268 unsigned char); |
| 274 | 269 |
| 275 void SetNack(int channel, bool nack_enabled); | 270 void SetNack(int channel, bool nack_enabled); |
| 276 bool SetSendCodec(int channel, const webrtc::CodecInst& send_codec); | 271 bool SetSendCodec(int channel, const webrtc::CodecInst& send_codec); |
| 277 bool ChangePlayout(bool playout); | 272 bool ChangePlayout(bool playout); |
| 278 bool ChangeSend(SendFlags send); | 273 bool ChangeSend(SendFlags send); |
| 279 bool ChangeSend(int channel, SendFlags send); | 274 bool ChangeSend(int channel, SendFlags send); |
| 280 bool ConfigureRecvChannel(int channel); | 275 bool ConfigureRecvChannel(int channel); |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 295 | 290 |
| 296 bool SetChannelRecvRtpHeaderExtensions( | 291 bool SetChannelRecvRtpHeaderExtensions( |
| 297 int channel_id, | 292 int channel_id, |
| 298 const std::vector<RtpHeaderExtension>& extensions); | 293 const std::vector<RtpHeaderExtension>& extensions); |
| 299 bool SetChannelSendRtpHeaderExtensions( | 294 bool SetChannelSendRtpHeaderExtensions( |
| 300 int channel_id, | 295 int channel_id, |
| 301 const std::vector<RtpHeaderExtension>& extensions); | 296 const std::vector<RtpHeaderExtension>& extensions); |
| 302 | 297 |
| 303 rtc::ThreadChecker thread_checker_; | 298 rtc::ThreadChecker thread_checker_; |
| 304 | 299 |
| 305 WebRtcVoiceEngine* const engine_; | 300 WebRtcVoiceEngine* const engine_ = nullptr; |
| 306 std::vector<AudioCodec> recv_codecs_; | 301 std::vector<AudioCodec> recv_codecs_; |
| 307 std::vector<AudioCodec> send_codecs_; | 302 std::vector<AudioCodec> send_codecs_; |
| 308 rtc::scoped_ptr<webrtc::CodecInst> send_codec_; | 303 rtc::scoped_ptr<webrtc::CodecInst> send_codec_; |
| 309 bool send_bitrate_setting_; | 304 bool send_bitrate_setting_ = false; |
| 310 int send_bitrate_bps_; | 305 int send_bitrate_bps_ = 0; |
| 311 AudioOptions options_; | 306 AudioOptions options_; |
| 312 bool dtmf_allowed_; | 307 bool dtmf_allowed_ = false; |
| 313 bool desired_playout_; | 308 bool desired_playout_ = false; |
| 314 bool nack_enabled_; | 309 bool nack_enabled_ = false; |
| 315 bool playout_; | 310 bool playout_ = false; |
| 316 bool typing_noise_detected_; | 311 SendFlags desired_send_ = SEND_NOTHING; |
| 317 SendFlags desired_send_; | 312 SendFlags send_ = SEND_NOTHING; |
| 318 SendFlags send_; | 313 webrtc::Call* const call_ = nullptr; |
| 319 webrtc::Call* const call_; | |
| 320 | 314 |
| 321 // SSRC of unsignalled receive stream, or -1 if there isn't one. | 315 // SSRC of unsignalled receive stream, or -1 if there isn't one. |
| 322 int64_t default_recv_ssrc_ = -1; | 316 int64_t default_recv_ssrc_ = -1; |
| 323 // Volume for unsignalled stream, which may be set before the stream exists. | 317 // Volume for unsignalled stream, which may be set before the stream exists. |
| 324 double default_recv_volume_ = 1.0; | 318 double default_recv_volume_ = 1.0; |
| 325 // SSRC to use for RTCP receiver reports; default to 1 in case of no signaled | 319 // SSRC to use for RTCP receiver reports; default to 1 in case of no signaled |
| 326 // send streams. See: https://code.google.com/p/webrtc/issues/detail?id=4740 | 320 // send streams. See: https://code.google.com/p/webrtc/issues/detail?id=4740 |
| 327 uint32_t receiver_reports_ssrc_ = 1; | 321 uint32_t receiver_reports_ssrc_ = 1; |
| 328 | 322 |
| 329 class WebRtcAudioSendStream; | 323 class WebRtcAudioSendStream; |
| 330 std::map<uint32_t, WebRtcAudioSendStream*> send_streams_; | 324 std::map<uint32_t, WebRtcAudioSendStream*> send_streams_; |
| 331 std::vector<RtpHeaderExtension> send_extensions_; | 325 std::vector<RtpHeaderExtension> send_extensions_; |
| 332 | 326 |
| 333 class WebRtcAudioReceiveStream; | 327 class WebRtcAudioReceiveStream; |
| 334 std::map<uint32_t, WebRtcAudioReceiveStream*> receive_channels_; | 328 std::map<uint32_t, WebRtcAudioReceiveStream*> receive_channels_; |
| 335 std::map<uint32_t, webrtc::AudioReceiveStream*> receive_streams_; | 329 std::map<uint32_t, webrtc::AudioReceiveStream*> receive_streams_; |
| 336 std::map<uint32_t, StreamParams> receive_stream_params_; | 330 std::map<uint32_t, StreamParams> receive_stream_params_; |
| 337 // receive_channels_ can be read from WebRtc callback thread. Access from | 331 // receive_channels_ can be read from WebRtc callback thread. Access from |
| 338 // the WebRtc thread must be synchronized with edits on the worker thread. | 332 // the WebRtc thread must be synchronized with edits on the worker thread. |
| 339 // Reads on the worker thread are ok. | 333 // Reads on the worker thread are ok. |
| 340 std::vector<RtpHeaderExtension> receive_extensions_; | 334 std::vector<RtpHeaderExtension> receive_extensions_; |
| 341 std::vector<webrtc::RtpExtension> recv_rtp_extensions_; | 335 std::vector<webrtc::RtpExtension> recv_rtp_extensions_; |
| 342 | 336 |
| 343 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(WebRtcVoiceMediaChannel); | 337 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(WebRtcVoiceMediaChannel); |
| 344 }; | 338 }; |
| 345 | |
| 346 } // namespace cricket | 339 } // namespace cricket |
| 347 | 340 |
| 348 #endif // TALK_MEDIA_WEBRTCVOICEENGINE_H_ | 341 #endif // TALK_MEDIA_WEBRTCVOICEENGINE_H_ |
| OLD | NEW |