| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "net/quic/congestion_control/fix_rate_sender.h" | 5 #include "net/quic/congestion_control/fix_rate_sender.h" |
| 6 | 6 |
| 7 #include <math.h> | 7 #include <math.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 | 10 |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 51 if (feedback.type == kFixRate) { | 51 if (feedback.type == kFixRate) { |
| 52 bitrate_ = feedback.fix_rate.bitrate; | 52 bitrate_ = feedback.fix_rate.bitrate; |
| 53 fix_rate_leaky_bucket_.SetDrainingRate(feedback_receive_time, bitrate_); | 53 fix_rate_leaky_bucket_.SetDrainingRate(feedback_receive_time, bitrate_); |
| 54 paced_sender_.UpdateBandwidthEstimate(feedback_receive_time, bitrate_); | 54 paced_sender_.UpdateBandwidthEstimate(feedback_receive_time, bitrate_); |
| 55 } | 55 } |
| 56 // Silently ignore invalid messages in release mode. | 56 // Silently ignore invalid messages in release mode. |
| 57 } | 57 } |
| 58 | 58 |
| 59 void FixRateSender::OnPacketAcked( | 59 void FixRateSender::OnPacketAcked( |
| 60 QuicPacketSequenceNumber /*acked_sequence_number*/, | 60 QuicPacketSequenceNumber /*acked_sequence_number*/, |
| 61 QuicByteCount bytes_acked, | 61 QuicByteCount bytes_acked) { |
| 62 QuicTime::Delta rtt) { | |
| 63 // RTT can't be negative. | |
| 64 DCHECK_LE(0, rtt.ToMicroseconds()); | |
| 65 | |
| 66 data_in_flight_ -= bytes_acked; | 62 data_in_flight_ -= bytes_acked; |
| 67 if (rtt.IsInfinite()) { | |
| 68 return; | |
| 69 } | |
| 70 latest_rtt_ = rtt; | |
| 71 } | 63 } |
| 72 | 64 |
| 73 void FixRateSender::OnPacketLost(QuicPacketSequenceNumber /*sequence_number*/, | 65 void FixRateSender::OnPacketLost(QuicPacketSequenceNumber /*sequence_number*/, |
| 74 QuicTime /*ack_receive_time*/) { | 66 QuicTime /*ack_receive_time*/) { |
| 75 // Ignore losses for fix rate sender. | 67 // Ignore losses for fix rate sender. |
| 76 } | 68 } |
| 77 | 69 |
| 78 bool FixRateSender::OnPacketSent( | 70 bool FixRateSender::OnPacketSent( |
| 79 QuicTime sent_time, | 71 QuicTime sent_time, |
| 80 QuicPacketSequenceNumber /*sequence_number*/, | 72 QuicPacketSequenceNumber /*sequence_number*/, |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 120 QuicByteCount window_size_bytes = bitrate_.ToBytesPerPeriod( | 112 QuicByteCount window_size_bytes = bitrate_.ToBytesPerPeriod( |
| 121 QuicTime::Delta::FromMicroseconds(kWindowSizeUs)); | 113 QuicTime::Delta::FromMicroseconds(kWindowSizeUs)); |
| 122 // Make sure window size is not less than a packet. | 114 // Make sure window size is not less than a packet. |
| 123 return max(kDefaultMaxPacketSize, window_size_bytes); | 115 return max(kDefaultMaxPacketSize, window_size_bytes); |
| 124 } | 116 } |
| 125 | 117 |
| 126 QuicBandwidth FixRateSender::BandwidthEstimate() const { | 118 QuicBandwidth FixRateSender::BandwidthEstimate() const { |
| 127 return bitrate_; | 119 return bitrate_; |
| 128 } | 120 } |
| 129 | 121 |
| 122 void FixRateSender::UpdateRtt(QuicTime::Delta rtt_sample) { |
| 123 // RTT can't be negative. |
| 124 DCHECK_LE(0, rtt_sample.ToMicroseconds()); |
| 125 if (rtt_sample.IsInfinite()) { |
| 126 return; |
| 127 } |
| 128 latest_rtt_ = rtt_sample; |
| 129 } |
| 130 |
| 130 QuicTime::Delta FixRateSender::SmoothedRtt() const { | 131 QuicTime::Delta FixRateSender::SmoothedRtt() const { |
| 131 // TODO(satyamshekhar): Calculate and return smoothed rtt. | 132 // TODO(satyamshekhar): Calculate and return smoothed rtt. |
| 132 return latest_rtt_; | 133 return latest_rtt_; |
| 133 } | 134 } |
| 134 | 135 |
| 135 QuicTime::Delta FixRateSender::RetransmissionDelay() const { | 136 QuicTime::Delta FixRateSender::RetransmissionDelay() const { |
| 136 // TODO(pwestin): Calculate and return retransmission delay. | 137 // TODO(pwestin): Calculate and return retransmission delay. |
| 137 // Use 2 * the latest RTT for now. | 138 // Use 2 * the latest RTT for now. |
| 138 return latest_rtt_.Add(latest_rtt_); | 139 return latest_rtt_.Add(latest_rtt_); |
| 139 } | 140 } |
| 140 | 141 |
| 141 QuicByteCount FixRateSender::GetCongestionWindow() const { | 142 QuicByteCount FixRateSender::GetCongestionWindow() const { |
| 142 return 0; | 143 return 0; |
| 143 } | 144 } |
| 144 | 145 |
| 145 } // namespace net | 146 } // namespace net |
| OLD | NEW |