blob: b21919c94a536392cef3089c124f7fa2f2c5e224 [file] [log] [blame]
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001/*
kjellander1afca732016-02-07 20:46:45 -08002 * Copyright (c) 2004 The WebRTC project authors. All Rights Reserved.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003 *
kjellander1afca732016-02-07 20:46:45 -08004 * 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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00009 */
10
kjellandera96e2d72016-02-04 23:52:28 -080011#ifndef WEBRTC_MEDIA_BASE_MEDIACHANNEL_H_
12#define WEBRTC_MEDIA_BASE_MEDIACHANNEL_H_
henrike@webrtc.org28e20752013-07-10 00:45:36 +000013
terelius54f91712016-06-01 11:18:56 -070014#include <algorithm>
kwiberg686a8ef2016-02-26 03:00:35 -080015#include <memory>
henrike@webrtc.org28e20752013-07-10 00:45:36 +000016#include <string>
17#include <vector>
18
skvladdc1c62c2016-03-16 19:07:43 -070019#include "webrtc/api/rtpparameters.h"
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000020#include "webrtc/base/basictypes.h"
kwiberga4ac4782016-04-29 08:00:22 -070021#include "webrtc/base/buffer.h"
jbaucheec21bd2016-03-20 06:15:43 -070022#include "webrtc/base/copyonwritebuffer.h"
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000023#include "webrtc/base/dscp.h"
24#include "webrtc/base/logging.h"
Honghai Zhangcc411c02016-03-29 17:27:21 -070025#include "webrtc/base/networkroute.h"
Karl Wibergbe579832015-11-10 22:34:18 +010026#include "webrtc/base/optional.h"
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000027#include "webrtc/base/sigslot.h"
28#include "webrtc/base/socket.h"
29#include "webrtc/base/window.h"
isheriff6f8d6862016-05-26 11:24:55 -070030#include "webrtc/config.h"
kjellandera96e2d72016-02-04 23:52:28 -080031#include "webrtc/media/base/codec.h"
kjellanderf4752772016-03-02 05:42:30 -080032#include "webrtc/media/base/mediaconstants.h"
kjellandera96e2d72016-02-04 23:52:28 -080033#include "webrtc/media/base/streamparams.h"
nisse09347852016-10-19 00:30:30 -070034// TODO(nisse): Temporarily; to be replaced with a forward declaration
35// of webrtc::VideoFrame when dependency on cricket::VideoFrame is deleted.
36#include "webrtc/media/base/videoframe.h"
nisse08582ff2016-02-04 01:24:52 -080037#include "webrtc/media/base/videosinkinterface.h"
nisse2ded9b12016-04-08 02:23:55 -070038#include "webrtc/media/base/videosourceinterface.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000039// TODO(juberti): re-evaluate this include
kjellander@webrtc.org9b8df252016-02-12 06:47:59 +010040#include "webrtc/pc/audiomonitor.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000041
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000042namespace rtc {
henrike@webrtc.org28e20752013-07-10 00:45:36 +000043class RateLimiter;
44class Timing;
45}
46
Tommif888bb52015-12-12 01:37:01 +010047namespace webrtc {
48class AudioSinkInterface;
49}
50
henrike@webrtc.org28e20752013-07-10 00:45:36 +000051namespace cricket {
52
Taylor Brandstetter1a018dc2016-03-08 12:37:39 -080053class AudioSource;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000054class VideoCapturer;
tommi1d5c19d2015-12-13 22:54:29 -080055struct RtpHeader;
56struct VideoFormat;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000057
henrike@webrtc.org28e20752013-07-10 00:45:36 +000058const int kScreencastDefaultFps = 5;
59
henrike@webrtc.org28e20752013-07-10 00:45:36 +000060template <class T>
Karl Wibergbe579832015-11-10 22:34:18 +010061static std::string ToStringIfSet(const char* key, const rtc::Optional<T>& val) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +000062 std::string str;
kwiberg102c6a62015-10-30 02:47:38 -070063 if (val) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +000064 str = key;
65 str += ": ";
kwiberg102c6a62015-10-30 02:47:38 -070066 str += val ? rtc::ToString(*val) : "";
henrike@webrtc.org28e20752013-07-10 00:45:36 +000067 str += ", ";
68 }
69 return str;
70}
71
Peter Thatcherc2ee2c82015-08-07 16:05:34 -070072template <class T>
73static std::string VectorToString(const std::vector<T>& vals) {
74 std::ostringstream ost;
75 ost << "[";
76 for (size_t i = 0; i < vals.size(); ++i) {
77 if (i > 0) {
78 ost << ", ";
79 }
80 ost << vals[i].ToString();
81 }
82 ost << "]";
83 return ost.str();
84}
85
skvladdc1c62c2016-03-16 19:07:43 -070086template <typename T>
87static T MinPositive(T a, T b) {
88 if (a <= 0) {
89 return b;
90 }
91 if (b <= 0) {
92 return a;
93 }
94 return std::min(a, b);
95}
96
nisse51542be2016-02-12 02:27:06 -080097// Construction-time settings, passed to
98// MediaControllerInterface::Create, and passed on when creating
99// MediaChannels.
100struct MediaConfig {
101 // Set DSCP value on packets. This flag comes from the
102 // PeerConnection constraint 'googDscp'.
103 bool enable_dscp = false;
104
nisse0db023a2016-03-01 04:29:59 -0800105 // Video-specific config.
106 struct Video {
107 // Enable WebRTC CPU Overuse Detection. This flag comes from the
perkj803d97f2016-11-01 11:45:46 -0700108 // PeerConnection constraint 'googCpuOveruseDetection'.
nisse0db023a2016-03-01 04:29:59 -0800109 bool enable_cpu_overuse_detection = true;
nisse51542be2016-02-12 02:27:06 -0800110
nisse0db023a2016-03-01 04:29:59 -0800111 // Enable WebRTC suspension of video. No video frames will be sent
112 // when the bitrate is below the configured minimum bitrate. This
113 // flag comes from the PeerConnection constraint
114 // 'googSuspendBelowMinBitrate', and WebRtcVideoChannel2 copies it
115 // to VideoSendStream::Config::suspend_below_min_bitrate.
116 bool suspend_below_min_bitrate = false;
nisse51542be2016-02-12 02:27:06 -0800117
nisse0db023a2016-03-01 04:29:59 -0800118 // Set to true if the renderer has an algorithm of frame selection.
119 // If the value is true, then WebRTC will hand over a frame as soon as
120 // possible without delay, and rendering smoothness is completely the duty
121 // of the renderer;
122 // If the value is false, then WebRTC is responsible to delay frame release
123 // in order to increase rendering smoothness.
124 //
125 // This flag comes from PeerConnection's RtcConfiguration, but is
126 // currently only set by the command line flag
127 // 'disable-rtc-smoothness-algorithm'.
128 // WebRtcVideoChannel2::AddRecvStream copies it to the created
129 // WebRtcVideoReceiveStream, where it is returned by the
130 // SmoothsRenderedFrames method. This method is used by the
131 // VideoReceiveStream, where the value is passed on to the
132 // IncomingVideoStream constructor.
133 bool disable_prerenderer_smoothing = false;
134 } video;
nisse51542be2016-02-12 02:27:06 -0800135};
136
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000137// Options that can be applied to a VoiceMediaChannel or a VoiceMediaEngine.
138// Used to be flags, but that makes it hard to selectively apply options.
139// We are moving all of the setting of options to structs like this,
140// but some things currently still use flags.
141struct AudioOptions {
142 void SetAll(const AudioOptions& change) {
kwiberg102c6a62015-10-30 02:47:38 -0700143 SetFrom(&echo_cancellation, change.echo_cancellation);
144 SetFrom(&auto_gain_control, change.auto_gain_control);
145 SetFrom(&noise_suppression, change.noise_suppression);
146 SetFrom(&highpass_filter, change.highpass_filter);
147 SetFrom(&stereo_swapping, change.stereo_swapping);
148 SetFrom(&audio_jitter_buffer_max_packets,
149 change.audio_jitter_buffer_max_packets);
150 SetFrom(&audio_jitter_buffer_fast_accelerate,
151 change.audio_jitter_buffer_fast_accelerate);
152 SetFrom(&typing_detection, change.typing_detection);
153 SetFrom(&aecm_generate_comfort_noise, change.aecm_generate_comfort_noise);
kwiberg102c6a62015-10-30 02:47:38 -0700154 SetFrom(&adjust_agc_delta, change.adjust_agc_delta);
155 SetFrom(&experimental_agc, change.experimental_agc);
156 SetFrom(&extended_filter_aec, change.extended_filter_aec);
157 SetFrom(&delay_agnostic_aec, change.delay_agnostic_aec);
158 SetFrom(&experimental_ns, change.experimental_ns);
Alejandro Luebsc9b0c262016-05-16 15:32:38 -0700159 SetFrom(&intelligibility_enhancer, change.intelligibility_enhancer);
peaha3333bf2016-06-30 00:02:34 -0700160 SetFrom(&level_control, change.level_control);
kwiberg102c6a62015-10-30 02:47:38 -0700161 SetFrom(&tx_agc_target_dbov, change.tx_agc_target_dbov);
162 SetFrom(&tx_agc_digital_compression_gain,
163 change.tx_agc_digital_compression_gain);
164 SetFrom(&tx_agc_limiter, change.tx_agc_limiter);
165 SetFrom(&recording_sample_rate, change.recording_sample_rate);
166 SetFrom(&playout_sample_rate, change.playout_sample_rate);
kwiberg102c6a62015-10-30 02:47:38 -0700167 SetFrom(&combined_audio_video_bwe, change.combined_audio_video_bwe);
minyue6b825df2016-10-31 04:08:32 -0700168 SetFrom(&audio_network_adaptor, change.audio_network_adaptor);
169 SetFrom(&audio_network_adaptor_config, change.audio_network_adaptor_config);
aleloie33c5d92016-10-20 01:53:27 -0700170 SetFrom(&level_control_initial_peak_level_dbfs,
171 change.level_control_initial_peak_level_dbfs);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000172 }
173
174 bool operator==(const AudioOptions& o) const {
175 return echo_cancellation == o.echo_cancellation &&
peaha3333bf2016-06-30 00:02:34 -0700176 auto_gain_control == o.auto_gain_control &&
177 noise_suppression == o.noise_suppression &&
178 highpass_filter == o.highpass_filter &&
179 stereo_swapping == o.stereo_swapping &&
180 audio_jitter_buffer_max_packets ==
181 o.audio_jitter_buffer_max_packets &&
182 audio_jitter_buffer_fast_accelerate ==
183 o.audio_jitter_buffer_fast_accelerate &&
184 typing_detection == o.typing_detection &&
185 aecm_generate_comfort_noise == o.aecm_generate_comfort_noise &&
186 experimental_agc == o.experimental_agc &&
187 extended_filter_aec == o.extended_filter_aec &&
188 delay_agnostic_aec == o.delay_agnostic_aec &&
189 experimental_ns == o.experimental_ns &&
190 intelligibility_enhancer == o.intelligibility_enhancer &&
191 level_control == o.level_control &&
192 adjust_agc_delta == o.adjust_agc_delta &&
193 tx_agc_target_dbov == o.tx_agc_target_dbov &&
194 tx_agc_digital_compression_gain ==
195 o.tx_agc_digital_compression_gain &&
196 tx_agc_limiter == o.tx_agc_limiter &&
197 recording_sample_rate == o.recording_sample_rate &&
198 playout_sample_rate == o.playout_sample_rate &&
aleloie33c5d92016-10-20 01:53:27 -0700199 combined_audio_video_bwe == o.combined_audio_video_bwe &&
minyue6b825df2016-10-31 04:08:32 -0700200 audio_network_adaptor == o.audio_network_adaptor &&
201 audio_network_adaptor_config == o.audio_network_adaptor_config &&
aleloie33c5d92016-10-20 01:53:27 -0700202 level_control_initial_peak_level_dbfs ==
203 o.level_control_initial_peak_level_dbfs;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000204 }
deadbeef119760a2016-04-04 11:43:27 -0700205 bool operator!=(const AudioOptions& o) const { return !(*this == o); }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000206
207 std::string ToString() const {
208 std::ostringstream ost;
209 ost << "AudioOptions {";
210 ost << ToStringIfSet("aec", echo_cancellation);
211 ost << ToStringIfSet("agc", auto_gain_control);
212 ost << ToStringIfSet("ns", noise_suppression);
213 ost << ToStringIfSet("hf", highpass_filter);
214 ost << ToStringIfSet("swap", stereo_swapping);
Henrik Lundin64dad832015-05-11 12:44:23 +0200215 ost << ToStringIfSet("audio_jitter_buffer_max_packets",
216 audio_jitter_buffer_max_packets);
Henrik Lundin5263b3c2015-06-01 10:29:41 +0200217 ost << ToStringIfSet("audio_jitter_buffer_fast_accelerate",
218 audio_jitter_buffer_fast_accelerate);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000219 ost << ToStringIfSet("typing", typing_detection);
wu@webrtc.org97077a32013-10-25 21:18:33 +0000220 ost << ToStringIfSet("comfort_noise", aecm_generate_comfort_noise);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000221 ost << ToStringIfSet("agc_delta", adjust_agc_delta);
222 ost << ToStringIfSet("experimental_agc", experimental_agc);
Henrik Lundin441f6342015-06-09 16:03:13 +0200223 ost << ToStringIfSet("extended_filter_aec", extended_filter_aec);
Bjorn Volckerbf395c12015-03-25 22:45:56 +0100224 ost << ToStringIfSet("delay_agnostic_aec", delay_agnostic_aec);
sergeyu@chromium.org9cf037b2014-02-07 19:03:26 +0000225 ost << ToStringIfSet("experimental_ns", experimental_ns);
Alejandro Luebsc9b0c262016-05-16 15:32:38 -0700226 ost << ToStringIfSet("intelligibility_enhancer", intelligibility_enhancer);
peaha3333bf2016-06-30 00:02:34 -0700227 ost << ToStringIfSet("level_control", level_control);
aleloie33c5d92016-10-20 01:53:27 -0700228 ost << ToStringIfSet("level_control_initial_peak_level_dbfs",
229 level_control_initial_peak_level_dbfs);
wu@webrtc.org97077a32013-10-25 21:18:33 +0000230 ost << ToStringIfSet("tx_agc_target_dbov", tx_agc_target_dbov);
231 ost << ToStringIfSet("tx_agc_digital_compression_gain",
232 tx_agc_digital_compression_gain);
233 ost << ToStringIfSet("tx_agc_limiter", tx_agc_limiter);
wu@webrtc.org97077a32013-10-25 21:18:33 +0000234 ost << ToStringIfSet("recording_sample_rate", recording_sample_rate);
235 ost << ToStringIfSet("playout_sample_rate", playout_sample_rate);
buildbot@webrtc.orgb4c7b092014-08-25 12:11:58 +0000236 ost << ToStringIfSet("combined_audio_video_bwe", combined_audio_video_bwe);
minyue6b825df2016-10-31 04:08:32 -0700237 ost << ToStringIfSet("audio_network_adaptor", audio_network_adaptor);
238 // The adaptor config is a serialized proto buffer and therefore not human
239 // readable. So we comment out the following line.
240 // ost << ToStringIfSet("audio_network_adaptor_config",
241 // audio_network_adaptor_config);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000242 ost << "}";
243 return ost.str();
244 }
245
246 // Audio processing that attempts to filter away the output signal from
247 // later inbound pickup.
Karl Wibergbe579832015-11-10 22:34:18 +0100248 rtc::Optional<bool> echo_cancellation;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000249 // Audio processing to adjust the sensitivity of the local mic dynamically.
Karl Wibergbe579832015-11-10 22:34:18 +0100250 rtc::Optional<bool> auto_gain_control;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000251 // Audio processing to filter out background noise.
Karl Wibergbe579832015-11-10 22:34:18 +0100252 rtc::Optional<bool> noise_suppression;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000253 // Audio processing to remove background noise of lower frequencies.
Karl Wibergbe579832015-11-10 22:34:18 +0100254 rtc::Optional<bool> highpass_filter;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000255 // Audio processing to swap the left and right channels.
Karl Wibergbe579832015-11-10 22:34:18 +0100256 rtc::Optional<bool> stereo_swapping;
Henrik Lundin64dad832015-05-11 12:44:23 +0200257 // Audio receiver jitter buffer (NetEq) max capacity in number of packets.
Karl Wibergbe579832015-11-10 22:34:18 +0100258 rtc::Optional<int> audio_jitter_buffer_max_packets;
Henrik Lundin5263b3c2015-06-01 10:29:41 +0200259 // Audio receiver jitter buffer (NetEq) fast accelerate mode.
Karl Wibergbe579832015-11-10 22:34:18 +0100260 rtc::Optional<bool> audio_jitter_buffer_fast_accelerate;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000261 // Audio processing to detect typing.
Karl Wibergbe579832015-11-10 22:34:18 +0100262 rtc::Optional<bool> typing_detection;
263 rtc::Optional<bool> aecm_generate_comfort_noise;
Karl Wibergbe579832015-11-10 22:34:18 +0100264 rtc::Optional<int> adjust_agc_delta;
265 rtc::Optional<bool> experimental_agc;
266 rtc::Optional<bool> extended_filter_aec;
267 rtc::Optional<bool> delay_agnostic_aec;
268 rtc::Optional<bool> experimental_ns;
Alejandro Luebsc9b0c262016-05-16 15:32:38 -0700269 rtc::Optional<bool> intelligibility_enhancer;
peaha3333bf2016-06-30 00:02:34 -0700270 rtc::Optional<bool> level_control;
aleloie33c5d92016-10-20 01:53:27 -0700271 // Specifies an optional initialization value for the level controller.
272 rtc::Optional<float> level_control_initial_peak_level_dbfs;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000273 // Note that tx_agc_* only applies to non-experimental AGC.
Karl Wibergbe579832015-11-10 22:34:18 +0100274 rtc::Optional<uint16_t> tx_agc_target_dbov;
275 rtc::Optional<uint16_t> tx_agc_digital_compression_gain;
276 rtc::Optional<bool> tx_agc_limiter;
277 rtc::Optional<uint32_t> recording_sample_rate;
278 rtc::Optional<uint32_t> playout_sample_rate;
buildbot@webrtc.orgb4c7b092014-08-25 12:11:58 +0000279 // Enable combined audio+bandwidth BWE.
nisse51542be2016-02-12 02:27:06 -0800280 // TODO(pthatcher): This flag is set from the
281 // "googCombinedAudioVideoBwe", but not used anywhere. So delete it,
282 // and check if any other AudioOptions members are unused.
Karl Wibergbe579832015-11-10 22:34:18 +0100283 rtc::Optional<bool> combined_audio_video_bwe;
minyue6b825df2016-10-31 04:08:32 -0700284 // Enable audio network adaptor.
285 rtc::Optional<bool> audio_network_adaptor;
286 // Config string for audio network adaptor.
287 rtc::Optional<std::string> audio_network_adaptor_config;
kwiberg102c6a62015-10-30 02:47:38 -0700288
289 private:
290 template <typename T>
Karl Wibergbe579832015-11-10 22:34:18 +0100291 static void SetFrom(rtc::Optional<T>* s, const rtc::Optional<T>& o) {
kwiberg102c6a62015-10-30 02:47:38 -0700292 if (o) {
293 *s = o;
294 }
295 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000296};
297
298// Options that can be applied to a VideoMediaChannel or a VideoMediaEngine.
299// Used to be flags, but that makes it hard to selectively apply options.
300// We are moving all of the setting of options to structs like this,
301// but some things currently still use flags.
302struct VideoOptions {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000303 void SetAll(const VideoOptions& change) {
kwiberg102c6a62015-10-30 02:47:38 -0700304 SetFrom(&video_noise_reduction, change.video_noise_reduction);
nisseb163c3f2016-01-29 01:14:38 -0800305 SetFrom(&screencast_min_bitrate_kbps, change.screencast_min_bitrate_kbps);
Niels Möller60653ba2016-03-02 11:41:36 +0100306 SetFrom(&is_screencast, change.is_screencast);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000307 }
308
309 bool operator==(const VideoOptions& o) const {
nisseb163c3f2016-01-29 01:14:38 -0800310 return video_noise_reduction == o.video_noise_reduction &&
Niels Möller60653ba2016-03-02 11:41:36 +0100311 screencast_min_bitrate_kbps == o.screencast_min_bitrate_kbps &&
312 is_screencast == o.is_screencast;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000313 }
deadbeef119760a2016-04-04 11:43:27 -0700314 bool operator!=(const VideoOptions& o) const { return !(*this == o); }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000315
316 std::string ToString() const {
317 std::ostringstream ost;
318 ost << "VideoOptions {";
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000319 ost << ToStringIfSet("noise reduction", video_noise_reduction);
nisseb163c3f2016-01-29 01:14:38 -0800320 ost << ToStringIfSet("screencast min bitrate kbps",
321 screencast_min_bitrate_kbps);
Niels Möller60653ba2016-03-02 11:41:36 +0100322 ost << ToStringIfSet("is_screencast ", is_screencast);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000323 ost << "}";
324 return ost.str();
325 }
326
nisseb163c3f2016-01-29 01:14:38 -0800327 // Enable denoising? This flag comes from the getUserMedia
328 // constraint 'googNoiseReduction', and WebRtcVideoEngine2 passes it
329 // on to the codec options. Disabled by default.
Karl Wibergbe579832015-11-10 22:34:18 +0100330 rtc::Optional<bool> video_noise_reduction;
nisseb163c3f2016-01-29 01:14:38 -0800331 // Force screencast to use a minimum bitrate. This flag comes from
332 // the PeerConnection constraint 'googScreencastMinBitrate'. It is
333 // copied to the encoder config by WebRtcVideoChannel2.
334 rtc::Optional<int> screencast_min_bitrate_kbps;
Niels Möller60653ba2016-03-02 11:41:36 +0100335 // Set by screencast sources. Implies selection of encoding settings
336 // suitable for screencast. Most likely not the right way to do
337 // things, e.g., screencast of a text document and screencast of a
338 // youtube video have different needs.
339 rtc::Optional<bool> is_screencast;
kwiberg102c6a62015-10-30 02:47:38 -0700340
341 private:
342 template <typename T>
Karl Wibergbe579832015-11-10 22:34:18 +0100343 static void SetFrom(rtc::Optional<T>* s, const rtc::Optional<T>& o) {
kwiberg102c6a62015-10-30 02:47:38 -0700344 if (o) {
345 *s = o;
346 }
347 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000348};
349
isheriffa1c548b2016-05-31 16:12:24 -0700350// TODO(isheriff): Remove this once client usage is fixed to use RtpExtension.
351struct RtpHeaderExtension {
352 RtpHeaderExtension() : id(0) {}
353 RtpHeaderExtension(const std::string& uri, int id) : uri(uri), id(id) {}
354
355 std::string ToString() const {
356 std::ostringstream ost;
357 ost << "{";
358 ost << "uri: " << uri;
359 ost << ", id: " << id;
360 ost << "}";
361 return ost.str();
362 }
363
364 std::string uri;
365 int id;
366};
367
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000368class MediaChannel : public sigslot::has_slots<> {
369 public:
370 class NetworkInterface {
371 public:
372 enum SocketType { ST_RTP, ST_RTCP };
jbaucheec21bd2016-03-20 06:15:43 -0700373 virtual bool SendPacket(rtc::CopyOnWriteBuffer* packet,
stefanc1aeaf02015-10-15 07:26:07 -0700374 const rtc::PacketOptions& options) = 0;
jbaucheec21bd2016-03-20 06:15:43 -0700375 virtual bool SendRtcp(rtc::CopyOnWriteBuffer* packet,
stefanc1aeaf02015-10-15 07:26:07 -0700376 const rtc::PacketOptions& options) = 0;
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000377 virtual int SetOption(SocketType type, rtc::Socket::Option opt,
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000378 int option) = 0;
379 virtual ~NetworkInterface() {}
380 };
381
terelius54f91712016-06-01 11:18:56 -0700382 explicit MediaChannel(const MediaConfig& config)
nisse51542be2016-02-12 02:27:06 -0800383 : enable_dscp_(config.enable_dscp), network_interface_(NULL) {}
384 MediaChannel() : enable_dscp_(false), network_interface_(NULL) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000385 virtual ~MediaChannel() {}
386
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000387 // Sets the abstract interface class for sending RTP/RTCP data.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000388 virtual void SetInterface(NetworkInterface *iface) {
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000389 rtc::CritScope cs(&network_interface_crit_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000390 network_interface_ = iface;
nisse51542be2016-02-12 02:27:06 -0800391 SetDscp(enable_dscp_ ? PreferredDscp() : rtc::DSCP_DEFAULT);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000392 }
nisse51542be2016-02-12 02:27:06 -0800393 virtual rtc::DiffServCodePoint PreferredDscp() const {
394 return rtc::DSCP_DEFAULT;
395 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000396 // Called when a RTP packet is received.
jbaucheec21bd2016-03-20 06:15:43 -0700397 virtual void OnPacketReceived(rtc::CopyOnWriteBuffer* packet,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000398 const rtc::PacketTime& packet_time) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000399 // Called when a RTCP packet is received.
jbaucheec21bd2016-03-20 06:15:43 -0700400 virtual void OnRtcpReceived(rtc::CopyOnWriteBuffer* packet,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000401 const rtc::PacketTime& packet_time) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000402 // Called when the socket's ability to send has changed.
403 virtual void OnReadyToSend(bool ready) = 0;
Honghai Zhangcc411c02016-03-29 17:27:21 -0700404 // Called when the network route used for sending packets changed.
Honghai Zhang0e533ef2016-04-19 15:41:36 -0700405 virtual void OnNetworkRouteChanged(
406 const std::string& transport_name,
407 const rtc::NetworkRoute& network_route) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000408 // Creates a new outgoing media stream with SSRCs and CNAME as described
409 // by sp.
410 virtual bool AddSendStream(const StreamParams& sp) = 0;
411 // Removes an outgoing media stream.
412 // ssrc must be the first SSRC of the media stream if the stream uses
413 // multiple SSRCs.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200414 virtual bool RemoveSendStream(uint32_t ssrc) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000415 // Creates a new incoming media stream with SSRCs and CNAME as described
416 // by sp.
417 virtual bool AddRecvStream(const StreamParams& sp) = 0;
418 // Removes an incoming media stream.
419 // ssrc must be the first SSRC of the media stream if the stream uses
420 // multiple SSRCs.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200421 virtual bool RemoveRecvStream(uint32_t ssrc) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000422
mallinath@webrtc.org92fdfeb2014-02-17 18:49:41 +0000423 // Returns the absoulte sendtime extension id value from media channel.
424 virtual int GetRtpSendTimeExtnId() const {
425 return -1;
426 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000427
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000428 // Base method to send packet using NetworkInterface.
jbaucheec21bd2016-03-20 06:15:43 -0700429 bool SendPacket(rtc::CopyOnWriteBuffer* packet,
430 const rtc::PacketOptions& options) {
stefanc1aeaf02015-10-15 07:26:07 -0700431 return DoSendPacket(packet, false, options);
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000432 }
433
jbaucheec21bd2016-03-20 06:15:43 -0700434 bool SendRtcp(rtc::CopyOnWriteBuffer* packet,
435 const rtc::PacketOptions& options) {
stefanc1aeaf02015-10-15 07:26:07 -0700436 return DoSendPacket(packet, true, options);
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000437 }
438
439 int SetOption(NetworkInterface::SocketType type,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000440 rtc::Socket::Option opt,
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000441 int option) {
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000442 rtc::CritScope cs(&network_interface_crit_);
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000443 if (!network_interface_)
444 return -1;
445
446 return network_interface_->SetOption(type, opt, option);
447 }
448
nisse51542be2016-02-12 02:27:06 -0800449 private:
wu@webrtc.orgde305012013-10-31 15:40:38 +0000450 // This method sets DSCP |value| on both RTP and RTCP channels.
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000451 int SetDscp(rtc::DiffServCodePoint value) {
wu@webrtc.orgde305012013-10-31 15:40:38 +0000452 int ret;
453 ret = SetOption(NetworkInterface::ST_RTP,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000454 rtc::Socket::OPT_DSCP,
wu@webrtc.orgde305012013-10-31 15:40:38 +0000455 value);
456 if (ret == 0) {
457 ret = SetOption(NetworkInterface::ST_RTCP,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000458 rtc::Socket::OPT_DSCP,
wu@webrtc.orgde305012013-10-31 15:40:38 +0000459 value);
460 }
461 return ret;
462 }
463
jbaucheec21bd2016-03-20 06:15:43 -0700464 bool DoSendPacket(rtc::CopyOnWriteBuffer* packet,
stefanc1aeaf02015-10-15 07:26:07 -0700465 bool rtcp,
466 const rtc::PacketOptions& options) {
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000467 rtc::CritScope cs(&network_interface_crit_);
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000468 if (!network_interface_)
469 return false;
470
stefanc1aeaf02015-10-15 07:26:07 -0700471 return (!rtcp) ? network_interface_->SendPacket(packet, options)
472 : network_interface_->SendRtcp(packet, options);
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000473 }
474
nisse51542be2016-02-12 02:27:06 -0800475 const bool enable_dscp_;
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000476 // |network_interface_| can be accessed from the worker_thread and
477 // from any MediaEngine threads. This critical section is to protect accessing
478 // of network_interface_ object.
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000479 rtc::CriticalSection network_interface_crit_;
henrike@webrtc.org1e09a712013-07-26 19:17:59 +0000480 NetworkInterface* network_interface_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000481};
482
wu@webrtc.org97077a32013-10-25 21:18:33 +0000483// The stats information is structured as follows:
484// Media are represented by either MediaSenderInfo or MediaReceiverInfo.
485// Media contains a vector of SSRC infos that are exclusively used by this
486// media. (SSRCs shared between media streams can't be represented.)
487
488// Information about an SSRC.
489// This data may be locally recorded, or received in an RTCP SR or RR.
490struct SsrcSenderInfo {
491 SsrcSenderInfo()
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000492 : ssrc(0),
wu@webrtc.org97077a32013-10-25 21:18:33 +0000493 timestamp(0) {
494 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200495 uint32_t ssrc;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000496 double timestamp; // NTP timestamp, represented as seconds since epoch.
497};
498
499struct SsrcReceiverInfo {
500 SsrcReceiverInfo()
501 : ssrc(0),
502 timestamp(0) {
503 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200504 uint32_t ssrc;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000505 double timestamp;
506};
507
508struct MediaSenderInfo {
509 MediaSenderInfo()
510 : bytes_sent(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000511 packets_sent(0),
512 packets_lost(0),
513 fraction_lost(0.0),
wu@webrtc.org97077a32013-10-25 21:18:33 +0000514 rtt_ms(0) {
515 }
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000516 void add_ssrc(const SsrcSenderInfo& stat) {
517 local_stats.push_back(stat);
518 }
519 // Temporary utility function for call sites that only provide SSRC.
520 // As more info is added into SsrcSenderInfo, this function should go away.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200521 void add_ssrc(uint32_t ssrc) {
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000522 SsrcSenderInfo stat;
523 stat.ssrc = ssrc;
524 add_ssrc(stat);
525 }
526 // Utility accessor for clients that are only interested in ssrc numbers.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200527 std::vector<uint32_t> ssrcs() const {
528 std::vector<uint32_t> retval;
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000529 for (std::vector<SsrcSenderInfo>::const_iterator it = local_stats.begin();
530 it != local_stats.end(); ++it) {
531 retval.push_back(it->ssrc);
532 }
533 return retval;
534 }
535 // Utility accessor for clients that make the assumption only one ssrc
536 // exists per media.
537 // This will eventually go away.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200538 uint32_t ssrc() const {
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000539 if (local_stats.size() > 0) {
540 return local_stats[0].ssrc;
541 } else {
542 return 0;
543 }
544 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200545 int64_t bytes_sent;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000546 int packets_sent;
547 int packets_lost;
548 float fraction_lost;
pkasting@chromium.org16825b12015-01-12 21:51:21 +0000549 int64_t rtt_ms;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000550 std::string codec_name;
551 std::vector<SsrcSenderInfo> local_stats;
552 std::vector<SsrcReceiverInfo> remote_stats;
553};
554
555struct MediaReceiverInfo {
556 MediaReceiverInfo()
557 : bytes_rcvd(0),
558 packets_rcvd(0),
559 packets_lost(0),
560 fraction_lost(0.0) {
561 }
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000562 void add_ssrc(const SsrcReceiverInfo& stat) {
563 local_stats.push_back(stat);
564 }
565 // Temporary utility function for call sites that only provide SSRC.
566 // As more info is added into SsrcSenderInfo, this function should go away.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200567 void add_ssrc(uint32_t ssrc) {
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000568 SsrcReceiverInfo stat;
569 stat.ssrc = ssrc;
570 add_ssrc(stat);
571 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200572 std::vector<uint32_t> ssrcs() const {
573 std::vector<uint32_t> retval;
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000574 for (std::vector<SsrcReceiverInfo>::const_iterator it = local_stats.begin();
575 it != local_stats.end(); ++it) {
576 retval.push_back(it->ssrc);
577 }
578 return retval;
579 }
580 // Utility accessor for clients that make the assumption only one ssrc
581 // exists per media.
582 // This will eventually go away.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200583 uint32_t ssrc() const {
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000584 if (local_stats.size() > 0) {
585 return local_stats[0].ssrc;
586 } else {
587 return 0;
588 }
589 }
590
Peter Boström0c4e06b2015-10-07 12:23:21 +0200591 int64_t bytes_rcvd;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000592 int packets_rcvd;
593 int packets_lost;
594 float fraction_lost;
buildbot@webrtc.org7e71b772014-06-13 01:14:01 +0000595 std::string codec_name;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000596 std::vector<SsrcReceiverInfo> local_stats;
597 std::vector<SsrcSenderInfo> remote_stats;
598};
599
600struct VoiceSenderInfo : public MediaSenderInfo {
601 VoiceSenderInfo()
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000602 : ext_seqnum(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000603 jitter_ms(0),
604 audio_level(0),
605 aec_quality_min(0.0),
606 echo_delay_median_ms(0),
607 echo_delay_std_ms(0),
608 echo_return_loss(0),
wu@webrtc.org967bfff2013-09-19 05:49:50 +0000609 echo_return_loss_enhancement(0),
ivoc8c63a822016-10-21 04:10:03 -0700610 residual_echo_likelihood(0.0f),
wu@webrtc.org967bfff2013-09-19 05:49:50 +0000611 typing_noise_detected(false) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000612 }
613
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000614 int ext_seqnum;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000615 int jitter_ms;
616 int audio_level;
617 float aec_quality_min;
618 int echo_delay_median_ms;
619 int echo_delay_std_ms;
620 int echo_return_loss;
621 int echo_return_loss_enhancement;
ivoc8c63a822016-10-21 04:10:03 -0700622 float residual_echo_likelihood;
wu@webrtc.org967bfff2013-09-19 05:49:50 +0000623 bool typing_noise_detected;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000624};
625
wu@webrtc.org97077a32013-10-25 21:18:33 +0000626struct VoiceReceiverInfo : public MediaReceiverInfo {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000627 VoiceReceiverInfo()
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000628 : ext_seqnum(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000629 jitter_ms(0),
630 jitter_buffer_ms(0),
631 jitter_buffer_preferred_ms(0),
632 delay_estimate_ms(0),
633 audio_level(0),
henrike@webrtc.orgb8c254a2014-02-14 23:38:45 +0000634 expand_rate(0),
minyue@webrtc.orgc0bd7be2015-02-18 15:24:13 +0000635 speech_expand_rate(0),
636 secondary_decoded_rate(0),
Henrik Lundin8e6fd462015-06-02 09:24:52 +0200637 accelerate_rate(0),
638 preemptive_expand_rate(0),
henrike@webrtc.orgb8c254a2014-02-14 23:38:45 +0000639 decoding_calls_to_silence_generator(0),
640 decoding_calls_to_neteq(0),
641 decoding_normal(0),
642 decoding_plc(0),
643 decoding_cng(0),
buildbot@webrtc.orgb525a9d2014-06-03 09:42:15 +0000644 decoding_plc_cng(0),
henrik.lundin63489782016-09-20 01:47:12 -0700645 decoding_muted_output(0),
Henrik Lundin8e6fd462015-06-02 09:24:52 +0200646 capture_start_ntp_time_ms(-1) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000647
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000648 int ext_seqnum;
649 int jitter_ms;
650 int jitter_buffer_ms;
651 int jitter_buffer_preferred_ms;
652 int delay_estimate_ms;
653 int audio_level;
minyue@webrtc.orgc0bd7be2015-02-18 15:24:13 +0000654 // fraction of synthesized audio inserted through expansion.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000655 float expand_rate;
minyue@webrtc.orgc0bd7be2015-02-18 15:24:13 +0000656 // fraction of synthesized speech inserted through expansion.
657 float speech_expand_rate;
658 // fraction of data out of secondary decoding, including FEC and RED.
659 float secondary_decoded_rate;
Henrik Lundin8e6fd462015-06-02 09:24:52 +0200660 // Fraction of data removed through time compression.
661 float accelerate_rate;
662 // Fraction of data inserted through time stretching.
663 float preemptive_expand_rate;
henrike@webrtc.orgb8c254a2014-02-14 23:38:45 +0000664 int decoding_calls_to_silence_generator;
665 int decoding_calls_to_neteq;
666 int decoding_normal;
667 int decoding_plc;
668 int decoding_cng;
669 int decoding_plc_cng;
henrik.lundin63489782016-09-20 01:47:12 -0700670 int decoding_muted_output;
buildbot@webrtc.orgb525a9d2014-06-03 09:42:15 +0000671 // Estimated capture start time in NTP time in ms.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200672 int64_t capture_start_ntp_time_ms;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000673};
674
wu@webrtc.org97077a32013-10-25 21:18:33 +0000675struct VideoSenderInfo : public MediaSenderInfo {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000676 VideoSenderInfo()
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000677 : packets_cached(0),
678 firs_rcvd(0),
henrike@webrtc.org704bf9e2014-02-27 17:52:04 +0000679 plis_rcvd(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000680 nacks_rcvd(0),
wu@webrtc.org987f2c92014-03-28 16:22:19 +0000681 send_frame_width(0),
682 send_frame_height(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000683 framerate_input(0),
684 framerate_sent(0),
685 nominal_bitrate(0),
686 preferred_bitrate(0),
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000687 adapt_reason(0),
buildbot@webrtc.org71dffb72014-06-24 07:24:49 +0000688 adapt_changes(0),
wu@webrtc.org9caf2762013-12-11 18:25:07 +0000689 avg_encode_ms(0),
sakal43536c32016-10-24 01:46:43 -0700690 encode_usage_percent(0),
691 frames_encoded(0) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000692
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000693 std::vector<SsrcGroup> ssrc_groups;
Peter Boströmb7d9a972015-12-18 16:01:11 +0100694 std::string encoder_implementation_name;
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000695 int packets_cached;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000696 int firs_rcvd;
henrike@webrtc.org704bf9e2014-02-27 17:52:04 +0000697 int plis_rcvd;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000698 int nacks_rcvd;
wu@webrtc.org987f2c92014-03-28 16:22:19 +0000699 int send_frame_width;
700 int send_frame_height;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000701 int framerate_input;
702 int framerate_sent;
703 int nominal_bitrate;
704 int preferred_bitrate;
705 int adapt_reason;
buildbot@webrtc.org71dffb72014-06-24 07:24:49 +0000706 int adapt_changes;
sergeyu@chromium.org5bc25c42013-12-05 00:24:06 +0000707 int avg_encode_ms;
wu@webrtc.org9caf2762013-12-11 18:25:07 +0000708 int encode_usage_percent;
sakal43536c32016-10-24 01:46:43 -0700709 uint32_t frames_encoded;
sakal87da4042016-10-31 06:53:47 -0700710 rtc::Optional<uint64_t> qp_sum;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000711};
712
wu@webrtc.org97077a32013-10-25 21:18:33 +0000713struct VideoReceiverInfo : public MediaReceiverInfo {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000714 VideoReceiverInfo()
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000715 : packets_concealed(0),
716 firs_sent(0),
henrike@webrtc.org704bf9e2014-02-27 17:52:04 +0000717 plis_sent(0),
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000718 nacks_sent(0),
719 frame_width(0),
720 frame_height(0),
721 framerate_rcvd(0),
722 framerate_decoded(0),
723 framerate_output(0),
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000724 framerate_render_input(0),
725 framerate_render_output(0),
sakale5ba44e2016-10-26 07:09:24 -0700726 frames_decoded(0),
wu@webrtc.org97077a32013-10-25 21:18:33 +0000727 decode_ms(0),
728 max_decode_ms(0),
729 jitter_buffer_ms(0),
730 min_playout_delay_ms(0),
731 render_delay_ms(0),
732 target_delay_ms(0),
buildbot@webrtc.org0581f0b2014-05-06 21:36:31 +0000733 current_delay_ms(0),
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000734 capture_start_ntp_time_ms(-1) {
735 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000736
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000737 std::vector<SsrcGroup> ssrc_groups;
Peter Boströmb7d9a972015-12-18 16:01:11 +0100738 std::string decoder_implementation_name;
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000739 int packets_concealed;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000740 int firs_sent;
henrike@webrtc.org704bf9e2014-02-27 17:52:04 +0000741 int plis_sent;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000742 int nacks_sent;
743 int frame_width;
744 int frame_height;
745 int framerate_rcvd;
746 int framerate_decoded;
747 int framerate_output;
pbos@webrtc.org1ed62242015-02-19 13:57:03 +0000748 // Framerate as sent to the renderer.
749 int framerate_render_input;
750 // Framerate that the renderer reports.
751 int framerate_render_output;
sakale5ba44e2016-10-26 07:09:24 -0700752 uint32_t frames_decoded;
wu@webrtc.org97077a32013-10-25 21:18:33 +0000753
754 // All stats below are gathered per-VideoReceiver, but some will be correlated
755 // across MediaStreamTracks. NOTE(hta): when sinking stats into per-SSRC
756 // structures, reflect this in the new layout.
757
758 // Current frame decode latency.
759 int decode_ms;
760 // Maximum observed frame decode latency.
761 int max_decode_ms;
762 // Jitter (network-related) latency.
763 int jitter_buffer_ms;
764 // Requested minimum playout latency.
765 int min_playout_delay_ms;
766 // Requested latency to account for rendering delay.
767 int render_delay_ms;
768 // Target overall delay: network+decode+render, accounting for
769 // min_playout_delay_ms.
770 int target_delay_ms;
771 // Current overall delay, possibly ramping towards target_delay_ms.
772 int current_delay_ms;
buildbot@webrtc.org0581f0b2014-05-06 21:36:31 +0000773
774 // Estimated capture start time in NTP time in ms.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200775 int64_t capture_start_ntp_time_ms;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000776};
777
wu@webrtc.org97077a32013-10-25 21:18:33 +0000778struct DataSenderInfo : public MediaSenderInfo {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000779 DataSenderInfo()
wu@webrtc.org97077a32013-10-25 21:18:33 +0000780 : ssrc(0) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000781 }
782
Peter Boström0c4e06b2015-10-07 12:23:21 +0200783 uint32_t ssrc;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000784};
785
wu@webrtc.org97077a32013-10-25 21:18:33 +0000786struct DataReceiverInfo : public MediaReceiverInfo {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000787 DataReceiverInfo()
wu@webrtc.org97077a32013-10-25 21:18:33 +0000788 : ssrc(0) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000789 }
790
Peter Boström0c4e06b2015-10-07 12:23:21 +0200791 uint32_t ssrc;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000792};
793
794struct BandwidthEstimationInfo {
795 BandwidthEstimationInfo()
796 : available_send_bandwidth(0),
797 available_recv_bandwidth(0),
798 target_enc_bitrate(0),
799 actual_enc_bitrate(0),
800 retransmit_bitrate(0),
801 transmit_bitrate(0),
pbos@webrtc.org058b1f12015-03-04 08:54:32 +0000802 bucket_delay(0) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000803 }
804
805 int available_send_bandwidth;
806 int available_recv_bandwidth;
807 int target_enc_bitrate;
808 int actual_enc_bitrate;
809 int retransmit_bitrate;
810 int transmit_bitrate;
pkasting@chromium.org16825b12015-01-12 21:51:21 +0000811 int64_t bucket_delay;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000812};
813
814struct VoiceMediaInfo {
815 void Clear() {
816 senders.clear();
817 receivers.clear();
818 }
819 std::vector<VoiceSenderInfo> senders;
820 std::vector<VoiceReceiverInfo> receivers;
821};
822
823struct VideoMediaInfo {
824 void Clear() {
825 senders.clear();
826 receivers.clear();
827 bw_estimations.clear();
828 }
829 std::vector<VideoSenderInfo> senders;
830 std::vector<VideoReceiverInfo> receivers;
831 std::vector<BandwidthEstimationInfo> bw_estimations;
832};
833
834struct DataMediaInfo {
835 void Clear() {
836 senders.clear();
837 receivers.clear();
838 }
839 std::vector<DataSenderInfo> senders;
840 std::vector<DataReceiverInfo> receivers;
841};
842
deadbeef13871492015-12-09 12:37:51 -0800843struct RtcpParameters {
844 bool reduced_size = false;
845};
846
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700847template <class Codec>
848struct RtpParameters {
solenberg7e4e01a2015-12-02 08:05:01 -0800849 virtual std::string ToString() const {
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700850 std::ostringstream ost;
851 ost << "{";
852 ost << "codecs: " << VectorToString(codecs) << ", ";
853 ost << "extensions: " << VectorToString(extensions);
854 ost << "}";
855 return ost.str();
856 }
857
858 std::vector<Codec> codecs;
isheriff6f8d6862016-05-26 11:24:55 -0700859 std::vector<webrtc::RtpExtension> extensions;
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700860 // TODO(pthatcher): Add streams.
deadbeef13871492015-12-09 12:37:51 -0800861 RtcpParameters rtcp;
Henrik Kjellander3fe372d2016-05-12 08:10:52 +0200862 virtual ~RtpParameters() = default;
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700863};
864
Taylor Brandstetter5f0b83b2016-03-18 15:02:07 -0700865// TODO(deadbeef): Rename to RtpSenderParameters, since they're intended to
866// encapsulate all the parameters needed for an RtpSender.
nisse05103312016-03-16 02:22:50 -0700867template <class Codec>
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700868struct RtpSendParameters : RtpParameters<Codec> {
solenberg7e4e01a2015-12-02 08:05:01 -0800869 std::string ToString() const override {
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700870 std::ostringstream ost;
871 ost << "{";
872 ost << "codecs: " << VectorToString(this->codecs) << ", ";
873 ost << "extensions: " << VectorToString(this->extensions) << ", ";
pbos378dc772016-01-28 15:58:41 -0800874 ost << "max_bandwidth_bps: " << max_bandwidth_bps << ", ";
nisse05103312016-03-16 02:22:50 -0700875 ost << "}";
876 return ost.str();
877 }
878
879 int max_bandwidth_bps = -1;
880};
881
882struct AudioSendParameters : RtpSendParameters<AudioCodec> {
883 std::string ToString() const override {
884 std::ostringstream ost;
885 ost << "{";
886 ost << "codecs: " << VectorToString(this->codecs) << ", ";
887 ost << "extensions: " << VectorToString(this->extensions) << ", ";
888 ost << "max_bandwidth_bps: " << max_bandwidth_bps << ", ";
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700889 ost << "options: " << options.ToString();
890 ost << "}";
891 return ost.str();
892 }
893
nisse05103312016-03-16 02:22:50 -0700894 AudioOptions options;
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700895};
896
897struct AudioRecvParameters : RtpParameters<AudioCodec> {
898};
899
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000900class VoiceMediaChannel : public MediaChannel {
901 public:
902 enum Error {
903 ERROR_NONE = 0, // No error.
904 ERROR_OTHER, // Other errors.
905 ERROR_REC_DEVICE_OPEN_FAILED = 100, // Could not open mic.
906 ERROR_REC_DEVICE_MUTED, // Mic was muted by OS.
907 ERROR_REC_DEVICE_SILENT, // No background noise picked up.
908 ERROR_REC_DEVICE_SATURATION, // Mic input is clipping.
909 ERROR_REC_DEVICE_REMOVED, // Mic was removed while active.
910 ERROR_REC_RUNTIME_ERROR, // Processing is encountering errors.
911 ERROR_REC_SRTP_ERROR, // Generic SRTP failure.
912 ERROR_REC_SRTP_AUTH_FAILED, // Failed to authenticate packets.
913 ERROR_REC_TYPING_NOISE_DETECTED, // Typing noise is detected.
914 ERROR_PLAY_DEVICE_OPEN_FAILED = 200, // Could not open playout.
915 ERROR_PLAY_DEVICE_MUTED, // Playout muted by OS.
916 ERROR_PLAY_DEVICE_REMOVED, // Playout removed while active.
917 ERROR_PLAY_RUNTIME_ERROR, // Errors in voice processing.
918 ERROR_PLAY_SRTP_ERROR, // Generic SRTP failure.
919 ERROR_PLAY_SRTP_AUTH_FAILED, // Failed to authenticate packets.
920 ERROR_PLAY_SRTP_REPLAY, // Packet replay detected.
921 };
922
923 VoiceMediaChannel() {}
terelius54f91712016-06-01 11:18:56 -0700924 explicit VoiceMediaChannel(const MediaConfig& config)
925 : MediaChannel(config) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000926 virtual ~VoiceMediaChannel() {}
Fredrik Solenbergb071a192015-09-17 16:42:56 +0200927 virtual bool SetSendParameters(const AudioSendParameters& params) = 0;
928 virtual bool SetRecvParameters(const AudioRecvParameters& params) = 0;
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -0700929 virtual webrtc::RtpParameters GetRtpSendParameters(uint32_t ssrc) const = 0;
930 virtual bool SetRtpSendParameters(
931 uint32_t ssrc,
932 const webrtc::RtpParameters& parameters) = 0;
933 virtual webrtc::RtpParameters GetRtpReceiveParameters(
934 uint32_t ssrc) const = 0;
935 virtual bool SetRtpReceiveParameters(
936 uint32_t ssrc,
937 const webrtc::RtpParameters& parameters) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000938 // Starts or stops playout of received audio.
aleloi84ef6152016-08-04 05:28:21 -0700939 virtual void SetPlayout(bool playout) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000940 // Starts or stops sending (and potentially capture) of local audio.
Taylor Brandstetter1a018dc2016-03-08 12:37:39 -0800941 virtual void SetSend(bool send) = 0;
solenberg1dd98f32015-09-10 01:57:14 -0700942 // Configure stream for sending.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200943 virtual bool SetAudioSend(uint32_t ssrc,
944 bool enable,
solenbergdfc8f4f2015-10-01 02:31:10 -0700945 const AudioOptions* options,
Taylor Brandstetter1a018dc2016-03-08 12:37:39 -0800946 AudioSource* source) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000947 // Gets current energy levels for all incoming streams.
948 virtual bool GetActiveStreams(AudioInfo::StreamList* actives) = 0;
949 // Get the current energy level of the stream sent to the speaker.
950 virtual int GetOutputLevel() = 0;
951 // Get the time in milliseconds since last recorded keystroke, or negative.
952 virtual int GetTimeSinceLastTyping() = 0;
953 // Temporarily exposed field for tuning typing detect options.
954 virtual void SetTypingDetectionParameters(int time_window,
955 int cost_per_typing, int reporting_threshold, int penalty_decay,
956 int type_event_delay) = 0;
solenberg4bac9c52015-10-09 02:32:53 -0700957 // Set speaker output volume of the specified ssrc.
958 virtual bool SetOutputVolume(uint32_t ssrc, double volume) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000959 // Returns if the telephone-event has been negotiated.
solenberg1d63dd02015-12-02 12:35:09 -0800960 virtual bool CanInsertDtmf() = 0;
961 // Send a DTMF |event|. The DTMF out-of-band signal will be used.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000962 // The |ssrc| should be either 0 or a valid send stream ssrc.
henrike@webrtc.org9de257d2013-07-17 14:42:53 +0000963 // The valid value for the |event| are 0 to 15 which corresponding to
964 // DTMF event 0-9, *, #, A-D.
solenberg1d63dd02015-12-02 12:35:09 -0800965 virtual bool InsertDtmf(uint32_t ssrc, int event, int duration) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000966 // Gets quality stats for the channel.
967 virtual bool GetStats(VoiceMediaInfo* info) = 0;
Tommif888bb52015-12-12 01:37:01 +0100968
969 virtual void SetRawAudioSink(
970 uint32_t ssrc,
kwiberg686a8ef2016-02-26 03:00:35 -0800971 std::unique_ptr<webrtc::AudioSinkInterface> sink) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000972};
973
Taylor Brandstetter5f0b83b2016-03-18 15:02:07 -0700974// TODO(deadbeef): Rename to VideoSenderParameters, since they're intended to
975// encapsulate all the parameters needed for a video RtpSender.
nisse05103312016-03-16 02:22:50 -0700976struct VideoSendParameters : RtpSendParameters<VideoCodec> {
nisse4b4dc862016-02-17 05:25:36 -0800977 // Use conference mode? This flag comes from the remote
978 // description's SDP line 'a=x-google-flag:conference', copied over
979 // by VideoChannel::SetRemoteContent_w, and ultimately used by
980 // conference mode screencast logic in
981 // WebRtcVideoChannel2::WebRtcVideoSendStream::CreateVideoEncoderConfig.
982 // The special screencast behaviour is disabled by default.
983 bool conference_mode = false;
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700984};
985
Taylor Brandstetter5f0b83b2016-03-18 15:02:07 -0700986// TODO(deadbeef): Rename to VideoReceiverParameters, since they're intended to
987// encapsulate all the parameters needed for a video RtpReceiver.
Peter Thatcherc2ee2c82015-08-07 16:05:34 -0700988struct VideoRecvParameters : RtpParameters<VideoCodec> {
989};
990
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000991class VideoMediaChannel : public MediaChannel {
992 public:
993 enum Error {
994 ERROR_NONE = 0, // No error.
995 ERROR_OTHER, // Other errors.
996 ERROR_REC_DEVICE_OPEN_FAILED = 100, // Could not open camera.
997 ERROR_REC_DEVICE_NO_DEVICE, // No camera.
998 ERROR_REC_DEVICE_IN_USE, // Device is in already use.
999 ERROR_REC_DEVICE_REMOVED, // Device is removed.
1000 ERROR_REC_SRTP_ERROR, // Generic sender SRTP failure.
1001 ERROR_REC_SRTP_AUTH_FAILED, // Failed to authenticate packets.
1002 ERROR_REC_CPU_MAX_CANT_DOWNGRADE, // Can't downgrade capture anymore.
1003 ERROR_PLAY_SRTP_ERROR = 200, // Generic receiver SRTP failure.
1004 ERROR_PLAY_SRTP_AUTH_FAILED, // Failed to authenticate packets.
1005 ERROR_PLAY_SRTP_REPLAY, // Packet replay detected.
1006 };
1007
nisse08582ff2016-02-04 01:24:52 -08001008 VideoMediaChannel() {}
terelius54f91712016-06-01 11:18:56 -07001009 explicit VideoMediaChannel(const MediaConfig& config)
1010 : MediaChannel(config) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001011 virtual ~VideoMediaChannel() {}
Fredrik Solenbergb071a192015-09-17 16:42:56 +02001012
1013 virtual bool SetSendParameters(const VideoSendParameters& params) = 0;
1014 virtual bool SetRecvParameters(const VideoRecvParameters& params) = 0;
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -07001015 virtual webrtc::RtpParameters GetRtpSendParameters(uint32_t ssrc) const = 0;
1016 virtual bool SetRtpSendParameters(
1017 uint32_t ssrc,
1018 const webrtc::RtpParameters& parameters) = 0;
1019 virtual webrtc::RtpParameters GetRtpReceiveParameters(
1020 uint32_t ssrc) const = 0;
1021 virtual bool SetRtpReceiveParameters(
1022 uint32_t ssrc,
1023 const webrtc::RtpParameters& parameters) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001024 // Gets the currently set codecs/payload types to be used for outgoing media.
1025 virtual bool GetSendCodec(VideoCodec* send_codec) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001026 // Starts or stops transmission (and potentially capture) of local video.
1027 virtual bool SetSend(bool send) = 0;
deadbeef5a4a75a2016-06-02 16:23:38 -07001028 // Configure stream for sending and register a source.
1029 // The |ssrc| must correspond to a registered send stream.
1030 virtual bool SetVideoSend(
1031 uint32_t ssrc,
1032 bool enable,
1033 const VideoOptions* options,
1034 rtc::VideoSourceInterface<cricket::VideoFrame>* source) = 0;
nisse08582ff2016-02-04 01:24:52 -08001035 // Sets the sink object to be used for the specified stream.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001036 // If SSRC is 0, the renderer is used for the 'default' stream.
nisse08582ff2016-02-04 01:24:52 -08001037 virtual bool SetSink(uint32_t ssrc,
1038 rtc::VideoSinkInterface<cricket::VideoFrame>* sink) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001039 // Gets quality stats for the channel.
pbos@webrtc.org058b1f12015-03-04 08:54:32 +00001040 virtual bool GetStats(VideoMediaInfo* info) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001041};
1042
1043enum DataMessageType {
mallinath@webrtc.org1112c302013-09-23 20:34:45 +00001044 // Chrome-Internal use only. See SctpDataMediaChannel for the actual PPID
1045 // values.
1046 DMT_NONE = 0,
1047 DMT_CONTROL = 1,
1048 DMT_BINARY = 2,
1049 DMT_TEXT = 3,
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001050};
1051
1052// Info about data received in DataMediaChannel. For use in
1053// DataMediaChannel::SignalDataReceived and in all of the signals that
1054// signal fires, on up the chain.
1055struct ReceiveDataParams {
1056 // The in-packet stream indentifier.
1057 // For SCTP, this is really SID, not SSRC.
Peter Boström0c4e06b2015-10-07 12:23:21 +02001058 uint32_t ssrc;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001059 // The type of message (binary, text, or control).
1060 DataMessageType type;
1061 // A per-stream value incremented per packet in the stream.
1062 int seq_num;
1063 // A per-stream value monotonically increasing with time.
1064 int timestamp;
1065
1066 ReceiveDataParams() :
1067 ssrc(0),
1068 type(DMT_TEXT),
1069 seq_num(0),
1070 timestamp(0) {
1071 }
1072};
1073
1074struct SendDataParams {
1075 // The in-packet stream indentifier.
1076 // For SCTP, this is really SID, not SSRC.
Peter Boström0c4e06b2015-10-07 12:23:21 +02001077 uint32_t ssrc;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001078 // The type of message (binary, text, or control).
1079 DataMessageType type;
1080
1081 // For SCTP, whether to send messages flagged as ordered or not.
1082 // If false, messages can be received out of order.
1083 bool ordered;
1084 // For SCTP, whether the messages are sent reliably or not.
1085 // If false, messages may be lost.
1086 bool reliable;
1087 // For SCTP, if reliable == false, provide partial reliability by
1088 // resending up to this many times. Either count or millis
1089 // is supported, not both at the same time.
1090 int max_rtx_count;
1091 // For SCTP, if reliable == false, provide partial reliability by
1092 // resending for up to this many milliseconds. Either count or millis
1093 // is supported, not both at the same time.
1094 int max_rtx_ms;
1095
1096 SendDataParams() :
1097 ssrc(0),
1098 type(DMT_TEXT),
1099 // TODO(pthatcher): Make these true by default?
1100 ordered(false),
1101 reliable(false),
1102 max_rtx_count(0),
1103 max_rtx_ms(0) {
1104 }
1105};
1106
1107enum SendDataResult { SDR_SUCCESS, SDR_ERROR, SDR_BLOCK };
1108
nisse05103312016-03-16 02:22:50 -07001109struct DataSendParameters : RtpSendParameters<DataCodec> {
solenberg7e4e01a2015-12-02 08:05:01 -08001110 std::string ToString() const {
Peter Thatcherc2ee2c82015-08-07 16:05:34 -07001111 std::ostringstream ost;
1112 // Options and extensions aren't used.
1113 ost << "{";
1114 ost << "codecs: " << VectorToString(codecs) << ", ";
pbos378dc772016-01-28 15:58:41 -08001115 ost << "max_bandwidth_bps: " << max_bandwidth_bps;
Peter Thatcherc2ee2c82015-08-07 16:05:34 -07001116 ost << "}";
1117 return ost.str();
1118 }
1119};
1120
1121struct DataRecvParameters : RtpParameters<DataCodec> {
1122};
1123
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001124class DataMediaChannel : public MediaChannel {
1125 public:
1126 enum Error {
1127 ERROR_NONE = 0, // No error.
1128 ERROR_OTHER, // Other errors.
1129 ERROR_SEND_SRTP_ERROR = 200, // Generic SRTP failure.
1130 ERROR_SEND_SRTP_AUTH_FAILED, // Failed to authenticate packets.
1131 ERROR_RECV_SRTP_ERROR, // Generic SRTP failure.
1132 ERROR_RECV_SRTP_AUTH_FAILED, // Failed to authenticate packets.
1133 ERROR_RECV_SRTP_REPLAY, // Packet replay detected.
1134 };
1135
1136 virtual ~DataMediaChannel() {}
1137
Fredrik Solenbergb071a192015-09-17 16:42:56 +02001138 virtual bool SetSendParameters(const DataSendParameters& params) = 0;
1139 virtual bool SetRecvParameters(const DataRecvParameters& params) = 0;
wu@webrtc.orga9890802013-12-13 00:21:03 +00001140
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001141 // TODO(pthatcher): Implement this.
1142 virtual bool GetStats(DataMediaInfo* info) { return true; }
1143
1144 virtual bool SetSend(bool send) = 0;
1145 virtual bool SetReceive(bool receive) = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001146
Honghai Zhangcc411c02016-03-29 17:27:21 -07001147 virtual void OnNetworkRouteChanged(const std::string& transport_name,
Honghai Zhang0e533ef2016-04-19 15:41:36 -07001148 const rtc::NetworkRoute& network_route) {}
Honghai Zhangcc411c02016-03-29 17:27:21 -07001149
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001150 virtual bool SendData(
1151 const SendDataParams& params,
jbaucheec21bd2016-03-20 06:15:43 -07001152 const rtc::CopyOnWriteBuffer& payload,
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001153 SendDataResult* result = NULL) = 0;
1154 // Signals when data is received (params, data, len)
1155 sigslot::signal3<const ReceiveDataParams&,
1156 const char*,
1157 size_t> SignalDataReceived;
wu@webrtc.orgd64719d2013-08-01 00:00:07 +00001158 // Signal when the media channel is ready to send the stream. Arguments are:
1159 // writable(bool)
1160 sigslot::signal1<bool> SignalReadyToSend;
buildbot@webrtc.org1d66be22014-05-29 22:54:24 +00001161 // Signal for notifying that the remote side has closed the DataChannel.
Peter Boström0c4e06b2015-10-07 12:23:21 +02001162 sigslot::signal1<uint32_t> SignalStreamClosedRemotely;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001163};
1164
1165} // namespace cricket
1166
kjellandera96e2d72016-02-04 23:52:28 -08001167#endif // WEBRTC_MEDIA_BASE_MEDIACHANNEL_H_