Skip to main content

Multipath Extension for QUIC
draft-ietf-quic-multipath-14

Document Type Active Internet-Draft (quic WG)
Authors Yanmei Liu , Yunfei Ma , Quentin De Coninck , Olivier Bonaventure , Christian Huitema , Mirja Kühlewind
Last updated 2025-04-24 (Latest revision 2025-04-23)
Replaces draft-lmbdhk-quic-multipath
RFC stream Internet Engineering Task Force (IETF)
Intended RFC status Proposed Standard
Formats
Additional resources Mailing list discussion
Stream WG state In WG Last Call
Associated WG milestone
Multipath Extension to QUIC to IESG
Document shepherd (None)
IESG IESG state I-D Exists
Consensus boilerplate Yes
Telechat date (None)
Responsible AD (None)
Send notices to (None)
draft-ietf-quic-multipath-14
QUIC Working Group                                  刘彦梅 (Y. Liu), Ed.
Internet-Draft                                              Alibaba Inc.
Intended status: Standards Track                          马云飞 (Y. Ma)
Expires: 25 October 2025                          Uber Technologies Inc.
                                                      Q. De Coninck, Ed.
                                              University of Mons (UMONS)
                                                          O. Bonaventure
                                                  UCLouvain and Tessares
                                                              C. Huitema
                                                    Private Octopus Inc.
                                                      M. Kuehlewind, Ed.
                                                                Ericsson
                                                           23 April 2025

                      Multipath Extension for QUIC
                      draft-ietf-quic-multipath-14

Abstract

   This document specifies a multipath extension for the QUIC protocol
   to enable the simultaneous usage of multiple paths for a single
   connection.

Discussion Venues

   This note is to be removed before publishing as an RFC.

   Discussion of this document takes place on the QUIC Working Group
   mailing list (quic@ietf.org), which is archived at
   https://mailarchive.ietf.org/arch/browse/quic/.

   Source for this draft and an issue tracker can be found at
   https://github.com/quicwg/multipath.

Status of This Memo

   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/.

Liu, et al.              Expires 25 October 2025                [Page 1]
Internet-Draft               Multipath QUIC                   April 2025

   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 25 October 2025.

Copyright Notice

   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.

Table of Contents

   1.  Introduction  . . . . . . . . . . . . . . . . . . . . . . . .   3
     1.1.  Conventions and Definitions . . . . . . . . . . . . . . .   5
   2.  Transport Handshake and Cryptographic Packet Protection . . .   5
     2.1.  initial_max_path_id Transport Parameter . . . . . . . . .   5
     2.2.  Relation to Other Transport Parameters  . . . . . . . . .   6
     2.3.  Handling ACK and PATH_ACK in 0-RTT and 1-RTT  . . . . . .   7
     2.4.  Nonce Calculation after Handshake Completion  . . . . . .   7
     2.5.  Key Phase Update Process  . . . . . . . . . . . . . . . .   8
   3.  Path Management . . . . . . . . . . . . . . . . . . . . . . .   8
     3.1.  Path Initiation and Validation  . . . . . . . . . . . . .   9
       3.1.1.  Path Establishment Example  . . . . . . . . . . . . .  10
       3.1.2.  Relation to Probing and Migration . . . . . . . . . .  11
       3.1.3.  Address Validation Token  . . . . . . . . . . . . . .  11
     3.2.  Handling Connection IDs . . . . . . . . . . . . . . . . .  11
       3.2.1.  Issuing New Connection IDs  . . . . . . . . . . . . .  12
       3.2.2.  Rotating and Retiring Connection IDs  . . . . . . . .  13
     3.3.  Path Status Management  . . . . . . . . . . . . . . . . .  13
     3.4.  Path Close  . . . . . . . . . . . . . . . . . . . . . . .  14
       3.4.1.  Path Closure Example  . . . . . . . . . . . . . . . .  16
       3.4.2.  Avoiding Spurious Stateless Resets  . . . . . . . . .  16
       3.4.3.  Handling PATH_ACK for Abandoned Paths . . . . . . . .  17
   4.  New Frames  . . . . . . . . . . . . . . . . . . . . . . . . .  17
     4.1.  PATH_ACK Frame  . . . . . . . . . . . . . . . . . . . . .  18
     4.2.  PATH_ABANDON Frame  . . . . . . . . . . . . . . . . . . .  18
       4.2.1.  Error Codes . . . . . . . . . . . . . . . . . . . . .  19

Liu, et al.              Expires 25 October 2025                [Page 2]
Internet-Draft               Multipath QUIC                   April 2025

     4.3.  PATH_AVAILABLE and PATH_BACKUP frames . . . . . . . . . .  19
     4.4.  PATH_NEW_CONNECTION_ID frame  . . . . . . . . . . . . . .  21
     4.5.  PATH_RETIRE_CONNECTION_ID frame . . . . . . . . . . . . .  22
     4.6.  MAX_PATH_ID frame . . . . . . . . . . . . . . . . . . . .  23
     4.7.  PATHS_BLOCKED and PATH_CIDS_BLOCKED frames  . . . . . . .  24
   5.  Implementation Considerations . . . . . . . . . . . . . . . .  25
     5.1.  CID Changes, Migration, and NAT Rebindings  . . . . . . .  25
     5.2.  Using Multiple Paths on the Same 4-tuple  . . . . . . . .  26
     5.3.  Congestion Control  . . . . . . . . . . . . . . . . . . .  27
     5.4.  Computing Path RTT  . . . . . . . . . . . . . . . . . . .  27
     5.5.  Packet Scheduling . . . . . . . . . . . . . . . . . . . .  29
     5.6.  Retransmissions . . . . . . . . . . . . . . . . . . . . .  30
     5.7.  PTO Expiration  . . . . . . . . . . . . . . . . . . . . .  30
     5.8.  Paths Having Different PMTU Sizes . . . . . . . . . . . .  30
     5.9.  Idle Timeout and Keep-Alives  . . . . . . . . . . . . . .  31
   6.  IANA Considerations . . . . . . . . . . . . . . . . . . . . .  31
   7.  Security Considerations . . . . . . . . . . . . . . . . . . .  33
     7.1.  Memory Allocation for Per-Path Resources  . . . . . . . .  34
     7.2.  Request Forgery with Spoofed Address  . . . . . . . . . .  34
     7.3.  Cryptographic handshake and AEAD Nonce  . . . . . . . . .  34
   8.  Contributors  . . . . . . . . . . . . . . . . . . . . . . . .  35
   9.  Acknowledgments . . . . . . . . . . . . . . . . . . . . . . .  35
   10. References  . . . . . . . . . . . . . . . . . . . . . . . . .  35
     10.1.  Normative References . . . . . . . . . . . . . . . . . .  35
     10.2.  Informative References . . . . . . . . . . . . . . . . .  36
   Authors' Addresses  . . . . . . . . . . . . . . . . . . . . . . .  36

1.  Introduction

   This document specifies an extension to QUIC version 1
   [QUIC-TRANSPORT] to enable the simultaneous usage of multiple paths
   for a single connection, using the same or different 4-tuples.

   Connection migration as specified in Section 9 of [QUIC-TRANSPORT]
   directs a peer to switch sending through a new preferred path, and,
   if successful, to release resources associated with the old path.
   The multipath extension specified in this document builds on this
   mechanism but introduces a path identifier, or path ID, to manage
   connection IDs and packet number spaces per path, enabling the use of
   multiple paths simultaneously.

   The connection ID of a packet binds the packet to a path ID, and
   therefore to a packet number space.  That means each connection ID is
   associated with exactly one path ID but multiple connection IDs are
   usually issued for each path ID.  The same path ID is used in both
   directions, starting with 0 for the initial path.  Path ID are
   generated monotonically increasing and cannot be reused.

Liu, et al.              Expires 25 October 2025                [Page 3]
Internet-Draft               Multipath QUIC                   April 2025

   This extension uses multiple packet number spaces, one for each path.
   Each path ID-specific packet number space starts at packet number 0.
   As such, each path maintains distinct packet number states for
   sending and receiving packets, as in [QUIC-TRANSPORT].  Using
   multiple packet number spaces enables direct use of the loss
   detection and congestion control mechanisms defined in
   [QUIC-RECOVERY] on a per-path basis.  However, use of multiple packet
   number spaces requires non-zero connection IDs in order to identify
   the path and the respective packet number space as well as a modified
   AEAD calculation including the path ID (see Section 2.4).

   As such, this extension specifies a departure from the specification
   of path management in Section 9 of [QUIC-TRANSPORT] and therefore
   requires a new transport parameter, as specified in Section 2.1, to
   indicate support of the multipath extension specified in this
   document.

   Further, this document specifies the needed path management
   mechanisms for path initiation in Section 3.1, handling of per-path
   connection IDs in Section 3.2, signaling of preferred path usage in
   Section 3.3, and explicit removal of paths that have been abandoned
   in Section 3.4.  Note that in this extension, a QUIC server does not
   initiate the creation of a path, but it has to validate a new path
   created by a client.

   This extension does not cover address discovery and management.
   Addresses and the actual decision to setup or tear down paths are
   assumed to be handled by the application.  But this document does not
   prevent future extensions from defining mechanisms to cope with the
   remaining scenarios.

   Further, this document does not specify scheduling algorithms that
   define how multiple, simultaneously open paths are used to send
   packets.  As these differ depending on application requirements, only
   some basic implementation guidance is discussed in Section 5.  This
   extension can be used with different scheduling algorithms that,
   e.g., can range from support for failover to simulatenous use of the
   aggregated capacity across all open paths.  There are currently no
   IETF specifications for simultaneously (concurrently) using multiple
   paths.

   Specifically, while failover between Wi-Fi and mobile networks is a
   well-known multipath use case, it only temporarily uses two paths at
   the same time to avoid transmission pauses.  Simultaneous path usage
   generally, however, needs more consideration than specified in this
   document to avoid negative performance impacts, e.g., when stream
   data is distributed over multiple paths with different delays.

