<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.30 (Ruby 3.4.8) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-ccwg-ratelimited-increase-03" category="std" consensus="true" submissionType="IETF" updates="RFC5681, RFC9002, RFC9260, RFC9438" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.31.0 -->
  <front>
    <title abbrev="Rate-Limited cwnd Increase">Increase of the Congestion Window when the Sender Is Rate-Limited</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-ccwg-ratelimited-increase-03"/>
    <author initials="M." surname="Welzl" fullname="Michael Welzl">
      <organization>University of Oslo</organization>
      <address>
        <postal>
          <street>PO Box 1080 Blindern</street>
          <city>0316  Oslo</city>
          <country>Norway</country>
        </postal>
        <email>michawe@ifi.uio.no</email>
        <uri>http://welzl.at/</uri>
      </address>
    </author>
    <author initials="T." surname="Henderson" fullname="Tom Henderson">
      <organization>University of Washington</organization>
      <address>
        <postal>
          <street>185 Stevens Way</street>
          <city>Seattle, WA 98195</city>
          <country>United States</country>
        </postal>
        <email>tomh@tomh.org</email>
        <uri>https://www.tomh.org/</uri>
      </address>
    </author>
    <author initials="G." surname="Fairhurst" fullname="Godred Fairhurst">
      <organization>University of Aberdeen</organization>
      <address>
        <postal>
          <street>Fraser Noble Building</street>
          <city>Aberdeen, AB24 3UE</city>
          <country>UK</country>
        </postal>
        <email>gorry@erg.abdn.ac.uk</email>
        <uri>https://www.erg.abdn.ac.uk/</uri>
      </address>
    </author>
    <author initials="M. P." surname="Tahiliani" fullname="Mohit P. Tahiliani">
      <organization>National Institute of Technology Karnataka</organization>
      <address>
        <postal>
          <street>P. O. Srinivasnagar, Surathkal</street>
          <city>Mangalore, Karnataka - 575025</city>
          <country>India</country>
        </postal>
        <email>tahiliani@nitk.edu.in</email>
        <uri>https://tahiliani.in/</uri>
      </address>
    </author>
    <date year="2026" month="February" day="17"/>
    <area>Transport</area>
    <workgroup>Congestion Control Working Group</workgroup>
    <abstract>
      <?line 74?>

<t>This document specifies how transport protocols increase their congestion window when the sender is rate-limited, and updates RFC 5681, RFC 9002, RFC 9260, and RFC 9438.
Such a limitation can be caused by the sending application not supplying data or by receiver flow control.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://mwelzl.github.io/draft-ccwg-ratelimited-increase/draft-ietf-ccwg-ratelimited-increase.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-ccwg-ratelimited-increase/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Congestion Control Working Group Working Group mailing list (<eref target="mailto:ccwg@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/ccwg/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/ccwg/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/mwelzl/draft-ccwg-ratelimited-increase"/>.</t>
    </note>
  </front>
  <middle>
    <?line 80?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>A sender of a congestion controlled transport protocol becomes "rate-limited" when it does not send any data
even though the congestion control rules would allow it to transmit data.
This could occur because the application has not provided sufficient data to fully utilise the congestion window (cwnd).
It could also occur because the receiver has limited the sender using flow control
(e.g., by the advertised TCP receiver window (rwnd) or by the connection or stream flow credit in QUIC).
Current RFCs specifying congestion control algorithms diverge regarding the rules for increasing the cwnd when the sender is rate-limited.</t>
      <t>Congestion Window Validation (CWV) <xref target="RFC7661"/> provides an experimental specification defining how to manage a cwnd that has
become larger than the current flight size, and how to respond to detected congestion when this is the case.
In contrast, this present document concerns the increase in cwnd when a sender is rate-limited. These two topics are distinct,
but are related, because both describe the management of the cwnd when a sender does not fully utilise the current cwnd.</t>
      <t>An appendix provides an example of how rate-limited increase can play out.</t>
      <t>RFC-Ed Note, please remove the following sentence prior to publication:
Another appendix provides an overview of the divergence in current RFCs and some implementations regarding cwnd increase when the sender is rate-limited (the second appendix is to be removed before publication).</t>
    </section>
    <section anchor="conventions-and-definitions">
      <name>Conventions and Definitions</name>
      <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
      <?line -18?>

