// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "net/quic/quic_flags.h" // When true, the use time based loss detection instead of nack. bool FLAGS_quic_use_time_loss_detection = false; // If true, it will return as soon as an error is detected while validating // CHLO. bool FLAGS_use_early_return_when_verifying_chlo = true; // When true, defaults to BBR congestion control instead of Cubic. bool FLAGS_quic_use_bbr_congestion_control = false; // If true, QUIC BBR congestion control may be enabled via Finch and/or via QUIC // connection options. bool FLAGS_quic_allow_bbr = false; // Time period for which a given connection_id should live in the time-wait // state. int64_t FLAGS_quic_time_wait_list_seconds = 200; // Currently, this number is quite conservative. The max QPS limit for an // individual server silo is currently set to 1000 qps, though the actual max // that we see in the wild is closer to 450 qps. Regardless, this means that // the longest time-wait list we should see is 200 seconds * 1000 qps = 200000. // Of course, there are usually many queries per QUIC connection, so we allow a // factor of 3 leeway. // // Maximum number of connections on the time-wait list. A negative value implies // no configured limit. int64_t FLAGS_quic_time_wait_list_max_connections = 600000; // Enables server-side support for QUIC stateless rejects. bool FLAGS_enable_quic_stateless_reject_support = true; // This flag is not in use, just to keep consistency for shared code. bool FLAGS_quic_always_log_bugs_for_tests = false; // If true, flow controller may grow the receive window size if necessary. bool FLAGS_quic_auto_tune_receive_window = true; // If true, multipath is enabled for the connection. bool FLAGS_quic_enable_multipath = false; // If true, require handshake confirmation for QUIC connections, functionally // disabling 0-rtt handshakes. // TODO(rtenneti): Enable this flag after CryptoServerTest's are fixed. bool FLAGS_quic_require_handshake_confirmation = false; // If true, Cubic's epoch is shifted when the sender is application-limited. bool FLAGS_shift_quic_cubic_epoch_when_app_limited = true; // If true, QUIC will measure head of line (HOL) blocking due between // streams due to packet losses on the headers stream. The // measurements will be surfaced via UMA histogram // Net.QuicSession.HeadersHOLBlockedTime. bool FLAGS_quic_measure_headers_hol_blocking_time = true; // Disable QUIC's userspace pacing. bool FLAGS_quic_disable_pacing = false; // If true, Close the connection instead of writing unencrypted stream data. bool FLAGS_quic_never_write_unencrypted_data = true; // If true, reject any incoming QUIC which does not have the FIXD tag. bool FLAGS_quic_require_fix = true; // If true, headers stream will support receiving PUSH_PROMISE frames. bool FLAGS_quic_supports_push_promise = true; // When turn on, log packet loss into transport connection stats LossEvent. bool FLAGS_quic_log_loss_event = true; // If true, make sure new incoming streams correctly cede to higher // priority (or batch) streams when doing QUIC writes. bool FLAGS_quic_cede_correctly = true; // If on, max number of incoming and outgoing streams will be different. // Incoming will be a little higher than outgoing to tolerate race condition. bool FLAGS_quic_different_max_num_open_streams = true; // If true, QUIC should correctly report if it supports ChaCha20. Otherwise, // QUIC will lie and claim that it does not support ChaCha20. The primary use // case for this is places where ChaCha20 is prohibitively expensive compared to // AES-GCM. bool FLAGS_quic_crypto_server_config_default_has_chacha20 = true; // If true, always log the cached network parameters, regardless of whether // bandwidth-resumption has been enabled. bool FLAGS_quic_log_received_parameters = true; // If true, QUIC will use newly refactored TCP sender code. bool FLAGS_quic_use_new_tcp_sender = true; // Saves the initial subkey secret in QUIC crypto when deriving keys from the // initial premaster secret. bool FLAGS_quic_save_initial_subkey_secret = true; // If true, the QUIC dispatcher will directly send version negotiation packets // without needing to create a QUIC session first. bool FLAGS_quic_stateless_version_negotiation = false; // QUIC Ack Decimation with tolerance for packet reordering. bool FLAGS_quic_ack_decimation2 = true; // If true, QUIC connections will defer responding to ACKs to their send alarms. bool FLAGS_quic_connection_defer_ack_response = true; // If true, calls to QuicAlarm::Cancel don't do anything if the alarm is not // set. bool FLAGS_quic_only_cancel_set_alarms = true; // Simplify QUIC's write path for inplace encryption now that FEC is gone. bool FLAGS_quic_inplace_encryption2 = true; // If true, SpdyFramer will call OnStreamEnd from SpdyFramerVisitorInterface // instead of empty-data sentinel calls when the stream is to be ended. bool FLAGS_spdy_on_stream_end = true; // If true, QuicCryptoServerConfig will use cached compressed certificates // if the uncompressed certs to be compressed hits the cache. bool FLAGS_quic_use_cached_compressed_certs = true; // Enable a connection option allowing connections to time out if more than 5 // consecutive RTOs are sent. bool FLAGS_quic_enable_rto_timeout = true; // Do not limit the max CWND to 200 packets in QUIC. bool FLAGS_quic_dont_limit_max_cwnd = true; // Don't copy QuicAckFrame or QuicStopWaitingFrame into the // QuicPacketGenerator. bool FLAGS_quic_dont_copy_acks = true; // Use a byte conservation approach instead of packet conservation in the // Slow Start Large Reduction experiment. bool FLAGS_quic_sslr_byte_conservation = true;