| Index: net/quic/core/quic_protocol.h
|
| diff --git a/net/quic/core/quic_protocol.h b/net/quic/core/quic_protocol.h
|
| index 624e48b0078e91076c2ed450439b91f6e6aa7838..ff3ed3551a02ca358e51b56976f8a9edfe810652 100644
|
| --- a/net/quic/core/quic_protocol.h
|
| +++ b/net/quic/core/quic_protocol.h
|
| @@ -29,6 +29,7 @@
|
| #include "net/base/net_export.h"
|
| #include "net/quic/core/interval_set.h"
|
| #include "net/quic/core/quic_bandwidth.h"
|
| +#include "net/quic/core/quic_constants.h"
|
| #include "net/quic/core/quic_time.h"
|
| #include "net/quic/core/quic_types.h"
|
|
|
| @@ -38,180 +39,6 @@ class QuicPacket;
|
| struct QuicPacketHeader;
|
| class QuicAckListenerInterface;
|
|
|
| -typedef uint64_t QuicConnectionId;
|
| -typedef uint32_t QuicStreamId;
|
| -typedef uint64_t QuicStreamOffset;
|
| -typedef uint64_t QuicPacketNumber;
|
| -typedef uint8_t QuicPathId;
|
| -typedef uint64_t QuicPublicResetNonceProof;
|
| -typedef uint8_t QuicPacketEntropyHash;
|
| -typedef uint32_t QuicHeaderId;
|
| -// QuicTag is the type of a tag in the wire protocol.
|
| -typedef uint32_t QuicTag;
|
| -typedef std::vector<QuicTag> QuicTagVector;
|
| -typedef std::map<QuicTag, std::string> QuicTagValueMap;
|
| -typedef uint16_t QuicPacketLength;
|
| -
|
| -// Default initial maximum size in bytes of a QUIC packet.
|
| -const QuicByteCount kDefaultMaxPacketSize = 1350;
|
| -// Default initial maximum size in bytes of a QUIC packet for servers.
|
| -const QuicByteCount kDefaultServerMaxPacketSize = 1000;
|
| -// The maximum packet size of any QUIC packet, based on ethernet's max size,
|
| -// minus the IP and UDP headers. IPv6 has a 40 byte header, UDP adds an
|
| -// additional 8 bytes. This is a total overhead of 48 bytes. Ethernet's
|
| -// max packet size is 1500 bytes, 1500 - 48 = 1452.
|
| -const QuicByteCount kMaxPacketSize = 1452;
|
| -// Default maximum packet size used in the Linux TCP implementation.
|
| -// Used in QUIC for congestion window computations in bytes.
|
| -const QuicByteCount kDefaultTCPMSS = 1460;
|
| -
|
| -// We match SPDY's use of 32 (since we'd compete with SPDY).
|
| -const QuicPacketCount kInitialCongestionWindow = 32;
|
| -
|
| -// Minimum size of initial flow control window, for both stream and session.
|
| -const uint32_t kMinimumFlowControlSendWindow = 16 * 1024; // 16 KB
|
| -
|
| -// Maximum flow control receive window limits for connection and stream.
|
| -const QuicByteCount kStreamReceiveWindowLimit = 16 * 1024 * 1024; // 16 MB
|
| -const QuicByteCount kSessionReceiveWindowLimit = 24 * 1024 * 1024; // 24 MB
|
| -
|
| -// Default limit on the size of uncompressed headers.
|
| -const QuicByteCount kDefaultMaxUncompressedHeaderSize = 16 * 1024; // 16 KB
|
| -
|
| -// Minimum size of the CWND, in packets, when doing bandwidth resumption.
|
| -const QuicPacketCount kMinCongestionWindowForBandwidthResumption = 10;
|
| -
|
| -// Maximum number of tracked packets.
|
| -const QuicPacketCount kMaxTrackedPackets = 10000;
|
| -
|
| -// Default size of the socket receive buffer in bytes.
|
| -const QuicByteCount kDefaultSocketReceiveBuffer = 1024 * 1024;
|
| -
|
| -// Don't allow a client to suggest an RTT shorter than 10ms.
|
| -const uint32_t kMinInitialRoundTripTimeUs = 10 * kNumMicrosPerMilli;
|
| -
|
| -// Don't allow a client to suggest an RTT longer than 15 seconds.
|
| -const uint32_t kMaxInitialRoundTripTimeUs = 15 * kNumMicrosPerSecond;
|
| -
|
| -// Maximum number of open streams per connection.
|
| -const size_t kDefaultMaxStreamsPerConnection = 100;
|
| -
|
| -// Number of bytes reserved for public flags in the packet header.
|
| -const size_t kPublicFlagsSize = 1;
|
| -// Number of bytes reserved for version number in the packet header.
|
| -const size_t kQuicVersionSize = 4;
|
| -// Number of bytes reserved for path id in the packet header.
|
| -const size_t kQuicPathIdSize = 1;
|
| -// Number of bytes reserved for private flags in the packet header.
|
| -const size_t kPrivateFlagsSize = 1;
|
| -
|
| -// Signifies that the QuicPacket will contain version of the protocol.
|
| -const bool kIncludeVersion = true;
|
| -// Signifies that the QuicPacket will contain path id.
|
| -const bool kIncludePathId = true;
|
| -// Signifies that the QuicPacket will include a diversification nonce.
|
| -const bool kIncludeDiversificationNonce = true;
|
| -
|
| -// Stream ID is reserved to denote an invalid ID.
|
| -const QuicStreamId kInvalidStreamId = 0;
|
| -
|
| -// Reserved ID for the crypto stream.
|
| -const QuicStreamId kCryptoStreamId = 1;
|
| -
|
| -// Reserved ID for the headers stream.
|
| -const QuicStreamId kHeadersStreamId = 3;
|
| -
|
| -// Header key used to identify final offset on data stream when sending HTTP/2
|
| -// trailing headers over QUIC.
|
| -NET_EXPORT_PRIVATE extern const char* const kFinalOffsetHeaderKey;
|
| -
|
| -// Maximum delayed ack time, in ms.
|
| -const int64_t kMaxDelayedAckTimeMs = 25;
|
| -
|
| -// Minimum tail loss probe time in ms.
|
| -static const int64_t kMinTailLossProbeTimeoutMs = 10;
|
| -
|
| -// The timeout before the handshake succeeds.
|
| -const int64_t kInitialIdleTimeoutSecs = 5;
|
| -// The default idle timeout.
|
| -const int64_t kDefaultIdleTimeoutSecs = 30;
|
| -// The maximum idle timeout that can be negotiated.
|
| -const int64_t kMaximumIdleTimeoutSecs = 60 * 10; // 10 minutes.
|
| -// The default timeout for a connection until the crypto handshake succeeds.
|
| -const int64_t kMaxTimeForCryptoHandshakeSecs = 10; // 10 secs.
|
| -
|
| -// Default limit on the number of undecryptable packets the connection buffers
|
| -// before the CHLO/SHLO arrive.
|
| -const size_t kDefaultMaxUndecryptablePackets = 10;
|
| -
|
| -// Default ping timeout.
|
| -const int64_t kPingTimeoutSecs = 15; // 15 secs.
|
| -
|
| -// Minimum number of RTTs between Server Config Updates (SCUP) sent to client.
|
| -const int kMinIntervalBetweenServerConfigUpdatesRTTs = 10;
|
| -
|
| -// Minimum time between Server Config Updates (SCUP) sent to client.
|
| -const int kMinIntervalBetweenServerConfigUpdatesMs = 1000;
|
| -
|
| -// Minimum number of packets between Server Config Updates (SCUP).
|
| -const int kMinPacketsBetweenServerConfigUpdates = 100;
|
| -
|
| -// The number of open streams that a server will accept is set to be slightly
|
| -// larger than the negotiated limit. Immediately closing the connection if the
|
| -// client opens slightly too many streams is not ideal: the client may have sent
|
| -// a FIN that was lost, and simultaneously opened a new stream. The number of
|
| -// streams a server accepts is a fixed increment over the negotiated limit, or a
|
| -// percentage increase, whichever is larger.
|
| -const float kMaxStreamsMultiplier = 1.1f;
|
| -const int kMaxStreamsMinimumIncrement = 10;
|
| -
|
| -// Available streams are ones with IDs less than the highest stream that has
|
| -// been opened which have neither been opened or reset. The limit on the number
|
| -// of available streams is 10 times the limit on the number of open streams.
|
| -const int kMaxAvailableStreamsMultiplier = 10;
|
| -
|
| -// Track the number of promises that are not yet claimed by a
|
| -// corresponding get. This must be smaller than
|
| -// kMaxAvailableStreamsMultiplier, because RST on a promised stream my
|
| -// create available streams entries.
|
| -const int kMaxPromisedStreamsMultiplier = kMaxAvailableStreamsMultiplier - 1;
|
| -
|
| -// TCP RFC calls for 1 second RTO however Linux differs from this default and
|
| -// define the minimum RTO to 200ms, we will use the same until we have data to
|
| -// support a higher or lower value.
|
| -static const int64_t kMinRetransmissionTimeMs = 200;
|
| -
|
| -// We define an unsigned 16-bit floating point value, inspired by IEEE floats
|
| -// (http://en.wikipedia.org/wiki/Half_precision_floating-point_format),
|
| -// with 5-bit exponent (bias 1), 11-bit mantissa (effective 12 with hidden
|
| -// bit) and denormals, but without signs, transfinites or fractions. Wire format
|
| -// 16 bits (little-endian byte order) are split into exponent (high 5) and
|
| -// mantissa (low 11) and decoded as:
|
| -// uint64_t value;
|
| -// if (exponent == 0) value = mantissa;
|
| -// else value = (mantissa | 1 << 11) << (exponent - 1)
|
| -const int kUFloat16ExponentBits = 5;
|
| -const int kUFloat16MaxExponent = (1 << kUFloat16ExponentBits) - 2; // 30
|
| -const int kUFloat16MantissaBits = 16 - kUFloat16ExponentBits; // 11
|
| -const int kUFloat16MantissaEffectiveBits = kUFloat16MantissaBits + 1; // 12
|
| -const uint64_t kUFloat16MaxValue = // 0x3FFC0000000
|
| - ((UINT64_C(1) << kUFloat16MantissaEffectiveBits) - 1)
|
| - << kUFloat16MaxExponent;
|
| -
|
| -// Default path ID.
|
| -const QuicPathId kDefaultPathId = 0;
|
| -// Invalid path ID.
|
| -const QuicPathId kInvalidPathId = 0xff;
|
| -
|
| -// kDiversificationNonceSize is the size, in bytes, of the nonce that a server
|
| -// may set in the packet header to ensure that its INITIAL keys are not
|
| -// duplicated.
|
| -const size_t kDiversificationNonceSize = 32;
|
| -
|
| -// The largest gap in packets we'll accept without closing the connection.
|
| -// This will likely have to be tuned.
|
| -const QuicPacketNumber kMaxPacketGap = 5000;
|
| -
|
| enum TransmissionType : int8_t {
|
| NOT_RETRANSMISSION,
|
| FIRST_TRANSMISSION_TYPE = NOT_RETRANSMISSION,
|
|
|