<?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.39 (Ruby 3.4.9) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-ccwg-ratelimited-increase-04" category="std" consensus="true" submissionType="IETF" updates="RFC5681, RFC9002, RFC9260, RFC9438" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.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-04"/>
    <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>
      </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="June" day="26"/>
    <area>Transport</area>
    <workgroup>Congestion Control Working Group</workgroup>
    <abstract>
      <?line 73?>

<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://ietf-wg-ccwg.github.io/draft-ietf-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 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/ietf-wg-ccwg/draft-ccwg-ratelimited-increase"/>.</t>
    </note>
  </front>
  <middle>
    <?line 79?>

<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 utilize 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 utilize 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"/>.</t>
        <t>Additionally, the following are defined:</t>
        <ul spacing="normal">
          <li>
            <t>cwnd-limited: A TCP flow that has sent the maximum number of segments permitted by the cwnd, where the application utilises the allowed sending rate {Section 4.5.3 of of ?RFC7661}.</t>
          </li>
          <li>
            <t>rate-limited: A TCP flow that does not consume more than one half of cwnd and hence operates in the non-validated phase.  This includes periods when an application is either idle or chooses to send at a rate less than the maximum permitted by the cwnd {Section 3 of ?RFC7661}.</t>
          </li>
          <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 can be 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 afterward, 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 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="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="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="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="2" month="March" year="2026"/>
            <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-05"/>
        </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 211?>

<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"/> suggested there was 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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
GsQlXQAA

-->

</rfc>
