blob: b750abb3a4f38776cd1315a42b54d0695da3beb2 [file] [log] [blame]
QUICHE teama6ef0a62019-03-07 20:34:33 -05001// 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 team5be974e2020-12-29 18:35:24 -050013#include "quic/core/quic_types.h"
14#include "quic/platform/api/quic_export.h"
QUICHE teama6ef0a62019-03-07 20:34:33 -050015
16// Definitions of constant values used throughout the QUIC code.
17
18namespace quic {
19
20// Simple time constants.
21const uint64_t kNumSecondsPerMinute = 60;
22const uint64_t kNumSecondsPerHour = kNumSecondsPerMinute * 60;
23const uint64_t kNumSecondsPerWeek = kNumSecondsPerHour * 24 * 7;
dschinazi6cf4d2a2019-04-30 16:20:23 -070024const uint64_t kNumMillisPerSecond = 1000;
QUICHE teama6ef0a62019-03-07 20:34:33 -050025const uint64_t kNumMicrosPerMilli = 1000;
dschinazi6cf4d2a2019-04-30 16:20:23 -070026const uint64_t kNumMicrosPerSecond = kNumMicrosPerMilli * kNumMillisPerSecond;
QUICHE teama6ef0a62019-03-07 20:34:33 -050027
28// Default number of connections for N-connection emulation.
29const uint32_t kDefaultNumConnections = 2;
30// Default initial maximum size in bytes of a QUIC packet.
31const QuicByteCount kDefaultMaxPacketSize = 1350;
32// Default initial maximum size in bytes of a QUIC packet for servers.
33const QuicByteCount kDefaultServerMaxPacketSize = 1000;
34// Maximum transmission unit on Ethernet.
35const QuicByteCount kEthernetMTU = 1500;
dschinazi66dea072019-04-09 11:41:06 -070036// 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 teama6ef0a62019-03-07 20:34:33 -050038// additional 8 bytes. This is a total overhead of 48 bytes. Ethernet's
39// max packet size is 1500 bytes, 1500 - 48 = 1452.
dschinazi66dea072019-04-09 11:41:06 -070040const QuicByteCount kMaxV6PacketSize = 1452;
QUICHE teama6ef0a62019-03-07 20:34:33 -050041// The maximum packet size of any QUIC packet over IPv4.
42// 1500(Ethernet) - 20(IPv4 header) - 8(UDP header) = 1472.
43const QuicByteCount kMaxV4PacketSize = 1472;
dschinazie8d7fa72019-04-05 14:44:40 -070044// The maximum incoming packet size allowed.
45const QuicByteCount kMaxIncomingPacketSize = kMaxV4PacketSize;
dschinazi66dea072019-04-09 11:41:06 -070046// The maximum outgoing packet size allowed.
47const QuicByteCount kMaxOutgoingPacketSize = kMaxV6PacketSize;
QUICHE teama6ef0a62019-03-07 20:34:33 -050048// ETH_MAX_MTU - MAX(sizeof(iphdr), sizeof(ip6_hdr)) - sizeof(udphdr).
49const QuicByteCount kMaxGsoPacketSize = 65535 - 40 - 8;
dschinazicd86dd12019-11-14 10:11:13 -080050// 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.
52const QuicByteCount kMaxAcceptedDatagramFrameSize = 65536;
dschinazi4ad1f462020-01-16 11:56:52 -080053// Default value of the max_packet_size transport parameter if it is not
54// transmitted.
55const QuicByteCount kDefaultMaxPacketSizeTransportParam = 65527;
QUICHE teama6ef0a62019-03-07 20:34:33 -050056// Default maximum packet size used in the Linux TCP implementation.
57// Used in QUIC for congestion window computations in bytes.
58const QuicByteCount kDefaultTCPMSS = 1460;
59const 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.
62const QuicByteCount kMinPacketSizeForVersionNegotiation = 1200;
63
64// We match SPDY's use of 32 (since we'd compete with SPDY).
65const QuicPacketCount kInitialCongestionWindow = 32;
66
fayangbe83ecd2019-04-26 13:58:09 -070067// Do not allow initial congestion window to be greater than 200 packets.
68const QuicPacketCount kMaxInitialCongestionWindow = 200;
69
fayangf1b99dc2019-05-14 06:29:18 -070070// Do not allow initial congestion window to be smaller than 10 packets.
71const QuicPacketCount kMinInitialCongestionWindow = 10;
72
QUICHE teama6ef0a62019-03-07 20:34:33 -050073// Minimum size of initial flow control window, for both stream and session.
dschinazic7036122019-04-30 12:46:34 -070074// This is only enforced when version.AllowsLowFlowControlLimits() is false.
dschinazif1e7b422020-04-30 12:21:28 -070075const QuicByteCount kMinimumFlowControlSendWindow = 16 * 1024; // 16 KB
dschinazic7036122019-04-30 12:46:34 -070076// Default size of initial flow control window, for both stream and session.
dschinazif1e7b422020-04-30 12:21:28 -070077const QuicByteCount kDefaultFlowControlSendWindow = 16 * 1024; // 16 KB
QUICHE teama6ef0a62019-03-07 20:34:33 -050078
79// Maximum flow control receive window limits for connection and stream.
80const QuicByteCount kStreamReceiveWindowLimit = 16 * 1024 * 1024; // 16 MB
81const QuicByteCount kSessionReceiveWindowLimit = 24 * 1024 * 1024; // 24 MB
82
QUICHE teama6ef0a62019-03-07 20:34:33 -050083// Minimum size of the CWND, in packets, when doing bandwidth resumption.
84const QuicPacketCount kMinCongestionWindowForBandwidthResumption = 10;
85
QUICHE teama6ef0a62019-03-07 20:34:33 -050086// Default size of the socket receive buffer in bytes.
87const QuicByteCount kDefaultSocketReceiveBuffer = 1024 * 1024;
88
89// Don't allow a client to suggest an RTT shorter than 10ms.
90const uint32_t kMinInitialRoundTripTimeUs = 10 * kNumMicrosPerMilli;
91
fayang0ddf8a52020-10-27 12:00:24 -070092// Don't allow a client to suggest an RTT longer than 1 second.
93const uint32_t kMaxInitialRoundTripTimeUs = kNumMicrosPerSecond;
QUICHE teama6ef0a62019-03-07 20:34:33 -050094
95// Maximum number of open streams per connection.
96const size_t kDefaultMaxStreamsPerConnection = 100;
97
98// Number of bytes reserved for public flags in the packet header.
99const size_t kPublicFlagsSize = 1;
100// Number of bytes reserved for version number in the packet header.
101const size_t kQuicVersionSize = 4;
102
haoyuewange3c51d92021-03-08 07:35:03 -0800103// Minimum number of active connection IDs that an end point can maintain.
104const uint32_t kMinNumOfActiveConnectionIds = 2;
105
dschinazi278efae2020-01-28 17:03:09 -0800106// Length of the retry integrity tag in bytes.
107// https://tools.ietf.org/html/draft-ietf-quic-transport-25#section-17.2.5
108const size_t kRetryIntegrityTagLength = 16;
109
haoyuewange0acd512020-11-05 09:18:36 -0800110// By default, UnackedPacketsMap allocates buffer of 64 after the first packet
111// is added.
112const int kDefaultUnackedPacketsInitialCapacity = 64;
113
QUICHE teama6ef0a62019-03-07 20:34:33 -0500114// Signifies that the QuicPacket will contain version of the protocol.
115const bool kIncludeVersion = true;
116// Signifies that the QuicPacket will include a diversification nonce.
117const bool kIncludeDiversificationNonce = true;
118
119// Header key used to identify final offset on data stream when sending HTTP/2
120// trailing headers over QUIC.
121QUIC_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.
126const int64_t kDefaultDelayedAckTimeMs = 25;
127
haoyuewang7cffa542020-07-15 17:12:27 -0700128// Default minimum delayed ack time, in ms (used only for sender control of ack
129// frequency).
haoyuewang24d8d702020-10-19 08:05:01 -0700130const uint32_t kDefaultMinAckDelayTimeMs = 5;
haoyuewang7cffa542020-07-15 17:12:27 -0700131
fkastenholz4dc4ba32019-07-30 09:55:25 -0700132// Default shift of the ACK delay in the IETF QUIC ACK frame.
133const uint32_t kDefaultAckDelayExponent = 3;
134
QUICHE teama6ef0a62019-03-07 20:34:33 -0500135// Minimum tail loss probe time in ms.
136static const int64_t kMinTailLossProbeTimeoutMs = 10;
137
138// The timeout before the handshake succeeds.
139const int64_t kInitialIdleTimeoutSecs = 5;
QUICHE teama6ef0a62019-03-07 20:34:33 -0500140// The maximum idle timeout that can be negotiated.
141const int64_t kMaximumIdleTimeoutSecs = 60 * 10; // 10 minutes.
142// The default timeout for a connection until the crypto handshake succeeds.
143const 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.
147const size_t kDefaultMaxUndecryptablePackets = 10;
148
149// Default ping timeout.
150const int64_t kPingTimeoutSecs = 15; // 15 secs.
151
152// Minimum number of RTTs between Server Config Updates (SCUP) sent to client.
153const int kMinIntervalBetweenServerConfigUpdatesRTTs = 10;
154
155// Minimum time between Server Config Updates (SCUP) sent to client.
156const int kMinIntervalBetweenServerConfigUpdatesMs = 1000;
157
158// Minimum number of packets between Server Config Updates (SCUP).
159const 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.
167const float kMaxStreamsMultiplier = 1.1f;
168const 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.
173const 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.
179const 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.
184static const int64_t kMinRetransmissionTimeMs = 200;
185// The delayed ack time must not be greater than half the min RTO.
186static_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)
198const int kUFloat16ExponentBits = 5;
199const int kUFloat16MaxExponent = (1 << kUFloat16ExponentBits) - 2; // 30
200const int kUFloat16MantissaBits = 16 - kUFloat16ExponentBits; // 11
201const int kUFloat16MantissaEffectiveBits = kUFloat16MantissaBits + 1; // 12
202const 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.
209const 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.
213const QuicPacketCount kMaxPacketGap = 5000;
214
haoyuewang47d67c32021-01-21 07:58:52 -0800215// The max number of sequence number intervals that
216// QuicPeerIssuedConnetionIdManager can maintain.
217const size_t kMaxNumConnectionIdSequenceNumberIntervals = 20;
218
QUICHE teama6ef0a62019-03-07 20:34:33 -0500219// The maximum number of random padding bytes to add.
220const 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.
225const 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
229QUIC_EXPORT_PRIVATE QuicPacketNumber MaxRandomInitialPacketNumber();
230
231// Used to represent an invalid or no control frame id.
232const QuicControlFrameId kInvalidControlFrameId = 0;
233
234// The max length a stream can have.
235const QuicByteCount kMaxStreamLength = (UINT64_C(1) << 62) - 1;
236
237// The max value that can be encoded using IETF Var Ints.
238const uint64_t kMaxIetfVarInt = UINT64_C(0x3fffffffffffffff);
239
240// The maximum stream id value that is supported - (2^32)-1
QUICHE teama6ef0a62019-03-07 20:34:33 -0500241const QuicStreamId kMaxQuicStreamId = 0xffffffff;
242
fkastenholz3c4eabf2019-04-22 07:49:59 -0700243// The maximum value that can be stored in a 32-bit QuicStreamCount.
244const QuicStreamCount kMaxQuicStreamCount = 0xffffffff;
245
QUICHE teama6ef0a62019-03-07 20:34:33 -0500246// Number of bytes reserved for packet header type.
247const size_t kPacketHeaderTypeSize = 1;
248
249// Number of bytes reserved for connection ID length.
250const size_t kConnectionIdLengthSize = 1;
251
252// Minimum length of random bytes in IETF stateless reset packet.
253const size_t kMinRandomBytesLengthInStatelessReset = 24;
254
255// Maximum length allowed for the token in a NEW_TOKEN frame.
256const size_t kMaxNewTokenTokenLength = 0xffff;
257
fayang14650e42019-06-04 10:30:33 -0700258// Default initial rtt used before any samples are received.
259const int kInitialRttMs = 100;
260
ianswett34030d02020-04-10 07:57:15 -0700261// Default threshold of packet reordering before a packet is declared lost.
262static const QuicPacketCount kDefaultPacketReorderingThreshold = 3;
263
fayangb0c7b4b2019-09-12 06:45:24 -0700264// 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.
266static const int kDefaultLossDelayShift = 2;
267
fayang01983412019-12-07 05:50:22 -0800268// Default fraction (1/8) of an RTT when doing IETF loss detection.
269static const int kDefaultIetfLossDelayShift = 3;
270
fayang4c908f02019-11-01 07:26:17 -0700271// Maximum number of retransmittable packets received before sending an ack.
272const QuicPacketCount kDefaultRetransmittablePacketsBeforeAck = 2;
273// Wait for up to 10 retransmittable packets before sending an ack.
274const 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.
278const QuicPacketCount kMinReceivedBeforeAckDecimation = 100;
haoyuewang52701b02020-10-15 13:29:17 -0700279// One quarter RTT delay when doing ack decimation.
280const float kAckDecimationDelay = 0.25;
fayang4c908f02019-11-01 07:26:17 -0700281
ianswett8f90e512019-12-18 10:50:27 -0800282// The default alarm granularity assumed by QUIC code.
283const QuicTime::Delta kAlarmGranularity = QuicTime::Delta::FromMilliseconds(1);
284
haoyuewangd0b353c2021-01-26 07:17:20 -0800285// Maximum number of unretired connection IDs a connection can have.
286const size_t kMaxNumConnectonIdsInUse = 10u;
287
QUICHE teama6ef0a62019-03-07 20:34:33 -0500288// 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.
291QUIC_EXPORT_PRIVATE QuicPacketNumber FirstSendingPacketNumber();
292
293// Used by clients to tell if a public reset is sent from a Google frontend.
294QUIC_EXPORT_PRIVATE extern const char* const kEPIDGoogleFrontEnd;
295QUIC_EXPORT_PRIVATE extern const char* const kEPIDGoogleFrontEnd0;
296
dschinazi9286a3f2021-02-25 14:50:26 -0800297// HTTP/3 Datagrams.
298enum : QuicDatagramFlowId {
299 kFirstDatagramFlowIdClient = 0,
300 kFirstDatagramFlowIdServer = 1,
301 kDatagramFlowIdIncrement = 2,
302};
303
QUICHE teama6ef0a62019-03-07 20:34:33 -0500304} // namespace quic
305
306#endif // QUICHE_QUIC_CORE_QUIC_CONSTANTS_H_