blob: fb71e11a895d34fed3cd64d294fa2d84898983f6 [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
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_
12#define MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
kwiberg3f55dea2016-02-29 05:51:59 -080014#include <memory>
perkj376b1922016-05-02 11:35:24 -070015#include <string>
stefan@webrtc.orgc5300432012-10-08 07:06:53 +000016#include <vector>
17
Erik Språngeee39202018-11-15 17:52:43 +010018#include "absl/types/optional.h"
Niels Möllerf9063782018-02-20 16:09:48 +010019#include "modules/video_coding/decoder_database.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020020#include "modules/video_coding/frame_buffer.h"
21#include "modules/video_coding/generic_decoder.h"
Jonas Olssona4d87372019-07-05 19:08:33 +020022#include "modules/video_coding/include/video_coding.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020023#include "modules/video_coding/jitter_buffer.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "modules/video_coding/receiver.h"
25#include "modules/video_coding/timing.h"
Steve Anton10542f22019-01-11 09:11:00 -080026#include "rtc_base/one_time_event.h"
Sebastian Janssonb55015e2019-04-09 13:44:04 +020027#include "rtc_base/synchronization/sequence_checker.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020028#include "rtc_base/thread_annotations.h"
29#include "rtc_base/thread_checker.h"
30#include "system_wrappers/include/clock.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000031
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000032namespace webrtc {
sprang@webrtc.org40709352013-11-26 11:41:59 +000033
Erik Språng08127a92016-11-16 16:41:30 +010034class VideoBitrateAllocator;
sprang1a646ee2016-12-01 06:34:11 -080035class VideoBitrateAllocationObserver;
Erik Språng08127a92016-11-16 16:41:30 +010036
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000037namespace vcm {
niklase@google.com470e71d2011-07-07 08:21:25 +000038
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000039class VCMProcessTimer {
40 public:
sprang40217c32016-11-21 05:41:52 -080041 static const int64_t kDefaultProcessIntervalMs = 1000;
42
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000043 VCMProcessTimer(int64_t periodMs, Clock* clock)
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000044 : _clock(clock),
45 _periodMs(periodMs),
46 _latestMs(_clock->TimeInMilliseconds()) {}
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000047 int64_t Period() const;
48 int64_t TimeUntilProcess() const;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000049 void Processed();
niklase@google.com470e71d2011-07-07 08:21:25 +000050
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000051 private:
52 Clock* _clock;
pkasting@chromium.org0b1534c2014-12-15 22:09:40 +000053 int64_t _periodMs;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000054 int64_t _latestMs;
niklase@google.com470e71d2011-07-07 08:21:25 +000055};
56
Peter Boström0b250722016-04-22 18:23:15 +020057class VideoReceiver : public Module {
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000058 public:
Niels Möllerdb64d992019-03-29 14:30:53 +010059 VideoReceiver(Clock* clock, VCMTiming* timing);
Tommifbf3bce2018-02-21 15:56:05 +010060 ~VideoReceiver() override;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000061
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000062 int32_t RegisterReceiveCodec(const VideoCodec* receiveCodec,
63 int32_t numberOfCores,
64 bool requireKeyFrame);
65
Peter Boström795dbe42015-11-27 14:09:07 +010066 void RegisterExternalDecoder(VideoDecoder* externalDecoder,
perkj796cfaf2015-12-10 09:27:38 -080067 uint8_t payloadType);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000068 int32_t RegisterReceiveCallback(VCMReceiveCallback* receiveCallback);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000069 int32_t RegisterFrameTypeCallback(VCMFrameTypeCallback* frameTypeCallback);
70 int32_t RegisterPacketRequestCallback(VCMPacketRequestCallback* callback);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000071
72 int32_t Decode(uint16_t maxWaitTimeMs);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000073
philipelfd5a20f2016-11-15 00:57:57 -080074 int32_t Decode(const webrtc::VCMEncodedFrame* frame);
75
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000076 int32_t IncomingPacket(const uint8_t* incomingPayload,
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +000077 size_t payloadLength,
Niels Möllerbe7a0ec2019-04-25 10:02:52 +020078 const RTPHeader& rtp_header,
79 const RTPVideoHeader& video_header);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000080
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000081 void SetNackSettings(size_t max_nack_list_size,
82 int max_packet_age_to_nack,
83 int max_incomplete_time_ms);
84
Peter Boström0b250722016-04-22 18:23:15 +020085 int64_t TimeUntilNextProcess() override;
86 void Process() override;
Tommifbf3bce2018-02-21 15:56:05 +010087 void ProcessThreadAttached(ProcessThread* process_thread) override;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000088
pbos@webrtc.org4dd40d62015-02-17 13:22:43 +000089 void TriggerDecoderShutdown();
sprang@webrtc.org40709352013-11-26 11:41:59 +000090
Tommifbf3bce2018-02-21 15:56:05 +010091 // Notification methods that are used to check our internal state and validate
92 // threading assumptions. These are called by VideoReceiveStream.
93 // See |IsDecoderThreadRunning()| for more details.
94 void DecoderThreadStarting();
95 void DecoderThreadStopped();
96
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000097 protected:
Tommifbf3bce2018-02-21 15:56:05 +010098 int32_t Decode(const webrtc::VCMEncodedFrame& frame);
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +000099 int32_t RequestKeyFrame();
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000100
101 private:
Tommifbf3bce2018-02-21 15:56:05 +0100102 // Used for DCHECKing thread correctness.
103 // In build where DCHECKs are enabled, will return false before
104 // DecoderThreadStarting is called, then true until DecoderThreadStopped
105 // is called.
106 // In builds where DCHECKs aren't enabled, it will return true.
107 bool IsDecoderThreadRunning();
108
109 rtc::ThreadChecker construction_thread_checker_;
110 rtc::ThreadChecker decoder_thread_checker_;
111 rtc::ThreadChecker module_thread_checker_;
pbos@webrtc.org20c1f562014-07-04 10:58:12 +0000112 Clock* const clock_;
sprang3911c262016-04-15 01:24:14 -0700113 rtc::CriticalSection process_crit_;
philipel721d4022016-12-15 07:10:57 -0800114 VCMTiming* _timing;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000115 VCMReceiver _receiver;
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000116 VCMDecodedFrameCallback _decodedFrameCallback;
niklase@google.com470e71d2011-07-07 08:21:25 +0000117
Tommifbf3bce2018-02-21 15:56:05 +0100118 // These callbacks are set on the construction thread before being attached
119 // to the module thread or decoding started, so a lock is not required.
120 VCMFrameTypeCallback* _frameTypeCallback;
Tommifbf3bce2018-02-21 15:56:05 +0100121 VCMPacketRequestCallback* _packetRequestCallback;
122
123 // Used on both the module and decoder thread.
danilchap56359be2017-09-07 07:53:45 -0700124 bool _scheduleKeyRequest RTC_GUARDED_BY(process_crit_);
125 bool drop_frames_until_keyframe_ RTC_GUARDED_BY(process_crit_);
sprang3911c262016-04-15 01:24:14 -0700126
Tommifbf3bce2018-02-21 15:56:05 +0100127 // Modified on the construction thread while not attached to the process
128 // thread. Once attached to the process thread, its value is only read
129 // so a lock is not required.
130 size_t max_nack_list_size_;
Peter Boströmed3277b2016-02-02 15:40:04 +0100131
Tommifbf3bce2018-02-21 15:56:05 +0100132 // Callbacks are set before the decoder thread starts.
133 // Once the decoder thread has been started, usage of |_codecDataBase| moves
134 // over to the decoder thread.
135 VCMDecoderDataBase _codecDataBase;
Tommifbf3bce2018-02-21 15:56:05 +0100136
137 VCMProcessTimer _receiveStatsTimer RTC_GUARDED_BY(module_thread_checker_);
138 VCMProcessTimer _retransmissionTimer RTC_GUARDED_BY(module_thread_checker_);
139 VCMProcessTimer _keyRequestTimer RTC_GUARDED_BY(module_thread_checker_);
Tommifbf3bce2018-02-21 15:56:05 +0100140 ThreadUnsafeOneTimeEvent first_frame_received_
141 RTC_GUARDED_BY(decoder_thread_checker_);
142 // Modified on the construction thread. Can be read without a lock and assumed
143 // to be non-null on the module and decoder threads.
144 ProcessThread* process_thread_ = nullptr;
145 bool is_attached_to_process_thread_
146 RTC_GUARDED_BY(construction_thread_checker_) = false;
147#if RTC_DCHECK_IS_ON
148 bool decoder_thread_is_running_ = false;
149#endif
niklase@google.com470e71d2011-07-07 08:21:25 +0000150};
andresp@webrtc.orgf7eb75b2013-09-14 00:25:28 +0000151
152} // namespace vcm
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000153} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200154#endif // MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_