| OLD | NEW |
| 1 // Copyright (c) 2016 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2016 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/core/quic_buffered_packet_store.h" | 5 #include "net/quic/core/quic_buffered_packet_store.h" |
| 6 | 6 |
| 7 #include <list> | 7 #include <list> |
| 8 | 8 |
| 9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 10 #include "net/quic/core/quic_bug_tracker.h" | 10 #include "net/quic/core/quic_bug_tracker.h" |
| 11 | 11 |
| 12 using std::list; | |
| 13 | |
| 14 namespace net { | 12 namespace net { |
| 15 | 13 |
| 16 typedef QuicBufferedPacketStore::BufferedPacket BufferedPacket; | 14 typedef QuicBufferedPacketStore::BufferedPacket BufferedPacket; |
| 17 typedef QuicBufferedPacketStore::EnqueuePacketResult EnqueuePacketResult; | 15 typedef QuicBufferedPacketStore::EnqueuePacketResult EnqueuePacketResult; |
| 18 typedef QuicBufferedPacketStore::BufferedPacketList BufferedPacketList; | 16 typedef QuicBufferedPacketStore::BufferedPacketList BufferedPacketList; |
| 19 | 17 |
| 20 // Max number of connections this store can keep track. | 18 // Max number of connections this store can keep track. |
| 21 static const size_t kDefaultMaxConnectionsInStore = 100; | 19 static const size_t kDefaultMaxConnectionsInStore = 100; |
| 22 // Up to half of the capacity can be used for storing non-CHLO packets. | 20 // Up to half of the capacity can be used for storing non-CHLO packets. |
| 23 static const size_t kMaxConnectionsWithoutCHLO = | 21 static const size_t kMaxConnectionsWithoutCHLO = |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 138 | 136 |
| 139 bool QuicBufferedPacketStore::HasBufferedPackets( | 137 bool QuicBufferedPacketStore::HasBufferedPackets( |
| 140 QuicConnectionId connection_id) const { | 138 QuicConnectionId connection_id) const { |
| 141 return base::ContainsKey(undecryptable_packets_, connection_id); | 139 return base::ContainsKey(undecryptable_packets_, connection_id); |
| 142 } | 140 } |
| 143 | 141 |
| 144 bool QuicBufferedPacketStore::HasChlosBuffered() const { | 142 bool QuicBufferedPacketStore::HasChlosBuffered() const { |
| 145 return !connections_with_chlo_.empty(); | 143 return !connections_with_chlo_.empty(); |
| 146 } | 144 } |
| 147 | 145 |
| 148 list<BufferedPacket> QuicBufferedPacketStore::DeliverPackets( | 146 std::list<BufferedPacket> QuicBufferedPacketStore::DeliverPackets( |
| 149 QuicConnectionId connection_id) { | 147 QuicConnectionId connection_id) { |
| 150 list<BufferedPacket> packets_to_deliver; | 148 std::list<BufferedPacket> packets_to_deliver; |
| 151 auto it = undecryptable_packets_.find(connection_id); | 149 auto it = undecryptable_packets_.find(connection_id); |
| 152 if (it != undecryptable_packets_.end()) { | 150 if (it != undecryptable_packets_.end()) { |
| 153 packets_to_deliver = std::move(it->second.buffered_packets); | 151 packets_to_deliver = std::move(it->second.buffered_packets); |
| 154 undecryptable_packets_.erase(connection_id); | 152 undecryptable_packets_.erase(connection_id); |
| 155 } | 153 } |
| 156 return packets_to_deliver; | 154 return packets_to_deliver; |
| 157 } | 155 } |
| 158 | 156 |
| 159 void QuicBufferedPacketStore::DiscardPackets(QuicConnectionId connection_id) { | 157 void QuicBufferedPacketStore::DiscardPackets(QuicConnectionId connection_id) { |
| 160 undecryptable_packets_.erase(connection_id); | 158 undecryptable_packets_.erase(connection_id); |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 194 | 192 |
| 195 size_t num_connections_without_chlo = | 193 size_t num_connections_without_chlo = |
| 196 undecryptable_packets_.size() - connections_with_chlo_.size(); | 194 undecryptable_packets_.size() - connections_with_chlo_.size(); |
| 197 bool reach_non_chlo_limit = | 195 bool reach_non_chlo_limit = |
| 198 FLAGS_quic_limit_num_new_sessions_per_epoll_loop && | 196 FLAGS_quic_limit_num_new_sessions_per_epoll_loop && |
| 199 num_connections_without_chlo >= kMaxConnectionsWithoutCHLO; | 197 num_connections_without_chlo >= kMaxConnectionsWithoutCHLO; |
| 200 | 198 |
| 201 return is_store_full || reach_non_chlo_limit; | 199 return is_store_full || reach_non_chlo_limit; |
| 202 } | 200 } |
| 203 | 201 |
| 204 list<BufferedPacket> QuicBufferedPacketStore::DeliverPacketsForNextConnection( | 202 std::list<BufferedPacket> |
| 203 QuicBufferedPacketStore::DeliverPacketsForNextConnection( |
| 205 QuicConnectionId* connection_id) { | 204 QuicConnectionId* connection_id) { |
| 206 if (connections_with_chlo_.empty()) { | 205 if (connections_with_chlo_.empty()) { |
| 207 // Returns empty list if no CHLO has been buffered. | 206 // Returns empty list if no CHLO has been buffered. |
| 208 return list<BufferedPacket>(); | 207 return std::list<BufferedPacket>(); |
| 209 } | 208 } |
| 210 *connection_id = connections_with_chlo_.front().first; | 209 *connection_id = connections_with_chlo_.front().first; |
| 211 connections_with_chlo_.erase(connections_with_chlo_.begin()); | 210 connections_with_chlo_.erase(connections_with_chlo_.begin()); |
| 212 | 211 |
| 213 list<BufferedPacket> packets = DeliverPackets(*connection_id); | 212 std::list<BufferedPacket> packets = DeliverPackets(*connection_id); |
| 214 DCHECK(!packets.empty()) << "Try to deliver connectons without CHLO"; | 213 DCHECK(!packets.empty()) << "Try to deliver connectons without CHLO"; |
| 215 return packets; | 214 return packets; |
| 216 } | 215 } |
| 217 | 216 |
| 218 bool QuicBufferedPacketStore::HasChloForConnection( | 217 bool QuicBufferedPacketStore::HasChloForConnection( |
| 219 QuicConnectionId connection_id) { | 218 QuicConnectionId connection_id) { |
| 220 return base::ContainsKey(connections_with_chlo_, connection_id); | 219 return base::ContainsKey(connections_with_chlo_, connection_id); |
| 221 } | 220 } |
| 222 | 221 |
| 223 } // namespace net | 222 } // namespace net |
| OLD | NEW |