| /* |
| * Copyright (c) 2019 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_VIDEO_RECEIVER2_H_ |
| #define MODULES_VIDEO_CODING_VIDEO_RECEIVER2_H_ |
| |
| #include "modules/video_coding/decoder_database.h" |
| #include "modules/video_coding/encoded_frame.h" |
| #include "modules/video_coding/generic_decoder.h" |
| #include "modules/video_coding/timing.h" |
| #include "rtc_base/thread_checker.h" |
| #include "system_wrappers/include/clock.h" |
| |
| namespace webrtc { |
| |
| // This class is a copy of vcm::VideoReceiver, trimmed down to what's used by |
| // VideoReceive stream, with the aim to incrementally trim it down further and |
| // ultimately delete it. It's difficult to do this incrementally with the |
| // original VideoReceiver class, since it is used by the legacy |
| // VideoCodingModule api. |
| class VideoReceiver2 { |
| public: |
| VideoReceiver2(Clock* clock, VCMTiming* timing); |
| ~VideoReceiver2(); |
| |
| int32_t RegisterReceiveCodec(const VideoCodec* receiveCodec, |
| int32_t numberOfCores, |
| bool requireKeyFrame); |
| |
| void RegisterExternalDecoder(VideoDecoder* externalDecoder, |
| uint8_t payloadType); |
| int32_t RegisterReceiveCallback(VCMReceiveCallback* receiveCallback); |
| |
| int32_t Decode(const webrtc::VCMEncodedFrame* frame); |
| |
| void TriggerDecoderShutdown(); |
| |
| // Notification methods that are used to check our internal state and validate |
| // threading assumptions. These are called by VideoReceiveStream. |
| // See |IsDecoderThreadRunning()| for more details. |
| void DecoderThreadStarting(); |
| void DecoderThreadStopped(); |
| |
| private: |
| // Used for DCHECKing thread correctness. |
| // In build where DCHECKs are enabled, will return false before |
| // DecoderThreadStarting is called, then true until DecoderThreadStopped |
| // is called. |
| // In builds where DCHECKs aren't enabled, it will return true. |
| bool IsDecoderThreadRunning(); |
| |
| rtc::ThreadChecker construction_thread_checker_; |
| rtc::ThreadChecker decoder_thread_checker_; |
| Clock* const clock_; |
| VCMTiming* timing_; |
| VCMDecodedFrameCallback decodedFrameCallback_; |
| |
| // Callbacks are set before the decoder thread starts. |
| // Once the decoder thread has been started, usage of |_codecDataBase| moves |
| // over to the decoder thread. |
| VCMDecoderDataBase codecDataBase_; |
| |
| #if RTC_DCHECK_IS_ON |
| bool decoder_thread_is_running_ = false; |
| #endif |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // MODULES_VIDEO_CODING_VIDEO_RECEIVER2_H_ |