1 /* 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 3 * 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 11 #ifndef WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_H_ 12 #define WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_H_ 13 14 #include <list> 15 16 #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h" 17 #include "webrtc/modules/rtp_rtcp/interface/rtp_rtcp_defines.h" 18 #include "webrtc/modules/video_coding/main/interface/video_coding_defines.h" 19 #include "webrtc/system_wrappers/interface/critical_section_wrapper.h" 20 #include "webrtc/system_wrappers/interface/scoped_ptr.h" 21 #include "webrtc/system_wrappers/interface/tick_util.h" 22 #include "webrtc/typedefs.h" 23 #include "webrtc/video_engine/include/vie_network.h" 24 #include "webrtc/video_engine/include/vie_rtp_rtcp.h" 25 #include "webrtc/video_engine/vie_defines.h" 26 #include "webrtc/video_engine/vie_frame_provider_base.h" 27 #include "webrtc/video_engine/vie_receiver.h" 28 #include "webrtc/video_engine/vie_sender.h" 29 #include "webrtc/video_engine/vie_sync_module.h" 30 31 namespace webrtc { 32 33 class CallStatsObserver; 34 class ChannelStatsObserver; 35 class Config; 36 class CriticalSectionWrapper; 37 class EncodedImageCallback; 38 class I420FrameCallback; 39 class PacedSender; 40 class ProcessThread; 41 class RtcpRttStats; 42 class RtpRtcp; 43 class ThreadWrapper; 44 class ViEDecoderObserver; 45 class ViEEffectFilter; 46 class ViERTCPObserver; 47 class ViERTPObserver; 48 class VideoCodingModule; 49 class VideoDecoder; 50 class VideoRenderCallback; 51 class VoEVideoSync; 52 53 class ViEChannel 54 : public VCMFrameTypeCallback, 55 public VCMReceiveCallback, 56 public VCMReceiveStatisticsCallback, 57 public VCMDecoderTimingCallback, 58 public VCMPacketRequestCallback, 59 public RtcpFeedback, 60 public RtpFeedback, 61 public ViEFrameProviderBase { 62 public: 63 friend class ChannelStatsObserver; 64 65 ViEChannel(int32_t channel_id, 66 int32_t engine_id, 67 uint32_t number_of_cores, 68 const Config& config, 69 ProcessThread& module_process_thread, 70 RtcpIntraFrameObserver* intra_frame_observer, 71 RtcpBandwidthObserver* bandwidth_observer, 72 RemoteBitrateEstimator* remote_bitrate_estimator, 73 RtcpRttStats* rtt_stats, 74 PacedSender* paced_sender, 75 RtpRtcp* default_rtp_rtcp, 76 bool sender); 77 ~ViEChannel(); 78 79 int32_t Init(); 80 81 // Sets the encoder to use for the channel. |new_stream| indicates the encoder 82 // type has changed and we should start a new RTP stream. 83 int32_t SetSendCodec(const VideoCodec& video_codec, bool new_stream = true); 84 int32_t SetReceiveCodec(const VideoCodec& video_codec); 85 int32_t GetReceiveCodec(VideoCodec* video_codec); 86 int32_t RegisterCodecObserver(ViEDecoderObserver* observer); 87 // Registers an external decoder. |buffered_rendering| means that the decoder 88 // will render frames after decoding according to the render timestamp 89 // provided by the video coding module. |render_delay| indicates the time 90 // needed to decode and render a frame. 91 int32_t RegisterExternalDecoder(const uint8_t pl_type, 92 VideoDecoder* decoder, 93 bool buffered_rendering, 94 int32_t render_delay); 95 int32_t DeRegisterExternalDecoder(const uint8_t pl_type); 96 int32_t ReceiveCodecStatistics(uint32_t* num_key_frames, 97 uint32_t* num_delta_frames); 98 uint32_t DiscardedPackets() const; 99 100 // Returns the estimated delay in milliseconds. 101 int ReceiveDelay() const; 102 103 // Only affects calls to SetReceiveCodec done after this call. 104 int32_t WaitForKeyFrame(bool wait); 105 106 // If enabled, a key frame request will be sent as soon as there are lost 107 // packets. If |only_key_frames| are set, requests are only sent for loss in 108 // key frames. 109 int32_t SetSignalPacketLossStatus(bool enable, bool only_key_frames); 110 111 int32_t SetRTCPMode(const RTCPMethod rtcp_mode); 112 int32_t GetRTCPMode(RTCPMethod* rtcp_mode); 113 int32_t SetNACKStatus(const bool enable); 114 int32_t SetFECStatus(const bool enable, 115 const unsigned char payload_typeRED, 116 const unsigned char payload_typeFEC); 117 int32_t SetHybridNACKFECStatus(const bool enable, 118 const unsigned char payload_typeRED, 119 const unsigned char payload_typeFEC); 120 int SetSenderBufferingMode(int target_delay_ms); 121 int SetReceiverBufferingMode(int target_delay_ms); 122 int32_t SetKeyFrameRequestMethod(const KeyFrameRequestMethod method); 123 bool EnableRemb(bool enable); 124 int SetSendTimestampOffsetStatus(bool enable, int id); 125 int SetReceiveTimestampOffsetStatus(bool enable, int id); 126 int SetSendAbsoluteSendTimeStatus(bool enable, int id); 127 int SetReceiveAbsoluteSendTimeStatus(bool enable, int id); 128 bool GetReceiveAbsoluteSendTimeStatus() const; 129 void SetRtcpXrRrtrStatus(bool enable); 130 void SetTransmissionSmoothingStatus(bool enable); 131 int32_t EnableTMMBR(const bool enable); 132 int32_t EnableKeyFrameRequestCallback(const bool enable); 133 134 // Sets SSRC for outgoing stream. 135 int32_t SetSSRC(const uint32_t SSRC, 136 const StreamType usage, 137 const unsigned char simulcast_idx); 138 139 // Gets SSRC for outgoing stream number |idx|. 140 int32_t GetLocalSSRC(uint8_t idx, unsigned int* ssrc); 141 142 // Gets SSRC for the incoming stream. 143 int32_t GetRemoteSSRC(uint32_t* ssrc); 144 145 // Gets the CSRC for the incoming stream. 146 int32_t GetRemoteCSRC(uint32_t CSRCs[kRtpCsrcSize]); 147 148 int SetRtxSendPayloadType(int payload_type); 149 // Only has an effect once RTX is enabled. 150 void SetPadWithRedundantPayloads(bool enable); 151 void SetRtxReceivePayloadType(int payload_type); 152 153 // Sets the starting sequence number, must be called before StartSend. 154 int32_t SetStartSequenceNumber(uint16_t sequence_number); 155 156 void SetRtpStateForSsrc(uint32_t ssrc, const RtpState& rtp_state); 157 RtpState GetRtpStateForSsrc(uint32_t ssrc); 158 159 // Sets the CName for the outgoing stream on the channel. 160 int32_t SetRTCPCName(const char rtcp_cname[]); 161 162 // Gets the CName of the incoming stream. 163 int32_t GetRemoteRTCPCName(char rtcp_cname[]); 164 int32_t RegisterRtpObserver(ViERTPObserver* observer); 165 int32_t RegisterRtcpObserver(ViERTCPObserver* observer); 166 int32_t SendApplicationDefinedRTCPPacket( 167 const uint8_t sub_type, 168 uint32_t name, 169 const uint8_t* data, 170 uint16_t data_length_in_bytes); 171 172 // Returns statistics reported by the remote client in an RTCP packet. 173 int32_t GetSendRtcpStatistics(uint16_t* fraction_lost, 174 uint32_t* cumulative_lost, 175 uint32_t* extended_max, 176 uint32_t* jitter_samples, 177 int32_t* rtt_ms); 178 179 // Called on receipt of RTCP report block from remote side. 180 void RegisterSendChannelRtcpStatisticsCallback( 181 RtcpStatisticsCallback* callback); 182 183 // Returns our localy created statistics of the received RTP stream. 184 int32_t GetReceivedRtcpStatistics(uint16_t* fraction_lost, 185 uint32_t* cumulative_lost, 186 uint32_t* extended_max, 187 uint32_t* jitter_samples, 188 int32_t* rtt_ms); 189 190 // Called on generation of RTCP stats 191 void RegisterReceiveChannelRtcpStatisticsCallback( 192 RtcpStatisticsCallback* callback); 193 194 // Gets sent/received packets statistics. 195 int32_t GetRtpStatistics(uint32_t* bytes_sent, 196 uint32_t* packets_sent, 197 uint32_t* bytes_received, 198 uint32_t* packets_received) const; 199 200 // Called on update of RTP statistics. 201 void RegisterSendChannelRtpStatisticsCallback( 202 StreamDataCountersCallback* callback); 203 204 // Called on update of RTP statistics. 205 void RegisterReceiveChannelRtpStatisticsCallback( 206 StreamDataCountersCallback* callback); 207 208 void GetRtcpPacketTypeCounters(RtcpPacketTypeCounter* packets_sent, 209 RtcpPacketTypeCounter* packets_received) const; 210 211 void GetBandwidthUsage(uint32_t* total_bitrate_sent, 212 uint32_t* video_bitrate_sent, 213 uint32_t* fec_bitrate_sent, 214 uint32_t* nackBitrateSent) const; 215 // TODO(holmer): Deprecated. We should use the SendSideDelayObserver instead 216 // to avoid deadlocks. 217 bool GetSendSideDelay(int* avg_send_delay, int* max_send_delay) const; 218 void RegisterSendSideDelayObserver(SendSideDelayObserver* observer); 219 void GetReceiveBandwidthEstimatorStats( 220 ReceiveBandwidthEstimatorStats* output) const; 221 222 // Called on any new send bitrate estimate. 223 void RegisterSendBitrateObserver(BitrateStatisticsObserver* observer); 224 225 int32_t StartRTPDump(const char file_nameUTF8[1024], 226 RTPDirections direction); 227 int32_t StopRTPDump(RTPDirections direction); 228 229 // Implements RtcpFeedback. 230 // TODO(pwestin) Depricate this functionality. 231 virtual void OnApplicationDataReceived(const int32_t id, 232 const uint8_t sub_type, 233 const uint32_t name, 234 const uint16_t length, 235 const uint8_t* data); 236 // Implements RtpFeedback. 237 virtual int32_t OnInitializeDecoder( 238 const int32_t id, 239 const int8_t payload_type, 240 const char payload_name[RTP_PAYLOAD_NAME_SIZE], 241 const int frequency, 242 const uint8_t channels, 243 const uint32_t rate); 244 virtual void OnIncomingSSRCChanged(const int32_t id, 245 const uint32_t ssrc); 246 virtual void OnIncomingCSRCChanged(const int32_t id, 247 const uint32_t CSRC, 248 const bool added); 249 virtual void ResetStatistics(uint32_t); 250 251 int32_t SetLocalReceiver(const uint16_t rtp_port, 252 const uint16_t rtcp_port, 253 const char* ip_address); 254 int32_t GetLocalReceiver(uint16_t* rtp_port, 255 uint16_t* rtcp_port, 256 char* ip_address) const; 257 int32_t SetSendDestination(const char* ip_address, 258 const uint16_t rtp_port, 259 const uint16_t rtcp_port, 260 const uint16_t source_rtp_port, 261 const uint16_t source_rtcp_port); 262 int32_t GetSendDestination(char* ip_address, 263 uint16_t* rtp_port, 264 uint16_t* rtcp_port, 265 uint16_t* source_rtp_port, 266 uint16_t* source_rtcp_port) const; 267 int32_t GetSourceInfo(uint16_t* rtp_port, 268 uint16_t* rtcp_port, 269 char* ip_address, 270 uint32_t ip_address_length); 271 272 int32_t SetRemoteSSRCType(const StreamType usage, const uint32_t SSRC); 273 274 int32_t StartSend(); 275 int32_t StopSend(); 276 bool Sending(); 277 int32_t StartReceive(); 278 int32_t StopReceive(); 279 280 int32_t RegisterSendTransport(Transport* transport); 281 int32_t DeregisterSendTransport(); 282 283 // Incoming packet from external transport. 284 int32_t ReceivedRTPPacket(const void* rtp_packet, 285 const int32_t rtp_packet_length, 286 const PacketTime& packet_time); 287 288 // Incoming packet from external transport. 289 int32_t ReceivedRTCPPacket(const void* rtcp_packet, 290 const int32_t rtcp_packet_length); 291 292 // Sets the maximum transfer unit size for the network link, i.e. including 293 // IP, UDP and RTP headers. 294 int32_t SetMTU(uint16_t mtu); 295 296 // Returns maximum allowed payload size, i.e. the maximum allowed size of 297 // encoded data in each packet. 298 uint16_t MaxDataPayloadLength() const; 299 int32_t SetMaxPacketBurstSize(uint16_t max_number_of_packets); 300 int32_t SetPacketBurstSpreadState(bool enable, const uint16_t frame_periodMS); 301 302 int32_t EnableColorEnhancement(bool enable); 303 304 // Gets the modules used by the channel. 305 RtpRtcp* rtp_rtcp(); 306 307 CallStatsObserver* GetStatsObserver(); 308 309 // Implements VCMReceiveCallback. 310 virtual int32_t FrameToRender(I420VideoFrame& video_frame); // NOLINT 311 312 // Implements VCMReceiveCallback. 313 virtual int32_t ReceivedDecodedReferenceFrame( 314 const uint64_t picture_id); 315 316 // Implements VCMReceiveCallback. 317 virtual void IncomingCodecChanged(const VideoCodec& codec); 318 319 // Implements VCMReceiveStatisticsCallback. 320 virtual int32_t OnReceiveStatisticsUpdate(const uint32_t bit_rate, 321 const uint32_t frame_rate); 322 323 // Implements VCMDecoderTimingCallback. 324 virtual void OnDecoderTiming(int decode_ms, 325 int max_decode_ms, 326 int current_delay_ms, 327 int target_delay_ms, 328 int jitter_buffer_ms, 329 int min_playout_delay_ms, 330 int render_delay_ms); 331 332 // Implements VideoFrameTypeCallback. 333 virtual int32_t RequestKeyFrame(); 334 335 // Implements VideoFrameTypeCallback. 336 virtual int32_t SliceLossIndicationRequest( 337 const uint64_t picture_id); 338 339 // Implements VideoPacketRequestCallback. 340 virtual int32_t ResendPackets(const uint16_t* sequence_numbers, 341 uint16_t length); 342 343 int32_t SetVoiceChannel(int32_t ve_channel_id, 344 VoEVideoSync* ve_sync_interface); 345 int32_t VoiceChannel(); 346 347 // Implements ViEFrameProviderBase. FrameCallbackChanged()348 virtual int FrameCallbackChanged() {return -1;} 349 350 int32_t RegisterEffectFilter(ViEEffectFilter* effect_filter); 351 352 // New-style callbacks, used by VideoReceiveStream. 353 void RegisterPreRenderCallback(I420FrameCallback* pre_render_callback); 354 void RegisterPreDecodeImageCallback( 355 EncodedImageCallback* pre_decode_callback); 356 357 void RegisterSendFrameCountObserver(FrameCountObserver* observer); 358 359 void ReceivedBWEPacket(int64_t arrival_time_ms, int payload_size, 360 const RTPHeader& header); 361 362 protected: 363 static bool ChannelDecodeThreadFunction(void* obj); 364 bool ChannelDecodeProcess(); 365 366 void OnRttUpdate(uint32_t rtt); 367 368 private: 369 void ReserveRtpRtcpModules(size_t total_modules) 370 EXCLUSIVE_LOCKS_REQUIRED(rtp_rtcp_cs_); 371 RtpRtcp* GetRtpRtcpModule(size_t simulcast_idx) const 372 EXCLUSIVE_LOCKS_REQUIRED(rtp_rtcp_cs_); 373 RtpRtcp* CreateRtpRtcpModule(); 374 // Assumed to be protected. 375 int32_t StartDecodeThread(); 376 int32_t StopDecodeThread(); 377 378 int32_t ProcessNACKRequest(const bool enable); 379 int32_t ProcessFECRequest(const bool enable, 380 const unsigned char payload_typeRED, 381 const unsigned char payload_typeFEC); 382 // Compute NACK list parameters for the buffering mode. 383 int GetRequiredNackListSize(int target_delay_ms); 384 void SetRtxSendStatus(bool enable); 385 386 // ViEChannel exposes methods that allow to modify observers and callbacks 387 // to be modified. Such an API-style is cumbersome to implement and maintain 388 // at all the levels when comparing to only setting them at construction. As 389 // so this class instantiates its children with a wrapper that can be modified 390 // at a later time. 391 template <class T> 392 class RegisterableCallback : public T { 393 public: RegisterableCallback()394 RegisterableCallback() 395 : critsect_(CriticalSectionWrapper::CreateCriticalSection()), 396 callback_(NULL) {} 397 Set(T * callback)398 void Set(T* callback) { 399 CriticalSectionScoped cs(critsect_.get()); 400 callback_ = callback; 401 } 402 403 protected: 404 // Note: this should be implemented with a RW-lock to allow simultaneous 405 // calls into the callback. However that doesn't seem to be needed for the 406 // current type of callbacks covered by this class. 407 scoped_ptr<CriticalSectionWrapper> critsect_; 408 T* callback_ GUARDED_BY(critsect_); 409 410 private: 411 DISALLOW_COPY_AND_ASSIGN(RegisterableCallback); 412 }; 413 414 class RegisterableBitrateStatisticsObserver: 415 public RegisterableCallback<BitrateStatisticsObserver> { Notify(const BitrateStatistics & stats,uint32_t ssrc)416 virtual void Notify(const BitrateStatistics& stats, uint32_t ssrc) { 417 CriticalSectionScoped cs(critsect_.get()); 418 if (callback_) 419 callback_->Notify(stats, ssrc); 420 } 421 } 422 send_bitrate_observer_; 423 424 class RegisterableFrameCountObserver 425 : public RegisterableCallback<FrameCountObserver> { FrameCountUpdated(FrameType frame_type,uint32_t frame_count,const unsigned int ssrc)426 virtual void FrameCountUpdated(FrameType frame_type, 427 uint32_t frame_count, 428 const unsigned int ssrc) { 429 CriticalSectionScoped cs(critsect_.get()); 430 if (callback_) 431 callback_->FrameCountUpdated(frame_type, frame_count, ssrc); 432 } 433 } send_frame_count_observer_; 434 435 class RegisterableSendSideDelayObserver : 436 public RegisterableCallback<SendSideDelayObserver> { SendSideDelayUpdated(int avg_delay_ms,int max_delay_ms,uint32_t ssrc)437 virtual void SendSideDelayUpdated(int avg_delay_ms, 438 int max_delay_ms, 439 uint32_t ssrc) OVERRIDE { 440 CriticalSectionScoped cs(critsect_.get()); 441 if (callback_) 442 callback_->SendSideDelayUpdated(avg_delay_ms, max_delay_ms, ssrc); 443 } 444 } send_side_delay_observer_; 445 446 int32_t channel_id_; 447 int32_t engine_id_; 448 uint32_t number_of_cores_; 449 uint8_t num_socket_threads_; 450 451 // Used for all registered callbacks except rendering. 452 scoped_ptr<CriticalSectionWrapper> callback_cs_; 453 scoped_ptr<CriticalSectionWrapper> rtp_rtcp_cs_; 454 455 RtpRtcp* default_rtp_rtcp_; 456 457 // Owned modules/classes. 458 scoped_ptr<RtpRtcp> rtp_rtcp_; 459 std::list<RtpRtcp*> simulcast_rtp_rtcp_; 460 std::list<RtpRtcp*> removed_rtp_rtcp_; 461 VideoCodingModule* const vcm_; 462 ViEReceiver vie_receiver_; 463 ViESender vie_sender_; 464 ViESyncModule vie_sync_; 465 466 // Helper to report call statistics. 467 scoped_ptr<ChannelStatsObserver> stats_observer_; 468 469 // Not owned. 470 ProcessThread& module_process_thread_; 471 ViEDecoderObserver* codec_observer_; 472 bool do_key_frame_callbackRequest_; 473 ViERTPObserver* rtp_observer_; 474 ViERTCPObserver* rtcp_observer_; 475 RtcpIntraFrameObserver* intra_frame_observer_; 476 RtcpRttStats* rtt_stats_; 477 PacedSender* paced_sender_; 478 bool pad_with_redundant_payloads_; 479 480 scoped_ptr<RtcpBandwidthObserver> bandwidth_observer_; 481 int send_timestamp_extension_id_; 482 int absolute_send_time_extension_id_; 483 484 Transport* external_transport_; 485 486 bool decoder_reset_; 487 // Current receive codec used for codec change callback. 488 VideoCodec receive_codec_; 489 bool wait_for_key_frame_; 490 ThreadWrapper* decode_thread_; 491 492 ViEEffectFilter* effect_filter_; 493 bool color_enhancement_; 494 495 // User set MTU, -1 if not set. 496 uint16_t mtu_; 497 const bool sender_; 498 499 int nack_history_size_sender_; 500 int max_nack_reordering_threshold_; 501 I420FrameCallback* pre_render_callback_; 502 503 std::map<uint32_t, RTCPReportBlock> prev_report_blocks_; 504 }; 505 506 } // namespace webrtc 507 508 #endif // WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_H_ 509