Liu, et al.              Expires 25 October 2025                [Page 4]
Internet-Draft               Multipath QUIC                   April 2025

1.1.  Conventions and Definitions

   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.

   We assume that the reader is familiar with the terminology used in
   [QUIC-TRANSPORT].  When this document uses the term "path", it refers
   to the notion of "network path" used in [QUIC-TRANSPORT].

2.  Transport Handshake and Cryptographic Packet Protection

   This document defines a new transport parameter initial_max_path_id
   to indicate the support of the multipath extension.  If any of the
   endpoints does not advertise the initial_max_path_id transport
   parameter, then the endpoints MUST NOT use any frame or mechanism
   defined in this document.  If the use of the multipath extension is
   agreed after handshake completion, a new AEAD usage applies to all
   1-RTT packets, as specified in Section Section 2.4 and new paths can
   be used, as specified in Section Section 3.

2.1.  initial_max_path_id Transport Parameter

   The new transport parameter is defined as follows:

   *  initial_max_path_id (current version uses 0x0f739bbc1b666d0d): a
      variable-length integer specifying the maximum path ID an endpoint
      is willing to maintain at connection initiation.  This value MUST
      NOT exceed 2^32-1, the maximum allowed value for the path ID due
      to restrictions on the nonce calculation (see Section 2.4).

   The initial_max_path_id transport parameter limits the initial
   maximum number of open paths that can be used during a connection.
   For example, if initial_max_path_id is set to 1, only connection IDs
   associated with path IDs 0 and 1 should be issued by the peer.  If an
   endpoint receives an initial_max_path_id transport parameter with
   value 0, the peer aims to enable the multipath extension without
   allowing extra paths immediately.

   Setting initial_max_path_id parameter is equivalent to sending a
   MAX_PATH_ID frame (Section 4.6) with the same value.  As such to
   allow for the use of more paths later, endpoints can send the
   MAX_PATH_ID frame to increase the maximum allowed path ID.

Liu, et al.              Expires 25 October 2025                [Page 5]
Internet-Draft               Multipath QUIC                   April 2025

   If an initial_max_path_id transport parameter value higher than
   2^32-1 is received, the receiver MUST close the connection with an
   error of type TRANSPORT_PARAMETER_ERROR.

   When advertising the initial_max_path_id transport parameter,
   endpoints MUST use non-zero length Source and Destination Connection
   IDs.  If an initial_max_path_id transport parameter is received and
   the carrying packet contains a zero-length connection ID, the
   receiver MUST treat this as a connection error of type
   PROTOCOL_VIOLATION and close the connection.

   Cipher suites with a nonce shorter than 12 bytes cannot be used
   together with the multipath extension.  If such a cipher suite is
   selected and the use of the multipath extension is supported,
   endpoints MUST abort the handshake with a an error of type
   TRANSPORT_PARAMETER_ERROR.

   The initial_max_path_id parameter MUST NOT be remembered for use in a
   subsequent connection (Section 7.4.1 of [QUIC-TRANSPORT]).

2.2.  Relation to Other Transport Parameters

   When the QUIC multipath extension is used, the
   active_connection_id_limit transport parameter [QUIC-TRANSPORT]
   limits the maximum number of active connection IDs per path.  As
   defined in Section 5.1.1 of [QUIC-TRANSPORT] connection IDs that are
   issued and not retired are considered active.

   If an endpoint receives a disable_active_migration transport
   parameter, it is forbidden to establish new paths to the peer's
   handshake address.  However, establishment of additional paths to
   other peer addresses (e.g carried by peer’s preferred_address) is
   immediately valid.

   If the server uses the preferred_address transport parameter, clients
   cannot assume that the initial server address and the addresses
   contained in this parameter can be simultaneously used for multipath
   (Section 9.6.2 of [QUIC-TRANSPORT]).  Use of the preferred address
   with the same local address is considered as a migration event that
   does not change the path ID.  A such, the path ID for the connection
   ID specified in the preferred_address transport parameter is 0.

Liu, et al.              Expires 25 October 2025                [Page 6]
Internet-Draft               Multipath QUIC                   April 2025

2.3.  Handling ACK and PATH_ACK in 0-RTT and 1-RTT

   The PATH_ACK frame (see Section 4.1) is used to acknowledge 1-RTT
   packets.  Compared to the ACK frame, as specified in Section 19.3 of
   [QUIC-TRANSPORT], the PATH_ACK frame additionally contains the path
   ID to identify the path-specific packet number space.  ACK frames
   when used with the multipath extension acknowledge packets for the
   path with path ID 0.  As multipath support is unknown during the
   handshake, acknowledgments of Initial and Handshake packets are sent
   using ACK frames.

   After the handshake concluded with support for the multipath
   extension, endpoints SHOULD use PATH_ACK frames instead of ACK
   frames, including for so far unacknowledged 0-RTT packets using Path
   ID 0.  Endpoints MUST still process ACK frames that acknowledge 0-RTT
   packets or 1-RTT packets.  For example, a sender may negotiate
   multipath support for later use and keep only the initial path with
   path ID 0 for a while.  During this single-path period, the sender
   might prefer to send ACK frames.

2.4.  Nonce Calculation after Handshake Completion

   Section 5.3 of [QUIC-TLS] specifies AEAD usage, and in particular the
   use of a nonce, N, formed by combining the packet protection IV with
   the packet number.  When multiple packet number spaces are used, the
   packet number alone would not guarantee the uniqueness of the nonce.
   Therefore, the nonce N is calculated for 1-RTT if the multipath
   extension is used by combining the packet protection IV with the
   packet number and with the least significant 32 bits of the path ID.
   In order to guarantee the uniqueness of the nonce, the path ID is
   limited to a max value of 2^32-1, as specified in Section Section 2.1

   To calculate the nonce, a 96-bit path-and-packet-number is composed
   of the least significant 32 bits of the path ID in network byte
   order, two zero bits, and the 62 bits of the reconstructed QUIC
   packet number in network byte order.  The IV length is equal to the
   nonce length.  If the IV is larger than 96 bits, the path-and-packet-
   number is left-padded with zeros to the size of the IV.  The
   exclusive OR of the padded packet number and the IV forms the AEAD
   nonce.  An AEAD algorithm where the nonce length is less than 12
   bytes MUST NOT be used with the QUIC multipath extension.

   For example, assuming the IV value is 6b26114b9cba2b63a9e8dd4f, the
   path ID is 3, and the packet number is aead, the nonce will be set to
   6b2611489cba2b63a9e873e2.

Liu, et al.              Expires 25 October 2025                [Page 7]
Internet-Draft               Multipath QUIC                   April 2025

2.5.  Key Phase Update Process

   The Key Phase bit update process is specified in Section 6 of
   [QUIC-TLS].  The general principles of key update are not changed in
   this specification.  Following [QUIC-TLS], the Key Phase bit is used
   to indicate which packet protection keys are used to protect the
   packet.  The Key Phase bit is toggled to signal each subsequent key
   update.

   Because of network delays, packets protected with the older key might
   arrive later than the packets protected with the new key, however
   receivers can solely rely on the Key Phase bit to determine the
   corresponding packet protection key, assuming that there is
   sufficient interval between two consecutive key updates (Section 6.5
   of [QUIC-TLS]).

   When this specification is used, endpoints SHOULD wait for at least
   three times the largest PTO among all the paths before initiating a
   new key update after receiving an acknowledgment that confirms the
   receipt of the previous key update.  This interval is different from
   that in [QUIC-TLS] which used three times the PTO of the sole single
   path.

   The choice of three times the largest PTO is a trade-off.  Packets
   that arrive after their decryption key has been discarded will be
   dropped.  Longer delays reduce the probability of losing packets but
   keeping old keys longer can negatively impact the security of the
   protocol.  The use of three times the largest PTO aims to minimize
   packet lost for all paths and therefore limits the impact on
   performance.

   Following Section 5.4 of [QUIC-TLS], the Key Phase bit is protected,
   so sending multiple packets with Key Phase bit flipping at the same
   time should not cause linkability issues.

3.  Path Management

   After completing the handshake indicating multipath support,
   endpoints can start using multiple paths.  An endpoint can open a new
   path when both endpoints have issued available connection IDs for at
   least one unused, common path ID, as the same path ID is used in both
   directions.

Liu, et al.              Expires 25 October 2025                [Page 8]
Internet-Draft               Multipath QUIC                   April 2025

   This documents specfies path initiation (see Section 3.1), issuing
   and retirement of per-path connection IDs (see Section 3.2), path
   status management (see Section 3.3) and path closure (see
   Section 3.4).  However, this document does not specify when a client
   decides to initiate or close a path, or how multiple open paths are
   used for sending.

3.1.  Path Initiation and Validation

   To open a new path, an endpoint MUST use a new connection ID
   associated with an unused path ID.  When sending a PATH_RESPONSE
   frame, an endpoint MUST use a connection ID associated to the same
   path ID as used in the packet that contained the PATH_CHALLENGE
   frame.

   A client that wants to use an additional path MUST validate the
   peer's address before sending any data packets as described in
   Section 8.2 of [QUIC-TRANSPORT], unless it has previously validated
   the 4-tuple used for that path.

   After receiving packets from the client on a new path, if the server
   decides to use the new path, the server MUST validate the peer's
   address before sending any data packets as described in (Section 8.2
   of [QUIC-TRANSPORT]), unless it has previously validated the 4-tuple
   used for that path.  Until the client's address is validated, the
   anti-amplification limit from Section 8 of [QUIC-TRANSPORT] applies.

   The server may receive packets for a yet unused path ID that do not
   contain a PATH_CHALLENGE frame.  Such packets are valid if they can
   be properly decrypted given a valid connection ID.

   Each endpoint MUST also validate that a minimum QUIC packet MTU of
   1200 bytes is supported on the path.  This can be done during initial
   path validation or separately later if the amplification limit
   prevents it initially, as specified in Section 8.2.1 of
   [QUIC-TRANSPORT].

   An endpoint that receives packets on a new path and does not want to
   establish this path is expected to close the path by sending a
   PATH_ABANDON on another path, as specified in Section 3.4.

   An endpoint that has no active connection ID for this path or lacks
   other resource to immediately configure a new path could delay
   sending the PATH_RESPONSE until sufficient resource are available.
   Long delays may cause the peer to repeat the PATH_CHALLENGE and
   eventually send a PATH_ABANDON, in which case the procedures
   specified in Section Section 3.4 apply.

