blob: fc9e307a088841d0e71372fc02b3d0f593b0c3ad [file] [log] [blame]
eladalonf1841382017-06-12 01:16:46 -07001/*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 *
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
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.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MEDIA_ENGINE_WEBRTCVIDEOENGINE_H_
12#define MEDIA_ENGINE_WEBRTCVIDEOENGINE_H_
eladalonf1841382017-06-12 01:16:46 -070013
14#include <map>
15#include <memory>
16#include <set>
17#include <string>
18#include <vector>
19
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020020#include "api/call/transport.h"
21#include "api/optional.h"
22#include "api/video/video_frame.h"
23#include "api/video_codecs/sdp_video_format.h"
Patrik Höglundbe214a22018-01-04 12:14:35 +010024#include "api/videosinkinterface.h"
Patrik Höglund9e194032018-01-04 15:58:20 +010025#include "api/videosourceinterface.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020026#include "call/call.h"
27#include "call/flexfec_receive_stream.h"
28#include "call/video_receive_stream.h"
29#include "call/video_send_stream.h"
30#include "media/base/mediaengine.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020031#include "media/engine/webrtcvideodecoderfactory.h"
32#include "media/engine/webrtcvideoencoderfactory.h"
33#include "rtc_base/asyncinvoker.h"
34#include "rtc_base/criticalsection.h"
35#include "rtc_base/networkroute.h"
36#include "rtc_base/thread_annotations.h"
37#include "rtc_base/thread_checker.h"
eladalonf1841382017-06-12 01:16:46 -070038
39namespace webrtc {
40class VideoDecoder;
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020041class VideoDecoderFactory;
eladalonf1841382017-06-12 01:16:46 -070042class VideoEncoder;
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020043class VideoEncoderFactory;
eladalonf1841382017-06-12 01:16:46 -070044struct MediaConfig;
45}
46
47namespace rtc {
48class Thread;
49} // namespace rtc
50
51namespace cricket {
52
andersc063f0c02017-09-11 11:50:51 -070053class DecoderFactoryAdapter;
eladalonf1841382017-06-12 01:16:46 -070054class VideoCapturer;
55class VideoProcessor;
56class VideoRenderer;
57class VoiceMediaChannel;
58class WebRtcDecoderObserver;
59class WebRtcEncoderObserver;
60class WebRtcLocalStreamInfo;
61class WebRtcRenderAdapter;
62class WebRtcVideoChannel;
63class WebRtcVideoChannelRecvInfo;
64class WebRtcVideoChannelSendInfo;
65class WebRtcVoiceEngine;
66class WebRtcVoiceMediaChannel;
67
eladalonf1841382017-06-12 01:16:46 -070068class UnsignalledSsrcHandler {
69 public:
70 enum Action {
71 kDropPacket,
72 kDeliverPacket,
73 };
74 virtual Action OnUnsignalledSsrc(WebRtcVideoChannel* channel,
75 uint32_t ssrc) = 0;
76 virtual ~UnsignalledSsrcHandler() = default;
77};
78
79// TODO(pbos): Remove, use external handlers only.
80class DefaultUnsignalledSsrcHandler : public UnsignalledSsrcHandler {
81 public:
82 DefaultUnsignalledSsrcHandler();
83 Action OnUnsignalledSsrc(WebRtcVideoChannel* channel,
84 uint32_t ssrc) override;
85
86 rtc::VideoSinkInterface<webrtc::VideoFrame>* GetDefaultSink() const;
87 void SetDefaultSink(WebRtcVideoChannel* channel,
88 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
89
90 virtual ~DefaultUnsignalledSsrcHandler() = default;
91
92 private:
93 rtc::VideoSinkInterface<webrtc::VideoFrame>* default_sink_;
94};
95
96// WebRtcVideoEngine is used for the new native WebRTC Video API (webrtc:1667).
97class WebRtcVideoEngine {
98 public:
Anders Carlssondd8c1652018-01-30 10:32:13 +010099#if defined(USE_BUILTIN_SW_CODECS)
Magnus Jedvert02e7a192017-09-23 17:21:32 +0200100 // Internal SW video codecs will be added on top of the external codecs.
101 WebRtcVideoEngine(
102 std::unique_ptr<WebRtcVideoEncoderFactory> external_video_encoder_factory,
103 std::unique_ptr<WebRtcVideoDecoderFactory>
104 external_video_decoder_factory);
Anders Carlssondd8c1652018-01-30 10:32:13 +0100105#endif
Magnus Jedvertd4b0c052017-09-14 10:24:54 +0200106
107 // These video codec factories represents all video codecs, i.e. both software
108 // and external hardware codecs.
109 WebRtcVideoEngine(
110 std::unique_ptr<webrtc::VideoEncoderFactory> video_encoder_factory,
111 std::unique_ptr<webrtc::VideoDecoderFactory> video_decoder_factory);
112
eladalonf1841382017-06-12 01:16:46 -0700113 virtual ~WebRtcVideoEngine();
114
eladalonf1841382017-06-12 01:16:46 -0700115 WebRtcVideoChannel* CreateChannel(webrtc::Call* call,
116 const MediaConfig& config,
117 const VideoOptions& options);
118
119 std::vector<VideoCodec> codecs() const;
120 RtpCapabilities GetCapabilities() const;
121
eladalonf1841382017-06-12 01:16:46 -0700122 private:
magjed2475ae22017-09-12 04:42:15 -0700123 const std::unique_ptr<DecoderFactoryAdapter> decoder_factory_;
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100124 const std::unique_ptr<webrtc::VideoEncoderFactory> encoder_factory_;
eladalonf1841382017-06-12 01:16:46 -0700125};
126
127class WebRtcVideoChannel : public VideoMediaChannel, public webrtc::Transport {
128 public:
129 WebRtcVideoChannel(webrtc::Call* call,
130 const MediaConfig& config,
131 const VideoOptions& options,
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100132 webrtc::VideoEncoderFactory* encoder_factory,
133 DecoderFactoryAdapter* decoder_factory);
eladalonf1841382017-06-12 01:16:46 -0700134 ~WebRtcVideoChannel() override;
135
136 // VideoMediaChannel implementation
137 rtc::DiffServCodePoint PreferredDscp() const override;
138
139 bool SetSendParameters(const VideoSendParameters& params) override;
140 bool SetRecvParameters(const VideoRecvParameters& params) override;
141 webrtc::RtpParameters GetRtpSendParameters(uint32_t ssrc) const override;
Zach Steinba37b4b2018-01-23 15:02:36 -0800142 webrtc::RTCError SetRtpSendParameters(
143 uint32_t ssrc,
144 const webrtc::RtpParameters& parameters) override;
eladalonf1841382017-06-12 01:16:46 -0700145 webrtc::RtpParameters GetRtpReceiveParameters(uint32_t ssrc) const override;
146 bool SetRtpReceiveParameters(
147 uint32_t ssrc,
148 const webrtc::RtpParameters& parameters) override;
149 bool GetSendCodec(VideoCodec* send_codec) override;
150 bool SetSend(bool send) override;
151 bool SetVideoSend(
152 uint32_t ssrc,
153 bool enable,
154 const VideoOptions* options,
155 rtc::VideoSourceInterface<webrtc::VideoFrame>* source) override;
156 bool AddSendStream(const StreamParams& sp) override;
157 bool RemoveSendStream(uint32_t ssrc) override;
158 bool AddRecvStream(const StreamParams& sp) override;
159 bool AddRecvStream(const StreamParams& sp, bool default_stream);
160 bool RemoveRecvStream(uint32_t ssrc) override;
161 bool SetSink(uint32_t ssrc,
162 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
163 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info) override;
164 bool GetStats(VideoMediaInfo* info) override;
165
166 void OnPacketReceived(rtc::CopyOnWriteBuffer* packet,
167 const rtc::PacketTime& packet_time) override;
168 void OnRtcpReceived(rtc::CopyOnWriteBuffer* packet,
169 const rtc::PacketTime& packet_time) override;
170 void OnReadyToSend(bool ready) override;
171 void OnNetworkRouteChanged(const std::string& transport_name,
172 const rtc::NetworkRoute& network_route) override;
eladalonf1841382017-06-12 01:16:46 -0700173 void SetInterface(NetworkInterface* iface) override;
174
175 // Implemented for VideoMediaChannelTest.
176 bool sending() const { return sending_; }
177
178 rtc::Optional<uint32_t> GetDefaultReceiveStreamSsrc();
179
Seth Hampson5897a6e2018-04-03 11:16:33 -0700180 StreamParams unsignaled_stream_params() { return unsignaled_stream_params_; }
181
eladalonf1841382017-06-12 01:16:46 -0700182 // AdaptReason is used for expressing why a WebRtcVideoSendStream request
183 // a lower input frame size than the currently configured camera input frame
184 // size. There can be more than one reason OR:ed together.
185 enum AdaptReason {
186 ADAPTREASON_NONE = 0,
187 ADAPTREASON_CPU = 1,
188 ADAPTREASON_BANDWIDTH = 2,
189 };
190
sprang67561a62017-06-15 06:34:42 -0700191 static constexpr int kDefaultQpMax = 56;
192
eladalonf1841382017-06-12 01:16:46 -0700193 private:
194 class WebRtcVideoReceiveStream;
195 struct VideoCodecSettings {
196 VideoCodecSettings();
197
198 // Checks if all members of |*this| are equal to the corresponding members
199 // of |other|.
200 bool operator==(const VideoCodecSettings& other) const;
201 bool operator!=(const VideoCodecSettings& other) const;
202
203 // Checks if all members of |a|, except |flexfec_payload_type|, are equal
204 // to the corresponding members of |b|.
205 static bool EqualsDisregardingFlexfec(const VideoCodecSettings& a,
206 const VideoCodecSettings& b);
207
208 VideoCodec codec;
209 webrtc::UlpfecConfig ulpfec;
210 int flexfec_payload_type;
211 int rtx_payload_type;
212 };
213
214 struct ChangedSendParameters {
215 // These optionals are unset if not changed.
216 rtc::Optional<VideoCodecSettings> codec;
217 rtc::Optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
Steve Antonbb50ce52018-03-26 10:24:32 -0700218 rtc::Optional<std::string> mid;
eladalonf1841382017-06-12 01:16:46 -0700219 rtc::Optional<int> max_bandwidth_bps;
220 rtc::Optional<bool> conference_mode;
221 rtc::Optional<webrtc::RtcpMode> rtcp_mode;
222 };
223
224 struct ChangedRecvParameters {
225 // These optionals are unset if not changed.
226 rtc::Optional<std::vector<VideoCodecSettings>> codec_settings;
227 rtc::Optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
228 // Keep track of the FlexFEC payload type separately from |codec_settings|.
229 // This allows us to recreate the FlexfecReceiveStream separately from the
230 // VideoReceiveStream when the FlexFEC payload type is changed.
231 rtc::Optional<int> flexfec_payload_type;
232 };
233
234 bool GetChangedSendParameters(const VideoSendParameters& params,
235 ChangedSendParameters* changed_params) const;
236 bool GetChangedRecvParameters(const VideoRecvParameters& params,
237 ChangedRecvParameters* changed_params) const;
238
239 void SetMaxSendBandwidth(int bps);
240
241 void ConfigureReceiverRtp(
242 webrtc::VideoReceiveStream::Config* config,
243 webrtc::FlexfecReceiveStream::Config* flexfec_config,
244 const StreamParams& sp) const;
245 bool ValidateSendSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700246 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700247 bool ValidateReceiveSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700248 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700249 void DeleteReceiveStream(WebRtcVideoReceiveStream* stream)
danilchapa37de392017-09-09 04:17:22 -0700250 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700251
252 static std::string CodecSettingsVectorToString(
253 const std::vector<VideoCodecSettings>& codecs);
254
255 // Wrapper for the sender part.
256 class WebRtcVideoSendStream
257 : public rtc::VideoSourceInterface<webrtc::VideoFrame> {
258 public:
259 WebRtcVideoSendStream(
260 webrtc::Call* call,
261 const StreamParams& sp,
262 webrtc::VideoSendStream::Config config,
263 const VideoOptions& options,
eladalonf1841382017-06-12 01:16:46 -0700264 bool enable_cpu_overuse_detection,
265 int max_bitrate_bps,
266 const rtc::Optional<VideoCodecSettings>& codec_settings,
267 const rtc::Optional<std::vector<webrtc::RtpExtension>>& rtp_extensions,
268 const VideoSendParameters& send_params);
269 virtual ~WebRtcVideoSendStream();
270
271 void SetSendParameters(const ChangedSendParameters& send_params);
Zach Steinba37b4b2018-01-23 15:02:36 -0800272 webrtc::RTCError SetRtpParameters(const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700273 webrtc::RtpParameters GetRtpParameters() const;
274
275 // Implements rtc::VideoSourceInterface<webrtc::VideoFrame>.
276 // WebRtcVideoSendStream acts as a source to the webrtc::VideoSendStream
277 // in |stream_|. This is done to proxy VideoSinkWants from the encoder to
278 // the worker thread.
279 void AddOrUpdateSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink,
280 const rtc::VideoSinkWants& wants) override;
281 void RemoveSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
282
283 bool SetVideoSend(bool mute,
284 const VideoOptions* options,
285 rtc::VideoSourceInterface<webrtc::VideoFrame>* source);
286
287 void SetSend(bool send);
288
289 const std::vector<uint32_t>& GetSsrcs() const;
290 VideoSenderInfo GetVideoSenderInfo(bool log_stats);
291 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info);
292
293 private:
294 // Parameters needed to reconstruct the underlying stream.
295 // webrtc::VideoSendStream doesn't support setting a lot of options on the
296 // fly, so when those need to be changed we tear down and reconstruct with
297 // similar parameters depending on which options changed etc.
298 struct VideoSendStreamParameters {
299 VideoSendStreamParameters(
300 webrtc::VideoSendStream::Config config,
301 const VideoOptions& options,
302 int max_bitrate_bps,
303 const rtc::Optional<VideoCodecSettings>& codec_settings);
304 webrtc::VideoSendStream::Config config;
305 VideoOptions options;
306 int max_bitrate_bps;
307 bool conference_mode;
308 rtc::Optional<VideoCodecSettings> codec_settings;
309 // Sent resolutions + bitrates etc. by the underlying VideoSendStream,
310 // typically changes when setting a new resolution or reconfiguring
311 // bitrates.
312 webrtc::VideoEncoderConfig encoder_config;
313 };
314
eladalonf1841382017-06-12 01:16:46 -0700315 rtc::scoped_refptr<webrtc::VideoEncoderConfig::EncoderSpecificSettings>
316 ConfigureVideoEncoderSettings(const VideoCodec& codec);
Niels Möller5bf8ccd2018-03-15 14:16:11 +0100317 void SetCodec(const VideoCodecSettings& codec);
eladalonf1841382017-06-12 01:16:46 -0700318 void RecreateWebRtcStream();
319 webrtc::VideoEncoderConfig CreateVideoEncoderConfig(
320 const VideoCodec& codec) const;
321 void ReconfigureEncoder();
Zach Steinba37b4b2018-01-23 15:02:36 -0800322 webrtc::RTCError ValidateRtpParameters(
323 const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700324
325 // Calls Start or Stop according to whether or not |sending_| is true,
326 // and whether or not the encoding in |rtp_parameters_| is active.
327 void UpdateSendState();
328
329 webrtc::VideoSendStream::DegradationPreference GetDegradationPreference()
danilchapa37de392017-09-09 04:17:22 -0700330 const RTC_EXCLUSIVE_LOCKS_REQUIRED(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700331
332 rtc::ThreadChecker thread_checker_;
333 rtc::AsyncInvoker invoker_;
334 rtc::Thread* worker_thread_;
Niels Möller1e062892018-02-07 10:18:32 +0100335 const std::vector<uint32_t> ssrcs_ RTC_GUARDED_BY(&thread_checker_);
336 const std::vector<SsrcGroup> ssrc_groups_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700337 webrtc::Call* const call_;
338 const bool enable_cpu_overuse_detection_;
339 rtc::VideoSourceInterface<webrtc::VideoFrame>* source_
Niels Möller1e062892018-02-07 10:18:32 +0100340 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700341
Niels Möller1e062892018-02-07 10:18:32 +0100342 webrtc::VideoSendStream* stream_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700343 rtc::VideoSinkInterface<webrtc::VideoFrame>* encoder_sink_
Niels Möller1e062892018-02-07 10:18:32 +0100344 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700345 // Contains settings that are the same for all streams in the MediaChannel,
346 // such as codecs, header extensions, and the global bitrate limit for the
347 // entire channel.
Niels Möller1e062892018-02-07 10:18:32 +0100348 VideoSendStreamParameters parameters_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700349 // Contains settings that are unique for each stream, such as max_bitrate.
350 // Does *not* contain codecs, however.
351 // TODO(skvlad): Move ssrcs_ and ssrc_groups_ into rtp_parameters_.
352 // TODO(skvlad): Combine parameters_ and rtp_parameters_ once we have only
353 // one stream per MediaChannel.
Niels Möller1e062892018-02-07 10:18:32 +0100354 webrtc::RtpParameters rtp_parameters_ RTC_GUARDED_BY(&thread_checker_);
magjeda35df422017-08-30 04:21:30 -0700355 std::unique_ptr<webrtc::VideoEncoder> allocated_encoder_
Niels Möller1e062892018-02-07 10:18:32 +0100356 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700357
Niels Möller1e062892018-02-07 10:18:32 +0100358 bool sending_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700359 };
360
361 // Wrapper for the receiver part, contains configs etc. that are needed to
362 // reconstruct the underlying VideoReceiveStream.
363 class WebRtcVideoReceiveStream
364 : public rtc::VideoSinkInterface<webrtc::VideoFrame> {
365 public:
366 WebRtcVideoReceiveStream(
367 webrtc::Call* call,
368 const StreamParams& sp,
369 webrtc::VideoReceiveStream::Config config,
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100370 DecoderFactoryAdapter* decoder_factory,
eladalonf1841382017-06-12 01:16:46 -0700371 bool default_stream,
372 const std::vector<VideoCodecSettings>& recv_codecs,
373 const webrtc::FlexfecReceiveStream::Config& flexfec_config);
374 ~WebRtcVideoReceiveStream();
375
376 const std::vector<uint32_t>& GetSsrcs() const;
377 rtc::Optional<uint32_t> GetFirstPrimarySsrc() const;
378
379 void SetLocalSsrc(uint32_t local_ssrc);
380 // TODO(deadbeef): Move these feedback parameters into the recv parameters.
381 void SetFeedbackParameters(bool nack_enabled,
382 bool remb_enabled,
383 bool transport_cc_enabled,
384 webrtc::RtcpMode rtcp_mode);
385 void SetRecvParameters(const ChangedRecvParameters& recv_params);
386
387 void OnFrame(const webrtc::VideoFrame& frame) override;
388 bool IsDefaultStream() const;
389
390 void SetSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
391
392 VideoReceiverInfo GetVideoReceiverInfo(bool log_stats);
393
394 private:
andersc063f0c02017-09-11 11:50:51 -0700395 struct SdpVideoFormatCompare {
396 bool operator()(const webrtc::SdpVideoFormat& lhs,
397 const webrtc::SdpVideoFormat& rhs) const {
398 return std::tie(lhs.name, lhs.parameters) <
399 std::tie(rhs.name, rhs.parameters);
400 }
perkj1f885312017-09-04 02:43:10 -0700401 };
andersc063f0c02017-09-11 11:50:51 -0700402 typedef std::map<webrtc::SdpVideoFormat,
403 std::unique_ptr<webrtc::VideoDecoder>,
404 SdpVideoFormatCompare>
405 DecoderMap;
perkj1f885312017-09-04 02:43:10 -0700406
eladalonf1841382017-06-12 01:16:46 -0700407 void RecreateWebRtcVideoStream();
408 void MaybeRecreateWebRtcFlexfecStream();
409
eladalonc0d481a2017-08-02 07:39:07 -0700410 void MaybeAssociateFlexfecWithVideo();
411 void MaybeDissociateFlexfecFromVideo();
412
perkj1f885312017-09-04 02:43:10 -0700413 void ConfigureCodecs(const std::vector<VideoCodecSettings>& recv_codecs,
andersc063f0c02017-09-11 11:50:51 -0700414 DecoderMap* old_codecs);
eladalonf1841382017-06-12 01:16:46 -0700415 void ConfigureFlexfecCodec(int flexfec_payload_type);
eladalonf1841382017-06-12 01:16:46 -0700416
417 std::string GetCodecNameFromPayloadType(int payload_type);
418
419 webrtc::Call* const call_;
420 StreamParams stream_params_;
421
422 // Both |stream_| and |flexfec_stream_| are managed by |this|. They are
423 // destroyed by calling call_->DestroyVideoReceiveStream and
424 // call_->DestroyFlexfecReceiveStream, respectively.
425 webrtc::VideoReceiveStream* stream_;
426 const bool default_stream_;
427 webrtc::VideoReceiveStream::Config config_;
428 webrtc::FlexfecReceiveStream::Config flexfec_config_;
429 webrtc::FlexfecReceiveStream* flexfec_stream_;
430
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100431 DecoderFactoryAdapter* decoder_factory_;
andersc063f0c02017-09-11 11:50:51 -0700432 DecoderMap allocated_decoders_;
eladalonf1841382017-06-12 01:16:46 -0700433
434 rtc::CriticalSection sink_lock_;
danilchapa37de392017-09-09 04:17:22 -0700435 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink_
436 RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700437 // Expands remote RTP timestamps to int64_t to be able to estimate how long
438 // the stream has been running.
439 rtc::TimestampWrapAroundHandler timestamp_wraparound_handler_
danilchapa37de392017-09-09 04:17:22 -0700440 RTC_GUARDED_BY(sink_lock_);
441 int64_t first_frame_timestamp_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700442 // Start NTP time is estimated as current remote NTP time (estimated from
443 // RTCP) minus the elapsed time, as soon as remote NTP time is available.
danilchapa37de392017-09-09 04:17:22 -0700444 int64_t estimated_remote_start_ntp_time_ms_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700445 };
446
447 void Construct(webrtc::Call* call, WebRtcVideoEngine* engine);
448
449 bool SendRtp(const uint8_t* data,
450 size_t len,
451 const webrtc::PacketOptions& options) override;
452 bool SendRtcp(const uint8_t* data, size_t len) override;
453
454 static std::vector<VideoCodecSettings> MapCodecs(
455 const std::vector<VideoCodec>& codecs);
456 // Select what video codec will be used for sending, i.e. what codec is used
457 // for local encoding, based on supported remote codecs. The first remote
458 // codec that is supported locally will be selected.
459 rtc::Optional<VideoCodecSettings> SelectSendVideoCodec(
460 const std::vector<VideoCodecSettings>& remote_mapped_codecs) const;
461
462 static bool NonFlexfecReceiveCodecsHaveChanged(
463 std::vector<VideoCodecSettings> before,
464 std::vector<VideoCodecSettings> after);
465
466 void FillSenderStats(VideoMediaInfo* info, bool log_stats);
467 void FillReceiverStats(VideoMediaInfo* info, bool log_stats);
468 void FillBandwidthEstimationStats(const webrtc::Call::Stats& stats,
469 VideoMediaInfo* info);
470 void FillSendAndReceiveCodecStats(VideoMediaInfo* video_media_info);
471
472 rtc::ThreadChecker thread_checker_;
473
474 uint32_t rtcp_receiver_report_ssrc_;
475 bool sending_;
476 webrtc::Call* const call_;
477
478 DefaultUnsignalledSsrcHandler default_unsignalled_ssrc_handler_;
479 UnsignalledSsrcHandler* const unsignalled_ssrc_handler_;
480
481 const MediaConfig::Video video_config_;
482
483 rtc::CriticalSection stream_crit_;
484 // Using primary-ssrc (first ssrc) as key.
485 std::map<uint32_t, WebRtcVideoSendStream*> send_streams_
danilchapa37de392017-09-09 04:17:22 -0700486 RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700487 std::map<uint32_t, WebRtcVideoReceiveStream*> receive_streams_
danilchapa37de392017-09-09 04:17:22 -0700488 RTC_GUARDED_BY(stream_crit_);
489 std::set<uint32_t> send_ssrcs_ RTC_GUARDED_BY(stream_crit_);
490 std::set<uint32_t> receive_ssrcs_ RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700491
492 rtc::Optional<VideoCodecSettings> send_codec_;
493 rtc::Optional<std::vector<webrtc::RtpExtension>> send_rtp_extensions_;
494
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100495 webrtc::VideoEncoderFactory* const encoder_factory_;
496 DecoderFactoryAdapter* const decoder_factory_;
eladalonf1841382017-06-12 01:16:46 -0700497 std::vector<VideoCodecSettings> recv_codecs_;
498 std::vector<webrtc::RtpExtension> recv_rtp_extensions_;
499 // See reason for keeping track of the FlexFEC payload type separately in
500 // comment in WebRtcVideoChannel::ChangedRecvParameters.
501 int recv_flexfec_payload_type_;
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +0100502 webrtc::BitrateConstraints bitrate_config_;
eladalonf1841382017-06-12 01:16:46 -0700503 // TODO(deadbeef): Don't duplicate information between
504 // send_params/recv_params, rtp_extensions, options, etc.
505 VideoSendParameters send_params_;
506 VideoOptions default_send_options_;
507 VideoRecvParameters recv_params_;
508 int64_t last_stats_log_ms_;
Seth Hampson5897a6e2018-04-03 11:16:33 -0700509 // This is a stream param that comes from the remote description, but wasn't
510 // signaled with any a=ssrc lines. It holds information that was signaled
511 // before the unsignaled receive stream is created when the first packet is
512 // received.
513 StreamParams unsignaled_stream_params_;
eladalonf1841382017-06-12 01:16:46 -0700514};
515
ilnik6b826ef2017-06-16 06:53:48 -0700516class EncoderStreamFactory
517 : public webrtc::VideoEncoderConfig::VideoStreamFactoryInterface {
518 public:
519 EncoderStreamFactory(std::string codec_name,
520 int max_qp,
521 int max_framerate,
Seth Hampson1370e302018-02-07 08:50:36 -0800522 bool is_screenshare,
523 bool screenshare_config_explicitly_enabled);
ilnik6b826ef2017-06-16 06:53:48 -0700524
525 private:
526 std::vector<webrtc::VideoStream> CreateEncoderStreams(
527 int width,
528 int height,
529 const webrtc::VideoEncoderConfig& encoder_config) override;
530
531 const std::string codec_name_;
532 const int max_qp_;
533 const int max_framerate_;
Seth Hampson1370e302018-02-07 08:50:36 -0800534 const bool is_screenshare_;
535 // Allows a screenshare specific configuration, which enables temporal
536 // layering and allows simulcast.
537 const bool screenshare_config_explicitly_enabled_;
ilnik6b826ef2017-06-16 06:53:48 -0700538};
539
eladalonf1841382017-06-12 01:16:46 -0700540} // namespace cricket
541
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200542#endif // MEDIA_ENGINE_WEBRTCVIDEOENGINE_H_