<section anchor="terminology">
        <name>Terminology</name>
        <t>This document uses the terms defined in <xref section="2" sectionFormat="of" target="RFC5681"/> and <xref section="3" sectionFormat="of" target="RFC7661"/>. Additionally, we define:</t>
        <ul spacing="normal">
          <li>
            <t>initcwnd: The initial value of the congestion window, also known as the "initial window" ("IW" in <xref target="RFC5681"/>).</t>
          </li>
          <li>
            <t>maxFS: the largest value of FlightSize since the last time that cwnd was decreased. If cwnd has never been decreased, maxFS is the maximum value of FlightSize since the start of the data transfer, and at least as large as initcwnd.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="rules">
      <name>Rate-Limited Increase</name>
      <t>When FlightSize &lt; cwnd, regardless of the current state of a congestion control algorithm, the following  "Rate-Limited Increase" rules apply for senders using a congestion controlled transport protocol:</t>
      <t>The sender <bcp14>MUST</bcp14> initialise the maxFS parameter to initcwnd when the congestion control algorithm is started. Thereafter when the FlightSize is updated, the sender updates maxFS:</t>
      <artwork><![CDATA[
maxFS = max(FlightSize, maxFS)
]]></artwork>
      <t>Upon a reduction of cwnd (for any reason), maxFS <bcp14>MUST</bcp14> be reset to zero. This ensures that maxFS is reinitialized using the first FlightSize measurement taken after the cwnd reduction.</t>
      <t>The sender <bcp14>MUST</bcp14> cap cwnd to be no larger than limit(maxFS).</t>
      <t>The function limit() returns the maximum cwnd value the congestion control algorithm would yield by increasing for all ACKs that would be produced by successfully transmitting one window of size maxFS.
For example, for Slow Start, as specified in <xref target="RFC5681"/>, limit(maxFS)=2*maxFS, such that equation 2 in <xref target="RFC5681"/> becomes:</t>
      <artwork><![CDATA[
cwnd_new = cwnd + min (N, SMSS)
cwnd = min(cwnd_new, 2*maxFS)
]]></artwork>
      <t>where cwnd and SMSS follow their definitions in <xref target="RFC5681"/> and N is the number of previously unacknowledged bytes acknowledged in the incoming ACK.</t>
      <t>Similarly, with Rate-Limited Increase applied in Congestion Avoidance, limit(maxFS)=SMSS+maxFS, such that equation 3 in <xref target="RFC5681"/> becomes:</t>
      <artwork><![CDATA[
cwnd_new = cwnd + SMSS*SMSS/cwnd
cwnd = min(cwnd_new, SMSS+maxFS)
]]></artwork>
      <t>where cwnd and SMSS follow their definitions in <xref target="RFC5681"/>.</t>
      <t>NOTE: This specification defines the current method used to increase the cwnd for a rate-limited sender. Without a way to reduce cwnd when the transport sender becomes rate-limited, maxFS can stay valid for a long time, possibly not reflecting the reality of the end-to-end Internet path in use. This is remedied by "Congestion Window Validation" in <xref target="RFC7661"/>, which also defines a "pipeACK" variable that measures the recently acknowledged size of the network pipe when the sender was rate-limited.</t>
      <section anchor="example">
        <name>Example</name>
        <t>We illustrate the working of Rate-Limited Increase by showing the increase of cwnd in two scenarios: when the growth of cwnd is unconstrained, and when the rate-limited sender is constrained by Rate-Limited Increase. For simplicity, this example accounts for the cwnd in segments, rather than bytes. In both cases, we assume the initial cwnd (initcwnd) = 10 segments, as defined for TCP in <xref target="RFC6928"/> and QUIC in <xref target="RFC9002"/>, a single connection begins with Slow Start, the sender transmits a total of 14 segments but pauses after transmitting 10 segments and resumes the transmission for the remaining 4 segments afterwards, no packets are lost, and an ACK is sent for every packet.</t>
        <section anchor="unconstrained-sender">
          <name>Unconstrained sender</name>
          <t>Initially, cwnd = initcwnd. Therefore, using initcwnd = 10 segments, the sender transmits 10 segments and pauses. Since the sender is in the Slow Start phase, the arrival of an each ACK for the 10 sent segments increases the cwnd by 1 segment, resulting in the cwnd increasing to 20 segments. Subsequently, after the pause, the sender transmits 4 segments and pauses again. As a consequence, the arrival of 4 ACKs results in cwnd further increasing to 24 segments, even though the sender is rate-limited (i.e., has never sent more than 10 segments per round-trip time (RTT)).</t>
        </section>
        <section anchor="sender-constrained-by-rate-limited-increase">
          <name>Sender constrained by Rate-Limited Increase</name>
          <t>Initially, cwnd = initcwnd. Therefore, using initcwnd = 10 segments, the sender transmits 10 segments and pauses; note that FlightSize and maxFS are both 10 segments at this point. Since the sender is in the Slow Start phase, the arrival of each ACK for the 10 sent segments increases the cwnd by 1 segment, resulting in the cwnd increasing to 20 segments. Subsequently, when the sender resumes and transmits 4 new segments, Rate-Limited Increase constrains the growth of the cwnd because FlightSize &lt; cwnd and therefore this caps the cwnd to be no larger than limit(maxFS) = 2 X maxFS = 2 X 10 segments = 20 segments.</t>
        </section>
      </section>
      <section anchor="discussion">
        <name>Discussion</name>
        <t>If the sending rate is less than the rate permitted by the cwnd for multiple RTTs, limited either by the sending application or by the receiver-advertised window, a continuous increase in the cwnd would cause a mismatch between the cwnd and the capacity that the path supports (i.e., over-estimating the capacity).