Liu, et al.              Expires 25 October 2025                [Page 9]
Internet-Draft               Multipath QUIC                   April 2025

   PATH_ACK frames (see Section 4.1) can be returned on any path.  If
   the PATH_ACK is preferred to be sent on the same path as the
   acknowledged packet (see Section 5.4 for further guidance), it can be
   beneficial to bundle a PATH_ACK frame with the PATH_RESPONSE frame
   during path validation.

   If validation succeeds, the client can continue to use the path.  If
   validation fails, the client MUST NOT use the path and can remove any
   status associated to the path initiation attempt.  As the used path
   ID is anyway consumed, the endpoint MUST explicitly close the path,
   as specified in Section 3.4.

3.1.1.  Path Establishment Example

   In the example below it is assumed that both endpoints have indicated
   an initial_max_path_id value of at least 2, which means both
   endpoints can use path IDs 0, 1, and 2.  Note that path ID 0 is
   already used for the initial path.

      Client                                                  Server

      (Exchanges start on default path)
      1-RTT[]: PATH_NEW_CONNECTION_ID[C1, Seq=0, PathID=1] -->
                <-- 1-RTT[]: PATH_NEW_CONNECTION_ID[S1, Seq=0, PathID=1]
                <-- 1-RTT[]: PATH_NEW_CONNECTION_ID[S2, Seq=0, PathID=2]
      ...
      (starts new path)
      1-RTT[0]: DCID=S1, PATH_CHALLENGE[X] -->
                              Checks AEAD using nonce(path ID 1, PN 0)
           <-- 1-RTT[0]: DCID=C1, PATH_RESPONSE[X], PATH_CHALLENGE[Y],
                                                PATH_ACK[PathID=1, PN=0]
      Checks AEAD using nonce(path ID 1, PN 0)
      1-RTT[1]: DCID=S1, PATH_RESPONSE[Y],
               PATH_ACK[PathID=1, PN=0], ... -->

                Figure 1: Example of new path establishment

   In Figure 1, the endpoints first exchange new available connection
   IDs with the PATH_NEW_CONNECTION_ID frame.  In this example, the
   client provides one connection ID (C1 with path ID 1), and server
   provides two connection IDs (S1 with path ID 1, and S2 with path ID
   2).

   Before the client opens a new path by sending a packet on that path
   with a PATH_CHALLENGE frame, it has to check whether there is an
   unused connection IDs for the same unused path ID available for each
   side.  In this example the path ID 1 is used which is the smallest
   unused path ID available as recommended in Section 3.2.

Liu, et al.              Expires 25 October 2025               [Page 10]
Internet-Draft               Multipath QUIC                   April 2025

   Respectively, the client chooses the connection ID S1 as the
   Destination Connection ID of the new path when sending the
   PATH_CHALLENGE frame.  The server replies with a PATH_RESPONSE
   bundled with the PATH_ACK using connection ID S1 associated with the
   same path ID.

3.1.2.  Relation to Probing and Migration

   Section 9.1 of [QUIC-TRANSPORT] introduces the concept of "probing"
   and "non-probing" frames.  A packet that contains at least one "non-
   probing" frame is a "non-probing" packet.  When the multipath
   extension is negotiated, the reception of a "non-probing" packet on a
   new path with a new so far unused path ID does not impact the path
   status of any existing path.  Therefore, any frame can be sent on a
   new path at any time as long as the anti-amplification limits (see
   Section 21.1.1.1 of [QUIC-TRANSPORT]) and the congestion control
   limits for this path are respected.

   The receiver may receive a connection ID associated with a used path
   ID on different 4-tuples, e.g., due to NAT rebinding.  This causes
   the receiver to initiate path validation as specified in Section 9.3
   of [QUIC-TRANSPORT] which MUST use a new connection ID for the same
   path ID.

3.1.3.  Address Validation Token

   As specified in Section 9.3 of [QUIC-TRANSPORT], the server is
   expected to send a new address validation token to a client following
   the successful validation of a new client address.  The client will
   receive several tokens.  When considering using a token for
   subsequent connections, it might be difficult for the client to pick
   the "right" token among multiple tokens obtained in a previous
   connection.  The client is likely to fall back to the strategy
   specified in Section 8.1.3 of [QUIC-TRANSPORT], i.e., pick the last
   received token.  To avoid issues when clients make the "wrong"
   choice, a server SHOULD issue tokens that are capable of validating
   any of the previously validated addresses.  Further guidance on token
   usage can be found in Section 8.1.3 of [QUIC-TRANSPORT].

3.2.  Handling Connection IDs

   When the multipath extension is used, endpoints have to use the
   PATH_NEW_CONNECTION_ID and PATH_RETIRE_CONNECTION_ID frames to
   indicate the respective path ID together with associated sequence
   number (see Section 5.1.1 of [QUIC-TRANSPORT]), at least for all
   paths with a path ID other than 0.  Each path ID has its own
   connection ID sequence number space whose initial value is 0.

Liu, et al.              Expires 25 October 2025               [Page 11]
Internet-Draft               Multipath QUIC                   April 2025

   Endpoints SHOULD also use PATH_NEW_CONNECTION_ID and
   PATH_RETIRE_CONNECTION_ID for the initial path with path ID 0.
   However, the use of NEW_CONNECTION_ID and RETIRE_CONNECTION_ID is
   still valid and endpoints need to process these frames as
   corresponding to path ID 0.

3.2.1.  Issuing New Connection IDs

   In order to let the peer open new paths, it is RECOMMENDED to
   proactively issue at least one Connection ID for each unused path ID
   up to the minimum of the peer's and the local maximum path ID limits.

   If for any reason an endpoint does not want to issue connection IDs
   for all unused path ID, it SHOULD NOT introduce discontinuity in the
   issuing of path IDs as path initiation requires available connection
   IDs for the same path ID on both sides.  For instance, if the maximum
   path ID limit is 2 and the endpoint wants to provide connection IDs
   for only one path ID inside range [1, 2], it should select path ID 1
   (and not Path ID 2).

   Similarly, endpoints SHOULD consume path IDs in a continuous way,
   i.e., when creating paths.  However, endpoints cannot expect to
   receive new connection IDs or path initiation attempts with in-order
   use of path IDs due to out-of-order delivery or path validation
   failure.

   Each endpoint maintains the set of connection IDs received from its
   peer for each path, any of which it can use when sending packets on
   that path; see also Section 5.1 of [QUIC-TRANSPORT].  Usually, it is
   desired to provide at least one additional connection ID for all used
   paths, to allow for (unintentional) migration events (Section 9.5 of
   [QUIC-TRANSPORT]).

   As further specified in Section 5.1 of [QUIC-TRANSPORT] connection
   IDs cannot be issued more than once on the same connection and
   therefore are unique for the scope of the connection, regardless of
   the associated path ID.

   Endpoints MUST NOT issue new connection IDs with path IDs greater
   than the Maximum Path Identifier field in MAX_PATH_ID frames (see
   Section 4.6) or the value of initial_max_path_id transport parameter
   if no MAX_PATH_ID frame was received yet.  Receipt of a frame with a
   greater path ID is a connection error as specified in Section 4.

Liu, et al.              Expires 25 October 2025               [Page 12]
Internet-Draft               Multipath QUIC                   April 2025

   When an endpoint finds it has not enough available unused path IDs,
   it SHOULD either send a MAX_PATH_ID frame to increase the active path
   limit (when limited by the sender) or a PATHS_BLOCKED frame (see
   Section 4.7) to inform the peer that its current limit prevented the
   creation of the new path.

3.2.2.  Rotating and Retiring Connection IDs

   Section 5.1.2 of [QUIC-TRANSPORT] indicates that an endpoint can
   change the connection ID it uses to another available one at any time
   during the connection.  For the extension specified in this document,
   endpoints MUST only rotate to another connection IDs associated to
   the same path ID.  Use of a connection ID associated with another
   path ID will be considered as an attempt to open a new path instead.

   An endpoint is supposed to retire connection ID that are not used
   anymore, and the server is supposed to provide replacements, as
   specified in Section 5.1.2. of [QUIC-TRANSPORT].  As such, when
   receiving a PATH_RETIRE_CONNECTION_ID frame, an endpoint SHOULD
   provide new connection IDs for that path, if still open, using
   PATH_NEW_CONNECTION_ID frames.

   While it it expected that the peer provides at least one unused
   connection ID for all active paths using the PATH_NEW_CONNECTION_ID
   after retirement of an old connection ID, an endpoint MAY send a
   PATH_CIDS_BLOCKED (see Section 4.7) if it wants to change the
   connection ID but no unused connection ID for a that path is
   available.  Further, an endpoint MAY also send a PATH_CIDS_BLOCKED
   frame if it wants to open a new path and has no connection IDs
   available for an unused path ID even though the Maximum Path
   Identifier value would allow for more paths.

   Retirement of connection IDs will not retire the path ID that
   corresponds to the connection ID or any other path resources as the
   packet number space is associated to the path ID.

   The peer that sends the PATH_RETIRE_CONNECTION_ID frame can keep
   sending data on the path that the retired connection ID was used on
   but has to use a different connection ID for the same path ID when
   doing so.

