| 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 7780024a8684ab200860ae21c8791611a9239b35..ddffa7219692be1580bb64046779a245bcdb3c79 100644
|
| --- a/webrtc/modules/congestion_controller/transport_feedback_adapter.cc
|
| +++ b/webrtc/modules/congestion_controller/transport_feedback_adapter.cc
|
| @@ -32,7 +32,9 @@ TransportFeedbackAdapter::TransportFeedbackAdapter(const Clock* clock)
|
| send_time_history_(clock, kSendTimeHistoryWindowMs),
|
| clock_(clock),
|
| current_offset_ms_(kNoTimestamp),
|
| - last_timestamp_us_(kNoTimestamp) {}
|
| + last_timestamp_us_(kNoTimestamp),
|
| + local_net_id_(0),
|
| + remote_net_id_(0) {}
|
|
|
| TransportFeedbackAdapter::~TransportFeedbackAdapter() {}
|
|
|
| @@ -43,7 +45,10 @@ void TransportFeedbackAdapter::AddPacket(uint16_t sequence_number,
|
| if (send_side_bwe_with_overhead_) {
|
| length += transport_overhead_bytes_per_packet_;
|
| }
|
| - send_time_history_.AddAndRemoveOld(sequence_number, length, pacing_info);
|
| + const int64_t creation_time_ms = clock_->TimeInMilliseconds();
|
| + send_time_history_.AddAndRemoveOld(
|
| + PacketFeedback(creation_time_ms, sequence_number, length, local_net_id_,
|
| + remote_net_id_, pacing_info));
|
| }
|
|
|
| void TransportFeedbackAdapter::OnSentPacket(uint16_t sequence_number,
|
| @@ -58,9 +63,11 @@ void TransportFeedbackAdapter::SetTransportOverhead(
|
| transport_overhead_bytes_per_packet_ = transport_overhead_bytes_per_packet;
|
| }
|
|
|
| -void TransportFeedbackAdapter::ClearSendTimeHistory() {
|
| +void TransportFeedbackAdapter::SetNetworkIds(uint16_t local_id,
|
| + uint16_t remote_id) {
|
| rtc::CritScope cs(&lock_);
|
| - send_time_history_.Clear();
|
| + local_net_id_ = local_id;
|
| + remote_net_id_ = remote_id;
|
| }
|
|
|
| std::vector<PacketFeedback> TransportFeedbackAdapter::GetPacketFeedbackVector(
|
| @@ -115,7 +122,10 @@ std::vector<PacketFeedback> TransportFeedbackAdapter::GetPacketFeedbackVector(
|
| // as received by another feedback.
|
| if (!send_time_history_.GetFeedback(&packet_feedback, false))
|
| ++failed_lookups;
|
| - packet_feedback_vector.push_back(packet_feedback);
|
| + if (packet_feedback.local_net_id == local_net_id_ &&
|
| + packet_feedback.remote_net_id == remote_net_id_) {
|
| + packet_feedback_vector.push_back(packet_feedback);
|
| + }
|
| }
|
|
|
| // Handle this iteration's received packet.
|
| @@ -124,7 +134,10 @@ std::vector<PacketFeedback> TransportFeedbackAdapter::GetPacketFeedbackVector(
|
| PacketFeedback packet_feedback(timestamp_ms, packet.sequence_number());
|
| if (!send_time_history_.GetFeedback(&packet_feedback, true))
|
| ++failed_lookups;
|
| - packet_feedback_vector.push_back(packet_feedback);
|
| + if (packet_feedback.local_net_id == local_net_id_ &&
|
| + packet_feedback.remote_net_id == remote_net_id_) {
|
| + packet_feedback_vector.push_back(packet_feedback);
|
| + }
|
|
|
| ++seq_num;
|
| }
|
|
|