Such unlimited growth in the cwnd is therefore disallowed.</t>
        <t>However, in most common congestion control algorithms, in the absence of an indication of congestion, a cwnd that has been fully utilized during an RTT (where a sender was cwnd-limited) permits the cwnd to be increased during the immediately following RTT. This increase is allowed by Rate-Limited Increase.</t>
        <section anchor="rate-based-congestion-control">
          <name>Rate-based congestion control</name>
          <t>The present document updates congestion control specifications that use a cwnd to limit the number of unacknowledged bytes (or packets) that a sender is allowed to emit. Use of a cwnd variable to control sending rate is not the only mechanism available and not the only mechanism that is used in practice.</t>
          <t>Congestion control algorithms can also constrain data transmission by explicitly calculating the sending rate over some time interval, by "pacing" packets (injecting pauses in between their transmission) or via combinations of the above (e.g., BBR combines these three methods <xref target="I-D.ietf-ccwg-bbr"/>). The guiding principle behind Rate-Limited Increase applies to all congestion control algorithms: in the absence of a congestion indication, a sender is allowed to increase its rate from the amount of data that it has transmitted during the previous RTT (this holds irrespective of whether the sender is rate-limited or not). Therefore, congestion control algorithms <bcp14>SHOULD</bcp14> implement a behavior that is equivalent to Rate-Limited Increase, irrespective of whether they use a cwnd variable or not.</t>
        </section>
        <section anchor="pacing">
          <name>Pacing</name>
          <t>Pacing mechanisms seek to avoid the negative impacts associated with "bursts" (flights of packets transmitted back-to-back). Rate-Limited Increase introduces a limit using "maxFS", which is based on the number of bytes in flight during a previous RTT; thus, as long as the number of bytes in flight per RTT is unaffected by pacing, Rate-Limited Increase does not constrain the use of pacing mechanisms.</t>
        </section>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>While congestion control designs could result in unwanted competing traffic, they do not directly result in new security considerations.</t>
      <t>The security considerations are the same as for other
