| Internet-Draft | Qlog for Careful Resume | May 2025 | 
| Custura & Fairhurst | Expires 24 November 2025 | [Page] | 
This document specifies a logging format for a cautious method for Careful Resume when using the IETF quic transport protocol. It defines the logging format for qlog.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 24 November 2025.¶
Copyright (c) 2025 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
This document defines a way to provide logging for Careful Resume[I-D.ietf-tsvwg-careful-resume] when used with QUIC [RFC9000][RFC9002].¶
[I-D.ietf-tsvwg-careful-resume] defines a Congestion Control (CC) mechanism called Careful Resume, which is expected to reduce the time to complete a transfer when the transfer sends significantly more data than allowed by the Initial congestion Window (IW), and where the BDP of the path is also significantly more than the IW. It introduces an alternative mechanism to select initial CC parameters that seeks to more rapidly and safely grow the sending rate controlled by the congestion window (CWND). CC algorithms that are rate-based can make similar adjustments to their target sending rate.¶
When used with the QUIC transport, Careful Resume provides transport services that resemble those that could be implemented in TCP, using methods such as TCP Control Block (TCB) [RFC9040] caching.¶
This subsection provides a brief summary of key terms and the requirements language.¶
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
The document uses language drawn from a range of IETF RFCs. The following terms are defined:¶
Careful Resume (CR): The method specified in [I-D.ietf-tsvwg-careful-resume]. All other terms in this section, except CWND, are defined in the same document.¶
CWND: The congestion window, or equivalent CC variable limiting the maximum sending rate;¶
current_rtt: A sample measurement of the current RTT;¶
PipeSize: A measure of the validated available capacity based on the acknowledged data;¶
saved_cwnd: The preserved capacity derived from observation of a previous connection;¶
saved_rtt: The preserved minimum RTT;¶
Unvalidated Packet: A packet sent when the CWND has been increased beyond the size normally permitted by the CC algorithm; if such a packet is acknowledged, it contributes to the PipeSize, if congestion is detected, it triggers entry to the Safe Retreat Phase.¶
Careful Resume[I-D.ietf-tsvwg-careful-resume] defines a series of phases that a congestion controller moves through as a connection uses the mechanism. The key phases are illustrated in Figure 1.¶
Normal ...> Connect -> Reconnaissance --------------------> Normal
(Observing)              |                                    ^
                         v                                    |
                        Unvalidated --------------------------+
                         |      |                             |
                         |      +--> Validating --------------+
                         |               |                    |
                         |               |                    |
                         +---------------+--> Safe Retreat ---+
