niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 1 | /* |
pwestin@webrtc.org | f6bb77a | 2012-01-24 17:16:59 +0000 | [diff] [blame] | 2 | * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 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 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 11 | #include "modules/rtp_rtcp/source/rtp_rtcp_impl.h" |
mflodman@webrtc.org | 2f225ca | 2013-01-09 13:54:43 +0000 | [diff] [blame] | 12 | |
pbos@webrtc.org | a048d7c | 2013-05-29 14:27:38 +0000 | [diff] [blame] | 13 | #include <string.h> |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 14 | |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 15 | #include <algorithm> |
mflodman@webrtc.org | 02270cd | 2015-02-06 13:10:19 +0000 | [diff] [blame] | 16 | #include <set> |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 17 | #include <string> |
mflodman@webrtc.org | 02270cd | 2015-02-06 13:10:19 +0000 | [diff] [blame] | 18 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 19 | #include "api/rtpparameters.h" |
Mirko Bonadei | 7120742 | 2017-09-15 13:58:09 +0200 | [diff] [blame] | 20 | #include "common_types.h" // NOLINT(build/include) |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 21 | #include "rtc_base/checks.h" |
| 22 | #include "rtc_base/logging.h" |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 23 | |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 24 | #ifdef _WIN32 |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 25 | // Disable warning C4355: 'this' : used in base member initializer list. |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 26 | #pragma warning(disable : 4355) |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 27 | #endif |
| 28 | |
| 29 | namespace webrtc { |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 30 | namespace { |
| 31 | const int64_t kRtpRtcpMaxIdleTimeProcessMs = 5; |
| 32 | const int64_t kRtpRtcpRttProcessTimeMs = 1000; |
| 33 | const int64_t kRtpRtcpBitrateProcessTimeMs = 10; |
sprang | a8ae6f2 | 2017-09-04 07:23:56 -0700 | [diff] [blame] | 34 | const int64_t kDefaultExpectedRetransmissionTimeMs = 125; |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 35 | } // namespace |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 36 | |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 37 | RTPExtensionType StringToRtpExtensionType(const std::string& extension) { |
isheriff | 6f8d686 | 2016-05-26 11:24:55 -0700 | [diff] [blame] | 38 | if (extension == RtpExtension::kTimestampOffsetUri) |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 39 | return kRtpExtensionTransmissionTimeOffset; |
isheriff | 6f8d686 | 2016-05-26 11:24:55 -0700 | [diff] [blame] | 40 | if (extension == RtpExtension::kAudioLevelUri) |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 41 | return kRtpExtensionAudioLevel; |
isheriff | 6f8d686 | 2016-05-26 11:24:55 -0700 | [diff] [blame] | 42 | if (extension == RtpExtension::kAbsSendTimeUri) |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 43 | return kRtpExtensionAbsoluteSendTime; |
isheriff | 6f8d686 | 2016-05-26 11:24:55 -0700 | [diff] [blame] | 44 | if (extension == RtpExtension::kVideoRotationUri) |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 45 | return kRtpExtensionVideoRotation; |
isheriff | 6f8d686 | 2016-05-26 11:24:55 -0700 | [diff] [blame] | 46 | if (extension == RtpExtension::kTransportSequenceNumberUri) |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 47 | return kRtpExtensionTransportSequenceNumber; |
isheriff | 6b4b5f3 | 2016-06-08 00:24:21 -0700 | [diff] [blame] | 48 | if (extension == RtpExtension::kPlayoutDelayUri) |
| 49 | return kRtpExtensionPlayoutDelay; |
ilnik | 00d802b | 2017-04-11 10:34:31 -0700 | [diff] [blame] | 50 | if (extension == RtpExtension::kVideoContentTypeUri) |
| 51 | return kRtpExtensionVideoContentType; |
ilnik | 04f4d12 | 2017-06-19 07:18:55 -0700 | [diff] [blame] | 52 | if (extension == RtpExtension::kVideoTimingUri) |
| 53 | return kRtpExtensionVideoTiming; |
Peter Boström | 9c01725 | 2016-02-26 16:26:20 +0100 | [diff] [blame] | 54 | RTC_NOTREACHED() << "Looking up unsupported RTP extension."; |
| 55 | return kRtpExtensionNone; |
| 56 | } |
| 57 | |
danilchap | d3f3c34 | 2017-07-25 04:20:12 -0700 | [diff] [blame] | 58 | RtpRtcp::Configuration::Configuration() = default; |
phoglund@webrtc.org | a22a9bd | 2013-01-14 10:01:55 +0000 | [diff] [blame] | 59 | |
pwestin@webrtc.org | 2853dde | 2012-05-11 11:08:54 +0000 | [diff] [blame] | 60 | RtpRtcp* RtpRtcp::CreateRtpRtcp(const RtpRtcp::Configuration& configuration) { |
| 61 | if (configuration.clock) { |
| 62 | return new ModuleRtpRtcpImpl(configuration); |
henrike@webrtc.org | f5da4da | 2012-02-15 23:54:59 +0000 | [diff] [blame] | 63 | } else { |
pbos@webrtc.org | 180e516 | 2014-07-11 15:36:26 +0000 | [diff] [blame] | 64 | // No clock implementation provided, use default clock. |
pwestin@webrtc.org | 2853dde | 2012-05-11 11:08:54 +0000 | [diff] [blame] | 65 | RtpRtcp::Configuration configuration_copy; |
| 66 | memcpy(&configuration_copy, &configuration, |
| 67 | sizeof(RtpRtcp::Configuration)); |
stefan@webrtc.org | 20ed36d | 2013-01-17 14:01:20 +0000 | [diff] [blame] | 68 | configuration_copy.clock = Clock::GetRealTimeClock(); |
pbos@webrtc.org | 180e516 | 2014-07-11 15:36:26 +0000 | [diff] [blame] | 69 | return new ModuleRtpRtcpImpl(configuration_copy); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 70 | } |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 71 | } |
| 72 | |
brandtr | 1743a19 | 2016-11-07 03:36:05 -0800 | [diff] [blame] | 73 | // Deprecated. |
| 74 | int32_t RtpRtcp::SetFecParameters(const FecProtectionParams* delta_params, |
| 75 | const FecProtectionParams* key_params) { |
| 76 | RTC_DCHECK(delta_params); |
| 77 | RTC_DCHECK(key_params); |
| 78 | return SetFecParameters(*delta_params, *key_params) ? 0 : -1; |
| 79 | } |
| 80 | |
pwestin@webrtc.org | 2853dde | 2012-05-11 11:08:54 +0000 | [diff] [blame] | 81 | ModuleRtpRtcpImpl::ModuleRtpRtcpImpl(const Configuration& configuration) |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 82 | : rtcp_sender_(configuration.audio, |
stefan@webrtc.org | a15fbfd | 2014-06-17 17:32:05 +0000 | [diff] [blame] | 83 | configuration.clock, |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 84 | configuration.receive_statistics, |
sprang | 86fd9ed | 2015-09-29 04:45:43 -0700 | [diff] [blame] | 85 | configuration.rtcp_packet_type_counter_observer, |
terelius | 429c345 | 2016-01-21 05:42:04 -0800 | [diff] [blame] | 86 | configuration.event_log, |
sprang | 86fd9ed | 2015-09-29 04:45:43 -0700 | [diff] [blame] | 87 | configuration.outgoing_transport), |
Peter Boström | ac547a6 | 2015-09-17 23:03:57 +0200 | [diff] [blame] | 88 | rtcp_receiver_(configuration.clock, |
Peter Boström | fe7a80c | 2015-04-23 17:53:17 +0200 | [diff] [blame] | 89 | configuration.receiver_only, |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 90 | configuration.rtcp_packet_type_counter_observer, |
mflodman@webrtc.org | 96abda0 | 2015-02-25 13:50:10 +0000 | [diff] [blame] | 91 | configuration.bandwidth_callback, |
| 92 | configuration.intra_frame_callback, |
Erik Språng | 6b8d355 | 2015-09-24 15:06:57 +0200 | [diff] [blame] | 93 | configuration.transport_feedback_callback, |
sprang | a790d83 | 2016-12-02 07:29:44 -0800 | [diff] [blame] | 94 | configuration.bitrate_allocation_observer, |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 95 | this), |
stefan@webrtc.org | a678a3b | 2013-01-21 07:42:11 +0000 | [diff] [blame] | 96 | clock_(configuration.clock), |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 97 | audio_(configuration.audio), |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 98 | keepalive_config_(configuration.keepalive_config), |
| 99 | last_bitrate_process_time_(clock_->TimeInMilliseconds()), |
| 100 | last_rtt_process_time_(clock_->TimeInMilliseconds()), |
| 101 | next_process_time_(clock_->TimeInMilliseconds() + |
| 102 | kRtpRtcpMaxIdleTimeProcessMs), |
| 103 | next_keepalive_time_(-1), |
asapersson | 35151f3 | 2016-05-02 23:44:01 -0700 | [diff] [blame] | 104 | packet_overhead_(28), // IPV4 UDP. |
stefan@webrtc.org | a271070 | 2013-03-05 09:02:06 +0000 | [diff] [blame] | 105 | nack_last_time_sent_full_(0), |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 106 | nack_last_time_sent_full_prev_(0), |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 107 | nack_last_seq_number_sent_(0), |
Peter Boström | e23e737 | 2015-10-08 11:44:14 +0200 | [diff] [blame] | 108 | key_frame_req_method_(kKeyFrameReqPliRtcp), |
mflodman@webrtc.org | 7c894b7 | 2012-11-26 12:40:15 +0000 | [diff] [blame] | 109 | remote_bitrate_(configuration.remote_bitrate_estimator), |
asapersson@webrtc.org | 1ae1d0c | 2013-11-20 12:46:11 +0000 | [diff] [blame] | 110 | rtt_stats_(configuration.rtt_stats), |
asapersson@webrtc.org | 1ae1d0c | 2013-11-20 12:46:11 +0000 | [diff] [blame] | 111 | rtt_ms_(0) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 112 | if (!configuration.receiver_only) { |
| 113 | rtp_sender_.reset(new RTPSender( |
| 114 | configuration.audio, |
| 115 | configuration.clock, |
| 116 | configuration.outgoing_transport, |
| 117 | configuration.paced_sender, |
| 118 | configuration.flexfec_sender, |
| 119 | configuration.transport_sequence_number_allocator, |
| 120 | configuration.transport_feedback_callback, |
| 121 | configuration.send_bitrate_observer, |
| 122 | configuration.send_frame_count_observer, |
| 123 | configuration.send_side_delay_observer, |
| 124 | configuration.event_log, |
| 125 | configuration.send_packet_observer, |
| 126 | configuration.retransmission_rate_limiter, |
| 127 | configuration.overhead_observer)); |
| 128 | // Make sure rtcp sender use same timestamp offset as rtp sender. |
| 129 | rtcp_sender_.SetTimestampOffset(rtp_sender_->TimestampOffset()); |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 130 | |
| 131 | if (keepalive_config_.timeout_interval_ms != -1) { |
| 132 | next_keepalive_time_ = |
| 133 | clock_->TimeInMilliseconds() + keepalive_config_.timeout_interval_ms; |
| 134 | } |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 135 | } |
danilchap | 71fead2 | 2016-08-18 02:01:49 -0700 | [diff] [blame] | 136 | |
| 137 | // Set default packet size limit. |
nisse | 284542b | 2017-01-10 08:58:32 -0800 | [diff] [blame] | 138 | // TODO(nisse): Kind-of duplicates |
| 139 | // webrtc::VideoSendStream::Config::Rtp::kDefaultMaxPacketSize. |
| 140 | const size_t kTcpOverIpv4HeaderSize = 40; |
| 141 | SetMaxRtpPacketSize(IP_PACKET_SIZE - kTcpOverIpv4HeaderSize); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 142 | } |
| 143 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 144 | // Returns the number of milliseconds until the module want a worker thread |
| 145 | // to call Process. |
pkasting@chromium.org | 0b1534c | 2014-12-15 22:09:40 +0000 | [diff] [blame] | 146 | int64_t ModuleRtpRtcpImpl::TimeUntilNextProcess() { |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 147 | return std::max<int64_t>(0, |
| 148 | next_process_time_ - clock_->TimeInMilliseconds()); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 149 | } |
| 150 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 151 | // Process any pending tasks such as timeouts (non time critical events). |
pbos | a26ac92 | 2016-02-25 04:50:01 -0800 | [diff] [blame] | 152 | void ModuleRtpRtcpImpl::Process() { |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 153 | const int64_t now = clock_->TimeInMilliseconds(); |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 154 | next_process_time_ = now + kRtpRtcpMaxIdleTimeProcessMs; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 155 | |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 156 | if (rtp_sender_) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 157 | if (now >= last_bitrate_process_time_ + kRtpRtcpBitrateProcessTimeMs) { |
| 158 | rtp_sender_->ProcessBitrate(); |
| 159 | last_bitrate_process_time_ = now; |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 160 | next_process_time_ = |
| 161 | std::min(next_process_time_, now + kRtpRtcpBitrateProcessTimeMs); |
| 162 | } |
| 163 | if (keepalive_config_.timeout_interval_ms > 0 && |
| 164 | now >= next_keepalive_time_) { |
| 165 | int64_t last_send_time_ms = rtp_sender_->LastTimestampTimeMs(); |
| 166 | // If no packet has been sent, |last_send_time_ms| will be 0, and so the |
| 167 | // keep-alive will be triggered as expected. |
| 168 | if (now >= last_send_time_ms + keepalive_config_.timeout_interval_ms) { |
| 169 | rtp_sender_->SendKeepAlive(keepalive_config_.payload_type); |
| 170 | next_keepalive_time_ = now + keepalive_config_.timeout_interval_ms; |
| 171 | } else { |
| 172 | next_keepalive_time_ = |
| 173 | last_send_time_ms + keepalive_config_.timeout_interval_ms; |
| 174 | } |
| 175 | next_process_time_ = std::min(next_process_time_, next_keepalive_time_); |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 176 | } |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 177 | } |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 178 | |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 179 | bool process_rtt = now >= last_rtt_process_time_ + kRtpRtcpRttProcessTimeMs; |
| 180 | if (rtcp_sender_.Sending()) { |
Danil Chapovalov | 760c4b4 | 2017-09-27 13:25:24 +0200 | [diff] [blame] | 181 | // Process RTT if we have received a report block and we haven't |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 182 | // processed RTT for at least |kRtpRtcpRttProcessTimeMs| milliseconds. |
Danil Chapovalov | 760c4b4 | 2017-09-27 13:25:24 +0200 | [diff] [blame] | 183 | if (rtcp_receiver_.LastReceivedReportBlockMs() > last_rtt_process_time_ && |
| 184 | process_rtt) { |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 185 | std::vector<RTCPReportBlock> receive_blocks; |
| 186 | rtcp_receiver_.StatisticsReceived(&receive_blocks); |
| 187 | int64_t max_rtt = 0; |
| 188 | for (std::vector<RTCPReportBlock>::iterator it = receive_blocks.begin(); |
| 189 | it != receive_blocks.end(); ++it) { |
| 190 | int64_t rtt = 0; |
srte | 3e69e5c | 2017-08-09 06:13:45 -0700 | [diff] [blame] | 191 | rtcp_receiver_.RTT(it->sender_ssrc, &rtt, NULL, NULL, NULL); |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 192 | max_rtt = (rtt > max_rtt) ? rtt : max_rtt; |
mflodman@webrtc.org | d7d4688 | 2012-02-14 12:49:59 +0000 | [diff] [blame] | 193 | } |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 194 | // Report the rtt. |
| 195 | if (rtt_stats_ && max_rtt != 0) |
| 196 | rtt_stats_->OnRttUpdate(max_rtt); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 197 | } |
asapersson@webrtc.org | 7d6bd22 | 2013-10-31 12:14:34 +0000 | [diff] [blame] | 198 | |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 199 | // Verify receiver reports are delivered and the reported sequence number |
| 200 | // is increasing. |
| 201 | int64_t rtcp_interval = RtcpReportInterval(); |
| 202 | if (rtcp_receiver_.RtcpRrTimeout(rtcp_interval)) { |
| 203 | LOG_F(LS_WARNING) << "Timeout: No RTCP RR received."; |
| 204 | } else if (rtcp_receiver_.RtcpRrSequenceNumberTimeout(rtcp_interval)) { |
| 205 | LOG_F(LS_WARNING) << |
| 206 | "Timeout: No increase in RTCP RR extended highest sequence number."; |
| 207 | } |
| 208 | |
| 209 | if (remote_bitrate_ && rtcp_sender_.TMMBR()) { |
| 210 | unsigned int target_bitrate = 0; |
| 211 | std::vector<unsigned int> ssrcs; |
| 212 | if (remote_bitrate_->LatestEstimate(&ssrcs, &target_bitrate)) { |
| 213 | if (!ssrcs.empty()) { |
| 214 | target_bitrate = target_bitrate / ssrcs.size(); |
| 215 | } |
| 216 | rtcp_sender_.SetTargetBitrate(target_bitrate); |
| 217 | } |
| 218 | } |
| 219 | } else { |
| 220 | // Report rtt from receiver. |
asapersson@webrtc.org | 7d6bd22 | 2013-10-31 12:14:34 +0000 | [diff] [blame] | 221 | if (process_rtt) { |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 222 | int64_t rtt_ms; |
| 223 | if (rtt_stats_ && rtcp_receiver_.GetAndResetXrRrRtt(&rtt_ms)) { |
| 224 | rtt_stats_->OnRttUpdate(rtt_ms); |
| 225 | } |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 226 | } |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 227 | } |
| 228 | |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 229 | // Get processed rtt. |
| 230 | if (process_rtt) { |
| 231 | last_rtt_process_time_ = now; |
sprang | 168794c | 2017-07-06 04:38:06 -0700 | [diff] [blame] | 232 | next_process_time_ = std::min( |
| 233 | next_process_time_, last_rtt_process_time_ + kRtpRtcpRttProcessTimeMs); |
sprang | e2d83d6 | 2016-02-19 09:03:26 -0800 | [diff] [blame] | 234 | if (rtt_stats_) { |
| 235 | // Make sure we have a valid RTT before setting. |
| 236 | int64_t last_rtt = rtt_stats_->LastProcessedRtt(); |
| 237 | if (last_rtt >= 0) |
| 238 | set_rtt_ms(last_rtt); |
| 239 | } |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 240 | } |
| 241 | |
Danil Chapovalov | 70ffead | 2016-07-20 15:26:59 +0200 | [diff] [blame] | 242 | if (rtcp_sender_.TimeToSendRTCPReport()) |
| 243 | rtcp_sender_.SendRTCP(GetFeedbackState(), kRtcpReport); |
mflodman@webrtc.org | 9dd0ebc | 2015-02-26 12:57:47 +0000 | [diff] [blame] | 244 | |
danilchap | 9bf610e | 2017-02-20 06:03:01 -0800 | [diff] [blame] | 245 | if (TMMBR() && rtcp_receiver_.UpdateTmmbrTimers()) { |
| 246 | rtcp_receiver_.NotifyTmmbrUpdated(); |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 247 | } |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 248 | } |
| 249 | |
pbos@webrtc.org | 0b0c241 | 2015-01-13 14:15:15 +0000 | [diff] [blame] | 250 | void ModuleRtpRtcpImpl::SetRtxSendStatus(int mode) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 251 | rtp_sender_->SetRtxStatus(mode); |
pwestin@webrtc.org | 8281e7d | 2012-01-10 14:09:18 +0000 | [diff] [blame] | 252 | } |
| 253 | |
pbos@webrtc.org | 0b0c241 | 2015-01-13 14:15:15 +0000 | [diff] [blame] | 254 | int ModuleRtpRtcpImpl::RtxSendStatus() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 255 | return rtp_sender_ ? rtp_sender_->RtxStatus() : kRtxOff; |
stefan@webrtc.org | ef92755 | 2014-06-05 08:25:29 +0000 | [diff] [blame] | 256 | } |
| 257 | |
| 258 | void ModuleRtpRtcpImpl::SetRtxSsrc(uint32_t ssrc) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 259 | rtp_sender_->SetRtxSsrc(ssrc); |
pwestin@webrtc.org | 8281e7d | 2012-01-10 14:09:18 +0000 | [diff] [blame] | 260 | } |
| 261 | |
Shao Changbin | e62202f | 2015-04-21 20:24:50 +0800 | [diff] [blame] | 262 | void ModuleRtpRtcpImpl::SetRtxSendPayloadType(int payload_type, |
| 263 | int associated_payload_type) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 264 | rtp_sender_->SetRtxPayloadType(payload_type, associated_payload_type); |
mflodman@webrtc.org | 9f5ebb5 | 2013-04-12 14:55:46 +0000 | [diff] [blame] | 265 | } |
| 266 | |
brandtr | 9dfff29 | 2016-11-14 05:14:50 -0800 | [diff] [blame] | 267 | rtc::Optional<uint32_t> ModuleRtpRtcpImpl::FlexfecSsrc() const { |
brandtr | 7c7796b | 2017-07-03 06:02:53 -0700 | [diff] [blame] | 268 | if (rtp_sender_) |
| 269 | return rtp_sender_->FlexfecSsrc(); |
| 270 | return rtc::Optional<uint32_t>(); |
brandtr | 9dfff29 | 2016-11-14 05:14:50 -0800 | [diff] [blame] | 271 | } |
| 272 | |
nisse | 479d3d7 | 2017-09-13 07:53:37 -0700 | [diff] [blame] | 273 | void ModuleRtpRtcpImpl::IncomingRtcpPacket(const uint8_t* rtcp_packet, |
| 274 | const size_t length) { |
| 275 | rtcp_receiver_.IncomingPacket(rtcp_packet, length); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 276 | } |
| 277 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 278 | int32_t ModuleRtpRtcpImpl::RegisterSendPayload( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 279 | const CodecInst& voice_codec) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 280 | return rtp_sender_->RegisterPayload( |
Sergey Ulanov | ec4f068 | 2016-07-28 15:19:10 -0700 | [diff] [blame] | 281 | voice_codec.plname, voice_codec.pltype, voice_codec.plfreq, |
| 282 | voice_codec.channels, (voice_codec.rate < 0) ? 0 : voice_codec.rate); |
pwestin@webrtc.org | 1da1ce0 | 2011-10-13 15:19:55 +0000 | [diff] [blame] | 283 | } |
| 284 | |
asapersson@webrtc.org | 9ffd8fe | 2015-01-21 08:22:50 +0000 | [diff] [blame] | 285 | int32_t ModuleRtpRtcpImpl::RegisterSendPayload(const VideoCodec& video_codec) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 286 | return rtp_sender_->RegisterPayload(video_codec.plName, video_codec.plType, |
Peter Boström | 9d0c432 | 2016-02-16 17:59:27 +0100 | [diff] [blame] | 287 | 90000, 0, 0); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 288 | } |
| 289 | |
Peter Boström | 8b79b07 | 2016-02-26 16:31:37 +0100 | [diff] [blame] | 290 | void ModuleRtpRtcpImpl::RegisterVideoSendPayload(int payload_type, |
| 291 | const char* payload_name) { |
| 292 | RTC_CHECK_EQ( |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 293 | 0, rtp_sender_->RegisterPayload(payload_name, payload_type, 90000, 0, 0)); |
Peter Boström | 8b79b07 | 2016-02-26 16:31:37 +0100 | [diff] [blame] | 294 | } |
| 295 | |
asapersson@webrtc.org | 9ffd8fe | 2015-01-21 08:22:50 +0000 | [diff] [blame] | 296 | int32_t ModuleRtpRtcpImpl::DeRegisterSendPayload(const int8_t payload_type) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 297 | return rtp_sender_->DeRegisterSendPayload(payload_type); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 298 | } |
| 299 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 300 | uint32_t ModuleRtpRtcpImpl::StartTimestamp() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 301 | return rtp_sender_->TimestampOffset(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 302 | } |
| 303 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 304 | // Configure start timestamp, default is a random number. |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 305 | void ModuleRtpRtcpImpl::SetStartTimestamp(const uint32_t timestamp) { |
danilchap | 71fead2 | 2016-08-18 02:01:49 -0700 | [diff] [blame] | 306 | rtcp_sender_.SetTimestampOffset(timestamp); |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 307 | rtp_sender_->SetTimestampOffset(timestamp); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 308 | } |
| 309 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 310 | uint16_t ModuleRtpRtcpImpl::SequenceNumber() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 311 | return rtp_sender_->SequenceNumber(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 312 | } |
| 313 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 314 | // Set SequenceNumber, default is a random number. |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 315 | void ModuleRtpRtcpImpl::SetSequenceNumber(const uint16_t seq_num) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 316 | rtp_sender_->SetSequenceNumber(seq_num); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 317 | } |
| 318 | |
Per | 83d0910 | 2016-04-15 14:59:13 +0200 | [diff] [blame] | 319 | void ModuleRtpRtcpImpl::SetRtpState(const RtpState& rtp_state) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 320 | rtp_sender_->SetRtpState(rtp_state); |
danilchap | 71fead2 | 2016-08-18 02:01:49 -0700 | [diff] [blame] | 321 | rtcp_sender_.SetTimestampOffset(rtp_state.start_timestamp); |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 322 | } |
| 323 | |
Per | 83d0910 | 2016-04-15 14:59:13 +0200 | [diff] [blame] | 324 | void ModuleRtpRtcpImpl::SetRtxState(const RtpState& rtp_state) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 325 | rtp_sender_->SetRtxRtpState(rtp_state); |
Per | 83d0910 | 2016-04-15 14:59:13 +0200 | [diff] [blame] | 326 | } |
| 327 | |
| 328 | RtpState ModuleRtpRtcpImpl::GetRtpState() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 329 | return rtp_sender_->GetRtpState(); |
Per | 83d0910 | 2016-04-15 14:59:13 +0200 | [diff] [blame] | 330 | } |
| 331 | |
| 332 | RtpState ModuleRtpRtcpImpl::GetRtxState() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 333 | return rtp_sender_->GetRtxRtpState(); |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 334 | } |
| 335 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 336 | uint32_t ModuleRtpRtcpImpl::SSRC() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 337 | return rtcp_sender_.SSRC(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 338 | } |
| 339 | |
stefan@webrtc.org | ef92755 | 2014-06-05 08:25:29 +0000 | [diff] [blame] | 340 | void ModuleRtpRtcpImpl::SetSSRC(const uint32_t ssrc) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 341 | if (rtp_sender_) { |
| 342 | rtp_sender_->SetSSRC(ssrc); |
| 343 | } |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 344 | rtcp_sender_.SetSSRC(ssrc); |
stefan@webrtc.org | 28a331e | 2013-09-17 07:49:56 +0000 | [diff] [blame] | 345 | SetRtcpReceiverSsrcs(ssrc); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 346 | } |
| 347 | |
pbos@webrtc.org | 9334ac2 | 2014-11-24 08:25:50 +0000 | [diff] [blame] | 348 | void ModuleRtpRtcpImpl::SetCsrcs(const std::vector<uint32_t>& csrcs) { |
pbos@webrtc.org | 9334ac2 | 2014-11-24 08:25:50 +0000 | [diff] [blame] | 349 | rtcp_sender_.SetCsrcs(csrcs); |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 350 | rtp_sender_->SetCsrcs(csrcs); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 351 | } |
| 352 | |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 353 | // TODO(pbos): Handle media and RTX streams separately (separate RTCP |
| 354 | // feedbacks). |
| 355 | RTCPSender::FeedbackState ModuleRtpRtcpImpl::GetFeedbackState() { |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 356 | RTCPSender::FeedbackState state; |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 357 | // This is called also when receiver_only is true. Hence below |
| 358 | // checks that rtp_sender_ exists. |
| 359 | if (rtp_sender_) { |
| 360 | StreamDataCounters rtp_stats; |
| 361 | StreamDataCounters rtx_stats; |
| 362 | rtp_sender_->GetDataCounters(&rtp_stats, &rtx_stats); |
| 363 | state.packets_sent = rtp_stats.transmitted.packets + |
| 364 | rtx_stats.transmitted.packets; |
| 365 | state.media_bytes_sent = rtp_stats.transmitted.payload_bytes + |
| 366 | rtx_stats.transmitted.payload_bytes; |
| 367 | state.send_bitrate = rtp_sender_->BitrateSent(); |
| 368 | } |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 369 | state.module = this; |
| 370 | |
| 371 | LastReceivedNTP(&state.last_rr_ntp_secs, |
| 372 | &state.last_rr_ntp_frac, |
| 373 | &state.remote_sr); |
| 374 | |
danilchap | 798896a | 2016-09-28 02:54:25 -0700 | [diff] [blame] | 375 | state.has_last_xr_rr = |
| 376 | rtcp_receiver_.LastReceivedXrReferenceTimeInfo(&state.last_xr_rr); |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 377 | |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 378 | return state; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 379 | } |
| 380 | |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 381 | // TODO(nisse): This method shouldn't be called for a receive-only |
| 382 | // stream. Delete rtp_sender_ check as soon as all applications are |
| 383 | // updated. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 384 | int32_t ModuleRtpRtcpImpl::SetSendingStatus(const bool sending) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 385 | if (rtcp_sender_.Sending() != sending) { |
| 386 | // Sends RTCP BYE when going from true to false |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 387 | if (rtcp_sender_.SetSendingStatus(GetFeedbackState(), sending) != 0) { |
andresp@webrtc.org | dc80bae | 2014-04-08 11:06:12 +0000 | [diff] [blame] | 388 | LOG(LS_WARNING) << "Failed to send RTCP BYE"; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 389 | } |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 390 | if (sending && rtp_sender_) { |
nisse | 7d59f6b | 2017-02-21 03:40:24 -0800 | [diff] [blame] | 391 | // Update Rtcp receiver config, to track Rtx config changes from |
| 392 | // the SetRtxStatus and SetRtxSsrc methods. |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 393 | SetRtcpReceiverSsrcs(rtp_sender_->SSRC()); |
nisse | 7d59f6b | 2017-02-21 03:40:24 -0800 | [diff] [blame] | 394 | } |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 395 | } |
| 396 | return 0; |
| 397 | } |
| 398 | |
| 399 | bool ModuleRtpRtcpImpl::Sending() const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 400 | return rtcp_sender_.Sending(); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 401 | } |
| 402 | |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 403 | // TODO(nisse): This method shouldn't be called for a receive-only |
| 404 | // stream. Delete rtp_sender_ check as soon as all applications are |
| 405 | // updated. |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 406 | void ModuleRtpRtcpImpl::SetSendingMediaStatus(const bool sending) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 407 | if (rtp_sender_) { |
| 408 | rtp_sender_->SetSendingMediaStatus(sending); |
| 409 | } else { |
| 410 | RTC_DCHECK(!sending); |
| 411 | } |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 412 | } |
| 413 | |
| 414 | bool ModuleRtpRtcpImpl::SendingMedia() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 415 | return rtp_sender_ ? rtp_sender_->SendingMedia() : false; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 416 | } |
| 417 | |
Sergey Ulanov | 525df3f | 2016-08-02 17:46:41 -0700 | [diff] [blame] | 418 | bool ModuleRtpRtcpImpl::SendOutgoingData( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 419 | FrameType frame_type, |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 420 | int8_t payload_type, |
| 421 | uint32_t time_stamp, |
stefan@webrtc.org | ddfdfed | 2012-07-03 13:21:22 +0000 | [diff] [blame] | 422 | int64_t capture_time_ms, |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 423 | const uint8_t* payload_data, |
pkasting@chromium.org | 4591fbd | 2014-11-20 22:28:14 +0000 | [diff] [blame] | 424 | size_t payload_size, |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 425 | const RTPFragmentationHeader* fragmentation, |
Sergey Ulanov | 525df3f | 2016-08-02 17:46:41 -0700 | [diff] [blame] | 426 | const RTPVideoHeader* rtp_video_header, |
| 427 | uint32_t* transport_frame_id_out) { |
mflodman@webrtc.org | 02270cd | 2015-02-06 13:10:19 +0000 | [diff] [blame] | 428 | rtcp_sender_.SetLastRtpTime(time_stamp, capture_time_ms); |
mflodman | 0b3d7ee | 2015-12-10 10:10:44 +0100 | [diff] [blame] | 429 | // Make sure an RTCP report isn't queued behind a key frame. |
mflodman@webrtc.org | 02270cd | 2015-02-06 13:10:19 +0000 | [diff] [blame] | 430 | if (rtcp_sender_.TimeToSendRTCPReport(kVideoFrameKey == frame_type)) { |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 431 | rtcp_sender_.SendRTCP(GetFeedbackState(), kRtcpReport); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 432 | } |
sprang | a8ae6f2 | 2017-09-04 07:23:56 -0700 | [diff] [blame] | 433 | int64_t expected_retransmission_time_ms = rtt_ms(); |
| 434 | if (expected_retransmission_time_ms == 0) { |
| 435 | // No rtt available (|kRtpRtcpRttProcessTimeMs| not yet passed?), so try to |
| 436 | // poll avg_rtt_ms directly from rtcp receiver. |
| 437 | if (rtcp_receiver_.RTT(rtcp_receiver_.RemoteSSRC(), nullptr, |
| 438 | &expected_retransmission_time_ms, nullptr, |
| 439 | nullptr) == -1) { |
| 440 | expected_retransmission_time_ms = kDefaultExpectedRetransmissionTimeMs; |
| 441 | } |
| 442 | } |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 443 | return rtp_sender_->SendOutgoingData( |
guoweis@webrtc.org | 4536289 | 2015-03-04 22:55:15 +0000 | [diff] [blame] | 444 | frame_type, payload_type, time_stamp, capture_time_ms, payload_data, |
sprang | a8ae6f2 | 2017-09-04 07:23:56 -0700 | [diff] [blame] | 445 | payload_size, fragmentation, rtp_video_header, transport_frame_id_out, |
| 446 | expected_retransmission_time_ms); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 447 | } |
| 448 | |
hclam@chromium.org | 2e402ce | 2013-06-20 20:18:31 +0000 | [diff] [blame] | 449 | bool ModuleRtpRtcpImpl::TimeToSendPacket(uint32_t ssrc, |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 450 | uint16_t sequence_number, |
stefan@webrtc.org | 9b82f5a | 2013-11-13 15:29:21 +0000 | [diff] [blame] | 451 | int64_t capture_time_ms, |
philipel | a1ed0b3 | 2016-06-01 06:31:17 -0700 | [diff] [blame] | 452 | bool retransmission, |
philipel | c7bf32a | 2017-02-17 03:59:43 -0800 | [diff] [blame] | 453 | const PacedPacketInfo& pacing_info) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 454 | return rtp_sender_->TimeToSendPacket(ssrc, sequence_number, capture_time_ms, |
philipel | 8aadd50 | 2017-02-23 02:56:13 -0800 | [diff] [blame] | 455 | retransmission, pacing_info); |
stefan@webrtc.org | 508a84b | 2013-06-17 12:53:37 +0000 | [diff] [blame] | 456 | } |
| 457 | |
philipel | c7bf32a | 2017-02-17 03:59:43 -0800 | [diff] [blame] | 458 | size_t ModuleRtpRtcpImpl::TimeToSendPadding( |
| 459 | size_t bytes, |
| 460 | const PacedPacketInfo& pacing_info) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 461 | return rtp_sender_->TimeToSendPadding(bytes, pacing_info); |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 462 | } |
| 463 | |
nisse | 284542b | 2017-01-10 08:58:32 -0800 | [diff] [blame] | 464 | size_t ModuleRtpRtcpImpl::MaxRtpPacketSize() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 465 | return rtp_sender_->MaxRtpPacketSize(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 466 | } |
| 467 | |
nisse | 284542b | 2017-01-10 08:58:32 -0800 | [diff] [blame] | 468 | void ModuleRtpRtcpImpl::SetMaxRtpPacketSize(size_t rtp_packet_size) { |
| 469 | RTC_DCHECK_LE(rtp_packet_size, IP_PACKET_SIZE) |
| 470 | << "rtp packet size too large: " << rtp_packet_size; |
| 471 | RTC_DCHECK_GT(rtp_packet_size, packet_overhead_) |
| 472 | << "rtp packet size too small: " << rtp_packet_size; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 473 | |
nisse | 284542b | 2017-01-10 08:58:32 -0800 | [diff] [blame] | 474 | rtcp_sender_.SetMaxRtpPacketSize(rtp_packet_size); |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 475 | if (rtp_sender_) |
| 476 | rtp_sender_->SetMaxRtpPacketSize(rtp_packet_size); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 477 | } |
| 478 | |
pbos | da903ea | 2015-10-02 02:36:56 -0700 | [diff] [blame] | 479 | RtcpMode ModuleRtpRtcpImpl::RTCP() const { |
Taylor Brandstetter | 5f0b83b | 2016-03-18 15:02:07 -0700 | [diff] [blame] | 480 | return rtcp_sender_.Status(); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 481 | } |
| 482 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 483 | // Configure RTCP status i.e on/off. |
pbos | da903ea | 2015-10-02 02:36:56 -0700 | [diff] [blame] | 484 | void ModuleRtpRtcpImpl::SetRTCPStatus(const RtcpMode method) { |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 485 | rtcp_sender_.SetRTCPStatus(method); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 486 | } |
pwestin@webrtc.org | 1da1ce0 | 2011-10-13 15:19:55 +0000 | [diff] [blame] | 487 | |
Peter Boström | 9ba52f8 | 2015-06-01 14:12:28 +0200 | [diff] [blame] | 488 | int32_t ModuleRtpRtcpImpl::SetCNAME(const char* c_name) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 489 | return rtcp_sender_.SetCNAME(c_name); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 490 | } |
| 491 | |
Erik Språng | 0ea42d3 | 2015-06-25 14:46:16 +0200 | [diff] [blame] | 492 | int32_t ModuleRtpRtcpImpl::AddMixedCNAME(uint32_t ssrc, const char* c_name) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 493 | return rtcp_sender_.AddMixedCNAME(ssrc, c_name); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 494 | } |
| 495 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 496 | int32_t ModuleRtpRtcpImpl::RemoveMixedCNAME(const uint32_t ssrc) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 497 | return rtcp_sender_.RemoveMixedCNAME(ssrc); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 498 | } |
| 499 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 500 | int32_t ModuleRtpRtcpImpl::RemoteCNAME( |
| 501 | const uint32_t remote_ssrc, |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 502 | char c_name[RTCP_CNAME_SIZE]) const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 503 | return rtcp_receiver_.CNAME(remote_ssrc, c_name); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 504 | } |
| 505 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 506 | int32_t ModuleRtpRtcpImpl::RemoteNTP( |
| 507 | uint32_t* received_ntpsecs, |
| 508 | uint32_t* received_ntpfrac, |
| 509 | uint32_t* rtcp_arrival_time_secs, |
| 510 | uint32_t* rtcp_arrival_time_frac, |
| 511 | uint32_t* rtcp_timestamp) const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 512 | return rtcp_receiver_.NTP(received_ntpsecs, |
| 513 | received_ntpfrac, |
| 514 | rtcp_arrival_time_secs, |
| 515 | rtcp_arrival_time_frac, |
pbos@webrtc.org | 376b4ea | 2014-07-15 15:51:33 +0000 | [diff] [blame] | 516 | rtcp_timestamp) |
| 517 | ? 0 |
| 518 | : -1; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 519 | } |
| 520 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 521 | // Get RoundTripTime. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 522 | int32_t ModuleRtpRtcpImpl::RTT(const uint32_t remote_ssrc, |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 523 | int64_t* rtt, |
| 524 | int64_t* avg_rtt, |
| 525 | int64_t* min_rtt, |
| 526 | int64_t* max_rtt) const { |
wu@webrtc.org | cd70119 | 2014-04-24 22:10:24 +0000 | [diff] [blame] | 527 | int32_t ret = rtcp_receiver_.RTT(remote_ssrc, rtt, avg_rtt, min_rtt, max_rtt); |
| 528 | if (rtt && *rtt == 0) { |
| 529 | // Try to get RTT from RtcpRttStats class. |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 530 | *rtt = rtt_ms(); |
wu@webrtc.org | cd70119 | 2014-04-24 22:10:24 +0000 | [diff] [blame] | 531 | } |
| 532 | return ret; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 533 | } |
| 534 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 535 | // Force a send of an RTCP packet. |
| 536 | // Normal SR and RR are triggered via the process function. |
Erik Språng | 242e22b | 2015-05-11 10:17:43 +0200 | [diff] [blame] | 537 | int32_t ModuleRtpRtcpImpl::SendRTCP(RTCPPacketType packet_type) { |
| 538 | return rtcp_sender_.SendRTCP(GetFeedbackState(), packet_type); |
| 539 | } |
| 540 | |
| 541 | // Force a send of an RTCP packet. |
| 542 | // Normal SR and RR are triggered via the process function. |
| 543 | int32_t ModuleRtpRtcpImpl::SendCompoundRTCP( |
| 544 | const std::set<RTCPPacketType>& packet_types) { |
| 545 | return rtcp_sender_.SendCompoundRTCP(GetFeedbackState(), packet_types); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 546 | } |
| 547 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 548 | int32_t ModuleRtpRtcpImpl::SetRTCPApplicationSpecificData( |
| 549 | const uint8_t sub_type, |
| 550 | const uint32_t name, |
| 551 | const uint8_t* data, |
| 552 | const uint16_t length) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 553 | return rtcp_sender_.SetApplicationSpecificData(sub_type, name, data, length); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 554 | } |
| 555 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 556 | // (XR) VOIP metric. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 557 | int32_t ModuleRtpRtcpImpl::SetRTCPVoIPMetrics( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 558 | const RTCPVoIPMetric* voip_metric) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 559 | return rtcp_sender_.SetRTCPVoIPMetrics(voip_metric); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 560 | } |
| 561 | |
asapersson@webrtc.org | 7d6bd22 | 2013-10-31 12:14:34 +0000 | [diff] [blame] | 562 | void ModuleRtpRtcpImpl::SetRtcpXrRrtrStatus(bool enable) { |
Danil Chapovalov | c1e55c7 | 2016-03-09 15:14:35 +0100 | [diff] [blame] | 563 | rtcp_receiver_.SetRtcpXrRrtrStatus(enable); |
| 564 | rtcp_sender_.SendRtcpXrReceiverReferenceTime(enable); |
asapersson@webrtc.org | 7d6bd22 | 2013-10-31 12:14:34 +0000 | [diff] [blame] | 565 | } |
| 566 | |
asapersson@webrtc.org | 8d02f5d | 2013-11-21 08:57:04 +0000 | [diff] [blame] | 567 | bool ModuleRtpRtcpImpl::RtcpXrRrtrStatus() const { |
| 568 | return rtcp_sender_.RtcpXrReceiverReferenceTime(); |
| 569 | } |
| 570 | |
asapersson@webrtc.org | 97d0489 | 2014-12-09 09:47:53 +0000 | [diff] [blame] | 571 | // TODO(asapersson): Replace this method with the one below. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 572 | int32_t ModuleRtpRtcpImpl::DataCountersRTP( |
pkasting@chromium.org | 4591fbd | 2014-11-20 22:28:14 +0000 | [diff] [blame] | 573 | size_t* bytes_sent, |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 574 | uint32_t* packets_sent) const { |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 575 | StreamDataCounters rtp_stats; |
| 576 | StreamDataCounters rtx_stats; |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 577 | rtp_sender_->GetDataCounters(&rtp_stats, &rtx_stats); |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 578 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 579 | if (bytes_sent) { |
asapersson@webrtc.org | cfd82df | 2015-01-22 09:39:59 +0000 | [diff] [blame] | 580 | *bytes_sent = rtp_stats.transmitted.payload_bytes + |
| 581 | rtp_stats.transmitted.padding_bytes + |
| 582 | rtp_stats.transmitted.header_bytes + |
| 583 | rtx_stats.transmitted.payload_bytes + |
| 584 | rtx_stats.transmitted.padding_bytes + |
| 585 | rtx_stats.transmitted.header_bytes; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 586 | } |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 587 | if (packets_sent) { |
asapersson@webrtc.org | cfd82df | 2015-01-22 09:39:59 +0000 | [diff] [blame] | 588 | *packets_sent = rtp_stats.transmitted.packets + |
| 589 | rtx_stats.transmitted.packets; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 590 | } |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 591 | return 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 592 | } |
| 593 | |
asapersson@webrtc.org | 97d0489 | 2014-12-09 09:47:53 +0000 | [diff] [blame] | 594 | void ModuleRtpRtcpImpl::GetSendStreamDataCounters( |
| 595 | StreamDataCounters* rtp_counters, |
| 596 | StreamDataCounters* rtx_counters) const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 597 | rtp_sender_->GetDataCounters(rtp_counters, rtx_counters); |
asapersson@webrtc.org | 97d0489 | 2014-12-09 09:47:53 +0000 | [diff] [blame] | 598 | } |
| 599 | |
bcornell | 30409b4 | 2015-07-10 18:10:05 -0700 | [diff] [blame] | 600 | void ModuleRtpRtcpImpl::GetRtpPacketLossStats( |
| 601 | bool outgoing, |
| 602 | uint32_t ssrc, |
| 603 | struct RtpPacketLossStats* loss_stats) const { |
| 604 | if (!loss_stats) return; |
| 605 | const PacketLossStats* stats_source = NULL; |
| 606 | if (outgoing) { |
| 607 | if (SSRC() == ssrc) { |
| 608 | stats_source = &send_loss_stats_; |
| 609 | } |
| 610 | } else { |
| 611 | if (rtcp_receiver_.RemoteSSRC() == ssrc) { |
| 612 | stats_source = &receive_loss_stats_; |
| 613 | } |
| 614 | } |
| 615 | if (stats_source) { |
| 616 | loss_stats->single_packet_loss_count = |
| 617 | stats_source->GetSingleLossCount(); |
| 618 | loss_stats->multiple_packet_loss_event_count = |
| 619 | stats_source->GetMultipleLossEventCount(); |
| 620 | loss_stats->multiple_packet_loss_packet_count = |
| 621 | stats_source->GetMultipleLossPacketCount(); |
| 622 | } |
| 623 | } |
| 624 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 625 | // Received RTCP report. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 626 | int32_t ModuleRtpRtcpImpl::RemoteRTCPStat( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 627 | std::vector<RTCPReportBlock>* receive_blocks) const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 628 | return rtcp_receiver_.StatisticsReceived(receive_blocks); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 629 | } |
| 630 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 631 | // (REMB) Receiver Estimated Max Bitrate. |
Danil Chapovalov | 51e21aa | 2017-10-10 17:46:26 +0200 | [diff] [blame] | 632 | void ModuleRtpRtcpImpl::SetRemb(uint32_t bitrate_bps, |
| 633 | const std::vector<uint32_t>& ssrcs) { |
Danil Chapovalov | f74d641 | 2017-10-18 13:32:57 +0200 | [diff] [blame] | 634 | rtcp_sender_.SetRemb(bitrate_bps, ssrcs); |
pwestin@webrtc.org | 741da94 | 2011-09-20 13:52:04 +0000 | [diff] [blame] | 635 | } |
| 636 | |
Danil Chapovalov | 51e21aa | 2017-10-10 17:46:26 +0200 | [diff] [blame] | 637 | void ModuleRtpRtcpImpl::UnsetRemb() { |
Danil Chapovalov | f74d641 | 2017-10-18 13:32:57 +0200 | [diff] [blame] | 638 | rtcp_sender_.UnsetRemb(); |
pwestin@webrtc.org | 741da94 | 2011-09-20 13:52:04 +0000 | [diff] [blame] | 639 | } |
| 640 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 641 | int32_t ModuleRtpRtcpImpl::RegisterSendRtpHeaderExtension( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 642 | const RTPExtensionType type, |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 643 | const uint8_t id) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 644 | return rtp_sender_->RegisterRtpHeaderExtension(type, id); |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 645 | } |
| 646 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 647 | int32_t ModuleRtpRtcpImpl::DeregisterSendRtpHeaderExtension( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 648 | const RTPExtensionType type) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 649 | return rtp_sender_->DeregisterRtpHeaderExtension(type); |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 650 | } |
| 651 | |
stefan | 53b6cc3 | 2017-02-03 08:13:57 -0800 | [diff] [blame] | 652 | bool ModuleRtpRtcpImpl::HasBweExtensions() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 653 | return rtp_sender_->IsRtpHeaderExtensionRegistered( |
stefan | 53b6cc3 | 2017-02-03 08:13:57 -0800 | [diff] [blame] | 654 | kRtpExtensionTransportSequenceNumber) || |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 655 | rtp_sender_->IsRtpHeaderExtensionRegistered( |
stefan | 53b6cc3 | 2017-02-03 08:13:57 -0800 | [diff] [blame] | 656 | kRtpExtensionAbsoluteSendTime) || |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 657 | rtp_sender_->IsRtpHeaderExtensionRegistered( |
stefan | 53b6cc3 | 2017-02-03 08:13:57 -0800 | [diff] [blame] | 658 | kRtpExtensionTransmissionTimeOffset); |
| 659 | } |
| 660 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 661 | // (TMMBR) Temporary Max Media Bit Rate. |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 662 | bool ModuleRtpRtcpImpl::TMMBR() const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 663 | return rtcp_sender_.TMMBR(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 664 | } |
| 665 | |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 666 | void ModuleRtpRtcpImpl::SetTMMBRStatus(const bool enable) { |
| 667 | rtcp_sender_.SetTMMBRStatus(enable); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 668 | } |
| 669 | |
danilchap | 853ecb2 | 2016-08-22 08:26:15 -0700 | [diff] [blame] | 670 | void ModuleRtpRtcpImpl::SetTmmbn(std::vector<rtcp::TmmbItem> bounding_set) { |
| 671 | rtcp_sender_.SetTmmbn(std::move(bounding_set)); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 672 | } |
| 673 | |
stefan@webrtc.org | 6a4bef4 | 2011-12-22 12:52:41 +0000 | [diff] [blame] | 674 | // Returns the currently configured retransmission mode. |
| 675 | int ModuleRtpRtcpImpl::SelectiveRetransmissions() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 676 | return rtp_sender_->SelectiveRetransmissions(); |
stefan@webrtc.org | 6a4bef4 | 2011-12-22 12:52:41 +0000 | [diff] [blame] | 677 | } |
| 678 | |
| 679 | // Enable or disable a retransmission mode, which decides which packets will |
| 680 | // be retransmitted if NACKed. |
| 681 | int ModuleRtpRtcpImpl::SetSelectiveRetransmissions(uint8_t settings) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 682 | return rtp_sender_->SetSelectiveRetransmissions(settings); |
stefan@webrtc.org | 6a4bef4 | 2011-12-22 12:52:41 +0000 | [diff] [blame] | 683 | } |
| 684 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 685 | // Send a Negative acknowledgment packet. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 686 | int32_t ModuleRtpRtcpImpl::SendNACK(const uint16_t* nack_list, |
| 687 | const uint16_t size) { |
bcornell | 30409b4 | 2015-07-10 18:10:05 -0700 | [diff] [blame] | 688 | for (int i = 0; i < size; ++i) { |
| 689 | receive_loss_stats_.AddLostPacket(nack_list[i]); |
| 690 | } |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 691 | uint16_t nack_length = size; |
| 692 | uint16_t start_id = 0; |
| 693 | int64_t now = clock_->TimeInMilliseconds(); |
| 694 | if (TimeToSendFullNackList(now)) { |
| 695 | nack_last_time_sent_full_ = now; |
| 696 | nack_last_time_sent_full_prev_ = now; |
| 697 | } else { |
| 698 | // Only send extended list. |
| 699 | if (nack_last_seq_number_sent_ == nack_list[size - 1]) { |
| 700 | // Last sequence number is the same, do not send list. |
| 701 | return 0; |
| 702 | } |
| 703 | // Send new sequence numbers. |
| 704 | for (int i = 0; i < size; ++i) { |
| 705 | if (nack_last_seq_number_sent_ == nack_list[i]) { |
| 706 | start_id = i + 1; |
| 707 | break; |
| 708 | } |
| 709 | } |
| 710 | nack_length = size - start_id; |
| 711 | } |
| 712 | |
| 713 | // Our RTCP NACK implementation is limited to kRtcpMaxNackFields sequence |
| 714 | // numbers per RTCP packet. |
| 715 | if (nack_length > kRtcpMaxNackFields) { |
| 716 | nack_length = kRtcpMaxNackFields; |
| 717 | } |
| 718 | nack_last_seq_number_sent_ = nack_list[start_id + nack_length - 1]; |
| 719 | |
philipel | 83f831a | 2016-03-12 03:30:23 -0800 | [diff] [blame] | 720 | return rtcp_sender_.SendRTCP(GetFeedbackState(), kRtcpNack, nack_length, |
| 721 | &nack_list[start_id]); |
| 722 | } |
| 723 | |
| 724 | void ModuleRtpRtcpImpl::SendNack( |
| 725 | const std::vector<uint16_t>& sequence_numbers) { |
| 726 | rtcp_sender_.SendRTCP(GetFeedbackState(), kRtcpNack, sequence_numbers.size(), |
| 727 | sequence_numbers.data()); |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 728 | } |
| 729 | |
| 730 | bool ModuleRtpRtcpImpl::TimeToSendFullNackList(int64_t now) const { |
asapersson@webrtc.org | e7b1e11 | 2013-12-16 14:40:36 +0000 | [diff] [blame] | 731 | // Use RTT from RtcpRttStats class if provided. |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 732 | int64_t rtt = rtt_ms(); |
asapersson@webrtc.org | e7b1e11 | 2013-12-16 14:40:36 +0000 | [diff] [blame] | 733 | if (rtt == 0) { |
| 734 | rtcp_receiver_.RTT(rtcp_receiver_.RemoteSSRC(), NULL, &rtt, NULL, NULL); |
| 735 | } |
stefan@webrtc.org | 8ca8a71 | 2013-04-23 16:48:32 +0000 | [diff] [blame] | 736 | |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 737 | const int64_t kStartUpRttMs = 100; |
asapersson@webrtc.org | e7b1e11 | 2013-12-16 14:40:36 +0000 | [diff] [blame] | 738 | int64_t wait_time = 5 + ((rtt * 3) >> 1); // 5 + RTT * 1.5. |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 739 | if (rtt == 0) { |
| 740 | wait_time = kStartUpRttMs; |
stefan@webrtc.org | 8ca8a71 | 2013-04-23 16:48:32 +0000 | [diff] [blame] | 741 | } |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 742 | |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 743 | // Send a full NACK list once within every |wait_time|. |
| 744 | if (rtt_stats_) { |
| 745 | return now - nack_last_time_sent_full_ > wait_time; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 746 | } |
asapersson@webrtc.org | ba8138b | 2014-12-08 13:29:02 +0000 | [diff] [blame] | 747 | return now - nack_last_time_sent_full_prev_ > wait_time; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 748 | } |
| 749 | |
asapersson@webrtc.org | 9ffd8fe | 2015-01-21 08:22:50 +0000 | [diff] [blame] | 750 | // Store the sent packets, needed to answer to Negative acknowledgment requests. |
pbos@webrtc.org | d16e839 | 2014-12-19 13:49:55 +0000 | [diff] [blame] | 751 | void ModuleRtpRtcpImpl::SetStorePacketsStatus(const bool enable, |
| 752 | const uint16_t number_to_store) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 753 | rtp_sender_->SetStorePacketsStatus(enable, number_to_store); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 754 | } |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 755 | |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 756 | bool ModuleRtpRtcpImpl::StorePackets() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 757 | return rtp_sender_->StorePackets(); |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 758 | } |
| 759 | |
pbos@webrtc.org | ce4e9a3 | 2014-12-18 13:50:16 +0000 | [diff] [blame] | 760 | void ModuleRtpRtcpImpl::RegisterRtcpStatisticsCallback( |
sprang@webrtc.org | a6ad6e5 | 2013-12-05 09:48:44 +0000 | [diff] [blame] | 761 | RtcpStatisticsCallback* callback) { |
| 762 | rtcp_receiver_.RegisterRtcpStatisticsCallback(callback); |
| 763 | } |
| 764 | |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 765 | RtcpStatisticsCallback* ModuleRtpRtcpImpl::GetRtcpStatisticsCallback() { |
sprang@webrtc.org | a6ad6e5 | 2013-12-05 09:48:44 +0000 | [diff] [blame] | 766 | return rtcp_receiver_.GetRtcpStatisticsCallback(); |
| 767 | } |
| 768 | |
sprang | 233bd87 | 2015-09-08 13:25:16 -0700 | [diff] [blame] | 769 | bool ModuleRtpRtcpImpl::SendFeedbackPacket( |
| 770 | const rtcp::TransportFeedback& packet) { |
| 771 | return rtcp_sender_.SendFeedbackPacket(packet); |
| 772 | } |
| 773 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 774 | // Send a TelephoneEvent tone using RFC 2833 (4733). |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 775 | int32_t ModuleRtpRtcpImpl::SendTelephoneEventOutband( |
| 776 | const uint8_t key, |
| 777 | const uint16_t time_ms, |
| 778 | const uint8_t level) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 779 | return rtp_sender_->SendTelephoneEvent(key, time_ms, level); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 780 | } |
| 781 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 782 | int32_t ModuleRtpRtcpImpl::SetAudioLevel( |
| 783 | const uint8_t level_d_bov) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 784 | return rtp_sender_->SetAudioLevel(level_d_bov); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 785 | } |
| 786 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 787 | int32_t ModuleRtpRtcpImpl::SetKeyFrameRequestMethod( |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 788 | const KeyFrameRequestMethod method) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 789 | key_frame_req_method_ = method; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 790 | return 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 791 | } |
| 792 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 793 | int32_t ModuleRtpRtcpImpl::RequestKeyFrame() { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 794 | switch (key_frame_req_method_) { |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 795 | case kKeyFrameReqPliRtcp: |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 796 | return SendRTCP(kRtcpPli); |
pwestin@webrtc.org | 5e95481 | 2012-02-10 12:13:12 +0000 | [diff] [blame] | 797 | case kKeyFrameReqFirRtcp: |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 798 | return SendRTCP(kRtcpFir); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 799 | } |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 800 | return -1; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 801 | } |
| 802 | |
brandtr | f1bb476 | 2016-11-07 03:05:06 -0800 | [diff] [blame] | 803 | void ModuleRtpRtcpImpl::SetUlpfecConfig(int red_payload_type, |
brandtr | d804895 | 2016-11-07 02:08:51 -0800 | [diff] [blame] | 804 | int ulpfec_payload_type) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 805 | rtp_sender_->SetUlpfecConfig(red_payload_type, ulpfec_payload_type); |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 806 | } |
| 807 | |
brandtr | 1743a19 | 2016-11-07 03:36:05 -0800 | [diff] [blame] | 808 | bool ModuleRtpRtcpImpl::SetFecParameters( |
| 809 | const FecProtectionParams& delta_params, |
| 810 | const FecProtectionParams& key_params) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 811 | return rtp_sender_->SetFecParameters(delta_params, key_params); |
marpan@google.com | 80c5d7a | 2011-07-15 21:32:40 +0000 | [diff] [blame] | 812 | } |
| 813 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 814 | void ModuleRtpRtcpImpl::SetRemoteSSRC(const uint32_t ssrc) { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 815 | // Inform about the incoming SSRC. |
| 816 | rtcp_sender_.SetRemoteSSRC(ssrc); |
| 817 | rtcp_receiver_.SetRemoteSSRC(ssrc); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 818 | } |
| 819 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 820 | void ModuleRtpRtcpImpl::BitrateSent(uint32_t* total_rate, |
| 821 | uint32_t* video_rate, |
| 822 | uint32_t* fec_rate, |
| 823 | uint32_t* nack_rate) const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 824 | *total_rate = rtp_sender_->BitrateSent(); |
| 825 | *video_rate = rtp_sender_->VideoBitrateSent(); |
| 826 | *fec_rate = rtp_sender_->FecOverheadRate(); |
| 827 | *nack_rate = rtp_sender_->NackOverheadRate(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 828 | } |
| 829 | |
pwestin@webrtc.org | 1da1ce0 | 2011-10-13 15:19:55 +0000 | [diff] [blame] | 830 | void ModuleRtpRtcpImpl::OnRequestSendReport() { |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 831 | SendRTCP(kRtcpSr); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 832 | } |
| 833 | |
Danil Chapovalov | 2800d74 | 2016-08-26 18:48:46 +0200 | [diff] [blame] | 834 | void ModuleRtpRtcpImpl::OnReceivedNack( |
| 835 | const std::vector<uint16_t>& nack_sequence_numbers) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 836 | if (!rtp_sender_) |
| 837 | return; |
| 838 | |
bcornell | 30409b4 | 2015-07-10 18:10:05 -0700 | [diff] [blame] | 839 | for (uint16_t nack_sequence_number : nack_sequence_numbers) { |
| 840 | send_loss_stats_.AddLostPacket(nack_sequence_number); |
| 841 | } |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 842 | if (!rtp_sender_->StorePackets() || |
stefan@webrtc.org | becf9c8 | 2013-02-01 15:09:57 +0000 | [diff] [blame] | 843 | nack_sequence_numbers.size() == 0) { |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 844 | return; |
| 845 | } |
asapersson@webrtc.org | e7b1e11 | 2013-12-16 14:40:36 +0000 | [diff] [blame] | 846 | // Use RTT from RtcpRttStats class if provided. |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 847 | int64_t rtt = rtt_ms(); |
asapersson@webrtc.org | e7b1e11 | 2013-12-16 14:40:36 +0000 | [diff] [blame] | 848 | if (rtt == 0) { |
| 849 | rtcp_receiver_.RTT(rtcp_receiver_.RemoteSSRC(), NULL, &rtt, NULL, NULL); |
| 850 | } |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 851 | rtp_sender_->OnReceivedNack(nack_sequence_numbers, rtt); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 852 | } |
| 853 | |
isheriff | 6b4b5f3 | 2016-06-08 00:24:21 -0700 | [diff] [blame] | 854 | void ModuleRtpRtcpImpl::OnReceivedRtcpReportBlocks( |
| 855 | const ReportBlockList& report_blocks) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 856 | if (rtp_sender_) |
| 857 | rtp_sender_->OnReceivedRtcpReportBlocks(report_blocks); |
isheriff | 6b4b5f3 | 2016-06-08 00:24:21 -0700 | [diff] [blame] | 858 | } |
| 859 | |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 860 | bool ModuleRtpRtcpImpl::LastReceivedNTP( |
| 861 | uint32_t* rtcp_arrival_time_secs, // When we got the last report. |
| 862 | uint32_t* rtcp_arrival_time_frac, |
| 863 | uint32_t* remote_sr) const { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 864 | // Remote SR: NTP inside the last received (mid 16 bits from sec and frac). |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 865 | uint32_t ntp_secs = 0; |
| 866 | uint32_t ntp_frac = 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 867 | |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 868 | if (!rtcp_receiver_.NTP(&ntp_secs, |
| 869 | &ntp_frac, |
| 870 | rtcp_arrival_time_secs, |
| 871 | rtcp_arrival_time_frac, |
| 872 | NULL)) { |
| 873 | return false; |
henrike@webrtc.org | d5657c2 | 2012-02-08 23:41:49 +0000 | [diff] [blame] | 874 | } |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 875 | *remote_sr = |
| 876 | ((ntp_secs & 0x0000ffff) << 16) + ((ntp_frac & 0xffff0000) >> 16); |
| 877 | return true; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 878 | } |
| 879 | |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 880 | // Called from RTCPsender. |
danilchap | 2b61639 | 2016-08-18 06:17:42 -0700 | [diff] [blame] | 881 | std::vector<rtcp::TmmbItem> ModuleRtpRtcpImpl::BoundingSet(bool* tmmbr_owner) { |
| 882 | return rtcp_receiver_.BoundingSet(tmmbr_owner); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 883 | } |
mflodman@webrtc.org | 2f225ca | 2013-01-09 13:54:43 +0000 | [diff] [blame] | 884 | |
| 885 | int64_t ModuleRtpRtcpImpl::RtcpReportInterval() { |
phoglund@webrtc.org | acfdd96 | 2013-01-16 10:27:33 +0000 | [diff] [blame] | 886 | if (audio_) |
mflodman@webrtc.org | 2f225ca | 2013-01-09 13:54:43 +0000 | [diff] [blame] | 887 | return RTCP_INTERVAL_AUDIO_MS; |
| 888 | else |
| 889 | return RTCP_INTERVAL_VIDEO_MS; |
| 890 | } |
stefan@webrtc.org | 28a331e | 2013-09-17 07:49:56 +0000 | [diff] [blame] | 891 | |
| 892 | void ModuleRtpRtcpImpl::SetRtcpReceiverSsrcs(uint32_t main_ssrc) { |
| 893 | std::set<uint32_t> ssrcs; |
| 894 | ssrcs.insert(main_ssrc); |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 895 | if (RtxSendStatus() != kRtxOff) |
| 896 | ssrcs.insert(rtp_sender_->RtxSsrc()); |
brandtr | 7c7796b | 2017-07-03 06:02:53 -0700 | [diff] [blame] | 897 | rtc::Optional<uint32_t> flexfec_ssrc = FlexfecSsrc(); |
| 898 | if (flexfec_ssrc) |
| 899 | ssrcs.insert(*flexfec_ssrc); |
stefan@webrtc.org | 28a331e | 2013-09-17 07:49:56 +0000 | [diff] [blame] | 900 | rtcp_receiver_.SetSsrcs(main_ssrc, ssrcs); |
| 901 | } |
| 902 | |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 903 | void ModuleRtpRtcpImpl::set_rtt_ms(int64_t rtt_ms) { |
danilchap | 7c9426c | 2016-04-14 03:05:31 -0700 | [diff] [blame] | 904 | rtc::CritScope cs(&critical_section_rtt_); |
asapersson@webrtc.org | 1ae1d0c | 2013-11-20 12:46:11 +0000 | [diff] [blame] | 905 | rtt_ms_ = rtt_ms; |
| 906 | } |
| 907 | |
pkasting@chromium.org | 16825b1 | 2015-01-12 21:51:21 +0000 | [diff] [blame] | 908 | int64_t ModuleRtpRtcpImpl::rtt_ms() const { |
danilchap | 7c9426c | 2016-04-14 03:05:31 -0700 | [diff] [blame] | 909 | rtc::CritScope cs(&critical_section_rtt_); |
asapersson@webrtc.org | 1ae1d0c | 2013-11-20 12:46:11 +0000 | [diff] [blame] | 910 | return rtt_ms_; |
| 911 | } |
| 912 | |
sprang@webrtc.org | ebad765 | 2013-12-05 14:29:02 +0000 | [diff] [blame] | 913 | void ModuleRtpRtcpImpl::RegisterSendChannelRtpStatisticsCallback( |
| 914 | StreamDataCountersCallback* callback) { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 915 | rtp_sender_->RegisterRtpStatisticsCallback(callback); |
sprang@webrtc.org | ebad765 | 2013-12-05 14:29:02 +0000 | [diff] [blame] | 916 | } |
| 917 | |
| 918 | StreamDataCountersCallback* |
| 919 | ModuleRtpRtcpImpl::GetSendChannelRtpStatisticsCallback() const { |
nisse | 14adba7 | 2017-03-20 03:52:39 -0700 | [diff] [blame] | 920 | return rtp_sender_->GetRtpStatisticsCallback(); |
sprang@webrtc.org | ebad765 | 2013-12-05 14:29:02 +0000 | [diff] [blame] | 921 | } |
sprang | 5e38c96 | 2016-12-01 05:18:09 -0800 | [diff] [blame] | 922 | |
| 923 | void ModuleRtpRtcpImpl::SetVideoBitrateAllocation( |
| 924 | const BitrateAllocation& bitrate) { |
| 925 | rtcp_sender_.SetVideoBitrateAllocation(bitrate); |
| 926 | } |
mflodman@webrtc.org | 02270cd | 2015-02-06 13:10:19 +0000 | [diff] [blame] | 927 | } // namespace webrtc |