congestion control methods.  Such methods rely on the receiver
appropriately acknowledging receipt of data.  The ability of an on-path or off-path attacker to influence congestion control depends
upon the security properties of the transport protocol being used.
Transport protocols that provide authentication (including those using encryption), or are carried over protocols that provide authentication,
can protect their congestion control algorithm from network attack. This is orthogonal to the specification of congestion control rules.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document requests no IANA action.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC7661">
          <front>
            <title>Updating TCP to Support Rate-Limited Traffic</title>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst"/>
            <author fullname="A. Sathiaseelan" initials="A." surname="Sathiaseelan"/>
            <author fullname="R. Secchi" initials="R." surname="Secchi"/>
            <date month="October" year="2015"/>
            <abstract>
              <t>This document provides a mechanism to address issues that arise when TCP is used for traffic that exhibits periods where the sending rate is limited by the application rather than the congestion window. It provides an experimental update to TCP that allows a TCP sender to restart quickly following a rate-limited interval. This method is expected to benefit applications that send rate-limited traffic using TCP while also providing an appropriate response if congestion is experienced.</t>
              <t>This document also evaluates the Experimental specification of TCP Congestion Window Validation (CWV) defined in RFC 2861 and concludes that RFC 2861 sought to address important issues but failed to deliver a widely used solution. This document therefore reclassifies the status of RFC 2861 from Experimental to Historic. This document obsoletes RFC 2861.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7661"/>
          <seriesInfo name="DOI" value="10.17487/RFC7661"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC5681">
          <front>
            <title>TCP Congestion Control</title>
            <author fullname="M. Allman" initials="M." surname="Allman"/>
            <author fullname="V. Paxson" initials="V." surname="Paxson"/>
            <author fullname="E. Blanton" initials="E." surname="Blanton"/>
            <date month="September" year="2009"/>
            <abstract>
              <t>This document defines TCP's four intertwined congestion control algorithms: slow start, congestion avoidance, fast retransmit, and fast recovery. In addition, the document specifies how TCP should begin transmission after a relatively long idle period, as well as discussing various acknowledgment generation methods. This document obsoletes RFC 2581. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5681"/>
          <seriesInfo name="DOI" value="10.17487/RFC5681"/>
        </reference>
        <reference anchor="RFC9002">
          <front>
            <title>QUIC Loss Detection and Congestion Control</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <author fullname="I. Swett" initials="I." role="editor" surname="Swett"/>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document describes loss detection and congestion control mechanisms for QUIC.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9002"/>
          <seriesInfo name="DOI" value="10.17487/RFC9002"/>
        </reference>
        <reference anchor="RFC9438">
          <front>
            <title>CUBIC for Fast and Long-Distance Networks</title>
            <author fullname="L. Xu" initials="L." surname="Xu"/>
            <author fullname="S. Ha" initials="S." surname="Ha"/>
            <author fullname="I. Rhee" initials="I." surname="Rhee"/>
            <author fullname="V. Goel" initials="V." surname="Goel"/>
            <author fullname="L. Eggert" initials="L." role="editor" surname="Eggert"/>
            <date month="August" year="2023"/>
            <abstract>
              <t>CUBIC is a standard TCP congestion control algorithm that uses a cubic function instead of a linear congestion window increase function to improve scalability and stability over fast and long-distance networks. CUBIC has been adopted as the default TCP congestion control algorithm by the Linux, Windows, and Apple stacks.</t>
              <t>This document updates the specification of CUBIC to include algorithmic improvements based on these implementations and recent academic work. Based on the extensive deployment experience with CUBIC, this document also moves the specification to the Standards Track and obsoletes RFC 8312. This document also updates RFC 5681, to allow for CUBIC's occasionally more aggressive sending behavior.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9438"/>
          <seriesInfo name="DOI" value="10.17487/RFC9438"/>
        </reference>
        <reference anchor="RFC9260">
          <front>
            <title>Stream Control Transmission Protocol</title>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="M. Tüxen" initials="M." surname="Tüxen"/>
            <author fullname="K. Nielsen" initials="K." surname="Nielsen"/>
            <date month="June" year="2022"/>
            <abstract>
              <t>This document describes the Stream Control Transmission Protocol (SCTP) and obsoletes RFC 4960. It incorporates the specification of the chunk flags registry from RFC 6096 and the specification of the I bit of DATA chunks from RFC 7053. Therefore, RFCs 6096 and 7053 are also obsoleted by this document. In addition, RFCs 4460 and 8540, which describe errata for SCTP, are obsoleted by this document.</t>
              <t>SCTP was originally designed to transport Public Switched Telephone Network (PSTN) signaling messages over IP networks. It is also suited to be used for other applications, for example, WebRTC.</t>
              <t>SCTP is a reliable transport protocol operating on top of a connectionless packet network, such as IP. It offers the following services to its users:</t>
              <t>The design of SCTP includes appropriate congestion avoidance behavior and resistance to flooding and masquerade attacks.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9260"/>
          <seriesInfo name="DOI" value="10.17487/RFC9260"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC6928">
          <front>
            <title>Increasing TCP's Initial Window</title>
            <author fullname="J. Chu" initials="J." surname="Chu"/>
            <author fullname="N. Dukkipati" initials="N." surname="Dukkipati"/>
            <author fullname="Y. Cheng" initials="Y." surname="Cheng"/>
            <author fullname="M. Mathis" initials="M." surname="Mathis"/>
            <date month="April" year="2013"/>
            <abstract>
              <t>This document proposes an experiment to increase the permitted TCP initial window (IW) from between 2 and 4 segments, as specified in RFC 3390, to 10 segments with a fallback to the existing recommendation when performance issues are detected. It discusses the motivation behind the increase, the advantages and disadvantages of the higher initial window, and presents results from several large-scale experiments showing that the higher initial window improves the overall performance of many web services without resulting in a congestion collapse. The document closes with a discussion of usage and deployment for further experimental purposes recommended by the IETF TCP Maintenance and Minor Extensions (TCPM) working group.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6928"/>
          <seriesInfo name="DOI" value="10.17487/RFC6928"/>
        </reference>
        <reference anchor="I-D.ietf-ccwg-bbr">
          <front>
            <title>BBR Congestion Control</title>
            <author fullname="Neal Cardwell" initials="N." surname="Cardwell">
              <organization>Google</organization>
            </author>
            <author fullname="Ian Swett" initials="I." surname="Swett">
              <organization>Google</organization>
            </author>
            <author fullname="Joseph Beshay" initials="J." surname="Beshay">
              <organization>Meta</organization>
            </author>
            <date day="20" month="October" year="2025"/>
            <abstract>
              <t>   This document specifies the BBR congestion control algorithm.  BBR
   ("Bottleneck Bandwidth and Round-trip propagation time") uses recent
   measurements of a transport connection's delivery rate, round-trip
   time, and packet loss rate to build an explicit model of the network
   path.  BBR then uses this model to control both how fast it sends
   data and the maximum volume of data it allows in flight in the
   network at any time.  Relative to loss-based congestion control
   algorithms such as Reno [RFC5681] or CUBIC [RFC9438], BBR offers
   substantially higher throughput for bottlenecks with shallow buffers
   or random losses, and substantially lower queueing delays for
   bottlenecks with deep buffers (avoiding "bufferbloat").  BBR can be
   implemented in any transport protocol that supports packet-delivery
   acknowledgment.  Thus far, open source implementations are available
   for TCP [RFC9293] and QUIC [RFC9000].  This document specifies
   version 3 of the BBR algorithm, BBRv3.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-ccwg-bbr-04"/>
        </reference>
        <reference anchor="RFC4341">
          <front>
            <title>Profile for Datagram Congestion Control Protocol (DCCP) Congestion Control ID 2: TCP-like Congestion Control</title>
            <author fullname="S. Floyd" initials="S." surname="Floyd"/>
            <author fullname="E. Kohler" initials="E." surname="Kohler"/>
            <date month="March" year="2006"/>
            <abstract>
              <t>This document contains the profile for Congestion Control Identifier 2 (CCID 2), TCP-like Congestion Control, in the Datagram Congestion Control Protocol (DCCP). CCID 2 should be used by senders who would like to take advantage of the available bandwidth in an environment with rapidly changing conditions, and who are able to adapt to the abrupt changes in the congestion window typical of TCP's Additive Increase Multiplicative Decrease (AIMD) congestion control. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4341"/>
          <seriesInfo name="DOI" value="10.17487/RFC4341"/>
        </reference>
        <reference anchor="RFC2861">
          <front>
            <title>TCP Congestion Window Validation</title>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="J. Padhye" initials="J." surname="Padhye"/>
            <author fullname="S. Floyd" initials="S." surname="Floyd"/>
            <date month="June" year="2000"/>
            <abstract>
              <t>This document describes a simple modification to TCP's congestion control algorithms to decay the congestion window cwnd after the transition from a sufficiently-long application-limited period, while using the slow-start threshold ssthresh to save information about the previous value of the congestion window. This memo defines an Experimental Protocol for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2861"/>
          <seriesInfo name="DOI" value="10.17487/RFC2861"/>
        </reference>
      </references>
    </references>
    <?line 208?>