Examples of these transitions between phases are provided in the annexe to [I-D.ietf-tsvwg-careful-resume].¶
There are currently no qlog events associated with this phase.¶
Careful Resume phases are abbreviated as follows:¶
+---------------------+-------------------------------+-------+-------+ | Trigger | Description | From | To | +---------------------+-------------------------------+-------+-------+ | cwnd_limited | When sender has confirmed the | Recon | Unval | | | RTT, has received an ACK for | | | | | the initial data without | | | | | reported congestion and has | | | | | more data to send than the | | | | | CWND would allow. | | | +---------------------+-------------------------------+-------+-------+ | rtt_not_validated | If the current_rtt is not | Recon | Norm | | | confirmed the sender MUST | Unval | | | | enter the Normal Phase. | | | +---------------------+-------------------------------+-------+-------+ | last_unvalidated_ | Completed sending all | Unval | Val | | packet_sent | unvalidated packets, e.g., | | | | | when flight_size is equal to | | | | | the CWND after the jump | | | +---------------------+-------------------------------+-------+-------+ | first_unvalidated_ | The sender enters the | Unval | Val | | packet_acknowledged | Validating Phase when an ACK | | | | | is received for the first | | | | | packet number (or higher) | | | | | sent in the Unvalidated Phase.| | | +---------------------+-------------------------------+-------+-------+ | rtt_exceeded | When greater than 1 RTT has | Unval | Val | | | passed in Unvalidated Phase. | | | +---------------------+-------------------------------+-------+-------+ | rate_limited | If the flight_size is less | Unval | Norm | | | than or equal to the PipeSize | | | | | sender enters Normal Phase. | | | +---------------------+-------------------------------+-------+-------+ | last_unvalidated_ | The sender enters the Normal | Val | Norm | | packet_acknowledged | Phase when an ACK is received | | | | | for the last packet number | | | | | (or higher) that was sent in | | | | | the Unvalidated Phase. | | | +---------------------+-------------------------------+-------+-------+ | path_changed | If a sender determines that | Unval | SR | | | it is not valid to use the | | | | | previous CC parameters due to | | | | | a detected path change (e.g., | | | | | a change in RTT or an | | | | | explicit signal indicating a | | | | | path change. | | | +---------------------+-------------------------------+-------+-------| | packet_loss | If a sender determines that | Unval | SR | | | congestion was experienced, | Val | | | | e.g., packet loss, the sender | | | | | enters the Safe Retreat Phase.| | | | | | | | | | If the sender determines | Recon | Norm | | | congestion was experienced in | | | | | the Recon Phase, the sender | | | | | enters the Normal Phase. | | | +---------------------+-------------------------------+-------+-------+ | ECN_CE | If a sender determines that | Unval | SR | | | congestion was experienced, | Val | | | | e.g., ECN-CE marking, sender | | | | | enters the Safe Retreat Phase.| | | | | | | | | | If the sender determines | Recon | Norm | | | congestion was experienced in | | | | | the Recon Phase, the sender | | | | | enters the Normal Phase. | | | +---------------------+-------------------------------+-------+-------+ | exit_recovery | The sender enters the Normal | SR | Norm | | | Phase when the last packet | | | | | sent in the Unvalidated Phase | | | | | is ACKed. | | | +---------------------+-------------------------------+-------+-------+
This section provides definitions that enable a Careful Resume implementation to generate qlog events when using QUIC. It introduces an event to report a phase transition at the sender, and its associated description. The event's state parameters (which include mandatory CR-specific metrics and optionally CWND or ssthresh) are intended to reflect the state after the phase transition.¶
The event and data structure definitions in this section are expressed in the Concise Data Definition Language (CDDL) [RFC8610] and its extensions described in [I-D.ietf-quic-qlog-quic-events]. The current convention is to use long names for variables. For example, "CWND" is expanded as "congestion_window" and "saved_cwnd" is expanded as "saved_congestion_window".¶
Importance: Extra¶
When the CC algorithm changes the Careful Resume Phase described in Section 3 of this specification.¶
Definition:¶
QUICCarefulResumePhaseUpdated = {
? old: CarefulResumePhase,
new: CarefulResumePhase,
state_data: CarefulResumeStateParameters,
? restored_data: CarefulResumeRestoredParameters,
? trigger:
        ; for the Unvalidated Phase,
        ; when there is more data to send than available CWND.
        "congestion_window_limited" /
        ; for the Validating Phase
        ; when more than one RTT has passed in the Unvalidated Phase.
        "rtt_exceeded" /
        ; for the Validating Phase
        "first_unvalidated_packet_acknowledged" /
        ; for the Validating Phase
        ; when all unvalidated packets have been sent.
        "last_unvalidated_packet_sent" /
        ; for the Normal Phase
        ; when no remaining unvalidated packets to be acknowledged.
        "last_unvalidated_packet_acknowledged" /
        ; for the Normal Phase
        ; when CR not allowed due to a detected RTT change.
        "rtt_not_validated" /
        ; for the Normal Phase,
        ; when sending fewer unvalidated packets than CWND permits.
        "rate_limited" /
        ; for the Safe Retreat Phase, when path change detected.
        "path_changed" /
        ; for the Safe Retreat Phase, when loss detected.
        ; for the Normal Phase,
        ; when loss detected in the Reconnaissance Phase.
        "packet_loss" /
        ; for the Safe Retreat Phase,
        ; when ECN congestion experienced reported.
        ; for the Normal Phase,
        ; when ECN congestion experienced in the Reconnaissance Phase.
        "ECN_CE" /
        ; for the Normal Phase 1 RTT after a congestion event
        "exit_recovery"
* $$quic-carefulresumephaseupdated-extension
}
CarefulResumePhase =
        "reconnaissance" /
        "unvalidated" /
        "validating" /
        "normal" /
        "safe_retreat"
CarefulResumeStateParameters = {
      pipesize: uint32,
      first_unvalidated_packet: uint32,
      last_unvalidated_packet: uint32,
      ? congestion_window: uint32,
      ? ssthresh: uint32
}
CarefulResumeRestoredParameters = {
      saved_congestion_window: uint32,
      saved_rtt: float32
}
$ProtocolEventData /= QUICCarefulResumePhaseUpdated
The authors would like to thank Robin Marx and Lucas Pardue for their fruitful comments in developing this specification.¶
Note by RM: This event type is to be added to the "qlog event schema URIs" registered at IANA, but the qlog event schema URIs registry has not yet been actually created at IANA because the qlog registry has not yet been created.¶
This document does not exhibit specific security considerations.¶