Pin Chrome's shortcut to the Win10 Start menu on install and OS upgrade.
[chromium-blink-merge.git] / net / quic / quic_ack_notifier_manager.cc
blob599e7d74c923eb1ec3e686c2712acd46d5b07321
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
3 // found in the LICENSE file.
5 #include "net/quic/quic_ack_notifier_manager.h"
7 #include <stddef.h>
8 #include <list>
9 #include <map>
10 #include <utility>
11 #include <vector>
13 #include "base/stl_util.h"
14 #include "net/quic/quic_ack_notifier.h"
15 #include "net/quic/quic_flags.h"
16 #include "net/quic/quic_protocol.h"
18 namespace net {
20 AckNotifierManager::AckNotifierManager() {}
22 AckNotifierManager::~AckNotifierManager() {
23 for (const auto& pair : ack_notifier_map_) {
24 for (QuicAckNotifier* notifier : pair.second) {
25 if (notifier->OnPacketAbandoned()) {
26 delete notifier;
32 void AckNotifierManager::OnPacketAcked(QuicPacketSequenceNumber sequence_number,
33 QuicTime::Delta delta_largest_observed) {
34 // Inform all the registered AckNotifiers of the new ACK.
35 auto map_it = ack_notifier_map_.find(sequence_number);
36 if (map_it == ack_notifier_map_.end()) {
37 // No AckNotifier is interested in this sequence number.
38 return;
41 // One or more AckNotifiers are registered as interested in this sequence
42 // number. Iterate through them and call OnAck on each.
43 for (QuicAckNotifier* ack_notifier : map_it->second) {
44 if (ack_notifier->OnAck(delta_largest_observed)) {
45 // If this has resulted in an empty AckNotifer, erase it.
46 delete ack_notifier;
50 // Remove the sequence number from the map as we have notified all the
51 // registered AckNotifiers, and we won't see it again.
52 ack_notifier_map_.erase(map_it);
55 void AckNotifierManager::OnPacketRetransmitted(
56 QuicPacketSequenceNumber old_sequence_number,
57 QuicPacketSequenceNumber new_sequence_number,
58 int packet_payload_size) {
59 auto map_it = ack_notifier_map_.find(old_sequence_number);
60 if (map_it == ack_notifier_map_.end()) {
61 // No AckNotifiers are interested in the old sequence number.
62 return;
65 // Update the existing QuicAckNotifiers to the new sequence number.
66 AckNotifierList& ack_notifier_list = map_it->second;
67 for (QuicAckNotifier* ack_notifier : ack_notifier_list) {
68 ack_notifier->OnPacketRetransmitted(packet_payload_size);
71 // The old sequence number is no longer of interest, copy the updated
72 // AckNotifiers to the new sequence number before deleting the old.
73 ack_notifier_map_[new_sequence_number] = ack_notifier_list;
74 ack_notifier_map_.erase(map_it);
77 void AckNotifierManager::OnSerializedPacket(
78 const SerializedPacket& serialized_packet) {
79 // Inform each attached AckNotifier of the packet's serialization.
80 AckNotifierList& notifier_list =
81 ack_notifier_map_[serialized_packet.sequence_number];
82 for (QuicAckNotifier* notifier : serialized_packet.notifiers) {
83 if (notifier == nullptr) {
84 LOG(DFATAL) << "AckNotifier should not be nullptr.";
85 continue;
87 notifier->OnSerializedPacket();
88 notifier_list.push_back(notifier);
92 void AckNotifierManager::OnPacketRemoved(
93 QuicPacketSequenceNumber sequence_number) {
94 // Determine if there are any notifiers interested in this packet.
95 auto map_it = ack_notifier_map_.find(sequence_number);
96 if (map_it == ack_notifier_map_.end()) {
97 return;
100 // Notify all of the interested notifiers that the packet is abandoned.
101 for (QuicAckNotifier* ack_notifier : map_it->second) {
102 DCHECK(ack_notifier);
103 if (ack_notifier->OnPacketAbandoned()) {
104 // If this has resulted in an empty AckNotifer, erase it.
105 delete ack_notifier;
109 // Remove the packet with given sequence number from the map.
110 ack_notifier_map_.erase(map_it);
113 } // namespace net