Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1396)

Unified Diff: webrtc/modules/congestion_controller/transport_feedback_adapter.cc

Issue 2743553003: Revert of Move delay_based_bwe_ into CongestionController (Closed)
Patch Set: Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/modules/congestion_controller/transport_feedback_adapter.cc
diff --git a/webrtc/modules/congestion_controller/transport_feedback_adapter.cc b/webrtc/modules/congestion_controller/transport_feedback_adapter.cc
index 3d1601cff85ca9cd7c8525865a96641158096d0f..d158eb97a116b4a0d36d80df638450b41e55ad3d 100644
--- a/webrtc/modules/congestion_controller/transport_feedback_adapter.cc
+++ b/webrtc/modules/congestion_controller/transport_feedback_adapter.cc
@@ -10,11 +10,17 @@
#include "webrtc/modules/congestion_controller/transport_feedback_adapter.h"
+#include <algorithm>
+#include <limits>
+
#include "webrtc/base/checks.h"
#include "webrtc/base/logging.h"
#include "webrtc/base/mod_ops.h"
+#include "webrtc/logging/rtc_event_log/rtc_event_log.h"
+#include "webrtc/modules/bitrate_controller/include/bitrate_controller.h"
#include "webrtc/modules/congestion_controller/delay_based_bwe.h"
#include "webrtc/modules/rtp_rtcp/source/rtcp_packet/transport_feedback.h"
+#include "webrtc/modules/utility/include/process_thread.h"
#include "webrtc/system_wrappers/include/field_trial.h"
namespace webrtc {
@@ -25,16 +31,26 @@
rtcp::TransportFeedback::kDeltaScaleFactor * (1 << 8);
const int64_t kBaseTimestampRangeSizeUs = kBaseTimestampScaleFactor * (1 << 24);
-TransportFeedbackAdapter::TransportFeedbackAdapter(Clock* clock)
+TransportFeedbackAdapter::TransportFeedbackAdapter(
+ RtcEventLog* event_log,
+ Clock* clock,
+ BitrateController* bitrate_controller)
: send_side_bwe_with_overhead_(
webrtc::field_trial::IsEnabled("WebRTC-SendSideBwe-WithOverhead")),
transport_overhead_bytes_per_packet_(0),
send_time_history_(clock, kSendTimeHistoryWindowMs),
+ event_log_(event_log),
clock_(clock),
current_offset_ms_(kNoTimestamp),
- last_timestamp_us_(kNoTimestamp) {}
+ last_timestamp_us_(kNoTimestamp),
+ bitrate_controller_(bitrate_controller) {}
TransportFeedbackAdapter::~TransportFeedbackAdapter() {}
+
+void TransportFeedbackAdapter::InitBwe() {
+ rtc::CritScope cs(&bwe_lock_);
+ delay_based_bwe_.reset(new DelayBasedBwe(event_log_, clock_));
+}
void TransportFeedbackAdapter::AddPacket(uint16_t sequence_number,
size_t length,
@@ -52,10 +68,25 @@
send_time_history_.OnSentPacket(sequence_number, send_time_ms);
}
+void TransportFeedbackAdapter::SetStartBitrate(int start_bitrate_bps) {
+ rtc::CritScope cs(&bwe_lock_);
+ delay_based_bwe_->SetStartBitrate(start_bitrate_bps);
+}
+
+void TransportFeedbackAdapter::SetMinBitrate(int min_bitrate_bps) {
+ rtc::CritScope cs(&bwe_lock_);
+ delay_based_bwe_->SetMinBitrate(min_bitrate_bps);
+}
+
void TransportFeedbackAdapter::SetTransportOverhead(
int transport_overhead_bytes_per_packet) {
rtc::CritScope cs(&lock_);
transport_overhead_bytes_per_packet_ = transport_overhead_bytes_per_packet;
+}
+
+int64_t TransportFeedbackAdapter::GetProbingIntervalMs() const {
+ rtc::CritScope cs(&bwe_lock_);
+ return delay_based_bwe_->GetProbingIntervalMs();
}
void TransportFeedbackAdapter::ClearSendTimeHistory() {
@@ -141,10 +172,25 @@
void TransportFeedbackAdapter::OnTransportFeedback(
const rtcp::TransportFeedback& feedback) {
last_packet_feedback_vector_ = GetPacketFeedbackVector(feedback);
+ DelayBasedBwe::Result result;
+ {
+ rtc::CritScope cs(&bwe_lock_);
+ result = delay_based_bwe_->IncomingPacketFeedbackVector(
+ last_packet_feedback_vector_);
+ }
+ if (result.updated)
+ bitrate_controller_->OnDelayBasedBweResult(result);
}
std::vector<PacketFeedback>
TransportFeedbackAdapter::GetTransportFeedbackVector() const {
return last_packet_feedback_vector_;
}
+
+void TransportFeedbackAdapter::OnRttUpdate(int64_t avg_rtt_ms,
+ int64_t max_rtt_ms) {
+ rtc::CritScope cs(&bwe_lock_);
+ delay_based_bwe_->OnRttUpdate(avg_rtt_ms, max_rtt_ms);
+}
+
} // namespace webrtc

Powered by Google App Engine
This is Rietveld 408576698