QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 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 |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #ifndef QUICHE_QUIC_CORE_QUIC_CONSTANTS_H_ |
| 6 | #define QUICHE_QUIC_CORE_QUIC_CONSTANTS_H_ |
| 7 | |
| 8 | #include <stddef.h> |
| 9 | |
| 10 | #include <cstdint> |
| 11 | #include <limits> |
| 12 | |
QUICHE team | 5be974e | 2020-12-29 18:35:24 -0500 | [diff] [blame] | 13 | #include "quic/core/quic_types.h" |
| 14 | #include "quic/platform/api/quic_export.h" |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 15 | |
| 16 | // Definitions of constant values used throughout the QUIC code. |
| 17 | |
| 18 | namespace quic { |
| 19 | |
| 20 | // Simple time constants. |
| 21 | const uint64_t kNumSecondsPerMinute = 60; |
| 22 | const uint64_t kNumSecondsPerHour = kNumSecondsPerMinute * 60; |
| 23 | const uint64_t kNumSecondsPerWeek = kNumSecondsPerHour * 24 * 7; |
dschinazi | 6cf4d2a | 2019-04-30 16:20:23 -0700 | [diff] [blame] | 24 | const uint64_t kNumMillisPerSecond = 1000; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 25 | const uint64_t kNumMicrosPerMilli = 1000; |
dschinazi | 6cf4d2a | 2019-04-30 16:20:23 -0700 | [diff] [blame] | 26 | const uint64_t kNumMicrosPerSecond = kNumMicrosPerMilli * kNumMillisPerSecond; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 27 | |
| 28 | // Default number of connections for N-connection emulation. |
| 29 | const uint32_t kDefaultNumConnections = 2; |
| 30 | // Default initial maximum size in bytes of a QUIC packet. |
| 31 | const QuicByteCount kDefaultMaxPacketSize = 1350; |
| 32 | // Default initial maximum size in bytes of a QUIC packet for servers. |
| 33 | const QuicByteCount kDefaultServerMaxPacketSize = 1000; |
| 34 | // Maximum transmission unit on Ethernet. |
| 35 | const QuicByteCount kEthernetMTU = 1500; |
dschinazi | 66dea07 | 2019-04-09 11:41:06 -0700 | [diff] [blame] | 36 | // The maximum packet size of any QUIC packet over IPv6, based on ethernet's max |
| 37 | // size, minus the IP and UDP headers. IPv6 has a 40 byte header, UDP adds an |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 38 | // additional 8 bytes. This is a total overhead of 48 bytes. Ethernet's |
| 39 | // max packet size is 1500 bytes, 1500 - 48 = 1452. |
dschinazi | 66dea07 | 2019-04-09 11:41:06 -0700 | [diff] [blame] | 40 | const QuicByteCount kMaxV6PacketSize = 1452; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 41 | // The maximum packet size of any QUIC packet over IPv4. |
| 42 | // 1500(Ethernet) - 20(IPv4 header) - 8(UDP header) = 1472. |
| 43 | const QuicByteCount kMaxV4PacketSize = 1472; |
dschinazi | e8d7fa7 | 2019-04-05 14:44:40 -0700 | [diff] [blame] | 44 | // The maximum incoming packet size allowed. |
| 45 | const QuicByteCount kMaxIncomingPacketSize = kMaxV4PacketSize; |
dschinazi | 66dea07 | 2019-04-09 11:41:06 -0700 | [diff] [blame] | 46 | // The maximum outgoing packet size allowed. |
| 47 | const QuicByteCount kMaxOutgoingPacketSize = kMaxV6PacketSize; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 48 | // ETH_MAX_MTU - MAX(sizeof(iphdr), sizeof(ip6_hdr)) - sizeof(udphdr). |
| 49 | const QuicByteCount kMaxGsoPacketSize = 65535 - 40 - 8; |
dschinazi | cd86dd1 | 2019-11-14 10:11:13 -0800 | [diff] [blame] | 50 | // The maximal IETF DATAGRAM frame size we'll accept. Choosing 2^16 ensures |
| 51 | // that it is greater than the biggest frame we could ever fit in a QUIC packet. |
| 52 | const QuicByteCount kMaxAcceptedDatagramFrameSize = 65536; |
dschinazi | 4ad1f46 | 2020-01-16 11:56:52 -0800 | [diff] [blame] | 53 | // Default value of the max_packet_size transport parameter if it is not |
| 54 | // transmitted. |
| 55 | const QuicByteCount kDefaultMaxPacketSizeTransportParam = 65527; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 56 | // Default maximum packet size used in the Linux TCP implementation. |
| 57 | // Used in QUIC for congestion window computations in bytes. |
| 58 | const QuicByteCount kDefaultTCPMSS = 1460; |
| 59 | const QuicByteCount kMaxSegmentSize = kDefaultTCPMSS; |
| 60 | // The minimum size of a packet which can elicit a version negotiation packet, |
| 61 | // as per section 8.1 of the QUIC spec. |
| 62 | const QuicByteCount kMinPacketSizeForVersionNegotiation = 1200; |
| 63 | |
| 64 | // We match SPDY's use of 32 (since we'd compete with SPDY). |
| 65 | const QuicPacketCount kInitialCongestionWindow = 32; |
| 66 | |
fayang | be83ecd | 2019-04-26 13:58:09 -0700 | [diff] [blame] | 67 | // Do not allow initial congestion window to be greater than 200 packets. |
| 68 | const QuicPacketCount kMaxInitialCongestionWindow = 200; |
| 69 | |
fayang | f1b99dc | 2019-05-14 06:29:18 -0700 | [diff] [blame] | 70 | // Do not allow initial congestion window to be smaller than 10 packets. |
| 71 | const QuicPacketCount kMinInitialCongestionWindow = 10; |
| 72 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 73 | // Minimum size of initial flow control window, for both stream and session. |
dschinazi | c703612 | 2019-04-30 12:46:34 -0700 | [diff] [blame] | 74 | // This is only enforced when version.AllowsLowFlowControlLimits() is false. |
dschinazi | f1e7b42 | 2020-04-30 12:21:28 -0700 | [diff] [blame] | 75 | const QuicByteCount kMinimumFlowControlSendWindow = 16 * 1024; // 16 KB |
dschinazi | c703612 | 2019-04-30 12:46:34 -0700 | [diff] [blame] | 76 | // Default size of initial flow control window, for both stream and session. |
dschinazi | f1e7b42 | 2020-04-30 12:21:28 -0700 | [diff] [blame] | 77 | const QuicByteCount kDefaultFlowControlSendWindow = 16 * 1024; // 16 KB |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 78 | |
| 79 | // Maximum flow control receive window limits for connection and stream. |
| 80 | const QuicByteCount kStreamReceiveWindowLimit = 16 * 1024 * 1024; // 16 MB |
| 81 | const QuicByteCount kSessionReceiveWindowLimit = 24 * 1024 * 1024; // 24 MB |
| 82 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 83 | // Minimum size of the CWND, in packets, when doing bandwidth resumption. |
| 84 | const QuicPacketCount kMinCongestionWindowForBandwidthResumption = 10; |
| 85 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 86 | // Default size of the socket receive buffer in bytes. |
| 87 | const QuicByteCount kDefaultSocketReceiveBuffer = 1024 * 1024; |
| 88 | |
| 89 | // Don't allow a client to suggest an RTT shorter than 10ms. |
| 90 | const uint32_t kMinInitialRoundTripTimeUs = 10 * kNumMicrosPerMilli; |
| 91 | |
fayang | 0ddf8a5 | 2020-10-27 12:00:24 -0700 | [diff] [blame] | 92 | // Don't allow a client to suggest an RTT longer than 1 second. |
| 93 | const uint32_t kMaxInitialRoundTripTimeUs = kNumMicrosPerSecond; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 94 | |
| 95 | // Maximum number of open streams per connection. |
| 96 | const size_t kDefaultMaxStreamsPerConnection = 100; |
| 97 | |
| 98 | // Number of bytes reserved for public flags in the packet header. |
| 99 | const size_t kPublicFlagsSize = 1; |
| 100 | // Number of bytes reserved for version number in the packet header. |
| 101 | const size_t kQuicVersionSize = 4; |
| 102 | |
haoyuewang | e3c51d9 | 2021-03-08 07:35:03 -0800 | [diff] [blame] | 103 | // Minimum number of active connection IDs that an end point can maintain. |
| 104 | const uint32_t kMinNumOfActiveConnectionIds = 2; |
| 105 | |
dschinazi | 278efae | 2020-01-28 17:03:09 -0800 | [diff] [blame] | 106 | // Length of the retry integrity tag in bytes. |
| 107 | // https://tools.ietf.org/html/draft-ietf-quic-transport-25#section-17.2.5 |
| 108 | const size_t kRetryIntegrityTagLength = 16; |
| 109 | |
haoyuewang | e0acd51 | 2020-11-05 09:18:36 -0800 | [diff] [blame] | 110 | // By default, UnackedPacketsMap allocates buffer of 64 after the first packet |
| 111 | // is added. |
| 112 | const int kDefaultUnackedPacketsInitialCapacity = 64; |
| 113 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 114 | // Signifies that the QuicPacket will contain version of the protocol. |
| 115 | const bool kIncludeVersion = true; |
| 116 | // Signifies that the QuicPacket will include a diversification nonce. |
| 117 | const bool kIncludeDiversificationNonce = true; |
| 118 | |
| 119 | // Header key used to identify final offset on data stream when sending HTTP/2 |
| 120 | // trailing headers over QUIC. |
| 121 | QUIC_EXPORT_PRIVATE extern const char* const kFinalOffsetHeaderKey; |
| 122 | |
| 123 | // Default maximum delayed ack time, in ms. |
| 124 | // Uses a 25ms delayed ack timer. Helps with better signaling |
| 125 | // in low-bandwidth (< ~384 kbps), where an ack is sent per packet. |
| 126 | const int64_t kDefaultDelayedAckTimeMs = 25; |
| 127 | |
haoyuewang | 7cffa54 | 2020-07-15 17:12:27 -0700 | [diff] [blame] | 128 | // Default minimum delayed ack time, in ms (used only for sender control of ack |
| 129 | // frequency). |
haoyuewang | 24d8d70 | 2020-10-19 08:05:01 -0700 | [diff] [blame] | 130 | const uint32_t kDefaultMinAckDelayTimeMs = 5; |
haoyuewang | 7cffa54 | 2020-07-15 17:12:27 -0700 | [diff] [blame] | 131 | |
fkastenholz | 4dc4ba3 | 2019-07-30 09:55:25 -0700 | [diff] [blame] | 132 | // Default shift of the ACK delay in the IETF QUIC ACK frame. |
| 133 | const uint32_t kDefaultAckDelayExponent = 3; |
| 134 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 135 | // Minimum tail loss probe time in ms. |
| 136 | static const int64_t kMinTailLossProbeTimeoutMs = 10; |
| 137 | |
| 138 | // The timeout before the handshake succeeds. |
| 139 | const int64_t kInitialIdleTimeoutSecs = 5; |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 140 | // The maximum idle timeout that can be negotiated. |
| 141 | const int64_t kMaximumIdleTimeoutSecs = 60 * 10; // 10 minutes. |
| 142 | // The default timeout for a connection until the crypto handshake succeeds. |
| 143 | const int64_t kMaxTimeForCryptoHandshakeSecs = 10; // 10 secs. |
| 144 | |
| 145 | // Default limit on the number of undecryptable packets the connection buffers |
| 146 | // before the CHLO/SHLO arrive. |
| 147 | const size_t kDefaultMaxUndecryptablePackets = 10; |
| 148 | |
| 149 | // Default ping timeout. |
| 150 | const int64_t kPingTimeoutSecs = 15; // 15 secs. |
| 151 | |
| 152 | // Minimum number of RTTs between Server Config Updates (SCUP) sent to client. |
| 153 | const int kMinIntervalBetweenServerConfigUpdatesRTTs = 10; |
| 154 | |
| 155 | // Minimum time between Server Config Updates (SCUP) sent to client. |
| 156 | const int kMinIntervalBetweenServerConfigUpdatesMs = 1000; |
| 157 | |
| 158 | // Minimum number of packets between Server Config Updates (SCUP). |
| 159 | const int kMinPacketsBetweenServerConfigUpdates = 100; |
| 160 | |
| 161 | // The number of open streams that a server will accept is set to be slightly |
| 162 | // larger than the negotiated limit. Immediately closing the connection if the |
| 163 | // client opens slightly too many streams is not ideal: the client may have sent |
| 164 | // a FIN that was lost, and simultaneously opened a new stream. The number of |
| 165 | // streams a server accepts is a fixed increment over the negotiated limit, or a |
| 166 | // percentage increase, whichever is larger. |
| 167 | const float kMaxStreamsMultiplier = 1.1f; |
| 168 | const int kMaxStreamsMinimumIncrement = 10; |
| 169 | |
| 170 | // Available streams are ones with IDs less than the highest stream that has |
| 171 | // been opened which have neither been opened or reset. The limit on the number |
| 172 | // of available streams is 10 times the limit on the number of open streams. |
| 173 | const int kMaxAvailableStreamsMultiplier = 10; |
| 174 | |
| 175 | // Track the number of promises that are not yet claimed by a |
| 176 | // corresponding get. This must be smaller than |
| 177 | // kMaxAvailableStreamsMultiplier, because RST on a promised stream my |
| 178 | // create available streams entries. |
| 179 | const int kMaxPromisedStreamsMultiplier = kMaxAvailableStreamsMultiplier - 1; |
| 180 | |
| 181 | // TCP RFC calls for 1 second RTO however Linux differs from this default and |
| 182 | // define the minimum RTO to 200ms, we will use the same until we have data to |
| 183 | // support a higher or lower value. |
| 184 | static const int64_t kMinRetransmissionTimeMs = 200; |
| 185 | // The delayed ack time must not be greater than half the min RTO. |
| 186 | static_assert(kDefaultDelayedAckTimeMs <= kMinRetransmissionTimeMs / 2, |
| 187 | "Delayed ack time must be less than or equal half the MinRTO"); |
| 188 | |
| 189 | // We define an unsigned 16-bit floating point value, inspired by IEEE floats |
| 190 | // (http://en.wikipedia.org/wiki/Half_precision_floating-point_format), |
| 191 | // with 5-bit exponent (bias 1), 11-bit mantissa (effective 12 with hidden |
| 192 | // bit) and denormals, but without signs, transfinites or fractions. Wire format |
| 193 | // 16 bits (little-endian byte order) are split into exponent (high 5) and |
| 194 | // mantissa (low 11) and decoded as: |
| 195 | // uint64_t value; |
| 196 | // if (exponent == 0) value = mantissa; |
| 197 | // else value = (mantissa | 1 << 11) << (exponent - 1) |
| 198 | const int kUFloat16ExponentBits = 5; |
| 199 | const int kUFloat16MaxExponent = (1 << kUFloat16ExponentBits) - 2; // 30 |
| 200 | const int kUFloat16MantissaBits = 16 - kUFloat16ExponentBits; // 11 |
| 201 | const int kUFloat16MantissaEffectiveBits = kUFloat16MantissaBits + 1; // 12 |
| 202 | const uint64_t kUFloat16MaxValue = // 0x3FFC0000000 |
| 203 | ((UINT64_C(1) << kUFloat16MantissaEffectiveBits) - 1) |
| 204 | << kUFloat16MaxExponent; |
| 205 | |
| 206 | // kDiversificationNonceSize is the size, in bytes, of the nonce that a server |
| 207 | // may set in the packet header to ensure that its INITIAL keys are not |
| 208 | // duplicated. |
| 209 | const size_t kDiversificationNonceSize = 32; |
| 210 | |
| 211 | // The largest gap in packets we'll accept without closing the connection. |
| 212 | // This will likely have to be tuned. |
| 213 | const QuicPacketCount kMaxPacketGap = 5000; |
| 214 | |
haoyuewang | 47d67c3 | 2021-01-21 07:58:52 -0800 | [diff] [blame] | 215 | // The max number of sequence number intervals that |
| 216 | // QuicPeerIssuedConnetionIdManager can maintain. |
| 217 | const size_t kMaxNumConnectionIdSequenceNumberIntervals = 20; |
| 218 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 219 | // The maximum number of random padding bytes to add. |
| 220 | const QuicByteCount kMaxNumRandomPaddingBytes = 256; |
| 221 | |
| 222 | // The size of stream send buffer data slice size in bytes. A data slice is |
| 223 | // piece of stream data stored in contiguous memory, and a stream frame can |
| 224 | // contain data from multiple data slices. |
| 225 | const QuicByteCount kQuicStreamSendBufferSliceSize = 4 * 1024; |
| 226 | |
| 227 | // For When using Random Initial Packet Numbers, they can start |
| 228 | // anyplace in the range 1...((2^31)-1) or 0x7fffffff |
| 229 | QUIC_EXPORT_PRIVATE QuicPacketNumber MaxRandomInitialPacketNumber(); |
| 230 | |
| 231 | // Used to represent an invalid or no control frame id. |
| 232 | const QuicControlFrameId kInvalidControlFrameId = 0; |
| 233 | |
| 234 | // The max length a stream can have. |
| 235 | const QuicByteCount kMaxStreamLength = (UINT64_C(1) << 62) - 1; |
| 236 | |
| 237 | // The max value that can be encoded using IETF Var Ints. |
| 238 | const uint64_t kMaxIetfVarInt = UINT64_C(0x3fffffffffffffff); |
| 239 | |
| 240 | // The maximum stream id value that is supported - (2^32)-1 |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 241 | const QuicStreamId kMaxQuicStreamId = 0xffffffff; |
| 242 | |
fkastenholz | 3c4eabf | 2019-04-22 07:49:59 -0700 | [diff] [blame] | 243 | // The maximum value that can be stored in a 32-bit QuicStreamCount. |
| 244 | const QuicStreamCount kMaxQuicStreamCount = 0xffffffff; |
| 245 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 246 | // Number of bytes reserved for packet header type. |
| 247 | const size_t kPacketHeaderTypeSize = 1; |
| 248 | |
| 249 | // Number of bytes reserved for connection ID length. |
| 250 | const size_t kConnectionIdLengthSize = 1; |
| 251 | |
| 252 | // Minimum length of random bytes in IETF stateless reset packet. |
| 253 | const size_t kMinRandomBytesLengthInStatelessReset = 24; |
| 254 | |
| 255 | // Maximum length allowed for the token in a NEW_TOKEN frame. |
| 256 | const size_t kMaxNewTokenTokenLength = 0xffff; |
| 257 | |
fayang | 14650e4 | 2019-06-04 10:30:33 -0700 | [diff] [blame] | 258 | // Default initial rtt used before any samples are received. |
| 259 | const int kInitialRttMs = 100; |
| 260 | |
ianswett | 34030d0 | 2020-04-10 07:57:15 -0700 | [diff] [blame] | 261 | // Default threshold of packet reordering before a packet is declared lost. |
| 262 | static const QuicPacketCount kDefaultPacketReorderingThreshold = 3; |
| 263 | |
fayang | b0c7b4b | 2019-09-12 06:45:24 -0700 | [diff] [blame] | 264 | // Default fraction (1/4) of an RTT the algorithm waits before determining a |
| 265 | // packet is lost due to early retransmission by time based loss detection. |
| 266 | static const int kDefaultLossDelayShift = 2; |
| 267 | |
fayang | 0198341 | 2019-12-07 05:50:22 -0800 | [diff] [blame] | 268 | // Default fraction (1/8) of an RTT when doing IETF loss detection. |
| 269 | static const int kDefaultIetfLossDelayShift = 3; |
| 270 | |
fayang | 4c908f0 | 2019-11-01 07:26:17 -0700 | [diff] [blame] | 271 | // Maximum number of retransmittable packets received before sending an ack. |
| 272 | const QuicPacketCount kDefaultRetransmittablePacketsBeforeAck = 2; |
| 273 | // Wait for up to 10 retransmittable packets before sending an ack. |
| 274 | const QuicPacketCount kMaxRetransmittablePacketsBeforeAck = 10; |
| 275 | // Minimum number of packets received before ack decimation is enabled. |
| 276 | // This intends to avoid the beginning of slow start, when CWNDs may be |
| 277 | // rapidly increasing. |
| 278 | const QuicPacketCount kMinReceivedBeforeAckDecimation = 100; |
haoyuewang | 52701b0 | 2020-10-15 13:29:17 -0700 | [diff] [blame] | 279 | // One quarter RTT delay when doing ack decimation. |
| 280 | const float kAckDecimationDelay = 0.25; |
fayang | 4c908f0 | 2019-11-01 07:26:17 -0700 | [diff] [blame] | 281 | |
ianswett | 8f90e51 | 2019-12-18 10:50:27 -0800 | [diff] [blame] | 282 | // The default alarm granularity assumed by QUIC code. |
| 283 | const QuicTime::Delta kAlarmGranularity = QuicTime::Delta::FromMilliseconds(1); |
| 284 | |
haoyuewang | d0b353c | 2021-01-26 07:17:20 -0800 | [diff] [blame] | 285 | // Maximum number of unretired connection IDs a connection can have. |
| 286 | const size_t kMaxNumConnectonIdsInUse = 10u; |
| 287 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 288 | // Packet number of first sending packet of a connection. Please note, this |
| 289 | // cannot be used as first received packet because peer can choose its starting |
| 290 | // packet number. |
| 291 | QUIC_EXPORT_PRIVATE QuicPacketNumber FirstSendingPacketNumber(); |
| 292 | |
| 293 | // Used by clients to tell if a public reset is sent from a Google frontend. |
| 294 | QUIC_EXPORT_PRIVATE extern const char* const kEPIDGoogleFrontEnd; |
| 295 | QUIC_EXPORT_PRIVATE extern const char* const kEPIDGoogleFrontEnd0; |
| 296 | |
dschinazi | 9286a3f | 2021-02-25 14:50:26 -0800 | [diff] [blame] | 297 | // HTTP/3 Datagrams. |
| 298 | enum : QuicDatagramFlowId { |
| 299 | kFirstDatagramFlowIdClient = 0, |
| 300 | kFirstDatagramFlowIdServer = 1, |
| 301 | kDatagramFlowIdIncrement = 2, |
| 302 | }; |
| 303 | |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 304 | } // namespace quic |
| 305 | |
| 306 | #endif // QUICHE_QUIC_CORE_QUIC_CONSTANTS_H_ |