<section anchor="an-example-using-cwnd-represented-in-bytes">
      <name>An Example Using cwnd Represented in Bytes</name>
      <t>The following informative example is provided for a sender that maintains the cwnd in bytes. 36 packets are sent in this example over four rounds of transmission. This shows the initial growth of the cwnd by a rate-limited sender, followed by a transmission that uses the full available cwnd.</t>
      <t>The initial sender state is:</t>
      <artwork><![CDATA[
  Sender sequence number (seqno) = 0
  MSS = 1000 bytes
  cwnd = 10000 bytes (initcwnd)
  maxFS = 10000 bytes (initcwnd)
  FlightSize (FS) = 0 bytes
  ssthresh is infinity, i.e. the congestion control algorithm is in slow start.
]]></artwork>
      <t>The network path’s bandwidth-delay product is such that, throughout this example, all packets in each round are sent before an ACK is received for the first packet in a round.
One ACK is generated for each 2*MSS received bytes.</t>
      <t>Round 1, the sender has 4000B to send in 4 packets: MSS=1000, cwnd=10000</t>
      <artwork><![CDATA[
  Send  seqno=0; FS=1000; maxFS=10000
  Send  seqno=1000; FS=1000; maxFS=10000
  Send  seqno=2000; FS=2000; maxFS=10000
  Send  seqno=3000; FS=3000; maxFS=10000
]]></artwork>
      <t>Received 2 ACKs; maxFS=10000, if (cwnd&lt;2*maxFS) {cwnd +=ACK’ed}</t>
      <artwork><![CDATA[
  ACK for  2000 ACK’ed=2000 : cwnd+= 2000; cwnd=12000
  ACK for  4000 ACK’ed=2000 : cwnd+= 2000; cwnd=14000
]]></artwork>
      <t>Note: This round maxFS was not increased and cwnd was increased.</t>
      <t>Round 2, the sender has 8000B to send in 8 packets: MSS=1000, cwnd=14000</t>
      <artwork><![CDATA[
  Send  seqno=4000; FS=1000; maxFS=10000
  Send  seqno=5000; FS=2000; maxFS=10000
  Send  seqno=6000; FS=3000; maxFS=10000
  Send  seqno=7000; FS=4000; maxFS=10000
  Send  seqno=8000; FS=5000; maxFS=10000
  Send  seqno=9000; FS=6000; maxFS=10000
  Send seqno=10000; FS=7000; maxFS=10000
  Send seqno=11000; FS=8000; maxFS=10000
]]></artwork>
      <t>Received 4 ACKs; maxFS=10000, if (cwnd&lt;2*maxFS) {cwnd +=ACK’ed}</t>
      <artwork><![CDATA[
  ACK for  6000 ACK’ed=2000 : cwnd+=2000; cwnd=16000
  ACK for  8000 ACK’ed=2000 : cwnd+=2000; cwnd=18000
  ACK for 10000 ACK’ed=2000 : cwnd+=2000; cwnd=20000
  ACK for 12000 ACK’ed=2000 : cwnd+=0; cwnd=20000
]]></artwork>
      <t>Note: This round maxFS was not increased and cwnd was increased to 2*maxFS.</t>
      <t>Round 3, the sender has 4000B to send in 4 packets: MSS=1000, cwnd=20000</t>
      <artwork><![CDATA[
  Send seqno=12000; FS=1000; maxFS=10000
  Send seqno=13000; FS=2000; maxFS=10000
  Send seqno=14000; FS=3000; maxFS=10000
  Send seqno=15000; FS=4000; maxFS=10000
]]></artwork>
      <t>Received 2 ACKs; maxFS=10000, if (cwnd&lt;2*maxFS) {cwnd +=ACK’ed}</t>
      <artwork><![CDATA[
  ACK for 14000 ACK’ed=2000 : cwnd+=0; cwnd=20000
  ACK for 16000 ACK’ed=2000 : cwnd+=0; cwnd=20000
]]></artwork>
      <t>Note: This round maxFS was not increased and cwnd was not increased.</t>
      <t>Round 4, the sender has 20000B to send in 20 packets: MSS=1000, cwnd=20000</t>
      <artwork><![CDATA[
  Send seqno=16000; FS= 1000; maxFS=10000
  Send seqno=17000; FS= 2000; maxFS=10000
  Send seqno=18000; FS= 3000; maxFS=10000
  Send seqno=19000; FS= 4000; maxFS=10000
  Send seqno=20000; FS= 5000; maxFS=10000
  Send seqno=21000; FS= 6000; maxFS=10000
  Send seqno=22000; FS= 7000; maxFS=10000
  Send seqno=23000; FS= 8000; maxFS=10000
  Send seqno=24000; FS= 9000; maxFS=10000
  Send seqno=25000; FS=10000; maxFS=10000
  Send seqno=26000; FS=11000; maxFS=11000
  Send seqno=27000; FS=12000; maxFS=12000
  Send seqno=28000; FS=13000; maxFS=13000
  Send seqno=29000; FS=14000; maxFS=14000
  Send seqno=30000; FS=15000; maxFS=15000
  Send seqno=31000; FS=16000; maxFS=16000
  Send seqno=32000; FS=17000; maxFS=17000
  Send seqno=33000; FS=18000; maxFS=18000
  Send seqno=34000; FS=19000; maxFS=19000
  Send seqno=35000; FS=20000; maxFS=20000
]]></artwork>
      <t>Received 10 ACKs; maxFS=20000, if (cwnd&lt;2*maxFS) {cwnd +=ACK’ed}</t>
      <artwork><![CDATA[
  ACK for 18000 ACK’ed=2000 : cwnd+=2000; cwnd=22000
  ACK for 20000 ACK’ed=2000 : cwnd+=2000; cwnd=24000
  ACK for 22000 ACK’ed=2000 : cwnd+=2000; cwnd=26000
  ACK for 24000 ACK’ed=2000 : cwnd+=2000; cwnd=28000
  ACK for 26000 ACK’ed=2000 : cwnd+=2000; cwnd=30000
  ACK for 28000 ACK’ed=2000 : cwnd+=2000; cwnd=32000
  ACK for 30000 ACK’ed=2000 : cwnd+=2000; cwnd=34000
  ACK for 32000 ACK’ed=2000 : cwnd+=2000; cwnd=36000
  ACK for 34000 ACK’ed=2000 : cwnd+=2000; cwnd=38000
  ACK for 36000 ACK’ed=2000 : cwnd+=2000; cwnd=40000
]]></artwork>
      <t>Note: In this round, maxFS was increased and cwnd was increased to 2*maxFS.</t>
    </section>
    <section anchor="the-state-of-rfcs-and-implementations">
      <name>The state of RFCs and implementations</name>
      <t>RFC-Ed Note: This section is provided as input for IETF discussion, and should be removed before publication.</t>
      <section anchor="tcp-reno-congestion-control">
        <name>TCP ("Reno" congestion control)</name>
        <section anchor="specification">
          <name>Specification</name>
          <t><xref target="RFC7661"/> suggests there is no increase limitation in the standard TCP behavior (which <xref target="RFC7661"/> changes), on page 4:</t>
          <ul empty="true">
            <li>
              <t>Standard TCP does not impose additional restrictions on the growth of
