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

Unified Diff: webrtc/call/call.cc

Issue 1803063004: Reset the BWE when the network changes (Closed) Base URL: https://chromium.googlesource.com/external/webrtc@master
Patch Set: Created 4 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/call/call.cc
diff --git a/webrtc/call/call.cc b/webrtc/call/call.cc
index 3fd7a931d0cecc88cff0b30a47557db5a21ed586..5fb54875c5901a9a6be69a0a4ef9af1c5150ea2b 100644
--- a/webrtc/call/call.cc
+++ b/webrtc/call/call.cc
@@ -88,6 +88,8 @@ class Call : public webrtc::Call, public PacketReceiver,
const webrtc::Call::Config::BitrateConfig& bitrate_config) override;
void SignalNetworkState(NetworkState state) override;
+ void OnNetworkChanged(int local_net_id, int remote_net_id) override;
+
void OnSentPacket(const rtc::SentPacket& sent_packet) override;
// Implements BitrateObserver.
@@ -101,7 +103,7 @@ class Call : public webrtc::Call, public PacketReceiver,
const uint8_t* packet,
size_t length,
const PacketTime& packet_time);
-
+ void ResetBweBitrates();
void ConfigureSync(const std::string& sync_group)
EXCLUSIVE_LOCKS_REQUIRED(receive_crit_);
@@ -167,6 +169,9 @@ class Call : public webrtc::Call, public PacketReceiver,
int64_t pacer_bitrate_sum_kbits_ GUARDED_BY(&bitrate_crit_);
int64_t num_bitrate_updates_ GUARDED_BY(&bitrate_crit_);
+ int local_network_id_ = 0;
+ int remote_network_id_ = 0;
pthatcher1 2016/03/16 21:22:03 If the signal has both old and new route infos, we
honghaiz3 2016/03/17 03:38:27 Keep this as we have discussed.
+
VieRemb remb_;
const std::unique_ptr<CongestionController> congestion_controller_;
@@ -570,6 +575,30 @@ void Call::SignalNetworkState(NetworkState state) {
}
}
+void Call::OnNetworkChanged(int local_net_id, int remote_net_id) {
+ RTC_DCHECK(configuration_thread_checker_.CalledOnValidThread());
+ // Reset the BWE estimate when network changes.
+ // Check if the network has actually changed.
+ if (local_net_id == local_network_id_ &&
+ remote_net_id == remote_network_id_) {
pthatcher1 2016/03/16 21:22:03 If we use NetworkRoute structs, we should also che
honghaiz3 2016/03/17 03:38:27 We can now use the null pointer for best connectio
+ return;
+ }
+ LOG(LS_INFO) << "Network changed: new local network id " << local_net_id
+ << " new remote network id " << remote_net_id;
+ local_network_id_ = local_net_id;
+ remote_network_id_ = remote_net_id;
+ ResetBweBitrates();
+}
+
+void Call::ResetBweBitrates() {
pthatcher1 2016/03/16 21:22:03 If !new_route.connected, we probably want to do so
honghaiz3 2016/03/17 03:38:27 Done. Add TODO.
+ LOG(LS_INFO) << "Reset BWE estimate to "
+ << config_.bitrate_config.start_bitrate_bps << "bps";
+ congestion_controller_->SetBweBitrates(
+ config_.bitrate_config.min_bitrate_bps,
+ config_.bitrate_config.start_bitrate_bps,
+ config_.bitrate_config.max_bitrate_bps);
pthatcher1 2016/03/16 21:22:03 Does this really restart the BWE?
honghaiz3 2016/03/17 03:38:27 Actually It may not. Maybe we can leave this to BW
+}
+
void Call::OnSentPacket(const rtc::SentPacket& sent_packet) {
if (first_packet_sent_ms_ == -1)
first_packet_sent_ms_ = clock_->TimeInMilliseconds();

Powered by Google App Engine
This is Rietveld 408576698