3.3.  Path Status Management

   An endpoint can send PATH_BACKUP and PATH_AVAILABLE frames (see
   Section 4.3) to inform the peer that it should send packets on the
   paths with the preference expressed by these frames.  Note that an
   endpoint might not follow the peer’s advertisements, but these frames
   are still a clear signal of the peer's preference of path usage.

Liu, et al.              Expires 25 October 2025               [Page 13]
Internet-Draft               Multipath QUIC                   April 2025

   Each peer indicates its preference of path usage independently of the
   other peer.  That means that peers may have different usage
   preferences for the same path.  Depending on the data sender's
   decisions, this may lead to usage of paths that have been indicated
   as "backup" by the peer or non-usage of some locally available paths.

   PATH_AVAILABLE indicates that a path is "available", i.e., it
   suggests to the peer to use its own logic to split traffic among
   available paths.

   PATH_BACKUP suggests that a path should only be used as backup i.e.
   that no traffic should be sent on that path if another path is
   available and usable.  If all established paths are indicated as
   backup paths, no guidance is provided about which path should be
   used.

   Similarly, if no frame indicating a path usage preference was
   received for a certain path, the preference of the peer is unknown
   and the sender needs to decide based on it own local logic if the
   path should be used.

   If an endpoint starts using a backup path because it has detected
   issues on the paths marked as "available", it is RECOMMENDED to
   update its own path state signaling such that the peer avoids using
   the broken path.  An endpoint that detects a path breakage can also
   explicitly close the path by sending a PATH_ABANDON frame (see
   Section 3.4) in order to avoid that its peer keeps using it and
   enable faster switchover to a backup path.  If the endpoints do not
   want to close the path immediately, as connectivity could be re-
   established, PING frames can potentially be used to quickly detect
   connectivity changes and switch back in a timely way.

   The PATH_AVAILABLE and PATH_BACKUP frames share a common, per-path
   sequence number space to detect and ignore outdated information, as
   further described in Section 4.3.  This is needed as they might
   arrive out-of-order, e.g., if sent using different paths.

3.4.  Path Close

   At any time in the connection, each endpoint can decide to abandon a
   path, for example following changes in local connectivity or local
   preferences.  An endpoint that wants to abandon a path MUST
   explicitly close the path by sending a PATH_ABANDON frame (see
   Section 4.2).  This is true whether the decision to close the path
   results from implicit signals such as an idle time-out (see
   Section 5.9) or packet losses as well as for any other reason such as
   management of local resources.

Liu, et al.              Expires 25 October 2025               [Page 14]
Internet-Draft               Multipath QUIC                   April 2025

   The peers that send a PATH_ABANDON frame MUST treat all connection
   IDs received from the peer for the path ID indicated in the
   PATH_ABANDON as immediately retired, and subsequently cannot send any
   packet on that path anymore.  Note that while abandoning a path will
   cause connection ID retirement, the inverse is not true: retiring the
   associated connection IDs does not indicate path abandonment (see
   further Section 3.2).

   PATH_ABANDON frames can be sent on any open path, not only on the
   path that is intended to be closed.  It is RECOMMENDED to send the
   PATH_ABANDON frames on another open path, especially if connectivity
   on the to-be-abandoned path is expected to be broken.

   When an endpoint receives a PATH_ABANDON frame, it MUST send a
   corresponding PATH_ABANDON frame, if it has not already done so, and
   respectively treat all connection IDs received from the peer for that
   path as immediately retired.  While that means retired connection IDs
   received from the peer cannot be used for sending anymore, packets
   from the peer might still be in transit.  Therefore, knowledge of the
   connection IDs issued to the peer and of the state of the number
   space associated to the path SHOULD be retained for 3 PTO after the
   PATH_ABANDON frame has been received.  This avoids generating
   spurious stateless packets, as discussed in Section 3.4.2, and helps
   acknowledge any potentially reordered, outstanding packets from the
   peer (see Section 3.4.3).

   It is also possible that an endpoint will receive a PATH_ABANDON
   frame before receiving or sending any traffic on a path.  For
   example, if the client tries to initiate a path and the path cannot
   be established, it will send a PATH_ABANDON frame (see Section 3.1).
   An endpoint may also decide to abandon an unused path for any other
   reason, for example, removing a hole from the sequence of path IDs in
   use.  This is not an error.

   If a peer sends a PATH_ABANDON frame but never receives a
   corresponding PATH_ABANDON frame, it might not be able to remove path
   state.  It is left to the implementation to handle this unexpected
   behavior as it does not impact interoperability.  If the endpoint is
   no longer willing to process the issued connection IDs for the
   abandoned path, it MAY close the connection, but SHOULD wait at least
   3 PTOs after sending the PATH_ABANDON frame.

   After a path is abandoned, the path ID MUST NOT be reused for new
   paths, as the path ID is part of the nonce calculation Section 2.4.

   If a PATH_ABANDON frame is received for the only open path of a QUIC
   connection, the receiving peer SHOULD send a CONNECTION_CLOSE frame
   and enter the closing state.  Alternatively, a client MAY instead try

Liu, et al.              Expires 25 October 2025               [Page 15]
Internet-Draft               Multipath QUIC                   April 2025

   to open a new path, if available, and only initiate connection
   closure if path validation fails or a CONNECTION_CLOSE frame is
   received from the server.  Similarly, the server MAY wait for a
   short, limited time such as one PTO if a path probing packet is
   received on a new path before sending the CONNECTION_CLOSE frame.

   Note that other explicit closing mechanisms of [QUIC-TRANSPORT] still
   apply on the whole connection.  In particular, the reception of
   either a CONNECTION_CLOSE (Section 10.2 of [QUIC-TRANSPORT]) or a
   Stateless Reset (Section 10.3 of [QUIC-TRANSPORT]) closes the
   connection.

3.4.1.  Path Closure Example

   In the example below, the client wants to close the path with path ID
   0.  It sends the PATH_ABANDON frame to terminate the path with path
   ID 0 on the path with path ID 1 using the connection ID S1.  After
   receiving the PATH_ABANDON frame for path ID 0, the server also sends
   a PATH_ABANDON frame with path ID 0 together with an PATH_ACK frame
   on the same path using connection ID C1.

   Client                                                      Server

   (client tells server to abandon a path with path ID 0)
   1-RTT[X]: DCID=S1 PATH_ABANDON[path ID=0]->
                              (server tells client to abandon a path)
                       <-1-RTT[Y]: DCID=C1 PATH_ABANDON[path ID=0],
                                              PATH_ACK[PATH ID=1, PN=X]
   1-RTT[U]: DCID=S1 PATH_ACK[path ID=1, PN=Y] ->

                    Figure 2: Example of closing a path.

   Note that if the PATH_ABANDON frame is instead sent on the to-be-
   abandoned path, the last acknowledgment still needs to be send on a
   different path as no further packets can be sent on the abandoned
   path after the PATH_ABANDON frame.

3.4.2.  Avoiding Spurious Stateless Resets

   Due to network delays, packets sent on an abandoned path can arrive
   well after the connection IDs have been retired.  If not recognized
   as bound to the local connection, such packet triggers the peer to
   send a Stateless Reset packet.  The rule to "retain knowledge of
   connection ID for 3 PTO after receiving a PATH_ABANDON" is intended
   to reduce the risk of sending such spurious stateless packets, but it
   cannot completely avoid that risk.

Liu, et al.              Expires 25 October 2025               [Page 16]
Internet-Draft               Multipath QUIC                   April 2025

   Section 10.3 of [QUIC-TRANSPORT] specified that the Stateless Reset
   Tokens associated with retired connection IDs cannot be used to
   identify Stateless Reset packets.  The immediate retirement of
   connection IDs received from the peer for an abandoned path
   guarantees that spurious Stateless Reset packets sent by the peer
   will not cause the closure of the QUIC connection.

3.4.3.  Handling PATH_ACK for Abandoned Paths

   When an endpoint sends a PATH_ABANDON frame, there may still be some
   packets in transit from the peer.  Further, if an endpoint receives a
   PATH_ABANDON frame, it may still receive reordered packets on the
   abandoned path.  Endpoints SHOULD promptly send PATH_ACK frames for
   all unacknowledged packets received on an abandoned path if path
   state is still retained to do so.

   PATH_ACK frames have to be sent on a different path than the path
   being abandoned after sending the PATH_ABANDON frame as connection
   IDs are immediately retired.

   When an endpoint finally deletes all state associated with the path,
   the packets sent over the path and not yet acknowledged MUST be
   considered lost.  PATH_ACK frames received with an abandoned path ID
   are silently ignored, as specified in Section 4.

4.  New Frames

   All frames defined in this document MUST only be sent in 1-RTT
   packets.  If an endpoint receives a multipath-specific frame in a
   different packet type, it MUST close the connection with an error of
   type PROTOCOL_VIOLATION.

   Receipt of multipath-specific frames that use a path ID that is
   greater than the announced Maximum Paths value in the MAX_PATH_ID
   frame or in the initial_max_path_id transport parameter, if no
   MAX_PATH_ID frame was received yet, MUST be treated as a connection
   error of type PROTOCOL_VIOLATION.

   If an endpoint receives a multipath-specific frame with a path ID
   that it cannot process anymore (e.g., because the path might have
   been abandoned), it MUST silently ignore the frame.

Liu, et al.              Expires 25 October 2025               [Page 17]
Internet-Draft               Multipath QUIC                   April 2025

