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

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

Issue 2000063003: Update the BWE when the network route changes. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc@master
Patch Set: Created 4 years, 7 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/congestion_controller.cc
diff --git a/webrtc/modules/congestion_controller/congestion_controller.cc b/webrtc/modules/congestion_controller/congestion_controller.cc
index 5767448a5f7bf711a24ef214ea47d5f5cac18f20..4e88fe634a37e808789e5b5171c0ae24f0dc1d09 100644
--- a/webrtc/modules/congestion_controller/congestion_controller.cc
+++ b/webrtc/modules/congestion_controller/congestion_controller.cc
@@ -32,6 +32,22 @@ namespace {
static const uint32_t kTimeOffsetSwitchThreshold = 30;
+// Makes sure that the bitrate and the min, max values are in valid range.
+static void ClampBitrates(int* bitrate_bps,
+ int* min_bitrate_bps,
+ int* max_bitrate_bps) {
+ // TODO(holmer): We should make sure the default bitrates are set to 10 kbps,
+ // and that we don't try to set the min bitrate to 0 from any applications.
+ // The congestion controller should allow a min bitrate of 0.
+ const int kMinBitrateBps = 10000;
+ if (*min_bitrate_bps < kMinBitrateBps)
+ *min_bitrate_bps = kMinBitrateBps;
+ if (*max_bitrate_bps > 0)
+ *max_bitrate_bps = std::max(*min_bitrate_bps, *max_bitrate_bps);
+ if (*bitrate_bps > 0)
+ *bitrate_bps = std::max(*min_bitrate_bps, *bitrate_bps);
+}
+
class WrappingBitrateEstimator : public RemoteBitrateEstimator {
public:
WrappingBitrateEstimator(RemoteBitrateObserver* observer, Clock* clock)
@@ -212,21 +228,10 @@ void CongestionController::Init() {
min_bitrate_bps_);
}
-
void CongestionController::SetBweBitrates(int min_bitrate_bps,
int start_bitrate_bps,
int max_bitrate_bps) {
- // TODO(holmer): We should make sure the default bitrates are set to 10 kbps,
- // and that we don't try to set the min bitrate to 0 from any applications.
- // The congestion controller should allow a min bitrate of 0.
- const int kMinBitrateBps = 10000;
- if (min_bitrate_bps < kMinBitrateBps)
- min_bitrate_bps = kMinBitrateBps;
- if (max_bitrate_bps > 0)
- max_bitrate_bps = std::max(min_bitrate_bps, max_bitrate_bps);
- if (start_bitrate_bps > 0)
- start_bitrate_bps = std::max(min_bitrate_bps, start_bitrate_bps);
-
+ ClampBitrates(&start_bitrate_bps, &min_bitrate_bps, &max_bitrate_bps);
bitrate_controller_->SetBitrates(start_bitrate_bps,
min_bitrate_bps,
max_bitrate_bps);
@@ -239,6 +244,24 @@ void CongestionController::SetBweBitrates(int min_bitrate_bps,
MaybeTriggerOnNetworkChanged();
}
+void CongestionController::ResetBweAndBitrates(int bitrate_bps,
+ int min_bitrate_bps,
+ int max_bitrate_bps) {
+ ClampBitrates(&bitrate_bps, &min_bitrate_bps, &max_bitrate_bps);
+ bitrate_controller_->ResetBitrates(bitrate_bps, min_bitrate_bps,
stefan-webrtc 2016/05/31 17:27:49 I wonder if we instead should simply recreate the
honghaiz3 2016/06/01 02:17:34 No we cannot because some of the objects in conges
stefan-webrtc 2016/06/01 07:38:36 I was referring to bitrate_controller_ and not con
honghaiz3 2016/06/01 16:54:10 Ah sorry that I mis-read it. It had similar issue
+ max_bitrate_bps);
+ min_bitrate_bps_ = min_bitrate_bps;
+ if (remote_bitrate_estimator_)
+ remote_bitrate_estimator_->SetMinBitrate(min_bitrate_bps);
stefan-webrtc 2016/05/31 17:27:49 Here too, shouldn't we recreate this object as wel
honghaiz3 2016/06/01 02:17:34 Cannot for the same reason. It was used by the vi
stefan-webrtc 2016/06/01 07:38:36 I see, could you add a TODO which says "Recreate t
honghaiz3 2016/06/01 16:54:10 Done.
+
+ RemoteBitrateEstimator* rbe =
+ new RemoteBitrateEstimatorAbsSendTime(&transport_feedback_adapter_);
+ transport_feedback_adapter_.SetBitrateEstimator(rbe);
+ rbe->SetMinBitrate(min_bitrate_bps);
+ // TODO(holmer): Trigger a new probe once mid-call probing is implemented.
+ MaybeTriggerOnNetworkChanged();
+}
+
BitrateController* CongestionController::GetBitrateController() const {
return bitrate_controller_.get();
}

Powered by Google App Engine
This is Rietveld 408576698