Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1038)

Unified Diff: net/quic/reliable_quic_stream.cc

Issue 368803003: QUIC_VERSION_21: headers and crypto streams are now flow controlled at (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: net/quic/reliable_quic_stream.cc
diff --git a/net/quic/reliable_quic_stream.cc b/net/quic/reliable_quic_stream.cc
index 44d3a036fdd0c2310317c8284ae1376106cddf62..f01c7d30cebf38674ce9bf8780d564bbe070c9bc 100644
--- a/net/quic/reliable_quic_stream.cc
+++ b/net/quic/reliable_quic_stream.cc
@@ -159,7 +159,8 @@ ReliableQuicStream::ReliableQuicStream(QuicStreamId id, QuicSession* session)
GetReceivedFlowControlWindow(session),
GetInitialStreamFlowControlWindowToSend(session),
GetInitialStreamFlowControlWindowToSend(session)),
- connection_flow_controller_(session_->flow_controller()) {
+ connection_flow_controller_(session_->flow_controller()),
+ stream_contributes_to_connection_flow_control_(true) {
}
ReliableQuicStream::~ReliableQuicStream() {
@@ -332,11 +333,14 @@ void ReliableQuicStream::OnCanWrite() {
void ReliableQuicStream::MaybeSendBlocked() {
flow_controller_.MaybeSendBlocked();
- connection_flow_controller_->MaybeSendBlocked();
+ if (stream_contributes_to_connection_flow_control_) {
wtc 2014/07/02 22:38:31 Nit: we can merge these two if statements as follo
jar (doing other things) 2014/07/14 21:49:23 +1 for early return suggestion.
ramant (doing other things) 2014/07/16 19:43:08 Done.
ramant (doing other things) 2014/07/16 19:43:08 Done.
+ connection_flow_controller_->MaybeSendBlocked();
+ }
// If we are connection level flow control blocked, then add the stream
// to the write blocked list. It will be given a chance to write when a
// connection level WINDOW_UPDATE arrives.
- if (connection_flow_controller_->IsBlocked() &&
+ if (stream_contributes_to_connection_flow_control_ &&
+ connection_flow_controller_->IsBlocked() &&
!flow_controller_.IsBlocked()) {
session_->MarkWriteBlocked(id(), EffectivePriority());
}
@@ -361,7 +365,10 @@ QuicConsumedData ReliableQuicStream::WritevData(
if (flow_controller_.IsEnabled()) {
// How much data we are allowed to write from flow control.
uint64 send_window = flow_controller_.SendWindowSize();
- if (connection_flow_controller_->IsEnabled()) {
+ // TODO(rjshade): Remove connection_flow_controller_->IsEnabled() check when
+ // removing QUIC_VERSION_19.
+ if (stream_contributes_to_connection_flow_control_ &&
+ connection_flow_controller_->IsEnabled()) {
send_window =
min(send_window, connection_flow_controller_->SendWindowSize());
}
@@ -490,9 +497,11 @@ bool ReliableQuicStream::MaybeIncreaseHighestReceivedOffset(uint64 new_offset) {
// If |new_offset| increased the stream flow controller's highest received
// offset, then we need to increase the connection flow controller's value
// by the incremental difference.
- connection_flow_controller_->UpdateHighestReceivedOffset(
- connection_flow_controller_->highest_received_byte_offset() +
- increment);
+ if (stream_contributes_to_connection_flow_control_) {
wtc 2014/07/02 22:38:30 Nit: merge this inner if with the if on line 496.
ramant (doing other things) 2014/07/16 19:43:08 Reworked the if statements.
+ connection_flow_controller_->UpdateHighestReceivedOffset(
+ connection_flow_controller_->highest_received_byte_offset() +
+ increment);
+ }
return true;
}
}
@@ -502,7 +511,9 @@ bool ReliableQuicStream::MaybeIncreaseHighestReceivedOffset(uint64 new_offset) {
void ReliableQuicStream::AddBytesSent(uint64 bytes) {
if (flow_controller_.IsEnabled()) {
flow_controller_.AddBytesSent(bytes);
- connection_flow_controller_->AddBytesSent(bytes);
+ if (stream_contributes_to_connection_flow_control_) {
+ connection_flow_controller_->AddBytesSent(bytes);
+ }
}
}
@@ -513,13 +524,18 @@ void ReliableQuicStream::AddBytesConsumed(uint64 bytes) {
flow_controller_.AddBytesConsumed(bytes);
}
- connection_flow_controller_->AddBytesConsumed(bytes);
+ if (stream_contributes_to_connection_flow_control_) {
+ connection_flow_controller_->AddBytesConsumed(bytes);
+ }
}
}
bool ReliableQuicStream::IsFlowControlBlocked() {
- return flow_controller_.IsBlocked() ||
- connection_flow_controller_->IsBlocked();
+ bool stream_flow_control_blocked = flow_controller_.IsBlocked();
+ bool connecton_flow_control_blocked =
+ stream_contributes_to_connection_flow_control_ &&
+ connection_flow_controller_->IsBlocked();
+ return stream_flow_control_blocked || connecton_flow_control_blocked;
wtc 2014/07/02 22:38:31 Nit: the new code loses some of the short circuit.
ramant (doing other things) 2014/07/16 19:43:08 Done.
}
} // namespace net

Powered by Google App Engine
This is Rietveld 408576698