4.1.  PATH_ACK Frame

   The PATH_ACK frame (types TBD-00 and TBD-01) is an extension of the
   ACK frame specified in Section 19.3 of [QUIC-TRANSPORT].  It is used
   to acknowledge packets that were sent on different paths, as each
   path has its own packet number space.  If the frame type is TBD-01,
   PATH_ACK frames also contain the sum of QUIC packets with associated
   ECN marks received on the acknowledged packet number space up to this
   point.

   PATH_ACK frame is formatted as shown in Figure 3.

     PATH_ACK Frame {
       Type (i) = TBD-00..TBD-01
            (experiments use  0x15228c00-0x15228c01),
       Path Identifier (i),
       Largest Acknowledged (i),
       ACK Delay (i),
       ACK Range Count (i),
       First ACK Range (i),
       ACK Range (..) ...,
       [ECN Counts (..)],
     }

                      Figure 3: PATH_ACK Frame Format

   Compared to the ACK frame specified in [QUIC-TRANSPORT], the
   following field is added:

   Path Identifier:  The path ID associated with the packet number space
      of the 0-RTT and 1-RTT packets which are acknowledged by the
      PATH_ACK frame.

4.2.  PATH_ABANDON Frame

   The PATH_ABANDON frame informs the peer to abandon a path.  After the
   PATH_ABANDON frame is sent on a path, the path can no longer be used
   for sending.

   PATH_ABANDON frames are formatted as shown in Figure 4.

     PATH_ABANDON Frame {
       Type (i) = TBD-02 (experiments use 0x15228c05),
       Path Identifier (i),
       Error Code (i),
     }

                    Figure 4: PATH_ABANDON Frame Format

Liu, et al.              Expires 25 October 2025               [Page 18]
Internet-Draft               Multipath QUIC                   April 2025

   PATH_ABANDON frames contain the following fields:

   Path Identifier:  The path ID associated to the to-be-abandoned path.

   Error Code:  A variable-length integer that indicates the reason for
      abandoning this path.  NO_ERROR(0x0) indicates that the path is
      being abandoned without any error being encountered.  Other error
      codes can be found in Section 4.2.1.

   PATH_ABANDON frames are ack-eliciting.  If a packet containing a
   PATH_ABANDON frame is considered lost, the peer SHOULD repeat it.

   Use of the PATH_ABANDON frame is specified in section Section 3.4.

