blob: 2a03a530ea5ebd00208c0188946172b5b3e9f131 [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
180 // AdaptReason is used for expressing why a WebRtcVideoSendStream request
181 // a lower input frame size than the currently configured camera input frame
182 // size. There can be more than one reason OR:ed together.
183 enum AdaptReason {
184 ADAPTREASON_NONE = 0,
185 ADAPTREASON_CPU = 1,
186 ADAPTREASON_BANDWIDTH = 2,
187 };
188
sprang67561a62017-06-15 06:34:42 -0700189 static constexpr int kDefaultQpMax = 56;
190
eladalonf1841382017-06-12 01:16:46 -0700191 private:
192 class WebRtcVideoReceiveStream;
193 struct VideoCodecSettings {
194 VideoCodecSettings();
195
196 // Checks if all members of |*this| are equal to the corresponding members
197 // of |other|.
198 bool operator==(const VideoCodecSettings& other) const;
199 bool operator!=(const VideoCodecSettings& other) const;
200
201 // Checks if all members of |a|, except |flexfec_payload_type|, are equal
202 // to the corresponding members of |b|.
203 static bool EqualsDisregardingFlexfec(const VideoCodecSettings& a,
204 const VideoCodecSettings& b);
205
206 VideoCodec codec;
207 webrtc::UlpfecConfig ulpfec;
208 int flexfec_payload_type;
209 int rtx_payload_type;
210 };
211
212 struct ChangedSendParameters {
213 // These optionals are unset if not changed.
214 rtc::Optional<VideoCodecSettings> codec;
215 rtc::Optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
Steve Antonbb50ce52018-03-26 10:24:32 -0700216 rtc::Optional<std::string> mid;
eladalonf1841382017-06-12 01:16:46 -0700217 rtc::Optional<int> max_bandwidth_bps;
218 rtc::Optional<bool> conference_mode;
219 rtc::Optional<webrtc::RtcpMode> rtcp_mode;
220 };
221
222 struct ChangedRecvParameters {
223 // These optionals are unset if not changed.
224 rtc::Optional<std::vector<VideoCodecSettings>> codec_settings;
225 rtc::Optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
226 // Keep track of the FlexFEC payload type separately from |codec_settings|.
227 // This allows us to recreate the FlexfecReceiveStream separately from the
228 // VideoReceiveStream when the FlexFEC payload type is changed.
229 rtc::Optional<int> flexfec_payload_type;
230 };
231
232 bool GetChangedSendParameters(const VideoSendParameters& params,
233 ChangedSendParameters* changed_params) const;
234 bool GetChangedRecvParameters(const VideoRecvParameters& params,
235 ChangedRecvParameters* changed_params) const;
236
237 void SetMaxSendBandwidth(int bps);
238
239 void ConfigureReceiverRtp(
240 webrtc::VideoReceiveStream::Config* config,
241 webrtc::FlexfecReceiveStream::Config* flexfec_config,
242 const StreamParams& sp) const;
243 bool ValidateSendSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700244 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700245 bool ValidateReceiveSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700246 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700247 void DeleteReceiveStream(WebRtcVideoReceiveStream* stream)
danilchapa37de392017-09-09 04:17:22 -0700248 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700249
250 static std::string CodecSettingsVectorToString(
251 const std::vector<VideoCodecSettings>& codecs);
252
253 // Wrapper for the sender part.
254 class WebRtcVideoSendStream
255 : public rtc::VideoSourceInterface<webrtc::VideoFrame> {
256 public:
257 WebRtcVideoSendStream(
258 webrtc::Call* call,
259 const StreamParams& sp,
260 webrtc::VideoSendStream::Config config,
261 const VideoOptions& options,
eladalonf1841382017-06-12 01:16:46 -0700262 bool enable_cpu_overuse_detection,
263 int max_bitrate_bps,
264 const rtc::Optional<VideoCodecSettings>& codec_settings,
265 const rtc::Optional<std::vector<webrtc::RtpExtension>>& rtp_extensions,
266 const VideoSendParameters& send_params);
267 virtual ~WebRtcVideoSendStream();
268
269 void SetSendParameters(const ChangedSendParameters& send_params);
Zach Steinba37b4b2018-01-23 15:02:36 -0800270 webrtc::RTCError SetRtpParameters(const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700271 webrtc::RtpParameters GetRtpParameters() const;
272
273 // Implements rtc::VideoSourceInterface<webrtc::VideoFrame>.
274 // WebRtcVideoSendStream acts as a source to the webrtc::VideoSendStream
275 // in |stream_|. This is done to proxy VideoSinkWants from the encoder to
276 // the worker thread.
277 void AddOrUpdateSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink,
278 const rtc::VideoSinkWants& wants) override;
279 void RemoveSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
280
281 bool SetVideoSend(bool mute,
282 const VideoOptions* options,
283 rtc::VideoSourceInterface<webrtc::VideoFrame>* source);
284
285 void SetSend(bool send);
286
287 const std::vector<uint32_t>& GetSsrcs() const;
288 VideoSenderInfo GetVideoSenderInfo(bool log_stats);
289 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info);
290
291 private:
292 // Parameters needed to reconstruct the underlying stream.
293 // webrtc::VideoSendStream doesn't support setting a lot of options on the
294 // fly, so when those need to be changed we tear down and reconstruct with
295 // similar parameters depending on which options changed etc.
296 struct VideoSendStreamParameters {
297 VideoSendStreamParameters(
298 webrtc::VideoSendStream::Config config,
299 const VideoOptions& options,
300 int max_bitrate_bps,
301 const rtc::Optional<VideoCodecSettings>& codec_settings);
302 webrtc::VideoSendStream::Config config;
303 VideoOptions options;
304 int max_bitrate_bps;
305 bool conference_mode;
306 rtc::Optional<VideoCodecSettings> codec_settings;
307 // Sent resolutions + bitrates etc. by the underlying VideoSendStream,
308 // typically changes when setting a new resolution or reconfiguring
309 // bitrates.
310 webrtc::VideoEncoderConfig encoder_config;
311 };
312
eladalonf1841382017-06-12 01:16:46 -0700313 rtc::scoped_refptr<webrtc::VideoEncoderConfig::EncoderSpecificSettings>
314 ConfigureVideoEncoderSettings(const VideoCodec& codec);
Niels Möller5bf8ccd2018-03-15 14:16:11 +0100315 void SetCodec(const VideoCodecSettings& codec);
eladalonf1841382017-06-12 01:16:46 -0700316 void RecreateWebRtcStream();
317 webrtc::VideoEncoderConfig CreateVideoEncoderConfig(
318 const VideoCodec& codec) const;
319 void ReconfigureEncoder();
Zach Steinba37b4b2018-01-23 15:02:36 -0800320 webrtc::RTCError ValidateRtpParameters(
321 const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700322
323 // Calls Start or Stop according to whether or not |sending_| is true,
324 // and whether or not the encoding in |rtp_parameters_| is active.
325 void UpdateSendState();
326
327 webrtc::VideoSendStream::DegradationPreference GetDegradationPreference()
danilchapa37de392017-09-09 04:17:22 -0700328 const RTC_EXCLUSIVE_LOCKS_REQUIRED(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700329
330 rtc::ThreadChecker thread_checker_;
331 rtc::AsyncInvoker invoker_;
332 rtc::Thread* worker_thread_;
Niels Möller1e062892018-02-07 10:18:32 +0100333 const std::vector<uint32_t> ssrcs_ RTC_GUARDED_BY(&thread_checker_);
334 const std::vector<SsrcGroup> ssrc_groups_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700335 webrtc::Call* const call_;
336 const bool enable_cpu_overuse_detection_;
337 rtc::VideoSourceInterface<webrtc::VideoFrame>* source_
Niels Möller1e062892018-02-07 10:18:32 +0100338 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700339
Niels Möller1e062892018-02-07 10:18:32 +0100340 webrtc::VideoSendStream* stream_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700341 rtc::VideoSinkInterface<webrtc::VideoFrame>* encoder_sink_
Niels Möller1e062892018-02-07 10:18:32 +0100342 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700343 // Contains settings that are the same for all streams in the MediaChannel,
344 // such as codecs, header extensions, and the global bitrate limit for the
345 // entire channel.
Niels Möller1e062892018-02-07 10:18:32 +0100346 VideoSendStreamParameters parameters_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700347 // Contains settings that are unique for each stream, such as max_bitrate.
348 // Does *not* contain codecs, however.
349 // TODO(skvlad): Move ssrcs_ and ssrc_groups_ into rtp_parameters_.
350 // TODO(skvlad): Combine parameters_ and rtp_parameters_ once we have only
351 // one stream per MediaChannel.
Niels Möller1e062892018-02-07 10:18:32 +0100352 webrtc::RtpParameters rtp_parameters_ RTC_GUARDED_BY(&thread_checker_);
magjeda35df422017-08-30 04:21:30 -0700353 std::unique_ptr<webrtc::VideoEncoder> allocated_encoder_
Niels Möller1e062892018-02-07 10:18:32 +0100354 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700355
Niels Möller1e062892018-02-07 10:18:32 +0100356 bool sending_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700357 };
358
359 // Wrapper for the receiver part, contains configs etc. that are needed to
360 // reconstruct the underlying VideoReceiveStream.
361 class WebRtcVideoReceiveStream
362 : public rtc::VideoSinkInterface<webrtc::VideoFrame> {
363 public:
364 WebRtcVideoReceiveStream(
365 webrtc::Call* call,
366 const StreamParams& sp,
367 webrtc::VideoReceiveStream::Config config,
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100368 DecoderFactoryAdapter* decoder_factory,
eladalonf1841382017-06-12 01:16:46 -0700369 bool default_stream,
370 const std::vector<VideoCodecSettings>& recv_codecs,
371 const webrtc::FlexfecReceiveStream::Config& flexfec_config);
372 ~WebRtcVideoReceiveStream();
373
374 const std::vector<uint32_t>& GetSsrcs() const;
375 rtc::Optional<uint32_t> GetFirstPrimarySsrc() const;
376
377 void SetLocalSsrc(uint32_t local_ssrc);
378 // TODO(deadbeef): Move these feedback parameters into the recv parameters.
379 void SetFeedbackParameters(bool nack_enabled,
380 bool remb_enabled,
381 bool transport_cc_enabled,
382 webrtc::RtcpMode rtcp_mode);
383 void SetRecvParameters(const ChangedRecvParameters& recv_params);
384
385 void OnFrame(const webrtc::VideoFrame& frame) override;
386 bool IsDefaultStream() const;
387
388 void SetSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
389
390 VideoReceiverInfo GetVideoReceiverInfo(bool log_stats);
391
392 private:
andersc063f0c02017-09-11 11:50:51 -0700393 struct SdpVideoFormatCompare {
394 bool operator()(const webrtc::SdpVideoFormat& lhs,
395 const webrtc::SdpVideoFormat& rhs) const {
396 return std::tie(lhs.name, lhs.parameters) <
397 std::tie(rhs.name, rhs.parameters);
398 }
perkj1f885312017-09-04 02:43:10 -0700399 };
andersc063f0c02017-09-11 11:50:51 -0700400 typedef std::map<webrtc::SdpVideoFormat,
401 std::unique_ptr<webrtc::VideoDecoder>,
402 SdpVideoFormatCompare>
403 DecoderMap;
perkj1f885312017-09-04 02:43:10 -0700404
eladalonf1841382017-06-12 01:16:46 -0700405 void RecreateWebRtcVideoStream();
406 void MaybeRecreateWebRtcFlexfecStream();
407
eladalonc0d481a2017-08-02 07:39:07 -0700408 void MaybeAssociateFlexfecWithVideo();
409 void MaybeDissociateFlexfecFromVideo();
410
perkj1f885312017-09-04 02:43:10 -0700411 void ConfigureCodecs(const std::vector<VideoCodecSettings>& recv_codecs,
andersc063f0c02017-09-11 11:50:51 -0700412 DecoderMap* old_codecs);
eladalonf1841382017-06-12 01:16:46 -0700413 void ConfigureFlexfecCodec(int flexfec_payload_type);
eladalonf1841382017-06-12 01:16:46 -0700414
415 std::string GetCodecNameFromPayloadType(int payload_type);
416
417 webrtc::Call* const call_;
418 StreamParams stream_params_;
419
420 // Both |stream_| and |flexfec_stream_| are managed by |this|. They are
421 // destroyed by calling call_->DestroyVideoReceiveStream and
422 // call_->DestroyFlexfecReceiveStream, respectively.
423 webrtc::VideoReceiveStream* stream_;
424 const bool default_stream_;
425 webrtc::VideoReceiveStream::Config config_;
426 webrtc::FlexfecReceiveStream::Config flexfec_config_;
427 webrtc::FlexfecReceiveStream* flexfec_stream_;
428
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100429 DecoderFactoryAdapter* decoder_factory_;
andersc063f0c02017-09-11 11:50:51 -0700430 DecoderMap allocated_decoders_;
eladalonf1841382017-06-12 01:16:46 -0700431
432 rtc::CriticalSection sink_lock_;
danilchapa37de392017-09-09 04:17:22 -0700433 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink_
434 RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700435 // Expands remote RTP timestamps to int64_t to be able to estimate how long
436 // the stream has been running.
437 rtc::TimestampWrapAroundHandler timestamp_wraparound_handler_
danilchapa37de392017-09-09 04:17:22 -0700438 RTC_GUARDED_BY(sink_lock_);
439 int64_t first_frame_timestamp_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700440 // Start NTP time is estimated as current remote NTP time (estimated from
441 // RTCP) minus the elapsed time, as soon as remote NTP time is available.
danilchapa37de392017-09-09 04:17:22 -0700442 int64_t estimated_remote_start_ntp_time_ms_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700443 };
444
445 void Construct(webrtc::Call* call, WebRtcVideoEngine* engine);
446
447 bool SendRtp(const uint8_t* data,
448 size_t len,
449 const webrtc::PacketOptions& options) override;
450 bool SendRtcp(const uint8_t* data, size_t len) override;
451
452 static std::vector<VideoCodecSettings> MapCodecs(
453 const std::vector<VideoCodec>& codecs);
454 // Select what video codec will be used for sending, i.e. what codec is used
455 // for local encoding, based on supported remote codecs. The first remote
456 // codec that is supported locally will be selected.
457 rtc::Optional<VideoCodecSettings> SelectSendVideoCodec(
458 const std::vector<VideoCodecSettings>& remote_mapped_codecs) const;
459
460 static bool NonFlexfecReceiveCodecsHaveChanged(
461 std::vector<VideoCodecSettings> before,
462 std::vector<VideoCodecSettings> after);
463
464 void FillSenderStats(VideoMediaInfo* info, bool log_stats);
465 void FillReceiverStats(VideoMediaInfo* info, bool log_stats);
466 void FillBandwidthEstimationStats(const webrtc::Call::Stats& stats,
467 VideoMediaInfo* info);
468 void FillSendAndReceiveCodecStats(VideoMediaInfo* video_media_info);
469
470 rtc::ThreadChecker thread_checker_;
471
472 uint32_t rtcp_receiver_report_ssrc_;
473 bool sending_;
474 webrtc::Call* const call_;
475
476 DefaultUnsignalledSsrcHandler default_unsignalled_ssrc_handler_;
477 UnsignalledSsrcHandler* const unsignalled_ssrc_handler_;
478
479 const MediaConfig::Video video_config_;
480
481 rtc::CriticalSection stream_crit_;
482 // Using primary-ssrc (first ssrc) as key.
483 std::map<uint32_t, WebRtcVideoSendStream*> send_streams_
danilchapa37de392017-09-09 04:17:22 -0700484 RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700485 std::map<uint32_t, WebRtcVideoReceiveStream*> receive_streams_
danilchapa37de392017-09-09 04:17:22 -0700486 RTC_GUARDED_BY(stream_crit_);
487 std::set<uint32_t> send_ssrcs_ RTC_GUARDED_BY(stream_crit_);
488 std::set<uint32_t> receive_ssrcs_ RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700489
490 rtc::Optional<VideoCodecSettings> send_codec_;
491 rtc::Optional<std::vector<webrtc::RtpExtension>> send_rtp_extensions_;
492
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100493 webrtc::VideoEncoderFactory* const encoder_factory_;
494 DecoderFactoryAdapter* const decoder_factory_;
eladalonf1841382017-06-12 01:16:46 -0700495 std::vector<VideoCodecSettings> recv_codecs_;
496 std::vector<webrtc::RtpExtension> recv_rtp_extensions_;
497 // See reason for keeping track of the FlexFEC payload type separately in
498 // comment in WebRtcVideoChannel::ChangedRecvParameters.
499 int recv_flexfec_payload_type_;
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +0100500 webrtc::BitrateConstraints bitrate_config_;
eladalonf1841382017-06-12 01:16:46 -0700501 // TODO(deadbeef): Don't duplicate information between
502 // send_params/recv_params, rtp_extensions, options, etc.
503 VideoSendParameters send_params_;
504 VideoOptions default_send_options_;
505 VideoRecvParameters recv_params_;
506 int64_t last_stats_log_ms_;
507};
508
ilnik6b826ef2017-06-16 06:53:48 -0700509class EncoderStreamFactory
510 : public webrtc::VideoEncoderConfig::VideoStreamFactoryInterface {
511 public:
512 EncoderStreamFactory(std::string codec_name,
513 int max_qp,
514 int max_framerate,
Seth Hampson1370e302018-02-07 08:50:36 -0800515 bool is_screenshare,
516 bool screenshare_config_explicitly_enabled);
ilnik6b826ef2017-06-16 06:53:48 -0700517
518 private:
519 std::vector<webrtc::VideoStream> CreateEncoderStreams(
520 int width,
521 int height,
522 const webrtc::VideoEncoderConfig& encoder_config) override;
523
524 const std::string codec_name_;
525 const int max_qp_;
526 const int max_framerate_;
Seth Hampson1370e302018-02-07 08:50:36 -0800527 const bool is_screenshare_;
528 // Allows a screenshare specific configuration, which enables temporal
529 // layering and allows simulcast.
530 const bool screenshare_config_explicitly_enabled_;
ilnik6b826ef2017-06-16 06:53:48 -0700531};
532
eladalonf1841382017-06-12 01:16:46 -0700533} // namespace cricket
534
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200535#endif // MEDIA_ENGINE_WEBRTCVIDEOENGINE_H_