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/tools/quic/quic_server_session.h" | 5 #include "net/tools/quic/quic_server_session.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "net/quic/crypto/cached_network_parameters.h" | 8 #include "net/quic/crypto/cached_network_parameters.h" |
9 #include "net/quic/quic_connection.h" | 9 #include "net/quic/quic_connection.h" |
10 #include "net/quic/quic_flags.h" | 10 #include "net/quic/quic_flags.h" |
(...skipping 30 matching lines...) Expand all Loading... |
41 | 41 |
42 if (!config()->HasReceivedConnectionOptions()) { | 42 if (!config()->HasReceivedConnectionOptions()) { |
43 return; | 43 return; |
44 } | 44 } |
45 | 45 |
46 // If the client has provided a bandwidth estimate from the same serving | 46 // If the client has provided a bandwidth estimate from the same serving |
47 // region, then pass it to the sent packet manager in preparation for possible | 47 // region, then pass it to the sent packet manager in preparation for possible |
48 // bandwidth resumption. | 48 // bandwidth resumption. |
49 const CachedNetworkParameters* cached_network_params = | 49 const CachedNetworkParameters* cached_network_params = |
50 crypto_stream_->previous_cached_network_params(); | 50 crypto_stream_->previous_cached_network_params(); |
51 if (FLAGS_quic_enable_bandwidth_resumption_experiment && | 51 const bool max_bandwidth_resumption = |
52 cached_network_params != nullptr && | 52 ContainsQuicTag(config()->ReceivedConnectionOptions(), kBWMX); |
53 ContainsQuicTag(config()->ReceivedConnectionOptions(), kBWRE) && | 53 if (cached_network_params != nullptr && |
| 54 (ContainsQuicTag(config()->ReceivedConnectionOptions(), kBWRE) || |
| 55 max_bandwidth_resumption) && |
54 cached_network_params->serving_region() == serving_region_) { | 56 cached_network_params->serving_region() == serving_region_) { |
55 connection()->ResumeConnectionState(*cached_network_params); | 57 connection()->ResumeConnectionState(*cached_network_params, |
| 58 max_bandwidth_resumption); |
56 } | 59 } |
57 | 60 |
58 if (FLAGS_enable_quic_fec && | 61 if (FLAGS_enable_quic_fec && |
59 ContainsQuicTag(config()->ReceivedConnectionOptions(), kFHDR)) { | 62 ContainsQuicTag(config()->ReceivedConnectionOptions(), kFHDR)) { |
60 // kFHDR config maps to FEC protection always for headers stream. | 63 // kFHDR config maps to FEC protection always for headers stream. |
61 // TODO(jri): Add crypto stream in addition to headers for kHDR. | 64 // TODO(jri): Add crypto stream in addition to headers for kHDR. |
62 headers_stream_->set_fec_policy(FEC_PROTECT_ALWAYS); | 65 headers_stream_->set_fec_policy(FEC_PROTECT_ALWAYS); |
63 } | 66 } |
64 } | 67 } |
65 | 68 |
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
193 DLOG(ERROR) << "Server push not yet supported"; | 196 DLOG(ERROR) << "Server push not yet supported"; |
194 return nullptr; | 197 return nullptr; |
195 } | 198 } |
196 | 199 |
197 QuicCryptoServerStream* QuicServerSession::GetCryptoStream() { | 200 QuicCryptoServerStream* QuicServerSession::GetCryptoStream() { |
198 return crypto_stream_.get(); | 201 return crypto_stream_.get(); |
199 } | 202 } |
200 | 203 |
201 } // namespace tools | 204 } // namespace tools |
202 } // namespace net | 205 } // namespace net |
OLD | NEW |