4.2.1.  Error Codes

   QUIC transport error codes are 62-bit unsigned integers (see
   Section 20.1 of [QUIC-TRANSPORT].  In addition to NO_ERROR(0x0), the
   following QUIC error codes are defined for use in the PATH_ABANDON
   frame:

   APPLICATION_ABANDON (TBD-10):  The endpoint is abandoning the path at
      the request of the application.

   RESOURCE_LIMIT_REACHED (TBD-11):  The endpoint is abandoning the path
      because it cannot allocate sufficient resources to maintain it.

   UNSTABLE_INTERFACE (TBD-12):  The endpoint is abandoning the path
      because the used interface is considered to be unstable.  This
      condition can occur, e.g., due to a weak wireless signal or
      frequent handover events during high-speed mobility.

   NO_CID_AVAILABLE (TBD-13):  The endpoint is abandoning the path due
      to the lack of a connection ID for this path.  This may occur when
      the peer initiates a new path but has not provided a corresponding
      connection ID for the path ID (or the packet containing the
      connection IDs has not arrived yet).

4.3.  PATH_AVAILABLE and PATH_BACKUP frames

   PATH_AVAILABLE frames are used by endpoints to inform the peer that
   the indicated path is available for sending.

   PATH_AVAILABLE frames are formatted as shown in Figure 5.

Liu, et al.              Expires 25 October 2025               [Page 19]
Internet-Draft               Multipath QUIC                   April 2025

     PATH_AVAILABLE Frame {
       Type (i) = TBD-04 (experiments use 0x15228c08),
       Path Identifier (i),
       Path Status Sequence Number (i),
     }

                   Figure 5: PATH_AVAILABLE Frame Format

   PATH_BACKUP frames are used by endpoints to inform the peer about its
   preference to not use the indicated path for sending.

   PATH_BACKUP frames are formatted as shown in Figure 6.

     PATH_BACKUP Frame {
       Type (i) = TBD-03 (experiments use 0x15228c07)
       Path Identifier (i),
       Path Status Sequence Number (i),
     }

                     Figure 6: PATH_BACKUP Frame Format

   Both PATH_AVAILABLE and PATH_BACKUP frames contain the following
   fields:

   Path Identifier:  The path ID that the status update corresponds to.
      All path IDs below the maximum path ID limit can be indicated,
      even if the path is not in active use yet.

   Path Status Sequence Number:  A variable-length integer specifying
      the per-path sequence number assigned for this frame.

   The sequence number space is common to the two frame types, and
   monotonically increasing values MUST be used when sending
   PATH_AVAILABLE or PATH_BACKUP frames for a given path ID.

   Frames may be received out of order.  A peer MUST ignore an incoming
   PATH_AVAILABLE or PATH_BACKUP frame if it previously received another
   PATH_BACKUP frame or PATH_AVAILABLE frame for the same path ID with a
   Path Status sequence number equal to or higher than the Path Status
   sequence number of the incoming frame.

   The requirement of monotonically increasing sequence numbers is per
   path.  Receivers could very well receive the same sequence number for
   PATH_AVAILABLE or PATH_BACKUP Frames on different paths.  As such,
   the receiver of the PATH_AVAILABLE or PATH_BACKUP frame needs to use
   and compare the sequence numbers separately for each path ID.

Liu, et al.              Expires 25 October 2025               [Page 20]
Internet-Draft               Multipath QUIC                   April 2025

   PATH_BACKUP and PATH_AVAILABLE frames are ack-eliciting.  If a packet
   containing a PATH_BACKUP or PATH_AVAILABLE frame is considered lost,
   the peer SHOULD resend the frame only if it contains the last status
   sent for that path -- as indicated by the sequence number.

   A PATH_BACKUP or a PATH_AVAILABLE frame MAY be bundled with a
   PATH_NEW_CONNECTION_ID frame or a PATH_RESPONSE frame in order to
   indicate the preferred path usage before or during path initiation.

4.4.  PATH_NEW_CONNECTION_ID frame

   The PATH_NEW_CONNECTION_ID frame (type=TBD-05) is an extension of the
   NEW_CONNECTION_ID frame specified in Section 19.15 of
   [QUIC-TRANSPORT].  It is used to provide its peer with alternative
   connection IDs for 1-RTT packets for a specific path.  The peer can
   then use a different connection ID on the same path to break
   linkability when migrating on that path; see also Section 9.5 of
   [QUIC-TRANSPORT].

   PATH_NEW_CONNECTION_ID frames are formatted as shown in Figure 7.

   PATH_NEW_CONNECTION_ID Frame {
     Type (i) = TBD-05 (experiments use 0x15228c09),
     Path Identifier (i),
     Sequence Number (i),
     Retire Prior To (i),
     Length (8),
     Connection ID (8..160),
     Stateless Reset Token (128),
   }

               Figure 7: PATH_NEW_CONNECTION_ID Frame Format

   Compared to the NEW_CONNECTION_ID frame specified in Section 19.15 of
   [QUIC-TRANSPORT], the following field is added:

   Path Identifier:  The path ID associated with the connection ID.
      This means the provided connection ID can only be used on the
      corresponding path.

   Note that, other than for the NEW_CONNECTION_ID frame of
   Section 19.15 of [QUIC-TRANSPORT], the sequence number applies on a
   per-path context.  This means different connection IDs on different
   paths may have the same sequence number value.

Liu, et al.              Expires 25 October 2025               [Page 21]
Internet-Draft               Multipath QUIC                   April 2025

   The Retire Prior To field indicates which connection IDs should be
   retired among those that share the path ID in the Path Identifier
   field.  Connection IDs associated with different path IDs are not
   affected.

   Note that the NEW_CONNECTION_ID frame can only be used to issue or
   retire connection IDs for the initial path with path ID 0.

   The last paragraph of Section 5.1.2 of [QUIC-TRANSPORT] specifies how
   to verify the Retire Prior To field of an incoming NEW_CONNECTION_ID
   frame.  The same rule applies for PATH_NEW_CONNECTION_ID frames, but
   it applies per path.  If the multipath extension is used, the rule
   for NEW_CONNECTION_ID frame is only applied for path ID 0.

4.5.  PATH_RETIRE_CONNECTION_ID frame

   The PATH_RETIRE_CONNECTION_ID frame (TBD-06) is an extension of the
   RETIRE_CONNECTION_ID frame specified in Section 19.16 of
   [QUIC-TRANSPORT].  It is used to indicate that an endpoint will no
   longer use a connection ID for a specific path ID that was issued by
   its peer.  To retire the connection ID used during the handshake on
   the initial path, path ID 0 is used.  Sending a
   PATH_RETIRE_CONNECTION_ID frame also serves as a request to the peer
   to send additional connection IDs for this path (see also Section 5.1
   of [QUIC-TRANSPORT]), unless the path specified by the path ID has
   been abandoned.  New path-specific connection IDs can be delivered to
   a peer using the PATH_NEW_CONNECTION_ID frame (see Section 4.4).

   PATH_RETIRE_CONNECTION_ID frames are formatted as shown in Figure 8.

   PATH_RETIRE_CONNECTION_ID Frame {
     Type (i) = TBD-06 (experiments use 0x15228c0a),
     Path Identifier (i),
     Sequence Number (i),
   }

              Figure 8: PATH_RETIRE_CONNECTION_ID Frame Format

   Compared to the RETIRE_CONNECTION_ID frame specified in Section 19.16
   of [QUIC-TRANSPORT], the following field is added:

   Path Identifier:  The path ID associated with the connection ID to
      retire.

   Note that the RETIRE_CONNECTION_ID frame can only be used to retire
   connection IDs for the initial path with path ID 0.

Liu, et al.              Expires 25 October 2025               [Page 22]
Internet-Draft               Multipath QUIC                   April 2025

   As the PATH_NEW_CONNECTION_ID frames applies the sequence number per
   path, the sequence number in the PATH_RETIRE_CONNECTION_ID frame is
   also per path.  The PATH_RETIRE_CONNECTION_ID frame retires the
   Connection ID with the specified path ID and sequence number.

   The processing of an incoming RETIRE_CONNECTION_ID frame is described
   in Section 19.16 of [QUIC-TRANSPORT].  The same processing applies
   for PATH_RETIRE_CONNECTION_ID frames per path, while with use of the
   multipath extension the processing of a RETIRE_CONNECTION_ID frame is
   only applied for path ID 0.

4.6.  MAX_PATH_ID frame

   A MAX_PATH_ID frame (type=0x15228c0c) informs the peer of the maximum
   path ID it is permitted to use.

   MAX_PATH_ID frames are formatted as shown in Figure 9.

   MAX_PATH_ID Frame {
     Type (i) = TBD-07 (experiments use 0x15228c0c),
     Maximum Path Identifier (i),
   }

                     Figure 9: MAX_PATH_ID Frame Format

   MAX_PATH_ID frames contain the following field:

   Maximum Path Identifier:  The maximum path ID that the sending
      endpoint is willing to accept.  This value MUST NOT exceed 2^32-1,
      which is the maximum allowed value for the path ID due to
      restrictions on the nonce calculation (see Section 2.4).  The
      Maximum Path Identifier value MUST NOT be lower than the value
      advertised in the initial_max_path_id transport parameter.

   Receipt of an invalid Maximum Path Identifier value MUST be treated
   as a connection error of type PROTOCOL_VIOLATION.

   Loss or reordering can cause an endpoint to receive a MAX_PATH_ID
   frame with a smaller Maximum Path Identifier value than was
   previously received.  MAX_PATH_ID frames that do not increase the
   path limit MUST be ignored.

   MAX_PATH_ID frames are ack-eliciting and SHOULD be retransmitted when
   lost and no more recent MAX_PATH_ID frame has been sent in the
   meantime.

Liu, et al.              Expires 25 October 2025               [Page 23]
Internet-Draft               Multipath QUIC                   April 2025

4.7.  PATHS_BLOCKED and PATH_CIDS_BLOCKED frames

   A sender can send a PATHS_BLOCKED frame (type=0x15228c0d) when it
   wishes to open a path but is unable to do so due to the maximum path
   ID limit set by its peer.

   A sender can send a PATH_CIDS_BLOCKED frame (type=0x15228c0e) when it
   wishes to open a path with a valid path ID or change the CID on an
   established path but is unable to do so because there are no unused
   connection IDs available for the corresponding path ID.

   Note that PATHS_BLOCKED and PATH_CIDS_BLOCKED frames are
   informational.  Sending a PATHS_BLOCKED or a PATH_CIDS_BLOCKED frame
   does not imply a particular action from the peer like sending a
   MAX_PATH_ID farme with a new Maximum Path Identifier value, but
   informs the peer that the maximum path ID limit or the absence of
   unused connection IDs prevented the creation or the usage of paths.
   If the successful reception of a PATHS_BLOCKED/PATH_CIDS_BLOCKED
   frame was acknowledged but no action is taken by the peer, this is
   likely a deliberate decision by the peer and repeating the
   PATHS_BLOCKED/PATH_CIDS_BLOCKED frame will not change that.

   PATHS_BLOCKED frames are formatted as shown in Figure 10.

   PATHS_BLOCKED Frame {
     Type (i) = TBD-08 (experiments use 0x15228c0d),
     Maximum Path Identifier (i),
   }

                Figure 10: MAX_PATH_ID_BLOCKED Frame Format

   PATHS_BLOCKED frames contain the following field:

   Maximum Path Identifier:  A variable-length integer indicating the
      maximum path ID that was allowed at the time the frame was sent.
      If the received value is lower than the currently allowed maximum
      value, this frame can be ignored.

   PATH_CIDS_BLOCKED frames are formatted as shown in Figure 11.

   PATH_CIDS_BLOCKED Frame {
     Type (i) = TBD-09 (experiments use 0x15228c0e),
     Path Identifier (i),
     Next Sequence Number (i),
   }

                 Figure 11: PATH_CIDS_BLOCKED Frame Format

Liu, et al.              Expires 25 October 2025               [Page 24]
Internet-Draft               Multipath QUIC                   April 2025

   PATH_CIDS_BLOCKED frames contain the following fields:

   Path Identifier:  Identifier of the path for which unused connection
      IDs are not available.

   Next Sequence Number:  The next sequence number that is expected to
      be issued for a connection ID for this path by the peer.

   Receipt of a value of Maximum Path Identifier or Path Identifier that
   is higher than the local maximum value MUST be treated as a
   connection error of type PROTOCOL_VIOLATION.

   Receipt of a value of Next Sequence Number that is higher than the
   sequence number of the next expected to be issued connection ID for
   this path MUST be treated as a connection error of type
   PROTOCOL_VIOLATION.

   PATHS_BLOCKED and PATH_CIDS_BLOCKED frames are ack-eliciting and MAY
   be retransmitted if the path is still blocked when the lost is
   detected.

5.  Implementation Considerations

   This section provides informational guidance for implementors.

5.1.  CID Changes, Migration, and NAT Rebindings

   With the multipath extension, each path uses a separate packet number
   space.  This is a major difference from [QUIC-TRANSPORT], which only
   defines three number spaces (Initial, Handshake and Application
   packets).

   For any given path, connection ID rotation, NAT rebinding, or client
   initiated migration as specified in [QUIC-TRANSPORT] might occur,
   like on a single path.  These events do not change the path ID,
   and do not affect the packet number space associated with the path.

   It is generally preferable to use multipath mechanisms such as
   creating a new path and later abandoning the old path, rather than
   doing migration of a single path as specified in [QUIC-TRANSPORT].
   This enables a smoother handover and allows a more controlled
   migration handling at the server side.  However, migration of a
   single path cannot be avoided in case of NAT rebinding, or if the
   server requests migration to a "preferred address" during the
   handshake.

Liu, et al.              Expires 25 October 2025               [Page 25]
Internet-Draft               Multipath QUIC                   April 2025

   Section 9.3 of [QUIC-TRANSPORT] allows an endpoint to skip validation
   of a peer address if that address has been seen recently.  However,
   when the multipath extension is used and an endpoint has multiple
   addresses that could lead to switching between different paths, it
   should rather maintain multiple open paths instead.

   Servers observing a 4-tuple change will perform path validation (see
   Section 9 of [QUIC-TRANSPORT]).  If path validation process succeeds,
   the endpoints set the path's congestion controller and round-trip
   time estimator according to Section 9.4 of [QUIC-TRANSPORT].

5.2.  Using Multiple Paths on the Same 4-tuple

   It is possible to create paths that refer to the same 4-tuple.  For
   example, the endpoints may want to create paths that use different
   Differentiated Service [RFC2475] markings.  This could be done in
   conjunction with scheduling algorithms that match streams to paths,
   so that for example data frames for low priority streams are sent
   over low priority paths.  Since these paths use different path IDs,
   they can be managed independently to suit the needs of the
   application.

   There may be cases in which paths are created with different
   4-tuples, but end up using the same 4-tuples as a consequence of path
   migrations.  Consider the following example where all paths use the
   same source and destination ports:

   *  Client starts path 1 from address 192.0.2.1 to server address
      198.51.100.1

   *  Client starts path 2 from address 192.0.2.2 to server address
      198.51.100.1

   *  Both paths are used for a while.

   *  Server sends packet from address 198.51.100.1 to client address
      192.0.2.1, with CID indicating path ID 2.

   *  Client receives the packet, recognizes a path migration, updates
      the source address of path 2 to 192.0.2.1.

Liu, et al.              Expires 25 October 2025               [Page 26]
Internet-Draft               Multipath QUIC                   April 2025

   Such unintentional use of the same 4-tuple on different paths ought
   to be rare.  When they happen, the two paths would be redundant, and
   the endpoint could want to close one of them.  Uncoordinated abandon
   of both endpoints may result in deleting both paths instead of just
   one.  To avoid this pitfall, endpoints could adopt a simple
   coordination rule, such as only letting the client initiate closure
   of duplicate paths, or perhaps relying on the application protocol to
   decide which paths should be closed.

5.3.  Congestion Control

   When the QUIC multipath extension is used, senders manage per-path
   congestion status as required in Section 9.4 of [QUIC-TRANSPORT].
   However, in [QUIC-TRANSPORT] only one active path is assumed and as
   such the requirement is to reset the congestion control status on
   path migration.  With the multipath extension, multiple paths can be
   used simultaneously, therefore separate congestion control state is
   maintained for each path.  This means a sender is not allowed to send
   more data on a given path than congestion control for that path
   indicates.

   When a Multipath QUIC connection uses two or more paths, there is no
   guarantee that these paths are fully disjoint.  When two (or more
   paths) share the same bottleneck, using a standard congestion control
   scheme could result in an unfair distribution of the bandwidth with
   the multipath connection getting more bandwidth than competing single
   paths connections.  Multipath TCP uses the linked increased algorithm
   (LIA) congestion control scheme specified in [RFC6356] to solve this
   problem.  This scheme can immediately be adapted to Multipath QUIC.
   Other coupled congestion control schemes have been proposed for
   Multipath TCP such as [OLIA].  Designers of congestion control
   algorithms specialized for Multipath QUIC are advised to follow BCP
   133; see Section 7.10 of [RFC9743].

   Section 5.1.2 of [QUIC-TRANSPORT] indicates that an endpoint can
   change the connection ID it uses to another available one at any time
   during the connection.  As such, a sole change of the Connection ID
   without any change in the address does not indicate a path change and
   the endpoint can keep the same congestion control and RTT measurement
   state.

5.4.  Computing Path RTT

   PATH_ACK frames indicate which path the acknowledged packets were
   sent on, but they may be received through any open path.  If
   successive acknowledgments are received on different paths, the
   measured RTT samples can fluctuate widely, which could result in poor
   performance depending e.g. on the used connection control.

Liu, et al.              Expires 25 October 2025               [Page 27]
Internet-Draft               Multipath QUIC                   April 2025

   Congestion control state as defined in [QUIC-RECOVERY] is kept per
   path ID.  However, depending on which path acknowledgements are sent,
   the actual RTT of a path cannot be calculated or may not be the right
   value to be used.

   Instead of using RTT, we define the acknowledgment delays as the sum
   of two one-way delays: the delay on the packet sending path and the
   delay on the return path chosen for the acknowledgments.  When
   different paths have different characteristics, acknowledgment delays
   can vary widely.  Consider for example a multipath transmission using
   both a terrestrial path, with a latency of 50ms in each direction,
   and a geostationary satellite path, with a latency of 300ms in each
   direction.  The acknowledgment delay will depend on the combination
   of paths used for the packet transmission and the acknowledgement
   transmission, as shown in Table 1.

            +======================+=============+===========+
            | ACK Path \ Data path | Terrestrial | Satellite |
            +======================+=============+===========+
            | Terrestrial          | 100ms       | 350ms     |
            +----------------------+-------------+-----------+
            | Satellite            | 350ms       | 600ms     |
            +----------------------+-------------+-----------+

              Table 1: Example of ACK delays using multiple
                                  paths

   The computed values reflect both the state of the network path and
   the scheduling decisions of the acknowledgement sender.  If we assume
   that the PATH_ACK will be sent over the terrestrial link, because
   this decision provides the best response time, the computed RTT value
   for the satellite path will be about 350ms.  This is lower than the
   600ms that would be measured if the PATH_ACK came over the satellite
   channel, but it is still the right value for computing for example
   the PTO timeout: if a PATH_ACK is not received after more than 350ms,
   either the data packet or its PATH_ACK were probably lost.

   The simplest implementation is to use the acknowledgment delay to
   compute smoothed_rtt and rttvar per Section 5.3 of [QUIC-RECOVERY]
   regardless of the path through which PATH_ACK frames are received.
   This approach will provide good results as long as acknowledgements
   are sent consistently over the same paths.  If at any time the sender
   revisits its sending preferences, this can also change the paths that
   are used to send acknowledgements.  However, this is not very
   different from route changes on a single path.  The RTT, RTT variance
   and PTO estimates will rapidly converge to reflect the new
   conditions.  There is one exception: the minimum RTT, which is also a
   known challenge when route changes occurs on a single path.  An

Liu, et al.              Expires 25 October 2025               [Page 28]
Internet-Draft               Multipath QUIC                   April 2025

   acknowledgement receiver can, however, remember the path over which
   the PATH_ACK that produced the minimum RTT was received, and restart
   the minimum RTT computation if that acknowledgement path changes or
   is abandoned.

   Further, congestion control functions that rely on delay estimates
   needs to consider cases where acknowledgements are sent over multiple
   paths with different delays explicitly.

5.5.  Packet Scheduling

   The transmission of data packets is limited by the arrival of data
   from the application and by congestion control.  Generally, QUIC
   packets that increase the number of bytes in flight can only be sent
   when the congestion window for the selected path allows it.

   Most frames, including control frames (PATH_CHALLENGE and
   PATH_RESPONSE being the notable exceptions), can be sent and received
   on any open path.  As such, a packet scheduler is needed to decide
   which path to use for sending the next packet, among those paths with
   an open congestion window.  If multiple paths are used to send data
   frames belonging to the same stream, data delivery will experience
   the maximum delay of all used paths due to in-order delivery.  The
   scheduling is a local decision, based on the preferences of the
   application and the implementation.

   This implies that an endpoint may send and receive PATH_ACK frames on
   a path different from the one that carried the acknowledged packets.
   As noted in Section 5.4, RTT estimates computed using the standard
   algorithm reflect both the characteristics of the path and the
   scheduling algorithm of PATH_ACK frames.  The estimates will converge
   faster if the scheduling strategy of PATH_ACK frames is stable.
   Implementations can choose different strategies such as, for
   instance, sending PATH_ACK frames either simply on the path where the
   acknowledged packets was received, or alternatively the shortest
   path, which results in shorter control loops and potentially better
   performance.

   Since packets that only carry PATH_ACK frames are not congestion
   controlled (see Section 7 of [QUIC-RECOVERY]), senders should
   carefully consider the load induced by these packets, especially if
   the capacity is unknown on that path, e.g., when that path is not
   used for sending data frames.

Liu, et al.              Expires 25 October 2025               [Page 29]
Internet-Draft               Multipath QUIC                   April 2025

5.6.  Retransmissions

   Simultaneous use of multiple paths enables different retransmission
   strategies to cope with losses such as: a) retransmitting lost frames
   over the same path, b) retransmitting lost frames on a different or
   dedicated path, and c) duplicate lost frames on several paths (not
   recommended for general purpose use due to the network overhead).
   While this document does not preclude a specific strategy, more
   detailed specification is out of scope.

   As noted in Section 2.2 of [QUIC-TRANSPORT], STREAM frame boundaries
   are not expected to be preserved when data is retransmitted.
   Especially when STREAM frames have to be retransmitted over a
   different path with a smaller MTU limit, new smaller STREAM frames
   might need to be sent instead.

