blob: aaab5fc1609c0ca6970932878d1e15787dc2df50 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
mikhal@webrtc.orga2031d52012-07-31 15:53:44 +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_GENERIC_DECODER_H_
12#define MODULES_VIDEO_CODING_GENERIC_DECODER_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
Ilya Nikolaevskiy43c108b2020-05-15 12:24:29 +020014#include <string>
tommi5b7fc8c2017-07-05 16:45:57 -070015
Artem Titovd15a5752021-02-10 14:31:24 +010016#include "api/sequence_checker.h"
Johannes Kron7ddea572019-09-11 12:00:22 +020017#include "api/units/time_delta.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020018#include "modules/video_coding/encoded_frame.h"
19#include "modules/video_coding/include/video_codec_interface.h"
20#include "modules/video_coding/timestamp_map.h"
21#include "modules/video_coding/timing.h"
Johannes Kron7ddea572019-09-11 12:00:22 +020022#include "rtc_base/experiments/field_trial_parser.h"
Markus Handell6deec382020-07-07 12:17:12 +020023#include "rtc_base/synchronization/mutex.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000024
philipel9d3ab612015-12-21 04:12:39 -080025namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000026
27class VCMReceiveCallback;
28
29enum { kDecoderFrameMemoryLength = 10 };
30
philipel9d3ab612015-12-21 04:12:39 -080031class VCMDecodedFrameCallback : public DecodedImageCallback {
32 public:
33 VCMDecodedFrameCallback(VCMTiming* timing, Clock* clock);
tommid0a71ba2017-03-14 04:16:20 -070034 ~VCMDecodedFrameCallback() override;
35 void SetUserReceiveCallback(VCMReceiveCallback* receiveCallback);
36 VCMReceiveCallback* UserReceiveCallback();
niklase@google.com470e71d2011-07-07 08:21:25 +000037
tommid0a71ba2017-03-14 04:16:20 -070038 int32_t Decoded(VideoFrame& decodedImage) override;
39 int32_t Decoded(VideoFrame& decodedImage, int64_t decode_time_ms) override;
40 void Decoded(VideoFrame& decodedImage,
Danil Chapovalov0040b662018-06-18 10:48:16 +020041 absl::optional<int32_t> decode_time_ms,
42 absl::optional<uint8_t> qp) override;
niklase@google.com470e71d2011-07-07 08:21:25 +000043
tommid0a71ba2017-03-14 04:16:20 -070044 void OnDecoderImplementationName(const char* implementation_name);
niklase@google.com470e71d2011-07-07 08:21:25 +000045
Johannes Kronb6b782d2021-03-03 14:39:44 +010046 void Map(uint32_t timestamp, const VCMFrameInformation& frameInfo);
Johannes Kronfc5d2762021-04-09 16:03:22 +020047 void ClearTimestampMap();
niklase@google.com470e71d2011-07-07 08:21:25 +000048
philipel9d3ab612015-12-21 04:12:39 -080049 private:
Artem Titovc8421c42021-02-02 10:57:19 +010050 SequenceChecker construction_thread_;
Artem Titovdcd7fc72021-08-09 13:02:57 +020051 // Protect `_timestampMap`.
tommid0a71ba2017-03-14 04:16:20 -070052 Clock* const _clock;
53 // This callback must be set before the decoder thread starts running
54 // and must only be unset when external threads (e.g decoder thread)
55 // have been stopped. Due to that, the variable should regarded as const
56 // while there are more than one threads involved, it must be set
57 // from the same thread, and therfore a lock is not required to access it.
58 VCMReceiveCallback* _receiveCallback = nullptr;
Lu Liu352314a2018-02-21 19:38:59 +000059 VCMTiming* _timing;
Markus Handell6deec382020-07-07 12:17:12 +020060 Mutex lock_;
Lu Liu352314a2018-02-21 19:38:59 +000061 VCMTimestampMap _timestampMap RTC_GUARDED_BY(lock_);
ilnik04f4d122017-06-19 07:18:55 -070062 int64_t ntp_offset_;
Johannes Kron7ddea572019-09-11 12:00:22 +020063 // Set by the field trial WebRTC-SlowDownDecoder to simulate a slow decoder.
64 FieldTrialOptional<TimeDelta> _extra_decode_time;
Johannes Kron111e9812020-10-26 13:54:40 +010065
Artem Titovdcd7fc72021-08-09 13:02:57 +020066 // Set by the field trial WebRTC-LowLatencyRenderer. The parameter `enabled`
Johannes Kron111e9812020-10-26 13:54:40 +010067 // determines if the low-latency renderer algorithm should be used for the
68 // case min playout delay=0 and max playout delay>0.
69 FieldTrialParameter<bool> low_latency_renderer_enabled_;
70 // Set by the field trial WebRTC-LowLatencyRenderer. The parameter
Artem Titovdcd7fc72021-08-09 13:02:57 +020071 // `include_predecode_buffer` determines if the predecode buffer should be
Johannes Kron111e9812020-10-26 13:54:40 +010072 // taken into account when calculating maximum number of frames in composition
73 // queue.
74 FieldTrialParameter<bool> low_latency_renderer_include_predecode_buffer_;
niklase@google.com470e71d2011-07-07 08:21:25 +000075};
76
philipel9d3ab612015-12-21 04:12:39 -080077class VCMGenericDecoder {
philipel9d3ab612015-12-21 04:12:39 -080078 public:
Danil Chapovalov7b78a312021-08-06 12:30:02 +020079 explicit VCMGenericDecoder(VideoDecoder* decoder);
philipel9d3ab612015-12-21 04:12:39 -080080 ~VCMGenericDecoder();
niklase@google.com470e71d2011-07-07 08:21:25 +000081
philipel9d3ab612015-12-21 04:12:39 -080082 /**
Yves Gerey665174f2018-06-19 15:03:05 +020083 * Initialize the decoder with the information from the VideoCodec
84 */
philipel9d3ab612015-12-21 04:12:39 -080085 int32_t InitDecode(const VideoCodec* settings, int32_t numberOfCores);
niklase@google.com470e71d2011-07-07 08:21:25 +000086
philipel9d3ab612015-12-21 04:12:39 -080087 /**
Yves Gerey665174f2018-06-19 15:03:05 +020088 * Decode to a raw I420 frame,
89 *
90 * inputVideoBuffer reference to encoded video frame
91 */
Johannes Kron05f84872020-01-16 14:09:33 +010092 int32_t Decode(const VCMEncodedFrame& inputFrame, Timestamp now);
niklase@google.com470e71d2011-07-07 08:21:25 +000093
philipel9d3ab612015-12-21 04:12:39 -080094 /**
Yves Gerey665174f2018-06-19 15:03:05 +020095 * Set decode callback. Deregistering while decoding is illegal.
96 */
philipel9d3ab612015-12-21 04:12:39 -080097 int32_t RegisterDecodeCompleteCallback(VCMDecodedFrameCallback* callback);
niklase@google.com470e71d2011-07-07 08:21:25 +000098
tommi5b7fc8c2017-07-05 16:45:57 -070099 bool IsSameDecoder(VideoDecoder* decoder) const {
Danil Chapovalov7b78a312021-08-06 12:30:02 +0200100 return decoder_ == decoder;
tommi5b7fc8c2017-07-05 16:45:57 -0700101 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000102
philipel9d3ab612015-12-21 04:12:39 -0800103 private:
Danil Chapovalov7b78a312021-08-06 12:30:02 +0200104 VCMDecodedFrameCallback* _callback = nullptr;
105 VideoDecoder* const decoder_;
ilnik00d802b2017-04-11 10:34:31 -0700106 VideoContentType _last_keyframe_content_type;
Erik Språngc12f6252021-01-13 21:49:59 +0100107 VideoDecoder::DecoderInfo decoder_info_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000108};
109
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000110} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +0000111
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200112#endif // MODULES_VIDEO_CODING_GENERIC_DECODER_H_