diff options
author | rtenneti@chromium.org <rtenneti@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-04-18 23:44:37 +0000 |
---|---|---|
committer | rtenneti@chromium.org <rtenneti@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-04-18 23:44:37 +0000 |
commit | 51cc134b9061bb13b3a4af42f256a9b16b15f2e3 (patch) | |
tree | f06eebafd935263f1cfd1c8f9003b093169ec458 /net/quic/quic_packet_creator.h | |
parent | e6a9ca2eef73df9fefc2b79845d908af1a5aa7f2 (diff) | |
download | chromium_src-51cc134b9061bb13b3a4af42f256a9b16b15f2e3.zip chromium_src-51cc134b9061bb13b3a4af42f256a9b16b15f2e3.tar.gz chromium_src-51cc134b9061bb13b3a4af42f256a9b16b15f2e3.tar.bz2 |
Land Recent QUIC Changes.
Disable QuicFlowController for QUIC versions < QUIC_VERSION_17
Chrome Beta was happily advertising a flow control receive window of
length 0, under the assumption that because the version of QUIC being
spoken didn't support flow control, a zero length window advertisement
would have no adverse effects.
On the server end, the refactoring in internal change: 64733866 resulted
in the QUIC version not being checked when querying
QuicFlowController::IsBlocked. IsBlocked would look at the client's
advertised receive window, and conclude that no data could be sent. This
would never change as the flow control accounting is protected behind
version checks.
Ultimately this means that once a stream was marked as write blocked, it
would never resume writing:
https://codereview.chromium.org/242453002/diff/1/net/quic/quic_session.cc?context=&column_width=80
(line# 286) resulting in a connection timeout.
This CL explicitly disables the QuicFlowController when the negotiated
QUIC version is < QUIC_VERSION_17.
Merge internal change: 65137349
This internal change was LGTM'ed by rch. Wanted to port this change
to disable flow control.
https://codereview.chromium.org/242583002/
Downgrading rst stream codes which wouldn't be recognized by the peer.
chromium: fixed chromium's unit tests to use AdjustErrorForVersion.
Merge internal change: 64783797
https://codereview.chromium.org/242483002/
Added WriteResult::WriteResult method for internal use.
Merge internal change: 64780998
https://codereview.chromium.org/242293003/
QUIC: When sending a RST stream for flow control accounting purposes,
include a more descriptive error code.
Prompted by alyssar's comment in internal change: 61236803
Chromium specific code:
+ deleted unused ConstructRstPacket method from
QuicNetworkTransactionTest.
+ Changed ConstructRstPacket to use the new descriptive error code.
Merge internal change: 64774941
https://codereview.chromium.org/242093003/
Pull out flow control functionality from ReliableQuicStream into a new
class, QuicFlowController.
Without this refactoring, all the accounting of bytes
sent/buffered/consumed, comparisons of these with limits to decide if
blocked or not, will be duplicated in ReliableQuicStream and
QuicConnection. Putting all this in a new class means it's easier to
have more comprehensive testing, simplifies ReliableQuicStream, and will
make it much easier to add Connection level flow control (work in
progress internal change: 63944402).
Refactor of QUIC stream flow control. No behavior change, still
protected behind FLAGS_enable_quic_stream_flow_control. This flag is
currently disabled.
Merge internal change: 64733866
https://codereview.chromium.org/242453002/
Plumbs through delta_largest_observed from
QuicSentPackerManager::HandleAckForSentPacket, up to the
QuicAckNotifier. Eventually these values get to the
QuicFasterStatsGatherer which now performs a more accurate RT
calculation.
The important changes are in QuicSentPacketManager (pulling the delta
out of ReceivedInfo), and in QuicFasterStatsGatherer (doing the new
calculation of RT). The rest is plumbing and updating tests.
Improve accuracy of QUIC FasterStats RT calculation by using the
delta time included with delayed ACKs.
Merge internal change: 64721749
https://codereview.chromium.org/241783002/
Fixed a bug in QuicPacketCreator when FEC was used for unsupported
versions, and made packet_creator tests run across all supported
versions of QUIC.
Merge internal change: 64701677
https://codereview.chromium.org/241483004/
Fix to ensure hybrid slow start is reset when QUIC's retransmission
timer fires.
Merge internal change: 64698621
https://codereview.chromium.org/241563002/
R=rch@chromium.org
Review URL: https://codereview.chromium.org/242593002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@264889 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/quic/quic_packet_creator.h')
-rw-r--r-- | net/quic/quic_packet_creator.h | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/net/quic/quic_packet_creator.h b/net/quic/quic_packet_creator.h index e3e84f4..83494da 100644 --- a/net/quic/quic_packet_creator.h +++ b/net/quic/quic_packet_creator.h @@ -115,6 +115,14 @@ class NET_EXPORT_PRIVATE QuicPacketCreator : public QuicFecBuilderInterface { // Returns true if there are frames pending to be serialized. bool HasPendingFrames(); + // Returns IN_FEC_GROUP or NOT_IN_FEC_GROUP, depending on whether FEC is + // enabled or not. Note: This does not mean that an FEC group is currently + // active; i.e., fec_group_.get() may still be NULL. + // TODO(jri): Straighten out naming: Enabling FEC for the connection + // should use FEC_ENABLED/DISABLED, and IN_FEC_GROUP/NOT_IN_FEC_GROUP should + // be used if a given packet is in an fec group. + InFecGroup IsFecEnabled() const; + // Returns the number of bytes which are available to be used by additional // frames in the packet. Since stream frames are slightly smaller when they // are the last frame in a packet, this method will return a different |