blob: 07e6c70e930280df055dbaa1aefcce68eee489be [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,
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100262 webrtc::VideoEncoderFactory* encoder_factory,
eladalonf1841382017-06-12 01:16:46 -0700263 bool enable_cpu_overuse_detection,
264 int max_bitrate_bps,
265 const rtc::Optional<VideoCodecSettings>& codec_settings,
266 const rtc::Optional<std::vector<webrtc::RtpExtension>>& rtp_extensions,
267 const VideoSendParameters& send_params);
268 virtual ~WebRtcVideoSendStream();
269
270 void SetSendParameters(const ChangedSendParameters& send_params);
Zach Steinba37b4b2018-01-23 15:02:36 -0800271 webrtc::RTCError SetRtpParameters(const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700272 webrtc::RtpParameters GetRtpParameters() const;
273
274 // Implements rtc::VideoSourceInterface<webrtc::VideoFrame>.
275 // WebRtcVideoSendStream acts as a source to the webrtc::VideoSendStream
276 // in |stream_|. This is done to proxy VideoSinkWants from the encoder to
277 // the worker thread.
278 void AddOrUpdateSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink,
279 const rtc::VideoSinkWants& wants) override;
280 void RemoveSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink) override;
281
282 bool SetVideoSend(bool mute,
283 const VideoOptions* options,
284 rtc::VideoSourceInterface<webrtc::VideoFrame>* source);
285
286 void SetSend(bool send);
287
288 const std::vector<uint32_t>& GetSsrcs() const;
289 VideoSenderInfo GetVideoSenderInfo(bool log_stats);
290 void FillBitrateInfo(BandwidthEstimationInfo* bwe_info);
291
292 private:
293 // Parameters needed to reconstruct the underlying stream.
294 // webrtc::VideoSendStream doesn't support setting a lot of options on the
295 // fly, so when those need to be changed we tear down and reconstruct with
296 // similar parameters depending on which options changed etc.
297 struct VideoSendStreamParameters {
298 VideoSendStreamParameters(
299 webrtc::VideoSendStream::Config config,
300 const VideoOptions& options,
301 int max_bitrate_bps,
302 const rtc::Optional<VideoCodecSettings>& codec_settings);
303 webrtc::VideoSendStream::Config config;
304 VideoOptions options;
305 int max_bitrate_bps;
306 bool conference_mode;
307 rtc::Optional<VideoCodecSettings> codec_settings;
308 // Sent resolutions + bitrates etc. by the underlying VideoSendStream,
309 // typically changes when setting a new resolution or reconfiguring
310 // bitrates.
311 webrtc::VideoEncoderConfig encoder_config;
312 };
313
eladalonf1841382017-06-12 01:16:46 -0700314 rtc::scoped_refptr<webrtc::VideoEncoderConfig::EncoderSpecificSettings>
315 ConfigureVideoEncoderSettings(const VideoCodec& codec);
Niels Möller5bf8ccd2018-03-15 14:16:11 +0100316 void SetCodec(const VideoCodecSettings& codec);
eladalonf1841382017-06-12 01:16:46 -0700317 void RecreateWebRtcStream();
318 webrtc::VideoEncoderConfig CreateVideoEncoderConfig(
319 const VideoCodec& codec) const;
320 void ReconfigureEncoder();
Zach Steinba37b4b2018-01-23 15:02:36 -0800321 webrtc::RTCError ValidateRtpParameters(
322 const webrtc::RtpParameters& parameters);
eladalonf1841382017-06-12 01:16:46 -0700323
324 // Calls Start or Stop according to whether or not |sending_| is true,
325 // and whether or not the encoding in |rtp_parameters_| is active.
326 void UpdateSendState();
327
328 webrtc::VideoSendStream::DegradationPreference GetDegradationPreference()
danilchapa37de392017-09-09 04:17:22 -0700329 const RTC_EXCLUSIVE_LOCKS_REQUIRED(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700330
331 rtc::ThreadChecker thread_checker_;
332 rtc::AsyncInvoker invoker_;
333 rtc::Thread* worker_thread_;
Niels Möller1e062892018-02-07 10:18:32 +0100334 const std::vector<uint32_t> ssrcs_ RTC_GUARDED_BY(&thread_checker_);
335 const std::vector<SsrcGroup> ssrc_groups_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700336 webrtc::Call* const call_;
337 const bool enable_cpu_overuse_detection_;
338 rtc::VideoSourceInterface<webrtc::VideoFrame>* source_
Niels Möller1e062892018-02-07 10:18:32 +0100339 RTC_GUARDED_BY(&thread_checker_);
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100340 webrtc::VideoEncoderFactory* const encoder_factory_
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_);
eladalonf1841382017-06-12 01:16:46 -0700344 rtc::VideoSinkInterface<webrtc::VideoFrame>* encoder_sink_
Niels Möller1e062892018-02-07 10:18:32 +0100345 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_);
magjeda35df422017-08-30 04:21:30 -0700356 std::unique_ptr<webrtc::VideoEncoder> allocated_encoder_
Niels Möller1e062892018-02-07 10:18:32 +0100357 RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700358
Niels Möller1e062892018-02-07 10:18:32 +0100359 bool sending_ RTC_GUARDED_BY(&thread_checker_);
eladalonf1841382017-06-12 01:16:46 -0700360 };
361
362 // Wrapper for the receiver part, contains configs etc. that are needed to
363 // reconstruct the underlying VideoReceiveStream.
364 class WebRtcVideoReceiveStream
365 : public rtc::VideoSinkInterface<webrtc::VideoFrame> {
366 public:
367 WebRtcVideoReceiveStream(
368 webrtc::Call* call,
369 const StreamParams& sp,
370 webrtc::VideoReceiveStream::Config config,
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100371 DecoderFactoryAdapter* decoder_factory,
eladalonf1841382017-06-12 01:16:46 -0700372 bool default_stream,
373 const std::vector<VideoCodecSettings>& recv_codecs,
374 const webrtc::FlexfecReceiveStream::Config& flexfec_config);
375 ~WebRtcVideoReceiveStream();
376
377 const std::vector<uint32_t>& GetSsrcs() const;
378 rtc::Optional<uint32_t> GetFirstPrimarySsrc() const;
379
380 void SetLocalSsrc(uint32_t local_ssrc);
381 // TODO(deadbeef): Move these feedback parameters into the recv parameters.
382 void SetFeedbackParameters(bool nack_enabled,
383 bool remb_enabled,
384 bool transport_cc_enabled,
385 webrtc::RtcpMode rtcp_mode);
386 void SetRecvParameters(const ChangedRecvParameters& recv_params);
387
388 void OnFrame(const webrtc::VideoFrame& frame) override;
389 bool IsDefaultStream() const;
390
391 void SetSink(rtc::VideoSinkInterface<webrtc::VideoFrame>* sink);
392
393 VideoReceiverInfo GetVideoReceiverInfo(bool log_stats);
394
395 private:
andersc063f0c02017-09-11 11:50:51 -0700396 struct SdpVideoFormatCompare {
397 bool operator()(const webrtc::SdpVideoFormat& lhs,
398 const webrtc::SdpVideoFormat& rhs) const {
399 return std::tie(lhs.name, lhs.parameters) <
400 std::tie(rhs.name, rhs.parameters);
401 }
perkj1f885312017-09-04 02:43:10 -0700402 };
andersc063f0c02017-09-11 11:50:51 -0700403 typedef std::map<webrtc::SdpVideoFormat,
404 std::unique_ptr<webrtc::VideoDecoder>,
405 SdpVideoFormatCompare>
406 DecoderMap;
perkj1f885312017-09-04 02:43:10 -0700407
eladalonf1841382017-06-12 01:16:46 -0700408 void RecreateWebRtcVideoStream();
409 void MaybeRecreateWebRtcFlexfecStream();
410
eladalonc0d481a2017-08-02 07:39:07 -0700411 void MaybeAssociateFlexfecWithVideo();
412 void MaybeDissociateFlexfecFromVideo();
413
perkj1f885312017-09-04 02:43:10 -0700414 void ConfigureCodecs(const std::vector<VideoCodecSettings>& recv_codecs,
andersc063f0c02017-09-11 11:50:51 -0700415 DecoderMap* old_codecs);
eladalonf1841382017-06-12 01:16:46 -0700416 void ConfigureFlexfecCodec(int flexfec_payload_type);
eladalonf1841382017-06-12 01:16:46 -0700417
418 std::string GetCodecNameFromPayloadType(int payload_type);
419
420 webrtc::Call* const call_;
421 StreamParams stream_params_;
422
423 // Both |stream_| and |flexfec_stream_| are managed by |this|. They are
424 // destroyed by calling call_->DestroyVideoReceiveStream and
425 // call_->DestroyFlexfecReceiveStream, respectively.
426 webrtc::VideoReceiveStream* stream_;
427 const bool default_stream_;
428 webrtc::VideoReceiveStream::Config config_;
429 webrtc::FlexfecReceiveStream::Config flexfec_config_;
430 webrtc::FlexfecReceiveStream* flexfec_stream_;
431
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100432 DecoderFactoryAdapter* decoder_factory_;
andersc063f0c02017-09-11 11:50:51 -0700433 DecoderMap allocated_decoders_;
eladalonf1841382017-06-12 01:16:46 -0700434
435 rtc::CriticalSection sink_lock_;
danilchapa37de392017-09-09 04:17:22 -0700436 rtc::VideoSinkInterface<webrtc::VideoFrame>* sink_
437 RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700438 // Expands remote RTP timestamps to int64_t to be able to estimate how long
439 // the stream has been running.
440 rtc::TimestampWrapAroundHandler timestamp_wraparound_handler_
danilchapa37de392017-09-09 04:17:22 -0700441 RTC_GUARDED_BY(sink_lock_);
442 int64_t first_frame_timestamp_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700443 // Start NTP time is estimated as current remote NTP time (estimated from
444 // RTCP) minus the elapsed time, as soon as remote NTP time is available.
danilchapa37de392017-09-09 04:17:22 -0700445 int64_t estimated_remote_start_ntp_time_ms_ RTC_GUARDED_BY(sink_lock_);
eladalonf1841382017-06-12 01:16:46 -0700446 };
447
448 void Construct(webrtc::Call* call, WebRtcVideoEngine* engine);
449
450 bool SendRtp(const uint8_t* data,
451 size_t len,
452 const webrtc::PacketOptions& options) override;
453 bool SendRtcp(const uint8_t* data, size_t len) override;
454
455 static std::vector<VideoCodecSettings> MapCodecs(
456 const std::vector<VideoCodec>& codecs);
457 // Select what video codec will be used for sending, i.e. what codec is used
458 // for local encoding, based on supported remote codecs. The first remote
459 // codec that is supported locally will be selected.
460 rtc::Optional<VideoCodecSettings> SelectSendVideoCodec(
461 const std::vector<VideoCodecSettings>& remote_mapped_codecs) const;
462
463 static bool NonFlexfecReceiveCodecsHaveChanged(
464 std::vector<VideoCodecSettings> before,
465 std::vector<VideoCodecSettings> after);
466
467 void FillSenderStats(VideoMediaInfo* info, bool log_stats);
468 void FillReceiverStats(VideoMediaInfo* info, bool log_stats);
469 void FillBandwidthEstimationStats(const webrtc::Call::Stats& stats,
470 VideoMediaInfo* info);
471 void FillSendAndReceiveCodecStats(VideoMediaInfo* video_media_info);
472
473 rtc::ThreadChecker thread_checker_;
474
475 uint32_t rtcp_receiver_report_ssrc_;
476 bool sending_;
477 webrtc::Call* const call_;
478
479 DefaultUnsignalledSsrcHandler default_unsignalled_ssrc_handler_;
480 UnsignalledSsrcHandler* const unsignalled_ssrc_handler_;
481
482 const MediaConfig::Video video_config_;
483
484 rtc::CriticalSection stream_crit_;
485 // Using primary-ssrc (first ssrc) as key.
486 std::map<uint32_t, WebRtcVideoSendStream*> send_streams_
danilchapa37de392017-09-09 04:17:22 -0700487 RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700488 std::map<uint32_t, WebRtcVideoReceiveStream*> receive_streams_
danilchapa37de392017-09-09 04:17:22 -0700489 RTC_GUARDED_BY(stream_crit_);
490 std::set<uint32_t> send_ssrcs_ RTC_GUARDED_BY(stream_crit_);
491 std::set<uint32_t> receive_ssrcs_ RTC_GUARDED_BY(stream_crit_);
eladalonf1841382017-06-12 01:16:46 -0700492
493 rtc::Optional<VideoCodecSettings> send_codec_;
494 rtc::Optional<std::vector<webrtc::RtpExtension>> send_rtp_extensions_;
495
Magnus Jedvert07e0d012017-10-31 11:24:54 +0100496 webrtc::VideoEncoderFactory* const encoder_factory_;
497 DecoderFactoryAdapter* const decoder_factory_;
eladalonf1841382017-06-12 01:16:46 -0700498 std::vector<VideoCodecSettings> recv_codecs_;
499 std::vector<webrtc::RtpExtension> recv_rtp_extensions_;
500 // See reason for keeping track of the FlexFEC payload type separately in
501 // comment in WebRtcVideoChannel::ChangedRecvParameters.
502 int recv_flexfec_payload_type_;
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +0100503 webrtc::BitrateConstraints bitrate_config_;
eladalonf1841382017-06-12 01:16:46 -0700504 // TODO(deadbeef): Don't duplicate information between
505 // send_params/recv_params, rtp_extensions, options, etc.
506 VideoSendParameters send_params_;
507 VideoOptions default_send_options_;
508 VideoRecvParameters recv_params_;
509 int64_t last_stats_log_ms_;
510};
511
ilnik6b826ef2017-06-16 06:53:48 -0700512class EncoderStreamFactory
513 : public webrtc::VideoEncoderConfig::VideoStreamFactoryInterface {
514 public:
515 EncoderStreamFactory(std::string codec_name,
516 int max_qp,
517 int max_framerate,
Seth Hampson1370e302018-02-07 08:50:36 -0800518 bool is_screenshare,
519 bool screenshare_config_explicitly_enabled);
ilnik6b826ef2017-06-16 06:53:48 -0700520
521 private:
522 std::vector<webrtc::VideoStream> CreateEncoderStreams(
523 int width,
524 int height,
525 const webrtc::VideoEncoderConfig& encoder_config) override;
526
527 const std::string codec_name_;
528 const int max_qp_;
529 const int max_framerate_;
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
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200538#endif // MEDIA_ENGINE_WEBRTCVIDEOENGINE_H_