blob: a3d5a2f42bc9d612d5025b0429c264ff08a4c83d [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
Steve Anton10542f22019-01-11 09:11:00 -080011#ifndef MEDIA_ENGINE_WEBRTC_VIDEO_ENGINE_H_
12#define MEDIA_ENGINE_WEBRTC_VIDEO_ENGINE_H_
eladalonf1841382017-06-12 01:16:46 -070013
14#include <map>
15#include <memory>
16#include <set>
17#include <string>
18#include <vector>
19
Danil Chapovalov00c71832018-06-15 15:58:38 +020020#include "absl/types/optional.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020021#include "api/call/transport.h"
Jiawei Ouc2ebe212018-11-08 10:02:56 -080022#include "api/video/video_bitrate_allocator_factory.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020023#include "api/video/video_frame.h"
Niels Möllerc6ce9c52018-05-11 11:15:30 +020024#include "api/video/video_sink_interface.h"
Niels Möller0327c2d2018-05-21 14:09:31 +020025#include "api/video/video_source_interface.h"
26#include "api/video_codecs/sdp_video_format.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020027#include "call/call.h"
28#include "call/flexfec_receive_stream.h"
29#include "call/video_receive_stream.h"
30#include "call/video_send_stream.h"
Steve Anton10542f22019-01-11 09:11:00 -080031#include "media/base/media_engine.h"
Steve Anton10542f22019-01-11 09:11:00 -080032#include "rtc_base/async_invoker.h"
33#include "rtc_base/critical_section.h"
34#include "rtc_base/network_route.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020035#include "rtc_base/thread_annotations.h"
36#include "rtc_base/thread_checker.h"
eladalonf1841382017-06-12 01:16:46 -070037
38namespace webrtc {
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020039class VideoDecoderFactory;
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020040class VideoEncoderFactory;
eladalonf1841382017-06-12 01:16:46 -070041struct MediaConfig;
Yves Gerey665174f2018-06-19 15:03:05 +020042} // namespace webrtc
eladalonf1841382017-06-12 01:16:46 -070043
44namespace rtc {
45class Thread;
46} // namespace rtc
47
48namespace cricket {
49
eladalonf1841382017-06-12 01:16:46 -070050class WebRtcVideoChannel;
eladalonf1841382017-06-12 01:16:46 -070051
eladalonf1841382017-06-12 01:16:46 -070052class UnsignalledSsrcHandler {
53 public:
54 enum Action {
55 kDropPacket,
56 kDeliverPacket,
57 };
58 virtual Action OnUnsignalledSsrc(WebRtcVideoChannel* channel,
59 uint32_t ssrc) = 0;
60 virtual ~UnsignalledSsrcHandler() = default;
61};
62
63// TODO(pbos): Remove, use external handlers only.
64class DefaultUnsignalledSsrcHandler : public UnsignalledSsrcHandler {
65 public:
66 DefaultUnsignalledSsrcHandler();
Yves Gerey665174f2018-06-19 15:03:05 +020067 Action OnUnsignalledSsrc(WebRtcVideoChannel* channel, uint32_t ssrc) override;
eladalonf1841382017-06-12 01:16:46 -070068
69 rtc::VideoSinkInterface<webrtc::VideoFrame>* GetDefaultSink() const;
70 void SetDefaultSink(WebRtcVideoChannel* channel,
71 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
72
73 virtual ~DefaultUnsignalledSsrcHandler() = default;
74
75 private:
76 rtc::VideoSinkInterface<webrtc::VideoFrame>* default_sink_;
77};
78
79// WebRtcVideoEngine is used for the new native WebRTC Video API (webrtc:1667).
Sebastian Jansson84848f22018-11-16 10:40:36 +010080class WebRtcVideoEngine : public VideoEngineInterface {
eladalonf1841382017-06-12 01:16:46 -070081 public:
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020082 // These video codec factories represents all video codecs, i.e. both software
83 // and external hardware codecs.
84 WebRtcVideoEngine(
85 std::unique_ptr<webrtc::VideoEncoderFactory> video_encoder_factory,
Jiawei Ouc2ebe212018-11-08 10:02:56 -080086 std::unique_ptr<webrtc::VideoDecoderFactory> video_decoder_factory,
87 std::unique_ptr<webrtc::VideoBitrateAllocatorFactory>
88 video_bitrate_allocator_factory);
Magnus Jedvertd4b0c052017-09-14 10:24:54 +020089
Sebastian Jansson84848f22018-11-16 10:40:36 +010090 ~WebRtcVideoEngine() override;
eladalonf1841382017-06-12 01:16:46 -070091
Sebastian Jansson84848f22018-11-16 10:40:36 +010092 VideoMediaChannel* CreateMediaChannel(
Benjamin Wrightbfb444c2018-10-15 10:20:24 -070093 webrtc::Call* call,
94 const MediaConfig& config,
95 const VideoOptions& options,
Sebastian Jansson84848f22018-11-16 10:40:36 +010096 const webrtc::CryptoOptions& crypto_options) override;
eladalonf1841382017-06-12 01:16:46 -070097
Sebastian Jansson84848f22018-11-16 10:40:36 +010098 std::vector<VideoCodec> codecs() const override;
99 RtpCapabilities GetCapabilities() const override;
eladalonf1841382017-06-12 01:16:46 -0700100
eladalonf1841382017-06-12 01:16:46 -0700101 private:
Magnus Jedvert59ab3532018-09-03 18:07:56 +0200102 const std::unique_ptr<webrtc::VideoDecoderFactory> decoder_factory_;
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100103 const std::unique_ptr<webrtc::VideoEncoderFactory> encoder_factory_;
Jiawei Ouc2ebe212018-11-08 10:02:56 -0800104 const std::unique_ptr<webrtc::VideoBitrateAllocatorFactory>
105 bitrate_allocator_factory_;
eladalonf1841382017-06-12 01:16:46 -0700106};
107
108class WebRtcVideoChannel : public VideoMediaChannel, public webrtc::Transport {
109 public:
Jiawei Ouc2ebe212018-11-08 10:02:56 -0800110 WebRtcVideoChannel(
111 webrtc::Call* call,
112 const MediaConfig& config,
113 const VideoOptions& options,
114 const webrtc::CryptoOptions& crypto_options,
115 webrtc::VideoEncoderFactory* encoder_factory,
116 webrtc::VideoDecoderFactory* decoder_factory,
117 webrtc::VideoBitrateAllocatorFactory* bitrate_allocator_factory);
eladalonf1841382017-06-12 01:16:46 -0700118 ~WebRtcVideoChannel() override;
119
120 // VideoMediaChannel implementation
121 rtc::DiffServCodePoint PreferredDscp() const override;
122
123 bool SetSendParameters(const VideoSendParameters& params) override;
124 bool SetRecvParameters(const VideoRecvParameters& params) override;
125 webrtc::RtpParameters GetRtpSendParameters(uint32_t ssrc) const override;
Zach Steinba37b4b2018-01-23 15:02:36 -0800126 webrtc::RTCError SetRtpSendParameters(
127 uint32_t ssrc,
128 const webrtc::RtpParameters& parameters) override;
eladalonf1841382017-06-12 01:16:46 -0700129 webrtc::RtpParameters GetRtpReceiveParameters(uint32_t ssrc) const override;
130 bool SetRtpReceiveParameters(
131 uint32_t ssrc,
132 const webrtc::RtpParameters& parameters) override;
133 bool GetSendCodec(VideoCodec* send_codec) override;
134 bool SetSend(bool send) override;
135 bool SetVideoSend(
136 uint32_t ssrc,
eladalonf1841382017-06-12 01:16:46 -0700137 const VideoOptions* options,
138 rtc::VideoSourceInterface<webrtc::VideoFrame>* source) override;
139 bool AddSendStream(const StreamParams& sp) override;
140 bool RemoveSendStream(uint32_t ssrc) override;
141 bool AddRecvStream(const StreamParams& sp) override;
142 bool AddRecvStream(const StreamParams& sp, bool default_stream);
143 bool RemoveRecvStream(uint32_t ssrc) override;
144 bool SetSink(uint32_t ssrc,
145 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
146 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info) override;
147 bool GetStats(VideoMediaInfo* info) override;
148
149 void OnPacketReceived(rtc::CopyOnWriteBuffer* packet,
Niels Möllere6933812018-11-05 13:01:41 +0100150 int64_t packet_time_us) override;
eladalonf1841382017-06-12 01:16:46 -0700151 void OnRtcpReceived(rtc::CopyOnWriteBuffer* packet,
Niels Möllere6933812018-11-05 13:01:41 +0100152 int64_t packet_time_us) override;
eladalonf1841382017-06-12 01:16:46 -0700153 void OnReadyToSend(bool ready) override;
154 void OnNetworkRouteChanged(const std::string& transport_name,
155 const rtc::NetworkRoute& network_route) override;
Anton Sukhanov98a462c2018-10-17 13:15:42 -0700156 void SetInterface(NetworkInterface* iface,
157 webrtc::MediaTransportInterface* media_transport) override;
eladalonf1841382017-06-12 01:16:46 -0700158
Benjamin Wright192eeec2018-10-17 17:27:25 -0700159 // E2E Encrypted Video Frame API
160 // Set a frame decryptor to a particular ssrc that will intercept all
161 // incoming video frames and attempt to decrypt them before forwarding the
162 // result.
163 void SetFrameDecryptor(uint32_t ssrc,
164 rtc::scoped_refptr<webrtc::FrameDecryptorInterface>
165 frame_decryptor) override;
166 // Set a frame encryptor to a particular ssrc that will intercept all
167 // outgoing video frames and attempt to encrypt them and forward the result
168 // to the packetizer.
169 void SetFrameEncryptor(uint32_t ssrc,
170 rtc::scoped_refptr<webrtc::FrameEncryptorInterface>
171 frame_encryptor) override;
172
eladalonf1841382017-06-12 01:16:46 -0700173 // Implemented for VideoMediaChannelTest.
174 bool sending() const { return sending_; }
175
Danil Chapovalov00c71832018-06-15 15:58:38 +0200176 absl::optional<uint32_t> GetDefaultReceiveStreamSsrc();
eladalonf1841382017-06-12 01:16:46 -0700177
Seth Hampson5897a6e2018-04-03 11:16:33 -0700178 StreamParams unsignaled_stream_params() { return unsignaled_stream_params_; }
179
eladalonf1841382017-06-12 01:16:46 -0700180 // 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
Jonas Oreland49ac5952018-09-26 16:04:32 +0200191 std::vector<webrtc::RtpSource> GetSources(uint32_t ssrc) const override;
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.
Danil Chapovalov00c71832018-06-15 15:58:38 +0200216 absl::optional<VideoCodecSettings> codec;
217 absl::optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
218 absl::optional<std::string> mid;
Johannes Kron9190b822018-10-29 11:22:05 +0100219 absl::optional<bool> extmap_allow_mixed;
Danil Chapovalov00c71832018-06-15 15:58:38 +0200220 absl::optional<int> max_bandwidth_bps;
221 absl::optional<bool> conference_mode;
222 absl::optional<webrtc::RtcpMode> rtcp_mode;
eladalonf1841382017-06-12 01:16:46 -0700223 };
224
225 struct ChangedRecvParameters {
226 // These optionals are unset if not changed.
Danil Chapovalov00c71832018-06-15 15:58:38 +0200227 absl::optional<std::vector<VideoCodecSettings>> codec_settings;
228 absl::optional<std::vector<webrtc::RtpExtension>> rtp_header_extensions;
eladalonf1841382017-06-12 01:16:46 -0700229 // Keep track of the FlexFEC payload type separately from |codec_settings|.
230 // This allows us to recreate the FlexfecReceiveStream separately from the
231 // VideoReceiveStream when the FlexFEC payload type is changed.
Danil Chapovalov00c71832018-06-15 15:58:38 +0200232 absl::optional<int> flexfec_payload_type;
eladalonf1841382017-06-12 01:16:46 -0700233 };
234
235 bool GetChangedSendParameters(const VideoSendParameters& params,
236 ChangedSendParameters* changed_params) const;
237 bool GetChangedRecvParameters(const VideoRecvParameters& params,
238 ChangedRecvParameters* changed_params) const;
239
240 void SetMaxSendBandwidth(int bps);
241
242 void ConfigureReceiverRtp(
243 webrtc::VideoReceiveStream::Config* config,
244 webrtc::FlexfecReceiveStream::Config* flexfec_config,
245 const StreamParams& sp) const;
246 bool ValidateSendSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700247 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700248 bool ValidateReceiveSsrcAvailability(const StreamParams& sp) const
danilchapa37de392017-09-09 04:17:22 -0700249 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700250 void DeleteReceiveStream(WebRtcVideoReceiveStream* stream)
danilchapa37de392017-09-09 04:17:22 -0700251 RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700252
253 static std::string CodecSettingsVectorToString(
254 const std::vector<VideoCodecSettings>& codecs);
255
256 // Wrapper for the sender part.
Christian Fremerey6c025412019-02-13 19:43:28 +0000257 class WebRtcVideoSendStream
258 : public rtc::VideoSourceInterface<webrtc::VideoFrame> {
eladalonf1841382017-06-12 01:16:46 -0700259 public:
260 WebRtcVideoSendStream(
261 webrtc::Call* call,
262 const StreamParams& sp,
263 webrtc::VideoSendStream::Config config,
264 const VideoOptions& options,
eladalonf1841382017-06-12 01:16:46 -0700265 bool enable_cpu_overuse_detection,
266 int max_bitrate_bps,
Danil Chapovalov00c71832018-06-15 15:58:38 +0200267 const absl::optional<VideoCodecSettings>& codec_settings,
268 const absl::optional<std::vector<webrtc::RtpExtension>>& rtp_extensions,
eladalonf1841382017-06-12 01:16:46 -0700269 const VideoSendParameters& send_params);
270 virtual ~WebRtcVideoSendStream();
271
272 void SetSendParameters(const ChangedSendParameters& send_params);
Zach Steinba37b4b2018-01-23 15:02:36 -0800273 webrtc::RTCError SetRtpParameters(const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700274 webrtc::RtpParameters GetRtpParameters() const;
275
Benjamin Wright192eeec2018-10-17 17:27:25 -0700276 void SetFrameEncryptor(
277 rtc::scoped_refptr<webrtc::FrameEncryptorInterface> frame_encryptor);
278
Christian Fremerey6c025412019-02-13 19:43:28 +0000279 // Implements rtc::VideoSourceInterface<webrtc::VideoFrame>.
280 // WebRtcVideoSendStream acts as a source to the webrtc::VideoSendStream
281 // in |stream_|. This is done to proxy VideoSinkWants from the encoder to
282 // the worker thread.
283 void AddOrUpdateSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink,
284 const rtc::VideoSinkWants& wants) override;
285 void RemoveSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
286
Niels Möllerff40b142018-04-09 08:49:14 +0200287 bool SetVideoSend(const VideoOptions* options,
eladalonf1841382017-06-12 01:16:46 -0700288 rtc::VideoSourceInterface<webrtc::VideoFrame>* source);
289
290 void SetSend(bool send);
291
292 const std::vector<uint32_t>& GetSsrcs() const;
293 VideoSenderInfo GetVideoSenderInfo(bool log_stats);
294 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info);
295
296 private:
297 // Parameters needed to reconstruct the underlying stream.
298 // webrtc::VideoSendStream doesn't support setting a lot of options on the
299 // fly, so when those need to be changed we tear down and reconstruct with
300 // similar parameters depending on which options changed etc.
301 struct VideoSendStreamParameters {
302 VideoSendStreamParameters(
303 webrtc::VideoSendStream::Config config,
304 const VideoOptions& options,
305 int max_bitrate_bps,
Danil Chapovalov00c71832018-06-15 15:58:38 +0200306 const absl::optional<VideoCodecSettings>& codec_settings);
eladalonf1841382017-06-12 01:16:46 -0700307 webrtc::VideoSendStream::Config config;
308 VideoOptions options;
309 int max_bitrate_bps;
310 bool conference_mode;
Danil Chapovalov00c71832018-06-15 15:58:38 +0200311 absl::optional<VideoCodecSettings> codec_settings;
eladalonf1841382017-06-12 01:16:46 -0700312 // Sent resolutions + bitrates etc. by the underlying VideoSendStream,
313 // typically changes when setting a new resolution or reconfiguring
314 // bitrates.
315 webrtc::VideoEncoderConfig encoder_config;
316 };
317
eladalonf1841382017-06-12 01:16:46 -0700318 rtc::scoped_refptr<webrtc::VideoEncoderConfig::EncoderSpecificSettings>
319 ConfigureVideoEncoderSettings(const VideoCodec& codec);
Niels Möller5bf8ccd2018-03-15 14:16:11 +0100320 void SetCodec(const VideoCodecSettings& codec);
eladalonf1841382017-06-12 01:16:46 -0700321 void RecreateWebRtcStream();
322 webrtc::VideoEncoderConfig CreateVideoEncoderConfig(
323 const VideoCodec& codec) const;
324 void ReconfigureEncoder();
eladalonf1841382017-06-12 01:16:46 -0700325
326 // Calls Start or Stop according to whether or not |sending_| is true,
327 // and whether or not the encoding in |rtp_parameters_| is active.
328 void UpdateSendState();
329
Taylor Brandstetter49fcc102018-05-16 14:20:41 -0700330 webrtc::DegradationPreference GetDegradationPreference() const
331 RTC_EXCLUSIVE_LOCKS_REQUIRED(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700332
333 rtc::ThreadChecker thread_checker_;
334 rtc::AsyncInvoker invoker_;
335 rtc::Thread* worker_thread_;
Niels Möller1e062892018-02-07 10:18:32 +0100336 const std::vector<uint32_t> ssrcs_ RTC_GUARDED_BY(&thread_checker_);
337 const std::vector<SsrcGroup> ssrc_groups_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700338 webrtc::Call* const call_;
339 const bool enable_cpu_overuse_detection_;
340 rtc::VideoSourceInterface<webrtc::VideoFrame>* source_
Niels Möller1e062892018-02-07 10:18:32 +0100341 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700342
Niels Möller1e062892018-02-07 10:18:32 +0100343 webrtc::VideoSendStream* stream_ RTC_GUARDED_BY(&thread_checker_);
Christian Fremerey6c025412019-02-13 19:43:28 +0000344 rtc::VideoSinkInterface<webrtc::VideoFrame>* encoder_sink_
345 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700346 // Contains settings that are the same for all streams in the MediaChannel,
347 // such as codecs, header extensions, and the global bitrate limit for the
348 // entire channel.
Niels Möller1e062892018-02-07 10:18:32 +0100349 VideoSendStreamParameters parameters_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700350 // Contains settings that are unique for each stream, such as max_bitrate.
351 // Does *not* contain codecs, however.
352 // TODO(skvlad): Move ssrcs_ and ssrc_groups_ into rtp_parameters_.
353 // TODO(skvlad): Combine parameters_ and rtp_parameters_ once we have only
354 // one stream per MediaChannel.
Niels Möller1e062892018-02-07 10:18:32 +0100355 webrtc::RtpParameters rtp_parameters_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700356
Niels Möller1e062892018-02-07 10:18:32 +0100357 bool sending_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700358 };
359
360 // Wrapper for the receiver part, contains configs etc. that are needed to
361 // reconstruct the underlying VideoReceiveStream.
362 class WebRtcVideoReceiveStream
363 : public rtc::VideoSinkInterface<webrtc::VideoFrame> {
364 public:
365 WebRtcVideoReceiveStream(
366 webrtc::Call* call,
367 const StreamParams& sp,
368 webrtc::VideoReceiveStream::Config config,
Magnus Jedvert59ab3532018-09-03 18:07:56 +0200369 webrtc::VideoDecoderFactory* decoder_factory,
eladalonf1841382017-06-12 01:16:46 -0700370 bool default_stream,
371 const std::vector<VideoCodecSettings>& recv_codecs,
372 const webrtc::FlexfecReceiveStream::Config& flexfec_config);
373 ~WebRtcVideoReceiveStream();
374
375 const std::vector<uint32_t>& GetSsrcs() const;
Florent Castelliabe301f2018-06-12 18:33:49 +0200376
Jonas Oreland49ac5952018-09-26 16:04:32 +0200377 std::vector<webrtc::RtpSource> GetSources();
378
Florent Castelliabe301f2018-06-12 18:33:49 +0200379 // Does not return codecs, they are filled by the owning WebRtcVideoChannel.
380 webrtc::RtpParameters GetRtpParameters() const;
eladalonf1841382017-06-12 01:16:46 -0700381
382 void SetLocalSsrc(uint32_t local_ssrc);
383 // TODO(deadbeef): Move these feedback parameters into the recv parameters.
384 void SetFeedbackParameters(bool nack_enabled,
385 bool remb_enabled,
386 bool transport_cc_enabled,
387 webrtc::RtcpMode rtcp_mode);
388 void SetRecvParameters(const ChangedRecvParameters& recv_params);
389
390 void OnFrame(const webrtc::VideoFrame& frame) override;
391 bool IsDefaultStream() const;
392
Benjamin Wright192eeec2018-10-17 17:27:25 -0700393 void SetFrameDecryptor(
394 rtc::scoped_refptr<webrtc::FrameDecryptorInterface> frame_decryptor);
395
eladalonf1841382017-06-12 01:16:46 -0700396 void SetSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
397
398 VideoReceiverInfo GetVideoReceiverInfo(bool log_stats);
399
400 private:
eladalonf1841382017-06-12 01:16:46 -0700401 void RecreateWebRtcVideoStream();
402 void MaybeRecreateWebRtcFlexfecStream();
403
eladalonc0d481a2017-08-02 07:39:07 -0700404 void MaybeAssociateFlexfecWithVideo();
405 void MaybeDissociateFlexfecFromVideo();
406
Niels Möllercbcbc222018-09-28 09:07:24 +0200407 void ConfigureCodecs(const std::vector<VideoCodecSettings>& recv_codecs);
eladalonf1841382017-06-12 01:16:46 -0700408 void ConfigureFlexfecCodec(int flexfec_payload_type);
eladalonf1841382017-06-12 01:16:46 -0700409
410 std::string GetCodecNameFromPayloadType(int payload_type);
411
412 webrtc::Call* const call_;
Niels Möllercbcbc222018-09-28 09:07:24 +0200413 const StreamParams stream_params_;
eladalonf1841382017-06-12 01:16:46 -0700414
415 // Both |stream_| and |flexfec_stream_| are managed by |this|. They are
416 // destroyed by calling call_->DestroyVideoReceiveStream and
417 // call_->DestroyFlexfecReceiveStream, respectively.
418 webrtc::VideoReceiveStream* stream_;
419 const bool default_stream_;
420 webrtc::VideoReceiveStream::Config config_;
421 webrtc::FlexfecReceiveStream::Config flexfec_config_;
422 webrtc::FlexfecReceiveStream* flexfec_stream_;
423
Niels Möllercbcbc222018-09-28 09:07:24 +0200424 webrtc::VideoDecoderFactory* const decoder_factory_;
eladalonf1841382017-06-12 01:16:46 -0700425
426 rtc::CriticalSection sink_lock_;
danilchapa37de392017-09-09 04:17:22 -0700427 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink_
428 RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700429 // Expands remote RTP timestamps to int64_t to be able to estimate how long
430 // the stream has been running.
431 rtc::TimestampWrapAroundHandler timestamp_wraparound_handler_
danilchapa37de392017-09-09 04:17:22 -0700432 RTC_GUARDED_BY(sink_lock_);
433 int64_t first_frame_timestamp_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700434 // Start NTP time is estimated as current remote NTP time (estimated from
435 // RTCP) minus the elapsed time, as soon as remote NTP time is available.
danilchapa37de392017-09-09 04:17:22 -0700436 int64_t estimated_remote_start_ntp_time_ms_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700437 };
438
439 void Construct(webrtc::Call* call, WebRtcVideoEngine* engine);
440
441 bool SendRtp(const uint8_t* data,
442 size_t len,
443 const webrtc::PacketOptions& options) override;
444 bool SendRtcp(const uint8_t* data, size_t len) override;
445
446 static std::vector<VideoCodecSettings> MapCodecs(
447 const std::vector<VideoCodec>& codecs);
448 // Select what video codec will be used for sending, i.e. what codec is used
449 // for local encoding, based on supported remote codecs. The first remote
450 // codec that is supported locally will be selected.
Danil Chapovalov00c71832018-06-15 15:58:38 +0200451 absl::optional<VideoCodecSettings> SelectSendVideoCodec(
eladalonf1841382017-06-12 01:16:46 -0700452 const std::vector<VideoCodecSettings>& remote_mapped_codecs) const;
453
454 static bool NonFlexfecReceiveCodecsHaveChanged(
455 std::vector<VideoCodecSettings> before,
456 std::vector<VideoCodecSettings> after);
457
458 void FillSenderStats(VideoMediaInfo* info, bool log_stats);
459 void FillReceiverStats(VideoMediaInfo* info, bool log_stats);
460 void FillBandwidthEstimationStats(const webrtc::Call::Stats& stats,
461 VideoMediaInfo* info);
462 void FillSendAndReceiveCodecStats(VideoMediaInfo* video_media_info);
463
464 rtc::ThreadChecker thread_checker_;
465
466 uint32_t rtcp_receiver_report_ssrc_;
467 bool sending_;
468 webrtc::Call* const call_;
469
470 DefaultUnsignalledSsrcHandler default_unsignalled_ssrc_handler_;
471 UnsignalledSsrcHandler* const unsignalled_ssrc_handler_;
472
473 const MediaConfig::Video video_config_;
474
475 rtc::CriticalSection stream_crit_;
476 // Using primary-ssrc (first ssrc) as key.
477 std::map<uint32_t, WebRtcVideoSendStream*> send_streams_
danilchapa37de392017-09-09 04:17:22 -0700478 RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700479 std::map<uint32_t, WebRtcVideoReceiveStream*> receive_streams_
danilchapa37de392017-09-09 04:17:22 -0700480 RTC_GUARDED_BY(stream_crit_);
481 std::set<uint32_t> send_ssrcs_ RTC_GUARDED_BY(stream_crit_);
482 std::set<uint32_t> receive_ssrcs_ RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700483
Danil Chapovalov00c71832018-06-15 15:58:38 +0200484 absl::optional<VideoCodecSettings> send_codec_;
485 absl::optional<std::vector<webrtc::RtpExtension>> send_rtp_extensions_;
eladalonf1841382017-06-12 01:16:46 -0700486
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100487 webrtc::VideoEncoderFactory* const encoder_factory_;
Magnus Jedvert59ab3532018-09-03 18:07:56 +0200488 webrtc::VideoDecoderFactory* const decoder_factory_;
Jiawei Ouc2ebe212018-11-08 10:02:56 -0800489 webrtc::VideoBitrateAllocatorFactory* const bitrate_allocator_factory_;
eladalonf1841382017-06-12 01:16:46 -0700490 std::vector<VideoCodecSettings> recv_codecs_;
491 std::vector<webrtc::RtpExtension> recv_rtp_extensions_;
492 // See reason for keeping track of the FlexFEC payload type separately in
493 // comment in WebRtcVideoChannel::ChangedRecvParameters.
494 int recv_flexfec_payload_type_;
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +0100495 webrtc::BitrateConstraints bitrate_config_;
eladalonf1841382017-06-12 01:16:46 -0700496 // TODO(deadbeef): Don't duplicate information between
497 // send_params/recv_params, rtp_extensions, options, etc.
498 VideoSendParameters send_params_;
Tim Haloun648d28a2018-10-18 16:52:22 -0700499 rtc::DiffServCodePoint preferred_dscp_;
eladalonf1841382017-06-12 01:16:46 -0700500 VideoOptions default_send_options_;
501 VideoRecvParameters recv_params_;
502 int64_t last_stats_log_ms_;
Åsa Persson2c7149b2018-10-15 09:36:10 +0200503 const bool discard_unknown_ssrc_packets_;
Seth Hampson5897a6e2018-04-03 11:16:33 -0700504 // This is a stream param that comes from the remote description, but wasn't
505 // signaled with any a=ssrc lines. It holds information that was signaled
506 // before the unsignaled receive stream is created when the first packet is
507 // received.
508 StreamParams unsignaled_stream_params_;
Benjamin Wright192eeec2018-10-17 17:27:25 -0700509 // Per peer connection crypto options that last for the lifetime of the peer
510 // connection.
511 const webrtc::CryptoOptions crypto_options_;
eladalonf1841382017-06-12 01:16:46 -0700512};
513
ilnik6b826ef2017-06-16 06:53:48 -0700514class EncoderStreamFactory
515 : public webrtc::VideoEncoderConfig::VideoStreamFactoryInterface {
516 public:
517 EncoderStreamFactory(std::string codec_name,
518 int max_qp,
Seth Hampson1370e302018-02-07 08:50:36 -0800519 bool is_screenshare,
520 bool screenshare_config_explicitly_enabled);
ilnik6b826ef2017-06-16 06:53:48 -0700521
522 private:
523 std::vector<webrtc::VideoStream> CreateEncoderStreams(
524 int width,
525 int height,
526 const webrtc::VideoEncoderConfig& encoder_config) override;
527
528 const std::string codec_name_;
529 const int max_qp_;
Seth Hampson1370e302018-02-07 08:50:36 -0800530 const bool is_screenshare_;
531 // Allows a screenshare specific configuration, which enables temporal
532 // layering and allows simulcast.
533 const bool screenshare_config_explicitly_enabled_;
ilnik6b826ef2017-06-16 06:53:48 -0700534};
535
eladalonf1841382017-06-12 01:16:46 -0700536} // namespace cricket
537
Steve Anton10542f22019-01-11 09:11:00 -0800538#endif // MEDIA_ENGINE_WEBRTC_VIDEO_ENGINE_H_