the congestion window when a TCP sender is unable to send at the
maximum rate allowed by the cwnd. In this case, the rate-limited
sender may grow a cwnd far beyond that corresponding to the current
transmit rate, resulting in a value that does not reflect current
information about the state of the network path the flow is using.</t>
            </li>
          </ul>
        </section>
        <section anchor="tcp-impl">
          <name>Implementation</name>
          <ul spacing="normal">
            <li>
              <t>ns-2 allows cwnd to grow when it is rate-limited by rwnd. (Rate-limited by the sending application: not tested.)</t>
            </li>
            <li>
              <t>Until release 3.42, ns-3 allowed cwnd to grow when rate-limited, either due to an application or rwnd limit.  Since release 3.42, ns-3 TCP models conform to Rate-Limited Increase, following the current Linux TCP approach in this regard (see next bullet).</t>
            </li>
            <li>
              <t>In Congestion Avoidance, Linux only allows the cwnd to grow when the sender is unconstrained.
Before kernel version 3.16, this also applied to Slow Start.
The check for "unconstrained" is perfomed by checking if FlightSize is greater or equal to cwnd.
Since kernel version 3.16, which was published in August 2014, in Slow Start, the increase
implements Rate-Limited Increase in the <tt>tcp_is_cwnd_limited</tt> function in <tt>tcp.h</tt>.</t>
            </li>
          </ul>
        </section>
        <section anchor="assessment">
          <name>Assessment</name>
          <t>Linux implements a limit to cwnd growth in accordance with Rate-Limited Increase;