5.7.  PTO Expiration

   An implementation should follow the mechanism specified in
   [QUIC-RECOVERY] for detecting packet loss on each individual path.  A
   special case happens when the PTO timer expires.  According to
   [QUIC-RECOVERY], no packet will be declared lost until either the
   packet sender receives a new acknowledgement for this path, or the
   path itself is finally declared broken.  This cautious process
   minimizes the risk of spurious retransmissions, but it may cause
   significant delivery delay for the frames contained in these "lost
   packets".

   Endpoints could take advantage of the multipath extension, and
   retransmit the content of the delayed packets on other available
   paths if the congestion control window on these paths allows.

5.8.  Paths Having Different PMTU Sizes

   An implementation should take care to handle different PMTU sizes
   across multiple paths.  As specified in Section 14.3 of
   [QUIC-TRANSPORT] the DPLPMTUD Maximum Packet Size (MPS) is maintained
   for each combination of local and remote IP addresses.  One simple
   option, if the PMTUs are relatively similar, is to apply the minimum
   PMTU of all paths to each path.  The benefit of such an approach is
   to simplify retransmission processing as the content of lost packets
   initially sent on one path can be sent on another path without
   further frame scheduling adaptations.

Liu, et al.              Expires 25 October 2025               [Page 30]
Internet-Draft               Multipath QUIC                   April 2025

5.9.  Idle Timeout and Keep-Alives

   [QUIC-TRANSPORT] defines an idle timeout for closing the connection
   which applies in case of multipath usage if no packet is received on
   any path for the duration of the idle timeout.

   This document does not specify per-path idle timeouts.  An endpoint
   can decide to close a path at any time, whether the path is in active
   use or not.  For example, an endpoint may wait to send the initial
   PATH_ABANDON frame until it anyway sends another frame.  Note that
   the receiver of an initial PATH_ABANDON frame is, however, required
   to immediately reply (see Section 3.4).

   If a path is not actively used for a while, it might not be usable
   anymore, e.g. due to middlebox timeouts.  To avoid such path
   breakage, endpoints can send ack-eliciting packets such as packets
   containing PING frames (Section 19.2 of [QUIC-TRANSPORT]) on that
   path to keep it alive.  Section 5.3 of [QUIC-TRANSPORT] defines an
   optional keep alive process.  This process can be applied to each
   path separately depending on application needs.  Some applications
   may decide to not keep any not-actively used path alive, keep only
   one additonal path alive, or multiple paths, e.g. for more redunancy.
   As discussed in Section 10.1.2 of [QUIC-TRANSPORT], the keep-alive
   interval needs to incorperate timeouts in middleboxes on the path.

   If a path was not actively used for a while and no keep alives have
   been sent, an endpoint can probe it before switching to active use if
   there are still other paths that are currently usable.

