| /* |
| * 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 WEBRTC_VIDEO_VIE_CHANNEL_H_ |
| #define WEBRTC_VIDEO_VIE_CHANNEL_H_ |
| |
| #include <list> |
| #include <map> |
| #include <memory> |
| #include <vector> |
| |
| #include "webrtc/base/criticalsection.h" |
| #include "webrtc/base/platform_thread.h" |
| #include "webrtc/base/scoped_ref_ptr.h" |
| #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h" |
| #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h" |
| #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h" |
| #include "webrtc/modules/video_coding/include/video_coding_defines.h" |
| #include "webrtc/system_wrappers/include/tick_util.h" |
| #include "webrtc/typedefs.h" |
| #include "webrtc/video/vie_receiver.h" |
| #include "webrtc/video/vie_sync_module.h" |
| |
| namespace webrtc { |
| |
| class CallStatsObserver; |
| class ChannelStatsObserver; |
| class Config; |
| class EncodedImageCallback; |
| class I420FrameCallback; |
| class IncomingVideoStream; |
| class PacedSender; |
| class PacketRouter; |
| class PayloadRouter; |
| class ProcessThread; |
| class ReceiveStatisticsProxy; |
| class RtcpRttStats; |
| class ViEChannelProtectionCallback; |
| class ViERTPObserver; |
| class VideoCodingModule; |
| class VideoRenderCallback; |
| class VoEVideoSync; |
| |
| enum StreamType { |
| kViEStreamTypeNormal = 0, // Normal media stream |
| kViEStreamTypeRtx = 1 // Retransmission media stream |
| }; |
| |
| class ViEChannel : public VCMFrameTypeCallback, |
| public VCMReceiveCallback, |
| public VCMReceiveStatisticsCallback, |
| public VCMDecoderTimingCallback, |
| public VCMPacketRequestCallback, |
| public RtpFeedback { |
| public: |
| friend class ChannelStatsObserver; |
| friend class ViEChannelProtectionCallback; |
| |
| ViEChannel(Transport* transport, |
| ProcessThread* module_process_thread, |
| PayloadRouter* send_payload_router, |
| VideoCodingModule* vcm, |
| RtcpIntraFrameObserver* intra_frame_observer, |
| RtcpBandwidthObserver* bandwidth_observer, |
| TransportFeedbackObserver* transport_feedback_observer, |
| RemoteBitrateEstimator* remote_bitrate_estimator, |
| RtcpRttStats* rtt_stats, |
| PacedSender* paced_sender, |
| PacketRouter* packet_router, |
| size_t max_rtp_streams, |
| bool sender); |
| ~ViEChannel(); |
| |
| int32_t Init(); |
| |
| // Sets the encoder to use for the channel. |new_stream| indicates the encoder |
| // type has changed and we should start a new RTP stream. |
| int32_t SetSendCodec(const VideoCodec& video_codec, bool new_stream = true); |
| |
| void SetProtectionMode(bool enable_nack, |
| bool enable_fec, |
| int payload_type_red, |
| int payload_type_fec); |
| |
| RtpState GetRtpStateForSsrc(uint32_t ssrc) const; |
| |
| // Gets send statistics for the rtp and rtx stream. |
| void GetSendStreamDataCounters(StreamDataCounters* rtp_counters, |
| StreamDataCounters* rtx_counters) const; |
| |
| void RegisterSendSideDelayObserver(SendSideDelayObserver* observer); |
| |
| // Called on any new send bitrate estimate. |
| void RegisterSendBitrateObserver(BitrateStatisticsObserver* observer); |
| |
| // Implements RtpFeedback. |
| int32_t OnInitializeDecoder(const int8_t payload_type, |
| const char payload_name[RTP_PAYLOAD_NAME_SIZE], |
| const int frequency, |
| const size_t channels, |
| const uint32_t rate) override; |
| void OnIncomingSSRCChanged(const uint32_t ssrc) override; |
| void OnIncomingCSRCChanged(const uint32_t CSRC, const bool added) override; |
| |
| int32_t StartSend(); |
| int32_t StopSend(); |
| |
| // Gets the modules used by the channel. |
| const std::vector<RtpRtcp*>& rtp_rtcp() const; |
| ViEReceiver* vie_receiver(); |
| VCMProtectionCallback* vcm_protection_callback(); |
| |
| |
| CallStatsObserver* GetStatsObserver(); |
| |
| // Implements VCMReceiveCallback. |
| virtual int32_t FrameToRender(VideoFrame& video_frame); // NOLINT |
| |
| // Implements VCMReceiveCallback. |
| virtual int32_t ReceivedDecodedReferenceFrame( |
| const uint64_t picture_id); |
| |
| // Implements VCMReceiveCallback. |
| void OnIncomingPayloadType(int payload_type) override; |
| void OnDecoderImplementationName(const char* implementation_name) override; |
| |
| // Implements VCMReceiveStatisticsCallback. |
| void OnReceiveRatesUpdated(uint32_t bit_rate, uint32_t frame_rate) override; |
| void OnDiscardedPacketsUpdated(int discarded_packets) override; |
| void OnFrameCountsUpdated(const FrameCounts& frame_counts) override; |
| |
| // Implements VCMDecoderTimingCallback. |
| virtual void OnDecoderTiming(int decode_ms, |
| int max_decode_ms, |
| int current_delay_ms, |
| int target_delay_ms, |
| int jitter_buffer_ms, |
| int min_playout_delay_ms, |
| int render_delay_ms); |
| |
| // Implements FrameTypeCallback. |
| virtual int32_t RequestKeyFrame(); |
| |
| // Implements FrameTypeCallback. |
| virtual int32_t SliceLossIndicationRequest( |
| const uint64_t picture_id); |
| |
| // Implements VideoPacketRequestCallback. |
| int32_t ResendPackets(const uint16_t* sequence_numbers, |
| uint16_t length) override; |
| |
| void RegisterPreRenderCallback(I420FrameCallback* pre_render_callback); |
| |
| void RegisterSendFrameCountObserver(FrameCountObserver* observer); |
| void RegisterRtcpPacketTypeCounterObserver( |
| RtcpPacketTypeCounterObserver* observer); |
| void RegisterReceiveStatisticsProxy( |
| ReceiveStatisticsProxy* receive_statistics_proxy); |
| void SetIncomingVideoStream(IncomingVideoStream* incoming_video_stream); |
| |
| protected: |
| void OnRttUpdate(int64_t avg_rtt_ms, int64_t max_rtt_ms); |
| |
| int ProtectionRequest(const FecProtectionParams* delta_fec_params, |
| const FecProtectionParams* key_fec_params, |
| uint32_t* sent_video_rate_bps, |
| uint32_t* sent_nack_rate_bps, |
| uint32_t* sent_fec_rate_bps); |
| |
| private: |
| static std::vector<RtpRtcp*> CreateRtpRtcpModules( |
| bool receiver_only, |
| ReceiveStatistics* receive_statistics, |
| Transport* outgoing_transport, |
| RtcpIntraFrameObserver* intra_frame_callback, |
| RtcpBandwidthObserver* bandwidth_callback, |
| TransportFeedbackObserver* transport_feedback_callback, |
| RtcpRttStats* rtt_stats, |
| RtcpPacketTypeCounterObserver* rtcp_packet_type_counter_observer, |
| RemoteBitrateEstimator* remote_bitrate_estimator, |
| RtpPacketSender* paced_sender, |
| TransportSequenceNumberAllocator* transport_sequence_number_allocator, |
| BitrateStatisticsObserver* send_bitrate_observer, |
| FrameCountObserver* send_frame_count_observer, |
| SendSideDelayObserver* send_side_delay_observer, |
| size_t num_modules); |
| |
| // Assumed to be protected. |
| void StartDecodeThread(); |
| void StopDecodeThread(); |
| |
| void ProcessNACKRequest(const bool enable); |
| // Compute NACK list parameters for the buffering mode. |
| int GetRequiredNackListSize(int target_delay_ms); |
| |
| // ViEChannel exposes methods that allow to modify observers and callbacks |
| // to be modified. Such an API-style is cumbersome to implement and maintain |
| // at all the levels when comparing to only setting them at construction. As |
| // so this class instantiates its children with a wrapper that can be modified |
| // at a later time. |
| template <class T> |
| class RegisterableCallback : public T { |
| public: |
| RegisterableCallback() : callback_(NULL) {} |
| |
| void Set(T* callback) { |
| rtc::CritScope lock(&critsect_); |
| callback_ = callback; |
| } |
| |
| protected: |
| // Note: this should be implemented with a RW-lock to allow simultaneous |
| // calls into the callback. However that doesn't seem to be needed for the |
| // current type of callbacks covered by this class. |
| rtc::CriticalSection critsect_; |
| T* callback_ GUARDED_BY(critsect_); |
| |
| private: |
| RTC_DISALLOW_COPY_AND_ASSIGN(RegisterableCallback); |
| }; |
| |
| class RegisterableBitrateStatisticsObserver: |
| public RegisterableCallback<BitrateStatisticsObserver> { |
| virtual void Notify(const BitrateStatistics& total_stats, |
| const BitrateStatistics& retransmit_stats, |
| uint32_t ssrc) { |
| rtc::CritScope lock(&critsect_); |
| if (callback_) |
| callback_->Notify(total_stats, retransmit_stats, ssrc); |
| } |
| } send_bitrate_observer_; |
| |
| class RegisterableFrameCountObserver |
| : public RegisterableCallback<FrameCountObserver> { |
| public: |
| virtual void FrameCountUpdated(const FrameCounts& frame_counts, |
| uint32_t ssrc) { |
| rtc::CritScope lock(&critsect_); |
| if (callback_) |
| callback_->FrameCountUpdated(frame_counts, ssrc); |
| } |
| |
| private: |
| } send_frame_count_observer_; |
| |
| class RegisterableSendSideDelayObserver : |
| public RegisterableCallback<SendSideDelayObserver> { |
| void SendSideDelayUpdated(int avg_delay_ms, |
| int max_delay_ms, |
| uint32_t ssrc) override { |
| rtc::CritScope lock(&critsect_); |
| if (callback_) |
| callback_->SendSideDelayUpdated(avg_delay_ms, max_delay_ms, ssrc); |
| } |
| } send_side_delay_observer_; |
| |
| class RegisterableRtcpPacketTypeCounterObserver |
| : public RegisterableCallback<RtcpPacketTypeCounterObserver> { |
| public: |
| void RtcpPacketTypesCounterUpdated( |
| uint32_t ssrc, |
| const RtcpPacketTypeCounter& packet_counter) override { |
| rtc::CritScope lock(&critsect_); |
| if (callback_) |
| callback_->RtcpPacketTypesCounterUpdated(ssrc, packet_counter); |
| } |
| |
| private: |
| } rtcp_packet_type_counter_observer_; |
| |
| const bool sender_; |
| |
| ProcessThread* const module_process_thread_; |
| PayloadRouter* const send_payload_router_; |
| |
| // Used for all registered callbacks except rendering. |
| rtc::CriticalSection crit_; |
| |
| // Owned modules/classes. |
| std::unique_ptr<ViEChannelProtectionCallback> vcm_protection_callback_; |
| |
| VideoCodingModule* const vcm_; |
| ViEReceiver vie_receiver_; |
| |
| // Helper to report call statistics. |
| std::unique_ptr<ChannelStatsObserver> stats_observer_; |
| |
| // Not owned. |
| ReceiveStatisticsProxy* receive_stats_callback_ GUARDED_BY(crit_); |
| FrameCounts receive_frame_counts_ GUARDED_BY(crit_); |
| IncomingVideoStream* incoming_video_stream_ GUARDED_BY(crit_); |
| RtcpIntraFrameObserver* const intra_frame_observer_; |
| RtcpRttStats* const rtt_stats_; |
| PacedSender* const paced_sender_; |
| PacketRouter* const packet_router_; |
| |
| const std::unique_ptr<RtcpBandwidthObserver> bandwidth_observer_; |
| TransportFeedbackObserver* const transport_feedback_observer_; |
| |
| int max_nack_reordering_threshold_; |
| I420FrameCallback* pre_render_callback_ GUARDED_BY(crit_); |
| |
| int64_t last_rtt_ms_ GUARDED_BY(crit_); |
| |
| // RtpRtcp modules, declared last as they use other members on construction. |
| const std::vector<RtpRtcp*> rtp_rtcp_modules_; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // WEBRTC_VIDEO_VIE_CHANNEL_H_ |