OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
45 Transport* outgoing_transport, | 45 Transport* outgoing_transport, |
46 RtcpIntraFrameObserver* intra_frame_callback, | 46 RtcpIntraFrameObserver* intra_frame_callback, |
47 RtcpBandwidthObserver* bandwidth_callback, | 47 RtcpBandwidthObserver* bandwidth_callback, |
48 TransportFeedbackObserver* transport_feedback_callback, | 48 TransportFeedbackObserver* transport_feedback_callback, |
49 RtcpRttStats* rtt_stats, | 49 RtcpRttStats* rtt_stats, |
50 RtpPacketSender* paced_sender, | 50 RtpPacketSender* paced_sender, |
51 TransportSequenceNumberAllocator* transport_sequence_number_allocator, | 51 TransportSequenceNumberAllocator* transport_sequence_number_allocator, |
52 SendStatisticsProxy* stats_proxy, | 52 SendStatisticsProxy* stats_proxy, |
53 SendDelayStats* send_delay_stats, | 53 SendDelayStats* send_delay_stats, |
54 RtcEventLog* event_log, | 54 RtcEventLog* event_log, |
| 55 RateLimiter* retransmission_rate_limiter, |
55 size_t num_modules) { | 56 size_t num_modules) { |
56 RTC_DCHECK_GT(num_modules, 0u); | 57 RTC_DCHECK_GT(num_modules, 0u); |
57 RtpRtcp::Configuration configuration; | 58 RtpRtcp::Configuration configuration; |
58 ReceiveStatistics* null_receive_statistics = configuration.receive_statistics; | 59 ReceiveStatistics* null_receive_statistics = configuration.receive_statistics; |
59 configuration.audio = false; | 60 configuration.audio = false; |
60 configuration.receiver_only = false; | 61 configuration.receiver_only = false; |
61 configuration.receive_statistics = null_receive_statistics; | 62 configuration.receive_statistics = null_receive_statistics; |
62 configuration.outgoing_transport = outgoing_transport; | 63 configuration.outgoing_transport = outgoing_transport; |
63 configuration.intra_frame_callback = intra_frame_callback; | 64 configuration.intra_frame_callback = intra_frame_callback; |
64 configuration.bandwidth_callback = bandwidth_callback; | 65 configuration.bandwidth_callback = bandwidth_callback; |
65 configuration.transport_feedback_callback = transport_feedback_callback; | 66 configuration.transport_feedback_callback = transport_feedback_callback; |
66 configuration.rtt_stats = rtt_stats; | 67 configuration.rtt_stats = rtt_stats; |
67 configuration.rtcp_packet_type_counter_observer = stats_proxy; | 68 configuration.rtcp_packet_type_counter_observer = stats_proxy; |
68 configuration.paced_sender = paced_sender; | 69 configuration.paced_sender = paced_sender; |
69 configuration.transport_sequence_number_allocator = | 70 configuration.transport_sequence_number_allocator = |
70 transport_sequence_number_allocator; | 71 transport_sequence_number_allocator; |
71 configuration.send_bitrate_observer = stats_proxy; | 72 configuration.send_bitrate_observer = stats_proxy; |
72 configuration.send_frame_count_observer = stats_proxy; | 73 configuration.send_frame_count_observer = stats_proxy; |
73 configuration.send_side_delay_observer = stats_proxy; | 74 configuration.send_side_delay_observer = stats_proxy; |
74 configuration.send_packet_observer = send_delay_stats; | 75 configuration.send_packet_observer = send_delay_stats; |
75 configuration.event_log = event_log; | 76 configuration.event_log = event_log; |
| 77 configuration.retransmission_rate_limiter = retransmission_rate_limiter; |
76 | 78 |
77 std::vector<RtpRtcp*> modules; | 79 std::vector<RtpRtcp*> modules; |
78 for (size_t i = 0; i < num_modules; ++i) { | 80 for (size_t i = 0; i < num_modules; ++i) { |
79 RtpRtcp* rtp_rtcp = RtpRtcp::CreateRtpRtcp(configuration); | 81 RtpRtcp* rtp_rtcp = RtpRtcp::CreateRtpRtcp(configuration); |
80 rtp_rtcp->SetSendingStatus(false); | 82 rtp_rtcp->SetSendingStatus(false); |
81 rtp_rtcp->SetSendingMediaStatus(false); | 83 rtp_rtcp->SetSendingMediaStatus(false); |
82 rtp_rtcp->SetRTCPStatus(RtcpMode::kCompound); | 84 rtp_rtcp->SetRTCPStatus(RtcpMode::kCompound); |
83 modules.push_back(rtp_rtcp); | 85 modules.push_back(rtp_rtcp); |
84 } | 86 } |
85 return modules; | 87 return modules; |
(...skipping 335 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
421 config.send_transport, | 423 config.send_transport, |
422 &encoder_feedback_, | 424 &encoder_feedback_, |
423 bandwidth_observer_.get(), | 425 bandwidth_observer_.get(), |
424 congestion_controller_->GetTransportFeedbackObserver(), | 426 congestion_controller_->GetTransportFeedbackObserver(), |
425 call_stats_->rtcp_rtt_stats(), | 427 call_stats_->rtcp_rtt_stats(), |
426 congestion_controller_->pacer(), | 428 congestion_controller_->pacer(), |
427 congestion_controller_->packet_router(), | 429 congestion_controller_->packet_router(), |
428 &stats_proxy_, | 430 &stats_proxy_, |
429 send_delay_stats, | 431 send_delay_stats, |
430 event_log, | 432 event_log, |
| 433 congestion_controller_->GetRetransmissionRateLimiter(), |
431 config_.rtp.ssrcs.size())), | 434 config_.rtp.ssrcs.size())), |
432 payload_router_(rtp_rtcp_modules_, config.encoder_settings.payload_type), | 435 payload_router_(rtp_rtcp_modules_, config.encoder_settings.payload_type), |
433 input_(&encoder_wakeup_event_, | 436 input_(&encoder_wakeup_event_, |
434 config_.local_renderer, | 437 config_.local_renderer, |
435 &stats_proxy_, | 438 &stats_proxy_, |
436 &overuse_detector_) { | 439 &overuse_detector_) { |
437 LOG(LS_INFO) << "VideoSendStream: " << config_.ToString(); | 440 LOG(LS_INFO) << "VideoSendStream: " << config_.ToString(); |
438 | 441 |
439 RTC_DCHECK(!config_.rtp.ssrcs.empty()); | 442 RTC_DCHECK(!config_.rtp.ssrcs.empty()); |
440 RTC_DCHECK(module_process_thread_); | 443 RTC_DCHECK(module_process_thread_); |
(...skipping 437 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
878 void VideoSendStream::SignalNetworkState(NetworkState state) { | 881 void VideoSendStream::SignalNetworkState(NetworkState state) { |
879 for (RtpRtcp* rtp_rtcp : rtp_rtcp_modules_) { | 882 for (RtpRtcp* rtp_rtcp : rtp_rtcp_modules_) { |
880 rtp_rtcp->SetRTCPStatus(state == kNetworkUp ? config_.rtp.rtcp_mode | 883 rtp_rtcp->SetRTCPStatus(state == kNetworkUp ? config_.rtp.rtcp_mode |
881 : RtcpMode::kOff); | 884 : RtcpMode::kOff); |
882 } | 885 } |
883 } | 886 } |
884 | 887 |
885 uint32_t VideoSendStream::OnBitrateUpdated(uint32_t bitrate_bps, | 888 uint32_t VideoSendStream::OnBitrateUpdated(uint32_t bitrate_bps, |
886 uint8_t fraction_loss, | 889 uint8_t fraction_loss, |
887 int64_t rtt) { | 890 int64_t rtt) { |
888 payload_router_.SetTargetSendBitrate(bitrate_bps); | |
889 // Get the encoder target rate. It is the estimated network rate - | 891 // Get the encoder target rate. It is the estimated network rate - |
890 // protection overhead. | 892 // protection overhead. |
891 uint32_t encoder_target_rate_bps = | 893 uint32_t encoder_target_rate_bps = |
892 protection_bitrate_calculator_.SetTargetRates( | 894 protection_bitrate_calculator_.SetTargetRates( |
893 bitrate_bps, stats_proxy_.GetSendFrameRate(), fraction_loss, rtt); | 895 bitrate_bps, stats_proxy_.GetSendFrameRate(), fraction_loss, rtt); |
894 | 896 |
895 uint32_t protection_bitrate = bitrate_bps - encoder_target_rate_bps; | 897 uint32_t protection_bitrate = bitrate_bps - encoder_target_rate_bps; |
896 { | 898 { |
897 // Limit the target bitrate to the configured max bitrate. | 899 // Limit the target bitrate to the configured max bitrate. |
898 rtc::CritScope lock(&encoder_settings_crit_); | 900 rtc::CritScope lock(&encoder_settings_crit_); |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
930 &module_nack_rate); | 932 &module_nack_rate); |
931 *sent_video_rate_bps += module_video_rate; | 933 *sent_video_rate_bps += module_video_rate; |
932 *sent_nack_rate_bps += module_nack_rate; | 934 *sent_nack_rate_bps += module_nack_rate; |
933 *sent_fec_rate_bps += module_fec_rate; | 935 *sent_fec_rate_bps += module_fec_rate; |
934 } | 936 } |
935 return 0; | 937 return 0; |
936 } | 938 } |
937 | 939 |
938 } // namespace internal | 940 } // namespace internal |
939 } // namespace webrtc | 941 } // namespace webrtc |
OLD | NEW |