6.  IANA Considerations

   This document defines a new transport parameter to enable
   simultaneous use of multiple paths within one QUIC connection.
   Further, it specifies new frame types for path management and new
   error codes when a path is abandoned.

   The current draft defines provisional values for experiments, but, if
   the draft is approved, IANA is requested to allocate short values as
   permanent with "IETF" as change controller and the QUIC WG as contact
   to the respective registries under
   https://www.iana.org/assignments/quic/quic.xhtml
   (https://www.iana.org/assignments/quic/quic.xhtml).

   The following entry in Table 2 should be added to the "QUIC Transport
   Parameters" registry under the "QUIC Protocol" heading.

Liu, et al.              Expires 25 October 2025               [Page 31]
Internet-Draft               Multipath QUIC                   April 2025

    +==========================+=====================+===============+
    | Value                    | Parameter Name.     | Specification |
    +==========================+=====================+===============+
    | TBD (current version     | initial_max_path_id | Section 2.1   |
    | uses 0x0f739bbc1b666d0d) |                     |               |
    +--------------------------+---------------------+---------------+

          Table 2: Addition to QUIC Transport Parameters Entries

   The following frame types defined in Table 3 should be added to the
   "QUIC Frame Types" registry under the "QUIC Protocol" heading.

   +========================+===========================+=============+
   | Value                  | Frame Name                |Specification|
   +========================+===========================+=============+
   | TBD-00 - TBD-01        | PATH_ACK                  |Section 4.1  |
   | (experiments use       |                           |             |
   | 0x15228c00-0x15228c01) |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-02 (experiments    | PATH_ABANDON              |Section 4.2  |
   | use 0x15228c05)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-03 (experiments    | PATH_BACKUP               |Section 4.3  |
   | use 0x15228c07)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-04 (experiments    | PATH_AVAILABLE            |Section 4.3  |
   | use 0x15228c08)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-05 (experiments    | PATH_NEW_CONNECTION_ID    |Section 4.4  |
   | use 0x15228c09)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-06 (experiments    | PATH_RETIRE_CONNECTION_ID |Section 4.5  |
   | use 0x15228c0a)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-07 (experiments    | MAX_PATH_ID               |Section 4.6  |
   | use 0x15228c0c)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-08 (experiments    | PATHS_BLOCKED             |Section 4.7  |
   | use 0x15228c0d)        |                           |             |
   +------------------------+---------------------------+-------------+
   | TBD-09 (experiments    | PATH_CIDS_BLOCKED         |Section 4.7  |
   | use 0x15228c0e)        |                           |             |
   +------------------------+---------------------------+-------------+

              Table 3: Addition to QUIC Frame Types Entries

Liu, et al.              Expires 25 October 2025               [Page 32]
Internet-Draft               Multipath QUIC                   April 2025

   The following transport error code defined in Table 4 are to be added
   to the "QUIC Transport Error Codes" registry under the "QUIC
   Protocol" heading.

   +===================+======================+=============+=============+
   |Value              |Code                  |Description  |Specification|
   +===================+======================+=============+=============+
   |TBD-10 (experiments|APPLICATION_ABANDON   |Path         |Section 4.2.1|
   |use                |                      |abandoned at |             |
   |0x004150504142414e)|                      |the          |             |
   |                   |                      |application's|             |
   |                   |                      |request      |             |
   +-------------------+----------------------+-------------+-------------+
   |TBD-11 (experiments|RESOURCE_LIMIT_REACHED|Path         |Section 4.2.1|
   |use                |                      |abandoned due|             |
   |0x0052534c494d4954)|                      |to resource  |             |
   |                   |                      |limitations  |             |
   |                   |                      |in the       |             |
   |                   |                      |transport    |             |
   +-------------------+----------------------+-------------+-------------+
   |TBD-12 (experiments|UNSTABLE_INTERFACE    |Path         |Section 4.2.1|
   |use                |                      |abandoned due|             |
   |0x00554e5f494e5446)|                      |to unstable  |             |
   |                   |                      |interfaces   |             |
   +-------------------+----------------------+-------------+-------------+
   |TBD-13 (experiments|NO_CID_AVAILABLE      |Path         |Section 4.2.1|
   |use                |                      |abandoned due|             |
   |0x004e4f5f4349445f)|                      |to no        |             |
   |                   |                      |available    |             |
   |                   |                      |connection   |             |
   |                   |                      |IDs for the  |             |
   |                   |                      |path         |             |
   +-------------------+----------------------+-------------+-------------+

                  Table 4: Error Codes for Multipath QUIC

7.  Security Considerations

   The multipath extension retains all security properties of
   [QUIC-TRANSPORT] and [QUIC-TLS] but requires some additional
   consideration regarding:

   *  potential additional resource usage for per-path connection IDs
      and multiple concurrent path contexts;

   *  a potentially increased amplification risk for request forgery
      attacks if multiple paths are used simultaneously;

Liu, et al.              Expires 25 October 2025               [Page 33]
Internet-Draft               Multipath QUIC                   April 2025

   *  changes to the nonce calculation due to the use of multiple packet
      number spaces.

7.1.  Memory Allocation for Per-Path Resources

   The maximum path ID limit in initial_max_path_id or MAX_PATH_ID frame
   limits the number of paths an endpoint is willing to maintain and
   thereby also limits the associated path resources.  Furthermore, as
   connection IDs have to be issued by both endpoints for the same path
   ID before an endpoint can open a path, each endpoint could also
   control the per-path resource usage by only issuing connection IDs
   for a limited number of paths.  However, using the maximum path ID
   limit in initial_max_path_id or the MAX_PATH_ID frame is preferred.

   To avoid unnecessary resource usage that could be exploited in a
   resource exhaustion attack, endpoints SHOULD allocate additional path
   resources, such as e.g. for packet number handling, only after path
   validation has successfully completed.

7.2.  Request Forgery with Spoofed Address

   Path validation as specified in Section 8.2. of [QUIC-TRANSPORT] for
   migration is used unchanged for path initiation in this extension.
   Therefore, the security considerations on source address spoofing as
   outlined in Section 21.5.4 of [QUIC-TRANSPORT] equally apply.
   Similarly, the anti-amplification limits as specified in Section 8 of
   [QUIC-TRANSPORT] need to be followed to limit the amplification risk.

   [QUIC-TRANSPORT] only allows the use of one path and the number of
   concurrent path validation attempts is limited by number of issued
   connection IDs.  This extension, however, allows for multiple open
   paths that could in theory be migrated all at the same time.  Further
   multiple paths could be initialized simultaneously.  Each open path
   could be used to further amplify an attack.  Therefore, endpoints
   need to limit the maximum number of paths and might consider
   additional measures to limit the number of concurrent path validation
   processes e.g. by pacing them out or limiting the number of path
   initiation attempts over a certain time period.

7.3.  Cryptographic handshake and AEAD Nonce

   The multipath extension as specified in this document is only enabled
   after a successful handshake when both endpoints indicate support for
   this extension.  Respectively, all new frames defined in this
   extension are only used in 1-RTT packets.  As the handshake is not
   changed by this extension, the transport security mechanisms as
   specified in [QUIC-TLS], such as encryption key exchange and peer
   authentication, remain unchanged.  As such, the respective security

Liu, et al.              Expires 25 October 2025               [Page 34]
Internet-Draft               Multipath QUIC                   April 2025

   considerations in [QUIC-TLS] apply unaltered.  However, note that the
   limits as discussed on Appendix B of [QUIC-TLS] apply to the total
   number of packets sent on all paths.

   This specification changes the AEAD calculation by using the path ID
   as part of AEAD nonce (see Section 2.4).  To ensure unique nonces,
   path IDs are limited to 32 bits and cannot be reused for another path
   of the same connection.

8.  Contributors

   This document is a collaboration of authors that combines work from
   three proposals.  Further contributors that were also involved one of
   the original proposals are:

   *  Qing An

   *  Zhenyu Li

9.  Acknowledgments

   Thanks to Marten Seemann, Kazuho Oku, Martin Thomson, Magnus
   Westerlund, Mike Bishop, Lucas Pardue, Michael Eriksson, Yu Zhu, and
   Gorry Fairhurst for their thorough reviews and valuable
   contributions.

10.  References

10.1.  Normative References

   [QUIC-RECOVERY]
              Iyengar, J., Ed. and I. Swett, Ed., "QUIC Loss Detection
              and Congestion Control", RFC 9002, DOI 10.17487/RFC9002,
              May 2021, <https://www.rfc-editor.org/rfc/rfc9002>.

   [QUIC-TLS] Thomson, M., Ed. and S. Turner, Ed., "Using TLS to Secure
              QUIC", RFC 9001, DOI 10.17487/RFC9001, May 2021,
              <https://www.rfc-editor.org/rfc/rfc9001>.

   [QUIC-TRANSPORT]
              Iyengar, J., Ed. and M. Thomson, Ed., "QUIC: A UDP-Based
              Multiplexed and Secure Transport", RFC 9000,
              DOI 10.17487/RFC9000, May 2021,
              <https://www.rfc-editor.org/rfc/rfc9000>.

Liu, et al.              Expires 25 October 2025               [Page 35]
Internet-Draft               Multipath QUIC                   April 2025

   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119,
              DOI 10.17487/RFC2119, March 1997,
              <https://www.rfc-editor.org/rfc/rfc2119>.

   [RFC8174]  Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
              2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
              May 2017, <https://www.rfc-editor.org/rfc/rfc8174>.

10.2.  Informative References

   [OLIA]     Khalili, R., Gast, N., Popovic, M., Upadhyay, U., and J.
              Le Boudec, "MPTCP is not pareto-optimal: performance
              issues and a possible solution", Proceedings of the 8th
              international conference on Emerging networking
              experiments and technologies, ACM , 2012.

   [RFC2475]  Blake, S., Black, D., Carlson, M., Davies, E., Wang, Z.,
              and W. Weiss, "An Architecture for Differentiated
              Services", RFC 2475, DOI 10.17487/RFC2475, December 1998,
              <https://www.rfc-editor.org/rfc/rfc2475>.

   [RFC6356]  Raiciu, C., Handley, M., and D. Wischik, "Coupled
              Congestion Control for Multipath Transport Protocols",
              RFC 6356, DOI 10.17487/RFC6356, October 2011,
              <https://www.rfc-editor.org/rfc/rfc6356>.

   [RFC9743]  Duke, M., Ed. and G. Fairhurst, Ed., "Specifying New
              Congestion Control Algorithms", BCP 133, RFC 9743,
              DOI 10.17487/RFC9743, March 2025,
              <https://www.rfc-editor.org/rfc/rfc9743>.

Authors' Addresses

   Yanmei Liu (editor)
   Alibaba Inc.
   Email: miaoji.lym@alibaba-inc.com

   Additional contact information:

      刘彦梅 (editor)
      Alibaba Inc.

   Yunfei Ma
   Uber Technologies Inc.
   Email: yunfei.ma@uber.com

Liu, et al.              Expires 25 October 2025               [Page 36]
Internet-Draft               Multipath QUIC                   April 2025

   Additional contact information:

      马云飞
      Uber Technologies Inc.

   Quentin De Coninck (editor)
   University of Mons (UMONS)
   Email: quentin.deconinck@umons.ac.be

   Olivier Bonaventure
   UCLouvain and Tessares
   Email: olivier.bonaventure@uclouvain.be

   Christian Huitema
   Private Octopus Inc.
   Email: huitema@huitema.net

   Mirja Kuehlewind (editor)
   Ericsson
   Email: mirja.kuehlewind@ericsson.com

Liu, et al.              Expires 25 October 2025               [Page 37]