in Slow Start, this limit follows the rule's upper limit, while in Congestion Avoidance, it is more conservative than Rate-Limited Increase.
The specification and the ns-2 and (older) ns-3 implementations are in conflict with Rate-Limited Increase.</t>
        </section>
      </section>
      <section anchor="cubic">
        <name>CUBIC</name>
        <section anchor="specification-1">
          <name>Specification</name>
          <t><xref section="5.8" sectionFormat="of" target="RFC9438"/> says:</t>
          <ul empty="true">
            <li>
              <t>Cubic doesn't increase cwnd when it's limited by the sending application or rwnd.</t>
            </li>
          </ul>
        </section>
        <section anchor="implementation">
          <name>Implementation</name>
          <t>The description of Linux described in <xref target="tcp-impl"/> also applies to Cubic.</t>
        </section>
        <section anchor="assessment-1">
          <name>Assessment</name>
          <t>Both the specification and the Linux implementation limit the cwnd growth in accordance with Rate-Limited Increase;
in Congestion Avoidance, this limit is more conservative than Rate-Limited Increase,
and in Slow Start, it implements the "maxFS" upper limit of Rate-Limited Increase.</t>
        </section>
      </section>
      <section anchor="the-stream-control-transmission-protocol-sctp">
        <name>The Stream Control Transmission Protocol (SCTP)</name>
        <section anchor="specification-2">
          <name>Specification</name>
          <t><xref section="7.2.1" sectionFormat="of" target="RFC9260"/> says:</t>
          <ul empty="true">
            <li>
              <t>When cwnd is less than or equal to ssthresh, an SCTP endpoint <bcp14>MUST</bcp14> use the slow-start algorithm to
increase cwnd only if the current congestion window is being fully utilized and the data sender
is not in Fast Recovery.
Only when these two conditions are met can the cwnd be increased; otherwise, the cwnd <bcp14>MUST NOT</bcp14> be increased.</t>
            </li>
          </ul>
        </section>
        <section anchor="assessment-2">
          <name>Assessment</name>
          <t>The quoted statement from <xref target="RFC9260"/> prescribes the same cwnd growth limitation that is also specified for Cubic and implemented for both Reno and Cubic in Linux.
It is in accordance with Rate-Limited Increase, and more conservative.</t>
          <t><xref section="7.2.1" sectionFormat="of" target="RFC9260"/> is specifically limited to Slow Start.
Congestion Avoidance is discussed in <xref section="7.2.2" sectionFormat="of" target="RFC9260"/>
However, this section neither contains a similar rule, nor does it refer back to the rule that limits the growth of cwnd
in Section 7.2.1. It is thus implicitly clear that the quoted rule only applies to Slow Start, whereas Rate-Limited Increase applies to both Slow Start and Congestion Avoidance.</t>
        </section>
      </section>
      <section anchor="the-quic-transport-protocol">
        <name>The QUIC Transport Protocol</name>
        <section anchor="specification-3">
          <name>Specification</name>
          <t><xref section="7.8" sectionFormat="of" target="RFC9002"/> states:</t>
          <ul empty="true">
            <li>
              <t>When bytes in flight is smaller than the congestion window and sending is not pacing limited, the congestion window is underutilized. This can happen due to insufficient application data or flow control limits. When this occurs, the congestion window <bcp14>SHOULD NOT</bcp14> be increased in either slow start or congestion avoidance.</t>
            </li>
          </ul>
        </section>
        <section anchor="assessment-3">
          <name>Assessment</name>
          <t>With the exception of pacing, this specification conservatively limits the growth in cwnd, similar to Cubic and SCTP. It is in accordance with Rate-Limited Increase, and more conservative.</t>
        </section>
      </section>
      <section anchor="the-datagram-congestion-control-protocol-dccp-ccid2">
        <name>The Datagram Congestion Control Protocol (DCCP) CCID2</name>
        <section anchor="specification-4">
          <name>Specification</name>
          <t><xref section="5.1" sectionFormat="of" target="RFC4341"/> states:
