blob: f5f9b00206cd2cac549d96d260dcd3cd2bcb14b9 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
pwestin@webrtc.org52fd98d2012-02-13 09:03:53 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
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
11#ifndef WEBRTC_MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_
12#define WEBRTC_MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_
13
Henrik Kjellander2557b862015-11-18 22:00:21 +010014#include "webrtc/modules/video_coding/include/video_coding.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000015
kwiberg3f55dea2016-02-29 05:51:59 -080016#include <memory>
stefan@webrtc.orgc5300432012-10-08 07:06:53 +000017#include <vector>
18
pbos@webrtc.org38344ed2014-09-24 06:05:00 +000019#include "webrtc/base/thread_annotations.h"
tommi@webrtc.orge07710c2015-02-19 17:43:25 +000020#include "webrtc/base/thread_checker.h"
Henrik Kjellander2557b862015-11-18 22:00:21 +010021#include "webrtc/modules/video_coding/codec_database.h"
22#include "webrtc/modules/video_coding/frame_buffer.h"
23#include "webrtc/modules/video_coding/generic_decoder.h"
24#include "webrtc/modules/video_coding/generic_encoder.h"
25#include "webrtc/modules/video_coding/jitter_buffer.h"
26#include "webrtc/modules/video_coding/media_optimization.h"
27#include "webrtc/modules/video_coding/receiver.h"
28#include "webrtc/modules/video_coding/timing.h"
kjellander@webrtc.orgb7ce9642015-11-18 23:04:10 +010029#include "webrtc/modules/video_coding/utility/qp_parser.h"
Henrik Kjellander98f53512015-10-28 18:17:40 +010030#include "webrtc/system_wrappers/include/clock.h"
31#include "webrtc/system_wrappers/include/critical_section_wrapper.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000032
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000033namespace webrtc {
sprang@webrtc.org40709352013-11-26 11:41:59 +000034
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000035namespace vcm {
niklase@google.com470e71d2011-07-07 08:21:25 +000036
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000037class VCMProcessTimer {
38 public:
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000039 VCMProcessTimer(int64_t periodMs, Clock* clock)
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000040 : _clock(clock),
41 _periodMs(periodMs),
42 _latestMs(_clock->TimeInMilliseconds()) {}
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000043 int64_t Period() const;
44 int64_t TimeUntilProcess() const;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000045 void Processed();
niklase@google.com470e71d2011-07-07 08:21:25 +000046
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000047 private:
48 Clock* _clock;
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000049 int64_t _periodMs;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000050 int64_t _latestMs;
niklase@google.com470e71d2011-07-07 08:21:25 +000051};
52
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000053class VideoSender {
54 public:
55 typedef VideoCodingModule::SenderNackMode SenderNackMode;
56
pbos@webrtc.org891d4832015-02-26 13:15:22 +000057 VideoSender(Clock* clock,
58 EncodedImageCallback* post_encode_callback,
mflodmanfcf54bd2015-04-14 21:28:08 +020059 VideoEncoderRateObserver* encoder_rate_observer,
60 VCMQMSettingsCallback* qm_settings_callback);
andresp@webrtc.org1df9dc32014-01-09 08:01:57 +000061
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000062 ~VideoSender();
63
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000064 // Register the send codec to be used.
tommi@webrtc.orge07710c2015-02-19 17:43:25 +000065 // This method must be called on the construction thread.
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000066 int32_t RegisterSendCodec(const VideoCodec* sendCodec,
67 uint32_t numberOfCores,
68 uint32_t maxPayloadSize);
tommi@webrtc.orge07710c2015-02-19 17:43:25 +000069
Peter Boström795dbe42015-11-27 14:09:07 +010070 void RegisterExternalEncoder(VideoEncoder* externalEncoder,
71 uint8_t payloadType,
72 bool internalSource);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000073
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000074 int Bitrate(unsigned int* bitrate) const;
75 int FrameRate(unsigned int* framerate) const;
76
77 int32_t SetChannelParameters(uint32_t target_bitrate, // bits/s.
78 uint8_t lossRate,
pkasting@chromium.org16825b12015-01-12 21:51:21 +000079 int64_t rtt);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000080
81 int32_t RegisterTransportCallback(VCMPacketizationCallback* transport);
82 int32_t RegisterSendStatisticsCallback(VCMSendStatisticsCallback* sendStats);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000083 int32_t RegisterProtectionCallback(VCMProtectionCallback* protection);
pbosba8c15b2015-07-14 09:36:34 -070084 void SetVideoProtection(VCMVideoProtection videoProtection);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000085
Miguel Casas-Sanchez47650702015-05-29 17:21:40 -070086 int32_t AddVideoFrame(const VideoFrame& videoFrame,
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000087 const VideoContentMetrics* _contentMetrics,
88 const CodecSpecificInfo* codecSpecificInfo);
89
90 int32_t IntraFrameRequest(int stream_index);
91 int32_t EnableFrameDropper(bool enable);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000092
henrik.lundin@webrtc.orgce8e0932013-11-18 12:18:43 +000093 void SuspendBelowMinBitrate();
94 bool VideoSuspended() const;
henrik.lundin@webrtc.org572699d2013-09-30 12:16:08 +000095
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000096 int64_t TimeUntilNextProcess();
pbosa26ac922016-02-25 04:50:01 -080097 void Process();
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000098
99 private:
Peter Boströmdcb89982015-09-15 14:43:47 +0200100 void SetEncoderParameters(EncoderParameters params)
Peter Boström233bfd22016-01-18 20:23:40 +0100101 EXCLUSIVE_LOCKS_REQUIRED(encoder_crit_);
Peter Boströmdcb89982015-09-15 14:43:47 +0200102
103 Clock* const clock_;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000104
kwiberg3f55dea2016-02-29 05:51:59 -0800105 std::unique_ptr<CriticalSectionWrapper> process_crit_sect_;
pbos5ad935c2016-01-25 03:52:44 -0800106 rtc::CriticalSection encoder_crit_;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000107 VCMGenericEncoder* _encoder;
Peter Boström233bfd22016-01-18 20:23:40 +0100108 VCMEncodedFrameCallback _encodedFrameCallback GUARDED_BY(encoder_crit_);
henrik.lundin@webrtc.orgbec11ef2013-09-23 19:54:25 +0000109 media_optimization::MediaOptimization _mediaOpt;
Peter Boströmdcb89982015-09-15 14:43:47 +0200110 VCMSendStatisticsCallback* _sendStatsCallback GUARDED_BY(process_crit_sect_);
Peter Boström233bfd22016-01-18 20:23:40 +0100111 VCMCodecDataBase _codecDataBase GUARDED_BY(encoder_crit_);
112 bool frame_dropper_enabled_ GUARDED_BY(encoder_crit_);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000113 VCMProcessTimer _sendStatsTimer;
andresp@webrtc.orge682aa52013-12-19 10:59:48 +0000114
tommi@webrtc.orge07710c2015-02-19 17:43:25 +0000115 // Must be accessed on the construction thread of VideoSender.
116 VideoCodec current_codec_;
117 rtc::ThreadChecker main_thread_;
118
mflodmanfcf54bd2015-04-14 21:28:08 +0200119 VCMQMSettingsCallback* const qm_settings_callback_;
andresp@webrtc.orge682aa52013-12-19 10:59:48 +0000120 VCMProtectionCallback* protection_callback_;
Erik Språng66a641a2015-06-11 14:20:07 +0200121
Peter Boström233bfd22016-01-18 20:23:40 +0100122 rtc::CriticalSection params_crit_;
123 EncoderParameters encoder_params_ GUARDED_BY(params_crit_);
124 bool encoder_has_internal_source_ GUARDED_BY(params_crit_);
125 std::vector<FrameType> next_frame_types_ GUARDED_BY(params_crit_);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000126};
127
128class VideoReceiver {
129 public:
130 typedef VideoCodingModule::ReceiverRobustness ReceiverRobustness;
131
philipel83f831a2016-03-12 03:30:23 -0800132 VideoReceiver(Clock* clock,
133 EventFactory* event_factory,
134 NackSender* nack_sender = nullptr,
135 KeyFrameRequestSender* keyframe_request_sender = nullptr);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000136 ~VideoReceiver();
137
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000138 int32_t RegisterReceiveCodec(const VideoCodec* receiveCodec,
139 int32_t numberOfCores,
140 bool requireKeyFrame);
141
Peter Boström795dbe42015-11-27 14:09:07 +0100142 void RegisterExternalDecoder(VideoDecoder* externalDecoder,
perkj796cfaf2015-12-10 09:27:38 -0800143 uint8_t payloadType);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000144 int32_t RegisterReceiveCallback(VCMReceiveCallback* receiveCallback);
145 int32_t RegisterReceiveStatisticsCallback(
146 VCMReceiveStatisticsCallback* receiveStats);
fischman@webrtc.org37bb4972013-10-23 23:59:45 +0000147 int32_t RegisterDecoderTimingCallback(
148 VCMDecoderTimingCallback* decoderTiming);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000149 int32_t RegisterFrameTypeCallback(VCMFrameTypeCallback* frameTypeCallback);
150 int32_t RegisterPacketRequestCallback(VCMPacketRequestCallback* callback);
151 int RegisterRenderBufferSizeCallback(VCMRenderBufferSizeCallback* callback);
152
153 int32_t Decode(uint16_t maxWaitTimeMs);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000154
155 int32_t ReceiveCodec(VideoCodec* currentReceiveCodec) const;
156 VideoCodecType ReceiveCodec() const;
157
158 int32_t IncomingPacket(const uint8_t* incomingPayload,
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +0000159 size_t payloadLength,
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000160 const WebRtcRTPHeader& rtpInfo);
161 int32_t SetMinimumPlayoutDelay(uint32_t minPlayoutDelayMs);
162 int32_t SetRenderDelay(uint32_t timeMS);
163 int32_t Delay() const;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000164 uint32_t DiscardedPackets() const;
165
166 int SetReceiverRobustnessMode(ReceiverRobustness robustnessMode,
167 VCMDecodeErrorMode errorMode);
168 void SetNackSettings(size_t max_nack_list_size,
169 int max_packet_age_to_nack,
170 int max_incomplete_time_ms);
171
172 void SetDecodeErrorMode(VCMDecodeErrorMode decode_error_mode);
173 int SetMinReceiverDelay(int desired_delay_ms);
174
pkasting@chromium.org16825b12015-01-12 21:51:21 +0000175 int32_t SetReceiveChannelParameters(int64_t rtt);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000176 int32_t SetVideoProtection(VCMVideoProtection videoProtection, bool enable);
177
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +0000178 int64_t TimeUntilNextProcess();
pbosa26ac922016-02-25 04:50:01 -0800179 void Process();
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000180
sprang@webrtc.org40709352013-11-26 11:41:59 +0000181 void RegisterPreDecodeImageCallback(EncodedImageCallback* observer);
pbos@webrtc.org4dd40d62015-02-17 13:22:43 +0000182 void TriggerDecoderShutdown();
sprang@webrtc.org40709352013-11-26 11:41:59 +0000183
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000184 protected:
pbos@webrtc.org776e6f22014-10-29 15:28:39 +0000185 int32_t Decode(const webrtc::VCMEncodedFrame& frame)
186 EXCLUSIVE_LOCKS_REQUIRED(_receiveCritSect);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000187 int32_t RequestKeyFrame();
188 int32_t RequestSliceLossIndication(const uint64_t pictureID) const;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000189
190 private:
pbos@webrtc.org20c1f562014-07-04 10:58:12 +0000191 Clock* const clock_;
kwiberg3f55dea2016-02-29 05:51:59 -0800192 std::unique_ptr<CriticalSectionWrapper> process_crit_sect_;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000193 CriticalSectionWrapper* _receiveCritSect;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000194 VCMTiming _timing;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000195 VCMReceiver _receiver;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000196 VCMDecodedFrameCallback _decodedFrameCallback;
pbos@webrtc.org20c1f562014-07-04 10:58:12 +0000197 VCMFrameTypeCallback* _frameTypeCallback GUARDED_BY(process_crit_sect_);
198 VCMReceiveStatisticsCallback* _receiveStatsCallback
199 GUARDED_BY(process_crit_sect_);
200 VCMDecoderTimingCallback* _decoderTimingCallback
201 GUARDED_BY(process_crit_sect_);
202 VCMPacketRequestCallback* _packetRequestCallback
203 GUARDED_BY(process_crit_sect_);
204 VCMRenderBufferSizeCallback* render_buffer_callback_
205 GUARDED_BY(process_crit_sect_);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000206 VCMGenericDecoder* _decoder;
tommi@webrtc.orga9da4c52012-07-20 11:17:23 +0000207#ifdef DEBUG_DECODER_BIT_STREAM
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000208 FILE* _bitStreamBeforeDecoder;
tommi@webrtc.orga9da4c52012-07-20 11:17:23 +0000209#endif
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000210 VCMFrameBuffer _frameFromFile;
pbos@webrtc.org20c1f562014-07-04 10:58:12 +0000211 bool _scheduleKeyRequest GUARDED_BY(process_crit_sect_);
Peter Boströmed3277b2016-02-02 15:40:04 +0100212 bool drop_frames_until_keyframe_ GUARDED_BY(process_crit_sect_);
pbos@webrtc.org20c1f562014-07-04 10:58:12 +0000213 size_t max_nack_list_size_ GUARDED_BY(process_crit_sect_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000214
pbos@webrtc.org776e6f22014-10-29 15:28:39 +0000215 VCMCodecDataBase _codecDataBase GUARDED_BY(_receiveCritSect);
Peter Boströmed3277b2016-02-02 15:40:04 +0100216 EncodedImageCallback* pre_decode_image_callback_ GUARDED_BY(_receiveCritSect);
217
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000218 VCMProcessTimer _receiveStatsTimer;
219 VCMProcessTimer _retransmissionTimer;
220 VCMProcessTimer _keyRequestTimer;
asapersson86b01602015-10-20 23:55:26 -0700221 QpParser qp_parser_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000222};
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000223
224} // namespace vcm
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000225} // namespace webrtc
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000226#endif // WEBRTC_MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_