Revert "Moved congestion controller to task queue."
This reverts commit 0cbcba7ea0dced1a7f353c64d6cf91d46ccb29f9. Reason for revert: Major regressions on perf bots. Original change's description: > Moved congestion controller to task queue. > > The goal of this work is to make it easier to experiment with the > bandwidth estimation implementation. For this reason network control > functionality is moved from SendSideCongestionController(SSCC), > PacedSender and BitrateController to the newly created > GoogCcNetworkController which implements the newly created > NetworkControllerInterface. This allows the implementation to be > replaced at runtime in the future. > > This is the first part of a split of a larger CL, see: > https://webrtc-review.googlesource.com/c/src/+/39788/8 > For further explanations. > > Bug: webrtc:8415 > Change-Id: I770189c04cc31b313bd4e57821acff55fbcb1ad3 > Reviewed-on: https://webrtc-review.googlesource.com/43840 > Commit-Queue: Sebastian Jansson <srte@webrtc.org> > Reviewed-by: Björn Terelius <terelius@webrtc.org> > Reviewed-by: Stefan Holmer <stefan@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#21868} TBR=terelius@webrtc.org,stefan@webrtc.org,srte@webrtc.org Change-Id: Ia8a273eb9e92b7d0d960c49658c228208170962d No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: webrtc:8415 Reviewed-on: https://webrtc-review.googlesource.com/47560 Reviewed-by: Sebastian Jansson <srte@webrtc.org> Commit-Queue: Sebastian Jansson <srte@webrtc.org> Cr-Commit-Position: refs/heads/master@{#21877}
This commit is contained in:
committed by
Commit Bot
parent
c5017136c7
commit
5a503b05e1
@ -340,11 +340,11 @@ TEST_F(BitrateControllerTest, OneBitrateObserverMultipleReportBlocks) {
|
||||
report_blocks.clear();
|
||||
|
||||
// All packets lost on stream with few packets, no back-off.
|
||||
report_blocks.push_back(CreateReportBlock(1, 2, 0, sequence_number[0]));
|
||||
report_blocks.push_back(CreateReportBlock(1, 2, 1, sequence_number[0]));
|
||||
report_blocks.push_back(CreateReportBlock(1, 3, 255, sequence_number[1]));
|
||||
bandwidth_observer_->OnReceivedRtcpReceiverReport(report_blocks, 50, time_ms);
|
||||
EXPECT_EQ(bitrate_observer_.last_bitrate_, last_bitrate);
|
||||
EXPECT_EQ(WeightedLoss(20, 0, 1, 255), bitrate_observer_.last_fraction_loss_);
|
||||
EXPECT_EQ(WeightedLoss(20, 1, 1, 255), bitrate_observer_.last_fraction_loss_);
|
||||
EXPECT_EQ(50, bitrate_observer_.last_rtt_);
|
||||
last_bitrate = bitrate_observer_.last_bitrate_;
|
||||
sequence_number[0] += 20;
|
||||
|
||||
@ -105,7 +105,7 @@ bool ReadBweLossExperimentParameters(float* low_loss_threshold,
|
||||
} // namespace
|
||||
|
||||
SendSideBandwidthEstimation::SendSideBandwidthEstimation(RtcEventLog* event_log)
|
||||
: lost_packets_since_last_loss_update_(0),
|
||||
: lost_packets_since_last_loss_update_Q8_(0),
|
||||
expected_packets_since_last_loss_update_(0),
|
||||
current_bitrate_bps_(0),
|
||||
min_bitrate_configured_(congestion_controller::GetMinBitrateBps()),
|
||||
@ -125,7 +125,6 @@ SendSideBandwidthEstimation::SendSideBandwidthEstimation(RtcEventLog* event_log)
|
||||
initially_lost_packets_(0),
|
||||
bitrate_at_2_seconds_kbps_(0),
|
||||
uma_update_state_(kNoUpdate),
|
||||
uma_rtt_state_(kNoUpdate),
|
||||
rampup_uma_stats_updated_(kNumUmaRampupMetrics, false),
|
||||
event_log_(event_log),
|
||||
last_rtc_event_log_ms_(-1),
|
||||
@ -207,28 +206,24 @@ void SendSideBandwidthEstimation::UpdateDelayBasedEstimate(
|
||||
}
|
||||
|
||||
void SendSideBandwidthEstimation::UpdateReceiverBlock(uint8_t fraction_loss,
|
||||
int64_t rtt_ms,
|
||||
int64_t rtt,
|
||||
int number_of_packets,
|
||||
int64_t now_ms) {
|
||||
const int kRoundingConstant = 128;
|
||||
int packets_lost = (static_cast<int>(fraction_loss) * number_of_packets +
|
||||
kRoundingConstant) >>
|
||||
8;
|
||||
UpdatePacketsLost(packets_lost, number_of_packets, now_ms);
|
||||
UpdateRtt(rtt_ms, now_ms);
|
||||
}
|
||||
|
||||
void SendSideBandwidthEstimation::UpdatePacketsLost(int packets_lost,
|
||||
int number_of_packets,
|
||||
int64_t now_ms) {
|
||||
last_feedback_ms_ = now_ms;
|
||||
if (first_report_time_ms_ == -1)
|
||||
first_report_time_ms_ = now_ms;
|
||||
|
||||
// Update RTT if we were able to compute an RTT based on this RTCP.
|
||||
// FlexFEC doesn't send RTCP SR, which means we won't be able to compute RTT.
|
||||
if (rtt > 0)
|
||||
last_round_trip_time_ms_ = rtt;
|
||||
|
||||
// Check sequence number diff and weight loss report
|
||||
if (number_of_packets > 0) {
|
||||
// Calculate number of lost packets.
|
||||
const int num_lost_packets_Q8 = fraction_loss * number_of_packets;
|
||||
// Accumulate reports.
|
||||
lost_packets_since_last_loss_update_ += packets_lost;
|
||||
lost_packets_since_last_loss_update_Q8_ += num_lost_packets_Q8;
|
||||
expected_packets_since_last_loss_update_ += number_of_packets;
|
||||
|
||||
// Don't generate a loss rate until it can be based on enough packets.
|
||||
@ -236,22 +231,21 @@ void SendSideBandwidthEstimation::UpdatePacketsLost(int packets_lost,
|
||||
return;
|
||||
|
||||
has_decreased_since_last_fraction_loss_ = false;
|
||||
int64_t lost_q8 = lost_packets_since_last_loss_update_ << 8;
|
||||
int64_t expected = expected_packets_since_last_loss_update_;
|
||||
last_fraction_loss_ = std::min<int>(lost_q8 / expected, 255);
|
||||
last_fraction_loss_ = lost_packets_since_last_loss_update_Q8_ /
|
||||
expected_packets_since_last_loss_update_;
|
||||
|
||||
// Reset accumulators.
|
||||
|
||||
lost_packets_since_last_loss_update_ = 0;
|
||||
lost_packets_since_last_loss_update_Q8_ = 0;
|
||||
expected_packets_since_last_loss_update_ = 0;
|
||||
last_packet_report_ms_ = now_ms;
|
||||
UpdateEstimate(now_ms);
|
||||
}
|
||||
UpdateUmaStatsPacketsLost(now_ms, packets_lost);
|
||||
UpdateUmaStats(now_ms, rtt, (fraction_loss * number_of_packets) >> 8);
|
||||
}
|
||||
|
||||
void SendSideBandwidthEstimation::UpdateUmaStatsPacketsLost(int64_t now_ms,
|
||||
int packets_lost) {
|
||||
void SendSideBandwidthEstimation::UpdateUmaStats(int64_t now_ms,
|
||||
int64_t rtt,
|
||||
int lost_packets) {
|
||||
int bitrate_kbps = static_cast<int>((current_bitrate_bps_ + 500) / 1000);
|
||||
for (size_t i = 0; i < kNumUmaRampupMetrics; ++i) {
|
||||
if (!rampup_uma_stats_updated_[i] &&
|
||||
@ -262,12 +256,14 @@ void SendSideBandwidthEstimation::UpdateUmaStatsPacketsLost(int64_t now_ms,
|
||||
}
|
||||
}
|
||||
if (IsInStartPhase(now_ms)) {
|
||||
initially_lost_packets_ += packets_lost;
|
||||
initially_lost_packets_ += lost_packets;
|
||||
} else if (uma_update_state_ == kNoUpdate) {
|
||||
uma_update_state_ = kFirstDone;
|
||||
bitrate_at_2_seconds_kbps_ = bitrate_kbps;
|
||||
RTC_HISTOGRAM_COUNTS("WebRTC.BWE.InitiallyLostPackets",
|
||||
initially_lost_packets_, 0, 100, 50);
|
||||
RTC_HISTOGRAM_COUNTS("WebRTC.BWE.InitialRtt", static_cast<int>(rtt), 0,
|
||||
2000, 50);
|
||||
RTC_HISTOGRAM_COUNTS("WebRTC.BWE.InitialBandwidthEstimate",
|
||||
bitrate_at_2_seconds_kbps_, 0, 2000, 50);
|
||||
} else if (uma_update_state_ == kFirstDone &&
|
||||
@ -280,19 +276,6 @@ void SendSideBandwidthEstimation::UpdateUmaStatsPacketsLost(int64_t now_ms,
|
||||
}
|
||||
}
|
||||
|
||||
void SendSideBandwidthEstimation::UpdateRtt(int64_t rtt_ms, int64_t now_ms) {
|
||||
// Update RTT if we were able to compute an RTT based on this RTCP.
|
||||
// FlexFEC doesn't send RTCP SR, which means we won't be able to compute RTT.
|
||||
if (rtt_ms > 0)
|
||||
last_round_trip_time_ms_ = rtt_ms;
|
||||
|
||||
if (!IsInStartPhase(now_ms) && uma_rtt_state_ == kNoUpdate) {
|
||||
uma_rtt_state_ = kDone;
|
||||
RTC_HISTOGRAM_COUNTS("WebRTC.BWE.InitialRtt", static_cast<int>(rtt_ms), 0,
|
||||
2000, 50);
|
||||
}
|
||||
}
|
||||
|
||||
void SendSideBandwidthEstimation::UpdateEstimate(int64_t now_ms) {
|
||||
uint32_t new_bitrate = current_bitrate_bps_;
|
||||
// We trust the REMB and/or delay-based estimate during the first 2 seconds if
|
||||
@ -374,7 +357,7 @@ void SendSideBandwidthEstimation::UpdateEstimate(int64_t now_ms) {
|
||||
new_bitrate *= 0.8;
|
||||
// Reset accumulators since we've already acted on missing feedback and
|
||||
// shouldn't to act again on these old lost packets.
|
||||
lost_packets_since_last_loss_update_ = 0;
|
||||
lost_packets_since_last_loss_update_Q8_ = 0;
|
||||
expected_packets_since_last_loss_update_ = 0;
|
||||
last_timeout_ms_ = now_ms;
|
||||
}
|
||||
|
||||
@ -42,18 +42,10 @@ class SendSideBandwidthEstimation {
|
||||
|
||||
// Call when we receive a RTCP message with a ReceiveBlock.
|
||||
void UpdateReceiverBlock(uint8_t fraction_loss,
|
||||
int64_t rtt_ms,
|
||||
int64_t rtt,
|
||||
int number_of_packets,
|
||||
int64_t now_ms);
|
||||
|
||||
// Call when we receive a RTCP message with a ReceiveBlock.
|
||||
void UpdatePacketsLost(int packets_lost,
|
||||
int number_of_packets,
|
||||
int64_t now_ms);
|
||||
|
||||
// Call when we receive a RTCP message with a ReceiveBlock.
|
||||
void UpdateRtt(int64_t rtt, int64_t now_ms);
|
||||
|
||||
void SetBitrates(int send_bitrate,
|
||||
int min_bitrate,
|
||||
int max_bitrate);
|
||||
@ -66,7 +58,7 @@ class SendSideBandwidthEstimation {
|
||||
|
||||
bool IsInStartPhase(int64_t now_ms) const;
|
||||
|
||||
void UpdateUmaStatsPacketsLost(int64_t now_ms, int packets_lost);
|
||||
void UpdateUmaStats(int64_t now_ms, int64_t rtt, int lost_packets);
|
||||
|
||||
// Updates history of min bitrates.
|
||||
// After this method returns min_bitrate_history_.front().second contains the
|
||||
@ -80,7 +72,7 @@ class SendSideBandwidthEstimation {
|
||||
std::deque<std::pair<int64_t, uint32_t> > min_bitrate_history_;
|
||||
|
||||
// incoming filters
|
||||
int lost_packets_since_last_loss_update_;
|
||||
int lost_packets_since_last_loss_update_Q8_;
|
||||
int expected_packets_since_last_loss_update_;
|
||||
|
||||
uint32_t current_bitrate_bps_;
|
||||
@ -103,7 +95,6 @@ class SendSideBandwidthEstimation {
|
||||
int initially_lost_packets_;
|
||||
int bitrate_at_2_seconds_kbps_;
|
||||
UmaState uma_update_state_;
|
||||
UmaState uma_rtt_state_;
|
||||
std::vector<bool> rampup_uma_stats_updated_;
|
||||
RtcEventLog* event_log_;
|
||||
int64_t last_rtc_event_log_ms_;
|
||||
|
||||
Reference in New Issue
Block a user