|  | /* | 
|  | *  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_VIDEO_CODING_IMPL_H_ | 
|  | #define MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_ | 
|  |  | 
|  | #include "modules/video_coding/include/video_coding.h" | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  | #include <vector> | 
|  |  | 
|  | #include "common_video/include/frame_callback.h" | 
|  | #include "modules/video_coding/codec_database.h" | 
|  | #include "modules/video_coding/frame_buffer.h" | 
|  | #include "modules/video_coding/generic_decoder.h" | 
|  | #include "modules/video_coding/generic_encoder.h" | 
|  | #include "modules/video_coding/jitter_buffer.h" | 
|  | #include "modules/video_coding/media_optimization.h" | 
|  | #include "modules/video_coding/qp_parser.h" | 
|  | #include "modules/video_coding/receiver.h" | 
|  | #include "modules/video_coding/timing.h" | 
|  | #include "rtc_base/onetimeevent.h" | 
|  | #include "rtc_base/sequenced_task_checker.h" | 
|  | #include "rtc_base/thread_annotations.h" | 
|  | #include "rtc_base/thread_checker.h" | 
|  | #include "system_wrappers/include/clock.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | class VideoBitrateAllocator; | 
|  | class VideoBitrateAllocationObserver; | 
|  |  | 
|  | namespace vcm { | 
|  |  | 
|  | class VCMProcessTimer { | 
|  | public: | 
|  | static const int64_t kDefaultProcessIntervalMs = 1000; | 
|  |  | 
|  | VCMProcessTimer(int64_t periodMs, Clock* clock) | 
|  | : _clock(clock), | 
|  | _periodMs(periodMs), | 
|  | _latestMs(_clock->TimeInMilliseconds()) {} | 
|  | int64_t Period() const; | 
|  | int64_t TimeUntilProcess() const; | 
|  | void Processed(); | 
|  |  | 
|  | private: | 
|  | Clock* _clock; | 
|  | int64_t _periodMs; | 
|  | int64_t _latestMs; | 
|  | }; | 
|  |  | 
|  | class VideoSender { | 
|  | public: | 
|  | typedef VideoCodingModule::SenderNackMode SenderNackMode; | 
|  |  | 
|  | VideoSender(Clock* clock, | 
|  | EncodedImageCallback* post_encode_callback); | 
|  |  | 
|  | ~VideoSender(); | 
|  |  | 
|  | // Register the send codec to be used. | 
|  | // This method must be called on the construction thread. | 
|  | int32_t RegisterSendCodec(const VideoCodec* sendCodec, | 
|  | uint32_t numberOfCores, | 
|  | uint32_t maxPayloadSize); | 
|  |  | 
|  | void RegisterExternalEncoder(VideoEncoder* externalEncoder, | 
|  | uint8_t payloadType, | 
|  | bool internalSource); | 
|  |  | 
|  | int Bitrate(unsigned int* bitrate) const; | 
|  | int FrameRate(unsigned int* framerate) const; | 
|  |  | 
|  | // Update the channel parameters based on new rates and rtt. This will also | 
|  | // cause an immediate call to VideoEncoder::SetRateAllocation(). | 
|  | int32_t SetChannelParameters( | 
|  | uint32_t target_bitrate_bps, | 
|  | uint8_t loss_rate, | 
|  | int64_t rtt, | 
|  | VideoBitrateAllocator* bitrate_allocator, | 
|  | VideoBitrateAllocationObserver* bitrate_updated_callback); | 
|  |  | 
|  | // Updates the channel parameters with a new bitrate allocation, but using the | 
|  | // current targit_bitrate, loss rate and rtt. That is, the distribution or | 
|  | // caps may be updated to a change to a new VideoCodec or allocation mode. | 
|  | // The new parameters will be stored as pending EncoderParameters, and the | 
|  | // encoder will only be updated on the next frame. | 
|  | void UpdateChannelParemeters( | 
|  | VideoBitrateAllocator* bitrate_allocator, | 
|  | VideoBitrateAllocationObserver* bitrate_updated_callback); | 
|  |  | 
|  | // Deprecated: | 
|  | // TODO(perkj): Remove once no projects use it. | 
|  | int32_t RegisterProtectionCallback(VCMProtectionCallback* protection); | 
|  |  | 
|  | int32_t AddVideoFrame(const VideoFrame& videoFrame, | 
|  | const CodecSpecificInfo* codecSpecificInfo); | 
|  |  | 
|  | int32_t IntraFrameRequest(size_t stream_index); | 
|  | int32_t EnableFrameDropper(bool enable); | 
|  |  | 
|  | private: | 
|  | EncoderParameters UpdateEncoderParameters( | 
|  | const EncoderParameters& params, | 
|  | VideoBitrateAllocator* bitrate_allocator, | 
|  | uint32_t target_bitrate_bps); | 
|  | void SetEncoderParameters(EncoderParameters params, bool has_internal_source) | 
|  | RTC_EXCLUSIVE_LOCKS_REQUIRED(encoder_crit_); | 
|  |  | 
|  | rtc::CriticalSection encoder_crit_; | 
|  | VCMGenericEncoder* _encoder; | 
|  | media_optimization::MediaOptimization _mediaOpt; | 
|  | VCMEncodedFrameCallback _encodedFrameCallback RTC_GUARDED_BY(encoder_crit_); | 
|  | EncodedImageCallback* const post_encode_callback_; | 
|  | VCMCodecDataBase _codecDataBase RTC_GUARDED_BY(encoder_crit_); | 
|  | bool frame_dropper_enabled_ RTC_GUARDED_BY(encoder_crit_); | 
|  |  | 
|  | // Must be accessed on the construction thread of VideoSender. | 
|  | VideoCodec current_codec_; | 
|  | rtc::SequencedTaskChecker sequenced_checker_; | 
|  |  | 
|  | rtc::CriticalSection params_crit_; | 
|  | EncoderParameters encoder_params_ RTC_GUARDED_BY(params_crit_); | 
|  | bool encoder_has_internal_source_ RTC_GUARDED_BY(params_crit_); | 
|  | std::vector<FrameType> next_frame_types_ RTC_GUARDED_BY(params_crit_); | 
|  | }; | 
|  |  | 
|  | class VideoReceiver : public Module { | 
|  | public: | 
|  | VideoReceiver(Clock* clock, | 
|  | EventFactory* event_factory, | 
|  | EncodedImageCallback* pre_decode_image_callback, | 
|  | VCMTiming* timing, | 
|  | NackSender* nack_sender = nullptr, | 
|  | KeyFrameRequestSender* keyframe_request_sender = nullptr); | 
|  | ~VideoReceiver(); | 
|  |  | 
|  | 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 RegisterReceiveStatisticsCallback( | 
|  | VCMReceiveStatisticsCallback* receiveStats); | 
|  | int32_t RegisterFrameTypeCallback(VCMFrameTypeCallback* frameTypeCallback); | 
|  | int32_t RegisterPacketRequestCallback(VCMPacketRequestCallback* callback); | 
|  |  | 
|  | int32_t Decode(uint16_t maxWaitTimeMs); | 
|  |  | 
|  | int32_t Decode(const webrtc::VCMEncodedFrame* frame); | 
|  |  | 
|  | // Called on the decoder thread when thread is exiting. | 
|  | void DecodingStopped(); | 
|  |  | 
|  | int32_t IncomingPacket(const uint8_t* incomingPayload, | 
|  | size_t payloadLength, | 
|  | const WebRtcRTPHeader& rtpInfo); | 
|  | int32_t SetMinimumPlayoutDelay(uint32_t minPlayoutDelayMs); | 
|  | int32_t SetRenderDelay(uint32_t timeMS); | 
|  | int32_t Delay() const; | 
|  |  | 
|  | // DEPRECATED. | 
|  | int SetReceiverRobustnessMode( | 
|  | VideoCodingModule::ReceiverRobustness robustnessMode, | 
|  | VCMDecodeErrorMode errorMode); | 
|  |  | 
|  | void SetNackSettings(size_t max_nack_list_size, | 
|  | int max_packet_age_to_nack, | 
|  | int max_incomplete_time_ms); | 
|  |  | 
|  | void SetDecodeErrorMode(VCMDecodeErrorMode decode_error_mode); | 
|  | int SetMinReceiverDelay(int desired_delay_ms); | 
|  |  | 
|  | int32_t SetReceiveChannelParameters(int64_t rtt); | 
|  | int32_t SetVideoProtection(VCMVideoProtection videoProtection, bool enable); | 
|  |  | 
|  | int64_t TimeUntilNextProcess() override; | 
|  | void Process() override; | 
|  |  | 
|  | void TriggerDecoderShutdown(); | 
|  |  | 
|  | protected: | 
|  | int32_t Decode(const webrtc::VCMEncodedFrame& frame) | 
|  | RTC_EXCLUSIVE_LOCKS_REQUIRED(receive_crit_); | 
|  | int32_t RequestKeyFrame(); | 
|  |  | 
|  | private: | 
|  | rtc::ThreadChecker construction_thread_; | 
|  | Clock* const clock_; | 
|  | rtc::CriticalSection process_crit_; | 
|  | rtc::CriticalSection receive_crit_; | 
|  | VCMTiming* _timing; | 
|  | VCMReceiver _receiver; | 
|  | VCMDecodedFrameCallback _decodedFrameCallback; | 
|  | VCMFrameTypeCallback* _frameTypeCallback RTC_GUARDED_BY(process_crit_); | 
|  | VCMReceiveStatisticsCallback* _receiveStatsCallback | 
|  | RTC_GUARDED_BY(process_crit_); | 
|  | VCMPacketRequestCallback* _packetRequestCallback | 
|  | RTC_GUARDED_BY(process_crit_); | 
|  |  | 
|  | VCMFrameBuffer _frameFromFile; | 
|  | bool _scheduleKeyRequest RTC_GUARDED_BY(process_crit_); | 
|  | bool drop_frames_until_keyframe_ RTC_GUARDED_BY(process_crit_); | 
|  | size_t max_nack_list_size_ RTC_GUARDED_BY(process_crit_); | 
|  |  | 
|  | VCMCodecDataBase _codecDataBase RTC_GUARDED_BY(receive_crit_); | 
|  | EncodedImageCallback* pre_decode_image_callback_; | 
|  |  | 
|  | VCMProcessTimer _receiveStatsTimer; | 
|  | VCMProcessTimer _retransmissionTimer; | 
|  | VCMProcessTimer _keyRequestTimer; | 
|  | QpParser qp_parser_; | 
|  | ThreadUnsafeOneTimeEvent first_frame_received_; | 
|  | }; | 
|  |  | 
|  | }  // namespace vcm | 
|  | }  // namespace webrtc | 
|  | #endif  // MODULES_VIDEO_CODING_VIDEO_CODING_IMPL_H_ |