| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #ifndef NET_QUIC_QUIC_ACK_NOTIFIER_H_ | 5 #ifndef NET_QUIC_QUIC_ACK_NOTIFIER_H_ |
| 6 #define NET_QUIC_QUIC_ACK_NOTIFIER_H_ | 6 #define NET_QUIC_QUIC_ACK_NOTIFIER_H_ |
| 7 | 7 |
| 8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
| 9 #include "net/quic/quic_protocol.h" | 9 #include "net/quic/quic_protocol.h" |
| 10 | 10 |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 DelegateInterface(); | 23 DelegateInterface(); |
| 24 // Args: | 24 // Args: |
| 25 // num_original_packets - Number of packets in the original transmission. | 25 // num_original_packets - Number of packets in the original transmission. |
| 26 // num_original_bytes - Number of packets in the original transmission. | 26 // num_original_bytes - Number of packets in the original transmission. |
| 27 // num_retransmitted_packets - Number of packets that had to be | 27 // num_retransmitted_packets - Number of packets that had to be |
| 28 // retransmitted. | 28 // retransmitted. |
| 29 // num_retransmitted_bytes - Number of bytes that had to be retransmitted. | 29 // num_retransmitted_bytes - Number of bytes that had to be retransmitted. |
| 30 virtual void OnAckNotification(int num_original_packets, | 30 virtual void OnAckNotification(int num_original_packets, |
| 31 int num_original_bytes, | 31 int num_original_bytes, |
| 32 int num_retransmitted_packets, | 32 int num_retransmitted_packets, |
| 33 int num_retransmitted_bytes) = 0; | 33 int num_retransmitted_bytes, |
| 34 QuicTime::Delta delta_largest_observed) = 0; |
| 34 protected: | 35 protected: |
| 35 friend class base::RefCounted<DelegateInterface>; | 36 friend class base::RefCounted<DelegateInterface>; |
| 36 | 37 |
| 37 // Delegates are ref counted. | 38 // Delegates are ref counted. |
| 38 virtual ~DelegateInterface(); | 39 virtual ~DelegateInterface(); |
| 39 }; | 40 }; |
| 40 | 41 |
| 41 // QuicAckNotifier is expected to keep its own reference to the delegate. | 42 // QuicAckNotifier is expected to keep its own reference to the delegate. |
| 42 explicit QuicAckNotifier(DelegateInterface* delegate); | 43 explicit QuicAckNotifier(DelegateInterface* delegate); |
| 43 virtual ~QuicAckNotifier(); | 44 virtual ~QuicAckNotifier(); |
| 44 | 45 |
| 45 // Register a sequence number that this AckNotifier should be interested in. | 46 // Register a sequence number that this AckNotifier should be interested in. |
| 46 void AddSequenceNumber(const QuicPacketSequenceNumber& sequence_number, | 47 void AddSequenceNumber(const QuicPacketSequenceNumber& sequence_number, |
| 47 int packet_payload_size); | 48 int packet_payload_size); |
| 48 | 49 |
| 49 // Called by the QuicConnection on receipt of new ACK frame, with the sequence | 50 // Called by the QuicConnection on receipt of new ACK frame, with the sequence |
| 50 // number referenced by the ACK frame. | 51 // number referenced by the ACK frame. |
| 51 // Deletes the matching sequence number from the stored set of sequence | 52 // Deletes the matching sequence number from the stored set of sequence |
| 52 // numbers. If this set is now empty, call the stored delegate's | 53 // numbers. If this set is now empty, call the stored delegate's |
| 53 // OnAckNotification method. | 54 // OnAckNotification method. |
| 54 // | 55 // |
| 55 // Returns true if the provided sequence_number caused the delegate to be | 56 // Returns true if the provided sequence_number caused the delegate to be |
| 56 // called, false otherwise. | 57 // called, false otherwise. |
| 57 bool OnAck(QuicPacketSequenceNumber sequence_number); | 58 bool OnAck(QuicPacketSequenceNumber sequence_number, |
| 59 QuicTime::Delta delta_largest_observed); |
| 58 | 60 |
| 59 bool IsEmpty() { return sequence_numbers_.empty(); } | 61 bool IsEmpty() { return sequence_numbers_.empty(); } |
| 60 | 62 |
| 61 // If a packet is retransmitted by the connection it will be sent with a | 63 // If a packet is retransmitted by the connection it will be sent with a |
| 62 // different sequence number. Updates our internal set of sequence_numbers to | 64 // different sequence number. Updates our internal set of sequence_numbers to |
| 63 // track the latest number. | 65 // track the latest number. |
| 64 void UpdateSequenceNumber(QuicPacketSequenceNumber old_sequence_number, | 66 void UpdateSequenceNumber(QuicPacketSequenceNumber old_sequence_number, |
| 65 QuicPacketSequenceNumber new_sequence_number); | 67 QuicPacketSequenceNumber new_sequence_number); |
| 66 | 68 |
| 67 private: | 69 private: |
| (...skipping 20 matching lines...) Expand all Loading... |
| 88 int original_byte_count_; | 90 int original_byte_count_; |
| 89 // Number of packets that had to be retransmitted. | 91 // Number of packets that had to be retransmitted. |
| 90 int retransmitted_packet_count_; | 92 int retransmitted_packet_count_; |
| 91 // Number of bytes that had to be retransmitted. | 93 // Number of bytes that had to be retransmitted. |
| 92 int retransmitted_byte_count_; | 94 int retransmitted_byte_count_; |
| 93 }; | 95 }; |
| 94 | 96 |
| 95 }; // namespace net | 97 }; // namespace net |
| 96 | 98 |
| 97 #endif // NET_QUIC_QUIC_ACK_NOTIFIER_H_ | 99 #endif // NET_QUIC_QUIC_ACK_NOTIFIER_H_ |
| OLD | NEW |