| 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/quic_session.h" | 5 #include "net/quic/quic_session.h" |
| 6 | 6 |
| 7 #include "base/stl_util.h" | 7 #include "base/stl_util.h" |
| 8 #include "net/quic/crypto/proof_verifier.h" | 8 #include "net/quic/crypto/proof_verifier.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 254 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 265 // individual stream. | 265 // individual stream. |
| 266 DVLOG(1) << ENDPOINT | 266 DVLOG(1) << ENDPOINT |
| 267 << "Received connection level flow control window update with " | 267 << "Received connection level flow control window update with " |
| 268 "byte offset: " << frames[i].byte_offset; | 268 "byte offset: " << frames[i].byte_offset; |
| 269 if (flow_controller_->UpdateSendWindowOffset(frames[i].byte_offset)) { | 269 if (flow_controller_->UpdateSendWindowOffset(frames[i].byte_offset)) { |
| 270 connection_window_updated = true; | 270 connection_window_updated = true; |
| 271 } | 271 } |
| 272 continue; | 272 continue; |
| 273 } | 273 } |
| 274 | 274 |
| 275 if (connection_->version() <= QUIC_VERSION_20 && | 275 if (connection_->version() <= QUIC_VERSION_21 && |
| 276 (stream_id == kCryptoStreamId || stream_id == kHeadersStreamId)) { | 276 (stream_id == kCryptoStreamId || stream_id == kHeadersStreamId)) { |
| 277 DLOG(DFATAL) << "WindowUpdate for stream " << stream_id << " in version " | 277 DLOG(DFATAL) << "WindowUpdate for stream " << stream_id << " in version " |
| 278 << QuicVersionToString(connection_->version()); | 278 << QuicVersionToString(connection_->version()); |
| 279 return; | 279 return; |
| 280 } | 280 } |
| 281 | 281 |
| 282 ReliableQuicStream* stream = GetStream(stream_id); | 282 ReliableQuicStream* stream = GetStream(stream_id); |
| 283 if (stream) { | 283 if (stream) { |
| 284 stream->OnWindowUpdateFrame(frames[i]); | 284 stream->OnWindowUpdateFrame(frames[i]); |
| 285 } | 285 } |
| (...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 493 // Streams which were created before the SHLO was received (0-RTT | 493 // Streams which were created before the SHLO was received (0-RTT |
| 494 // requests) are now informed of the peer's initial flow control window. | 494 // requests) are now informed of the peer's initial flow control window. |
| 495 uint32 new_window = config_.ReceivedInitialFlowControlWindowBytes(); | 495 uint32 new_window = config_.ReceivedInitialFlowControlWindowBytes(); |
| 496 OnNewStreamFlowControlWindow(new_window); | 496 OnNewStreamFlowControlWindow(new_window); |
| 497 OnNewSessionFlowControlWindow(new_window); | 497 OnNewSessionFlowControlWindow(new_window); |
| 498 } | 498 } |
| 499 | 499 |
| 500 return; | 500 return; |
| 501 } | 501 } |
| 502 | 502 |
| 503 // QUIC_VERSION_20 and higher can have independent stream and session flow | 503 // QUIC_VERSION_21 and higher can have independent stream and session flow |
| 504 // control windows. | 504 // control windows. |
| 505 if (config_.HasReceivedInitialStreamFlowControlWindowBytes()) { | 505 if (config_.HasReceivedInitialStreamFlowControlWindowBytes()) { |
| 506 // Streams which were created before the SHLO was received (0-RTT | 506 // Streams which were created before the SHLO was received (0-RTT |
| 507 // requests) are now informed of the peer's initial flow control window. | 507 // requests) are now informed of the peer's initial flow control window. |
| 508 OnNewStreamFlowControlWindow( | 508 OnNewStreamFlowControlWindow( |
| 509 config_.ReceivedInitialStreamFlowControlWindowBytes()); | 509 config_.ReceivedInitialStreamFlowControlWindowBytes()); |
| 510 } | 510 } |
| 511 if (config_.HasReceivedInitialSessionFlowControlWindowBytes()) { | 511 if (config_.HasReceivedInitialSessionFlowControlWindowBytes()) { |
| 512 OnNewSessionFlowControlWindow( | 512 OnNewSessionFlowControlWindow( |
| 513 config_.ReceivedInitialSessionFlowControlWindowBytes()); | 513 config_.ReceivedInitialSessionFlowControlWindowBytes()); |
| 514 } | 514 } |
| 515 } | 515 } |
| 516 | 516 |
| 517 void QuicSession::OnNewStreamFlowControlWindow(uint32 new_window) { | 517 void QuicSession::OnNewStreamFlowControlWindow(uint32 new_window) { |
| 518 if (new_window < kDefaultFlowControlSendWindow) { | 518 if (new_window < kDefaultFlowControlSendWindow) { |
| 519 LOG(ERROR) | 519 LOG(ERROR) |
| 520 << "Peer sent us an invalid stream flow control send window: " | 520 << "Peer sent us an invalid stream flow control send window: " |
| 521 << new_window << ", below default: " << kDefaultFlowControlSendWindow; | 521 << new_window << ", below default: " << kDefaultFlowControlSendWindow; |
| 522 if (connection_->connected()) { | 522 if (connection_->connected()) { |
| 523 connection_->SendConnectionClose(QUIC_FLOW_CONTROL_INVALID_WINDOW); | 523 connection_->SendConnectionClose(QUIC_FLOW_CONTROL_INVALID_WINDOW); |
| 524 } | 524 } |
| 525 return; | 525 return; |
| 526 } | 526 } |
| 527 | 527 |
| 528 // Inform all existing streams about the new window. | 528 // Inform all existing streams about the new window. |
| 529 if (connection_->version() > QUIC_VERSION_20) { | 529 if (connection_->version() >= QUIC_VERSION_21) { |
| 530 GetCryptoStream()->flow_controller()->UpdateSendWindowOffset(new_window); | 530 GetCryptoStream()->flow_controller()->UpdateSendWindowOffset(new_window); |
| 531 headers_stream_->flow_controller()->UpdateSendWindowOffset(new_window); | 531 headers_stream_->flow_controller()->UpdateSendWindowOffset(new_window); |
| 532 } | 532 } |
| 533 for (DataStreamMap::iterator it = stream_map_.begin(); | 533 for (DataStreamMap::iterator it = stream_map_.begin(); |
| 534 it != stream_map_.end(); ++it) { | 534 it != stream_map_.end(); ++it) { |
| 535 it->second->flow_controller()->UpdateSendWindowOffset(new_window); | 535 it->second->flow_controller()->UpdateSendWindowOffset(new_window); |
| 536 } | 536 } |
| 537 } | 537 } |
| 538 | 538 |
| 539 void QuicSession::OnNewSessionFlowControlWindow(uint32 new_window) { | 539 void QuicSession::OnNewSessionFlowControlWindow(uint32 new_window) { |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 752 closed_streams_.clear(); | 752 closed_streams_.clear(); |
| 753 } | 753 } |
| 754 | 754 |
| 755 void QuicSession::OnSuccessfulVersionNegotiation(const QuicVersion& version) { | 755 void QuicSession::OnSuccessfulVersionNegotiation(const QuicVersion& version) { |
| 756 if (version < QUIC_VERSION_19) { | 756 if (version < QUIC_VERSION_19) { |
| 757 flow_controller_->Disable(); | 757 flow_controller_->Disable(); |
| 758 } | 758 } |
| 759 | 759 |
| 760 // Disable stream level flow control based on negotiated version. Streams may | 760 // Disable stream level flow control based on negotiated version. Streams may |
| 761 // have been created with a different version. | 761 // have been created with a different version. |
| 762 if (version <= QUIC_VERSION_20) { | 762 if (version < QUIC_VERSION_21) { |
| 763 GetCryptoStream()->flow_controller()->Disable(); | 763 GetCryptoStream()->flow_controller()->Disable(); |
| 764 headers_stream_->flow_controller()->Disable(); | 764 headers_stream_->flow_controller()->Disable(); |
| 765 } | 765 } |
| 766 for (DataStreamMap::iterator it = stream_map_.begin(); | 766 for (DataStreamMap::iterator it = stream_map_.begin(); |
| 767 it != stream_map_.end(); ++it) { | 767 it != stream_map_.end(); ++it) { |
| 768 if (version <= QUIC_VERSION_16) { | 768 if (version <= QUIC_VERSION_16) { |
| 769 it->second->flow_controller()->Disable(); | 769 it->second->flow_controller()->Disable(); |
| 770 } | 770 } |
| 771 } | 771 } |
| 772 } | 772 } |
| 773 | 773 |
| 774 } // namespace net | 774 } // namespace net |
| OLD | NEW |