| /* |
| * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef MODULES_VIDEO_CODING_GENERIC_DECODER_H_ |
| #define MODULES_VIDEO_CODING_GENERIC_DECODER_H_ |
| |
| #include <cstdint> |
| #include <deque> |
| #include <optional> |
| #include <string> |
| #include <utility> |
| |
| #include "absl/types/variant.h" |
| #include "api/field_trials_view.h" |
| #include "api/sequence_checker.h" |
| #include "api/video/encoded_frame.h" |
| #include "api/video_codecs/video_decoder.h" |
| #include "common_video/frame_instrumentation_data.h" |
| #include "common_video/include/corruption_score_calculator.h" |
| #include "modules/video_coding/encoded_frame.h" |
| #include "modules/video_coding/timing/timing.h" |
| #include "rtc_base/synchronization/mutex.h" |
| |
| namespace webrtc { |
| |
| class VCMReceiveCallback; |
| |
| struct FrameInfo { |
| FrameInfo() = default; |
| FrameInfo(const FrameInfo&) = delete; |
| FrameInfo& operator=(const FrameInfo&) = delete; |
| FrameInfo(FrameInfo&&) = default; |
| FrameInfo& operator=(FrameInfo&&) = default; |
| |
| uint32_t rtp_timestamp; |
| // This is likely not optional, but some inputs seem to sometimes be negative. |
| // TODO(bugs.webrtc.org/13756): See if this can be replaced with Timestamp |
| // once all inputs to this field use Timestamp instead of an integer. |
| std::optional<Timestamp> render_time; |
| std::optional<Timestamp> decode_start; |
| VideoRotation rotation; |
| VideoContentType content_type; |
| EncodedImage::Timing timing; |
| int64_t ntp_time_ms; |
| RtpPacketInfos packet_infos; |
| // ColorSpace is not stored here, as it might be modified by decoders. |
| VideoFrameType frame_type; |
| std::optional< |
| absl::variant<FrameInstrumentationSyncData, FrameInstrumentationData>> |
| frame_instrumentation_data; |
| }; |
| |
| class VCMDecodedFrameCallback : public DecodedImageCallback { |
| public: |
| VCMDecodedFrameCallback( |
| VCMTiming* timing, |
| Clock* clock, |
| const FieldTrialsView& field_trials, |
| CorruptionScoreCalculator* corruption_score_calculator); |
| ~VCMDecodedFrameCallback() override; |
| void SetUserReceiveCallback(VCMReceiveCallback* receiveCallback); |
| VCMReceiveCallback* UserReceiveCallback(); |
| |
| int32_t Decoded(VideoFrame& decodedImage) override; |
| int32_t Decoded(VideoFrame& decodedImage, int64_t decode_time_ms) override; |
| void Decoded(VideoFrame& decodedImage, |
| std::optional<int32_t> decode_time_ms, |
| std::optional<uint8_t> qp) override; |
| |
| void OnDecoderInfoChanged(const VideoDecoder::DecoderInfo& decoder_info); |
| |
| void Map(FrameInfo frameInfo); |
| void ClearTimestampMap(); |
| |
| private: |
| std::pair<std::optional<FrameInfo>, size_t> FindFrameInfo( |
| uint32_t rtp_timestamp) RTC_EXCLUSIVE_LOCKS_REQUIRED(lock_); |
| |
| SequenceChecker construction_thread_; |
| Clock* const _clock; |
| // This callback must be set before the decoder thread starts running |
| // and must only be unset when external threads (e.g decoder thread) |
| // have been stopped. Due to that, the variable should regarded as const |
| // while there are more than one threads involved, it must be set |
| // from the same thread, and therfore a lock is not required to access it. |
| VCMReceiveCallback* _receiveCallback = nullptr; |
| VCMTiming* _timing; |
| Mutex lock_; |
| std::deque<FrameInfo> frame_infos_ RTC_GUARDED_BY(lock_); |
| int64_t ntp_offset_; |
| CorruptionScoreCalculator* const corruption_score_calculator_; |
| }; |
| |
| class VCMGenericDecoder { |
| public: |
| explicit VCMGenericDecoder(VideoDecoder* decoder); |
| ~VCMGenericDecoder(); |
| |
| /** |
| * Initialize the decoder with the information from the `settings` |
| */ |
| bool Configure(const VideoDecoder::Settings& settings); |
| |
| /** |
| * Decode to a raw I420 frame, |
| * |
| * inputVideoBuffer reference to encoded video frame |
| */ |
| // TODO(https://bugs.webrtc.org/9378): Remove VCMEncodedFrame variant |
| // once the usage from code in deprecated/ is gone. |
| int32_t Decode(const VCMEncodedFrame& inputFrame, Timestamp now); |
| int32_t Decode(const EncodedFrame& inputFrame, Timestamp now); |
| |
| /** |
| * Set decode callback. Deregistering while decoding is illegal. |
| */ |
| int32_t RegisterDecodeCompleteCallback(VCMDecodedFrameCallback* callback); |
| |
| bool IsSameDecoder(VideoDecoder* decoder) const { |
| return decoder_ == decoder; |
| } |
| |
| private: |
| int32_t Decode(const EncodedImage& frame, |
| Timestamp now, |
| int64_t render_time_ms, |
| const std::optional<absl::variant<FrameInstrumentationSyncData, |
| FrameInstrumentationData>>& |
| frame_instrumentation_data); |
| VCMDecodedFrameCallback* _callback = nullptr; |
| VideoDecoder* const decoder_; |
| VideoContentType _last_keyframe_content_type; |
| VideoDecoder::DecoderInfo decoder_info_; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // MODULES_VIDEO_CODING_GENERIC_DECODER_H_ |