&gt;There are currently no standards governing TCP's use of the congestion window during an application-limited period.  In particular, it is possible for TCP's congestion window to grow quite large during a long uncongested period when the sender is application limited, sending at a low rate.  <xref target="RFC2861"/> essentially suggests that TCP's congestion window not be increased during application-limited periods when the congestion window is not being fully utilized.</t>
        </section>
        <section anchor="assessment-4">
          <name>Assessment</name>
          <t>A DCCP Congestion Control ID (CCID) specifing TCP-like behaviour ought to follow the method specified in this document. The current guidance relates only to <xref target="RFC2861"/>.
The text in <xref section="5.1" sectionFormat="of" target="RFC4341"/> is updated by this document to specify the management of the
cwnd when the sender is rate-limited.</t>
        </section>
      </section>
    </section>
    <section anchor="change-log">
      <name>Change Log</name>
      <ul spacing="normal">
        <li>
          <t>-00 was the first individual submission for feedback by CCWG.</t>
        </li>
        <li>
          <t>-01 includes editorial improvements
          </t>
          <ul spacing="normal">
            <li>
              <t>Removes application interaction with QUIC pacing, since pacing might be within the QUIC stack.</t>
            </li>
            <li>
              <t>Adds explicit mention of DCCP/CCID2.</t>
            </li>
            <li>
              <t>Adds this change log.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>-02 addresses comments from IETF-119
          </t>
          <ul spacing="normal">
            <li>
              <t>Discusses rate-based controls and pacing.</t>
            </li>
            <li>
              <t>Trims the list of possible RFCs to update.</t>
            </li>
            <li>
              <t>Some editorial fixes: "congestion control algorithm" instead of "mechanism" for consistency with RFC5033.bis; earlier definition of maxFS; explicit mention of RFCs to update in abstract.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>-03 addresses comments from IETF-120
          </t>
          <ul spacing="normal">
            <li>
              <t>Introduces a third rule, with <bcp14>MAY</bcp14>, that avoids having an unvalidated long-lived maxFS (using pipeACK from RFC 7661).</t>
            </li>
            <li>
              <t>Changes "inc" to "limit" and adapts the wording of rule 2 to make it clearer (thanks to Neal Cardwell).</t>
            </li>
            <li>
              <t>Appendix: updates ns-3 in line with the recent implementation.</t>
            </li>
            <li>
              <t>Appendix: makes the RFC 9002 text clearer and shorter.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>draft-ietf-ccwg-ratelimited-increase-00
          </t>
          <ul spacing="normal">
            <li>
              <t>adds Mohit Tahiliani as a co-author</t>
            </li>
            <li>
              <t>refines the "rule" text (shorter, clearer)</t>
            </li>
            <li>
              <t>adds an example</t>
            </li>
          </ul>
        </li>
        <li>
          <t>draft-ietf-ccwg-ratelimited-increase-01
          </t>
          <ul spacing="normal">
            <li>
              <t>Clarified what we mean with an RTT</t>
            </li>
            <li>
              <t>rephrased example regarding initcwnd, citing RFCs 6928 and 9002</t>
            </li>
            <li>
              <t>removed the too vague rule 1 and made rule 2 (now rule 1) a <bcp14>MUST</bcp14></t>
            </li>
          </ul>
        </li>
        <li>
          <t>draft-ietf-ccwg-ratelimited-increase-02
          </t>
          <ul spacing="normal">
            <li>
              <t>Improved the last sentence of section 3.1.2.</t>
            </li>
            <li>
              <t>Removed a confusing and unnecessary sentence about pacing (as suggested at IETF-123).</t>
            </li>
          </ul>
        </li>
        <li>
          <t>draft-ietf-ccwg-ratelimited-increase-03
          </t>
          <ul spacing="normal">
            <li>
              <t>The editors checked rule 2, and found that rule 1 was sufficient, and did not depend on the ordering of rules in newCWV (RFC7661), hence rule 2 was finally removed.</t>
            </li>
            <li>
              <t>Cleaned language and improved text explaining how this compliments RFC7661.</t>
            </li>
            <li>
              <t>Checked/updated definitions.</t>
            </li>
            <li>
              <t>Added an example with cwnd in bytes.</t>
            </li>
          </ul>
        </li>
      </ul>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors would like to thank Neal Cardwell and Martin Duke for suggesting improvements to this document.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
WwAA

-->

</rfc>
