<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" category="exp" consensus="false" docName="draft-ietf-tsvwg-multipath-dccp-04" indexInclude="true" ipr="trust200902" prepTime="2022-03-07T11:34:35" scripts="Common,Latin" sortRefs="true" submissionType="IETF" symRefs="true" tocDepth="3" tocInclude="true" xml:lang="en">
  <!-- xml2rfc v2v3 conversion 3.9.1 -->
  <front>
    <title abbrev="Multipath DCCP">DCCP Extensions for Multipath Operation with Multiple Addresses</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-multipath-dccp-04" stream="IETF"/>
    <author initials="M." surname="Amend" fullname="Markus Amend" role="editor">
      <organization abbrev="DT" showOnFrontPage="true">Deutsche Telekom</organization>
      <address>
        <postal>
          <street>Deutsche-Telekom-Allee 9</street>
          <city>Darmstadt</city>
          <code>64295</code>
          <country>Germany</country>
        </postal>
        <email>Markus.Amend@telekom.de</email>
      </address>
    </author>
    <author initials="A." surname="Brunstrom" fullname="Anna Brunstrom">
      <organization showOnFrontPage="true">Karlstad University</organization>
      <address>
        <postal>
          <street>Universitetsgatan 2</street>
          <city>Karlstad</city>
          <code>651 88</code>
          <country>Sweden</country>
        </postal>
        <email>anna.brunstrom@kau.se</email>
      </address>
    </author>
    <author initials="A." surname="Kassler" fullname="Andreas Kassler">
      <organization showOnFrontPage="true">Karlstad University</organization>
      <address>
        <postal>
          <street>Universitetsgatan 2</street>
          <city>Karlstad</city>
          <code>651 88</code>
          <country>Sweden</country>
        </postal>
        <email>andreas.kassler@kau.se</email>
      </address>
    </author>
    <author initials="V." surname="Rakocevic" fullname="Veselin Rakocevic">
      <organization showOnFrontPage="true">City University of London</organization>
      <address>
        <postal>
          <street>Northampton Square</street>
          <city>London</city>
          <country>United Kingdom</country>
        </postal>
        <email>veselin.rakocevic.1@city.ac.uk</email>
      </address>
    </author>
    <author initials="S." surname="Johnson" fullname="Stephen Johnson">
      <organization showOnFrontPage="true">BT</organization>
      <address>
        <postal>
          <street>Adastral Park</street>
          <city>Martlesham Heath</city>
          <code>IP5 3RE</code>
          <country>United Kingdom</country>
        </postal>
        <email>stephen.h.johnson@bt.com</email>
      </address>
    </author>
    <date month="03" year="2022" day="07"/>
    <area>transport</area>
    <workgroup>Transport Area Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">DCCP communication is currently restricted to a single path per
connection, yet multiple paths often exist between peers.  The
simultaneous use of these multiple paths for a DCCP session could
improve resource usage within the network and, thus, improve user
experience through higher throughput and improved resilience to
network failures.
Use cases for a Multipath DCCP (MP-DCCP) are mobile devices (handsets, vehicles) and residential home gateways simultaneously connected to distinct paths as, e.g., 
a cellular link and a WiFi link
or to a mobile radio station and a fixed access network.  Compared to existing multipath protocols such as MPTCP, MP-DCCP provides specific support for non-TCP user
traffic as UDP or plain IP.  More details on potential use cases are provided in <xref target="website" format="default" sectionFormat="of" derivedContent="website"/>, <xref target="slide" format="default" sectionFormat="of" derivedContent="slide"/>, and <xref target="paper" format="default" sectionFormat="of" derivedContent="paper"/>.
All these use cases profit from an Open Source Linux reference implementation provided under <xref target="website" format="default" sectionFormat="of" derivedContent="website"/>.</t>
      <t indent="0" pn="section-abstract-2">This document presents a set of extensions to
traditional DCCP to support multipath operation.  Multipath DCCP provides 
the ability to simultaneously use multiple
paths between peers.  The protocol offers
the same type of service to applications as DCCP and it provides the
components necessary to establish and use multiple DCCP flows across
potentially disjoint paths.</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
        This Internet-Draft is submitted in full conformance with the
        provisions of BCP 78 and BCP 79.
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
        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 <eref target="https://datatracker.ietf.org/drafts/current/" brackets="none"/>.
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
        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."
        </t>
        <t indent="0" pn="section-boilerplate.1-4">
        This Internet-Draft will expire on 8 September 2022.
        </t>
      </section>
      <section anchor="copyright" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.2">
        <name slugifiedName="name-copyright-notice">Copyright Notice</name>
        <t indent="0" pn="section-boilerplate.2-1">
            Copyright (c) 2022 IETF Trust and the persons identified as the
            document authors. All rights reserved.
        </t>
        <t indent="0" pn="section-boilerplate.2-2">
            This document is subject to BCP 78 and the IETF Trust's Legal
            Provisions Relating to IETF Documents
            (<eref target="https://trustee.ietf.org/license-info" brackets="none"/>) 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 Simplified BSD License text as described in
            Section 4.e of the Trust Legal Provisions and are provided without
            warranty as described in the Simplified BSD License.
        </t>
      </section>
    </boilerplate>
    <toc>
      <section anchor="toc" numbered="false" removeInRFC="false" toc="exclude" pn="section-toc.1">
        <name slugifiedName="name-table-of-contents">Table of Contents</name>
        <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1">
          <li pn="section-toc.1-1.1">
            <t indent="0" pn="section-toc.1-1.1.1"><xref derivedContent="1" format="counter" sectionFormat="of" target="section-1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-introduction">Introduction</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.1.2">
              <li pn="section-toc.1-1.1.2.1">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.1.1"><xref derivedContent="1.1" format="counter" sectionFormat="of" target="section-1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-dccp-in-the-netwo">Multipath DCCP in the Networking Stack</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.2">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.2.1"><xref derivedContent="1.2" format="counter" sectionFormat="of" target="section-1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-terminology">Terminology</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.3">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.3.1"><xref derivedContent="1.3" format="counter" sectionFormat="of" target="section-1.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-concept">MP-DCCP Concept</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.4">
                <t indent="0" pn="section-toc.1-1.1.2.4.1"><xref derivedContent="1.4" format="counter" sectionFormat="of" target="section-1.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-requirements-language">Requirements Language</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.2">
            <t indent="0" pn="section-toc.1-1.2.1"><xref derivedContent="2" format="counter" sectionFormat="of" target="section-2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-operation-overview">Operation Overview</xref></t>
          </li>
          <li pn="section-toc.1-1.3">
            <t indent="0" pn="section-toc.1-1.3.1"><xref derivedContent="3" format="counter" sectionFormat="of" target="section-3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-protocol">MP-DCCP Protocol</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2">
              <li pn="section-toc.1-1.3.2.1">
                <t indent="0" pn="section-toc.1-1.3.2.1.1"><xref derivedContent="3.1" format="counter" sectionFormat="of" target="section-3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-capable-feature">Multipath Capable Feature</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.2">
                <t indent="0" pn="section-toc.1-1.3.2.2.1"><xref derivedContent="3.2" format="counter" sectionFormat="of" target="section-3.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-option">Multipath Option</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2.2.2">
                  <li pn="section-toc.1-1.3.2.2.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.1.1"><xref derivedContent="3.2.1" format="counter" sectionFormat="of" target="section-3.2.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_confirm">MP_CONFIRM</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.2">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.2.1"><xref derivedContent="3.2.2" format="counter" sectionFormat="of" target="section-3.2.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_join">MP_JOIN</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.3">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.3.1"><xref derivedContent="3.2.3" format="counter" sectionFormat="of" target="section-3.2.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_fast_close">MP_FAST_CLOSE</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.4">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.4.1"><xref derivedContent="3.2.4" format="counter" sectionFormat="of" target="section-3.2.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_key">MP_KEY</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.5">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.5.1"><xref derivedContent="3.2.5" format="counter" sectionFormat="of" target="section-3.2.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_seq">MP_SEQ</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.6">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.6.1"><xref derivedContent="3.2.6" format="counter" sectionFormat="of" target="section-3.2.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_hmac">MP_HMAC</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.7">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.7.1"><xref derivedContent="3.2.7" format="counter" sectionFormat="of" target="section-3.2.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_rtt">MP_RTT</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.8">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.8.1"><xref derivedContent="3.2.8" format="counter" sectionFormat="of" target="section-3.2.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_addaddr">MP_ADDADDR</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.9">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.9.1"><xref derivedContent="3.2.9" format="counter" sectionFormat="of" target="section-3.2.9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_removeaddr">MP_REMOVEADDR</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.10">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.10.1"><xref derivedContent="3.2.10" format="counter" sectionFormat="of" target="section-3.2.10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_prio">MP_PRIO</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.11">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.11.1"><xref derivedContent="3.2.11" format="counter" sectionFormat="of" target="section-3.2.11"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_close">MP_CLOSE</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.3.2.3">
                <t indent="0" pn="section-toc.1-1.3.2.3.1"><xref derivedContent="3.3" format="counter" sectionFormat="of" target="section-3.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-handshaking-procedu">MP-DCCP Handshaking Procedure</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.4">
                <t indent="0" pn="section-toc.1-1.3.2.4.1"><xref derivedContent="3.4" format="counter" sectionFormat="of" target="section-3.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-close-a-mp-dccp-connection">Close a MP-DCCP connection</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.5">
                <t indent="0" pn="section-toc.1-1.3.2.5.1"><xref derivedContent="3.5" format="counter" sectionFormat="of" target="section-3.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fallback">Fallback</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.6">
                <t indent="0" pn="section-toc.1-1.3.2.6.1"><xref derivedContent="3.6" format="counter" sectionFormat="of" target="section-3.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-congestion-control-consider">Congestion Control Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.7">
                <t indent="0" pn="section-toc.1-1.3.2.7.1"><xref derivedContent="3.7" format="counter" sectionFormat="of" target="section-3.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-maximum-packet-size-conside">Maximum Packet Size Considerations</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.4">
            <t indent="0" pn="section-toc.1-1.4.1"><xref derivedContent="4" format="counter" sectionFormat="of" target="section-4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-security-considerations">Security Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.5">
            <t indent="0" pn="section-toc.1-1.5.1"><xref derivedContent="5" format="counter" sectionFormat="of" target="section-5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-interactions-with-middlebox">Interactions with Middleboxes</xref></t>
          </li>
          <li pn="section-toc.1-1.6">
            <t indent="0" pn="section-toc.1-1.6.1"><xref derivedContent="6" format="counter" sectionFormat="of" target="section-6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-implementation">Implementation</xref></t>
          </li>
          <li pn="section-toc.1-1.7">
            <t indent="0" pn="section-toc.1-1.7.1"><xref derivedContent="7" format="counter" sectionFormat="of" target="section-7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-acknowledgments">Acknowledgments</xref></t>
          </li>
          <li pn="section-toc.1-1.8">
            <t indent="0" pn="section-toc.1-1.8.1"><xref derivedContent="8" format="counter" sectionFormat="of" target="section-8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-iana-considerations">IANA Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.9">
            <t indent="0" pn="section-toc.1-1.9.1"><xref derivedContent="9" format="counter" sectionFormat="of" target="section-9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
          </li>
          <li pn="section-toc.1-1.10">
            <t indent="0" pn="section-toc.1-1.10.1"><xref derivedContent="Appendix A" format="default" sectionFormat="of" target="section-appendix.a"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-differences-from-multipath-">Differences from Multipath TCP</xref></t>
          </li>
          <li pn="section-toc.1-1.11">
            <t indent="0" pn="section-toc.1-1.11.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.b"/><xref derivedContent="" format="title" sectionFormat="of" target="name-authors-addresses">Authors' Addresses</xref></t>
          </li>
        </ul>
      </section>
    </toc>
  </front>
  <middle>
    <section anchor="intro" numbered="true" toc="include" removeInRFC="false" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">Multipath DCCP (MP-DCCP) is a set of extensions to regular DCCP
<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, i.e., the Datagram Congestion Control Protocol denoting a
transport protocol that provides bidirectional unicast connections of
congestion-controlled unreliable datagrams. A multipath extension to 
DCCP enables the transport of user data  across multiple paths 
simultaneously. This is beneficial to applications that transfer fairly 
large amounts of data, due to the possibility to aggregate capacity of the 
multiple paths. In addition, it enables to tradeoff timeliness and reliability, 
which is important for low latency applications that do not require 
guaranteed delivery services such as Audio/Video streaming.
DCCP multipath operation is suggested
in the context of ongoing 3GPP work on 5G multi-access solutions
<xref target="I-D.amend-tsvwg-multipath-framework-mpdccp" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-multipath-framework-mpdccp"/> and for hybrid access
networks <xref target="I-D.lhwxz-hybrid-access-network-architecture" format="default" sectionFormat="of" derivedContent="I-D.lhwxz-hybrid-access-network-architecture"/><xref target="I-D.muley-network-based-bonding-hybrid-access" format="default" sectionFormat="of" derivedContent="I-D.muley-network-based-bonding-hybrid-access"/>.
It can be applied for load-balancing, seamless session handover, and
aggregation purposes (referred to as ATSSS; Access steering, switching, and splitting
in 3GPP terminology <xref target="TS23.501" format="default" sectionFormat="of" derivedContent="TS23.501"/>).</t>
      <t indent="0" pn="section-1-2">This document presents the protocol changes required to add multipath
capability to DCCP; specifically, those for signaling and setting up
multiple paths ("subflows"), managing these subflows, reordering of
data, and termination of sessions.
DCCP, as stated in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> does not provide reliable and ordered
delivery. Consequently, multiple application subflows may be multiplexed over a
single DCCP connection with no inherent performance penalty 
for flows that do not require in-ordered delivery. DCCP
does not provide built-in support for those multiple application subflows.</t>
      <t indent="0" pn="section-1-3">In the following, use of the term subflow will refer to physical
separate DCCP subflows transmitted via different paths, but not to
application subflows. Application subflows are differing content-wise
by source and destination port per application as, for example, enabled
by Service Codes introduced to DCCP in <xref target="RFC5595" format="default" sectionFormat="of" derivedContent="RFC5595"/>, and those subflows
can be multiplexed over a single DCCP connection. For sake of consistency
we assume that only a single application is served by a DCCP connection
here as shown in <xref target="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" format="default" sectionFormat="of" derivedContent="Figure 1"/>
while use of that feature should not impact DCCP operation on each single path
as noted in (<xref target="RFC5595" format="default" sectionFormat="of" derivedContent="RFC5595"/>, sect. 2.4).</t>
      <section anchor="mpdccp_network_stack" numbered="true" toc="include" removeInRFC="false" pn="section-1.1">
        <name slugifiedName="name-multipath-dccp-in-the-netwo">Multipath DCCP in the Networking Stack</name>
        <t indent="0" pn="section-1.1-1">MP-DCCP operates at the transport layer and aims to be transparent to
both higher and lower layers.  It is a set of additional features on
top of standard DCCP; <xref target="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" format="default" sectionFormat="of" derivedContent="Figure 1"/> illustrates this layering.  MP-DCCP is
designed to be used by applications in the same way as DCCP with no
changes to the application itself.</t>
        <figure anchor="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" align="left" suppress-title="false" pn="figure-1">
          <name slugifiedName="name-comparison-of-standard-dccp">Comparison of Standard DCCP and MP-DCCP Protocol Stacks</name>
          <artwork name="" type="" align="left" alt="" pn="section-1.1-2.1"><![CDATA[
                             +-------------------------------+
                             |           Application         |
+---------------+            +-------------------------------+
|  Application  |            |            MP-DCCP            |
+---------------+            + - - - - - - - + - - - - - - - +
|      DCCP     |            |Subflow (DCCP) |Subflow (DCCP) |
+---------------+            +-------------------------------+
|      IP       |            |       IP      |      IP       |
+---------------+            +-------------------------------+
]]></artwork>
        </figure>
      </section>
      <section anchor="terminology" numbered="true" toc="include" removeInRFC="false" pn="section-1.2">
        <name slugifiedName="name-terminology">Terminology</name>
        <t indent="0" pn="section-1.2-1">Throughout this document we make use of terms that are either specific
for multipath transport or are defined in the context of MP-DCCP,
similar to <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, as follows:</t>
        <t indent="0" pn="section-1.2-2">Path: A sequence of links between a sender and a receiver, defined in
this context by a 4-tuple of source and destination address/ port pairs.</t>
        <t indent="0" pn="section-1.2-3">Subflow: A flow of DCCP segments operating over an individual path,
which forms part of a larger MP-DCCP connection. A subflow is started
and terminated similar to a regular (single-path) DCCP connection.</t>
        <t indent="0" pn="section-1.2-4">(MP-DCCP) Connection: A set of one or more subflows, over which an
application can communicate between two hosts. There is a one-to-one
mapping between a connection and an application socket.</t>
        <t indent="0" pn="section-1.2-5">Token: A locally unique identifier given to a multipath connection by a
host. May also be referred to as a "Connection ID".</t>
        <t indent="0" pn="section-1.2-6">Host: An end host operating an MP-DCCP implementation, and either
initiating or accepting an MP-DCCP connection. In addition to these
terms, within framework of MP-DCCP the interpretation of, and effect on,
regular single-path DCCP semantics is discussed in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.</t>
      </section>
      <section anchor="concept" numbered="true" toc="include" removeInRFC="false" pn="section-1.3">
        <name slugifiedName="name-mp-dccp-concept">MP-DCCP Concept</name>
        <t indent="0" pn="section-1.3-1"><xref target="ref-example-mp-dccp-usage-scenario" format="default" sectionFormat="of" derivedContent="Figure 2"/> provides a general overview of the MP-DCCP working mode, whose main 
characteristics are summarized within this section.</t>
        <figure anchor="ref-example-mp-dccp-usage-scenario" align="left" suppress-title="false" pn="figure-2">
          <name slugifiedName="name-example-mp-dccp-usage-scena">Example MP-DCCP Usage Scenario</name>
          <artwork name="" type="" align="left" alt="" pn="section-1.3-2.1"><![CDATA[
           Host A                               Host B
------------------------             ------------------------
Address A1    Address A2             Address B1    Address B2
----------    ----------             ----------    ----------
  |             |                      |             |
  |         (DCCP flow setup)          |             |
  |----------------------------------->|             |
  |<-----------------------------------|             |
  |             |                      |             |
  |             |  (DCCP flow setup)   |             |
  |             |--------------------->|             |
  |             |<---------------------|             |
  | merge individual DCCP flows to one multipath connection
  |             |                      |             |
]]></artwork>
        </figure>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-1.3-3">
          <li pn="section-1.3-3.1">An MPDCCP connection begins with a 4-way handshaking procedure, between 
2 hosts as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. In <xref target="ref-example-mp-dccp-usage-scenario" format="default" sectionFormat="of" derivedContent="Figure 2"/>
an MPDCCP connection is established between addresses A1 and B1 on Hosts
A and B, respectively.</li>
          <li pn="section-1.3-3.2">If extra paths are available, additional DCCP subflows are created on 
these paths and are attached to the existing MPDCCP session, which
continues to appear as a single connection to the applications at both
ends. The creation of an additional DCCP subflow is illustrated between Address A2
on Host A and Address B1 on Host B.</li>
          <li pn="section-1.3-3.3">MPDCCP identifies multiple paths by the presence of multiple
addresses at hosts.  Combinations of these multiple addresses
equate to the additional paths.  In the example, other potential
paths that could be set up are A1&lt;-&gt;B2 and A2&lt;-&gt;B2.  Although this
additional session is shown as being initiated from A2, it could
equally have been initiated from B1 or B2.</li>
          <li pn="section-1.3-3.4">The discovery and setup of additional subflows will be achieved
through a path management method; this document describes supportive measures by which a host can initiate new subflows and available addresses can be signaled between peers. The definition of a path management method is however out of scope of this document.</li>
          <li pn="section-1.3-3.5">MPDCCP adds connection-level sequence numbers and exchange of
RTT information to enable optional reordering functionalities.</li>
          <li pn="section-1.3-3.6">Subflows are terminated as regular DCCP connections, as described
in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> section 8.3). The MPDCCP connection is terminated by a
connection-level DCCP-CloseReq or DCCP-Close message.</li>
        </ul>
      </section>
      <section anchor="requirements-language" numbered="true" toc="include" removeInRFC="false" pn="section-1.4">
        <name slugifiedName="name-requirements-language">Requirements Language</name>
        <t indent="0" pn="section-1.4-1">The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
document are to be interpreted as described in <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/>.</t>
      </section>
    </section>
    <section anchor="op_overview" numbered="true" toc="include" removeInRFC="false" pn="section-2">
      <name slugifiedName="name-operation-overview">Operation Overview</name>
      <t indent="0" pn="section-2-1">DCCP according to RFC 4340 <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> allows multiple application 
subflows to be multiplexed over a single DCCP connection with 
potentially same performance. However, DCCP does not provide built-in 
support for multiple subflows and the Congestion Manager (CM) 
<xref target="RFC3124" format="default" sectionFormat="of" derivedContent="RFC3124"/>, as a generic multiplexing facility, can not fully support 
multiple congestion control mechanisms for multiple DCCP flows between 
same source and destination addresses.</t>
      <t indent="0" pn="section-2-2">The proposed extension of DCCP towards Multipath-DCCP (MP-DCCP) is 
described in detail in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.</t>
      <t indent="0" pn="section-2-3">As a high level overview on the key functionality of MP-DCCP, the data 
stream from a DCCP application is split 
by MP-DCCP operation into one or more subflows which can be 
transmitted via different also physically isolated paths.
The corresponding control information allows the receiver to optionally 
re-assemble and deliver the received data in the right order to the 
recipient application. The details of the transmission scheduling mechanism and 
optional reordering mechanism are up to the sender and receiver, respectively,
and are outside the scope of the MP-DCCP protocol.
The following sections define MP-DCCP behavior in detail.</t>
      <t indent="0" pn="section-2-4">The Multipath Capability for MP-DCCP can be negotiated with a new DCCP 
feature, as described and fully specified in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>. Once 
negotiated, all subsequent MP-DCCP operations are signalled with a 
variable length multipath-related option, as described in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>.</t>
      <t indent="0" pn="section-2-5">A Multipath DCCP connection provides a bidirectional byte-stream between 
two hosts exchanging data as in standard DCCP manner thus not requiring 
any change to the applications. However, Multipath DCCP enables the 
hosts to use different paths with different IP addresses to transport 
the packets of the MP-DCCP connection. MP-DCCP manages the request, 
set-up, authentication, prioritization, modification, and removal of
the DCCP subflows on different paths as well as exchange of performance 
parameters. The number of concurrent DCCP subflows can vary during the 
lifetime of the Multipath DCCP connection. All MP-DCCP operations are 
signaled with MP-DCCP options described in detail in {#MP_OPT}.</t>
    </section>
    <section anchor="protocol" numbered="true" toc="include" removeInRFC="false" pn="section-3">
      <name slugifiedName="name-mp-dccp-protocol">MP-DCCP Protocol</name>
      <t indent="0" pn="section-3-1">The DCCP protocol feature list (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> section 6.4) will be
enhanced by a new Multipath related feature with Feature number 10, as
shown in <xref target="ref-feature-list" format="default" sectionFormat="of" derivedContent="Table 1"/>.</t>
      <table anchor="ref-feature-list" align="center" pn="table-1">
        <name slugifiedName="name-proposed-feature-set">Proposed Feature Set</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Number</th>
            <th align="left" colspan="1" rowspan="1">Meaning</th>
            <th align="center" colspan="1" rowspan="1">Rule</th>
            <th align="center" colspan="1" rowspan="1">Rec'n Value</th>
            <th align="center" colspan="1" rowspan="1">Initial Req'd</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="left" colspan="1" rowspan="1">Reserved</td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="left" colspan="1" rowspan="1">Congestion Control ID (CCID)</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">2</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">2</td>
            <td align="left" colspan="1" rowspan="1">Allow Short Seqnos</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">3</td>
            <td align="left" colspan="1" rowspan="1">Sequence Window</td>
            <td align="center" colspan="1" rowspan="1">NN</td>
            <td align="center" colspan="1" rowspan="1">100</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">4</td>
            <td align="left" colspan="1" rowspan="1">ECN Incapable</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">5</td>
            <td align="left" colspan="1" rowspan="1">Ack Ratio</td>
            <td align="center" colspan="1" rowspan="1">NN</td>
            <td align="center" colspan="1" rowspan="1">2</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">6</td>
            <td align="left" colspan="1" rowspan="1">Send Ack Vector</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">7</td>
            <td align="left" colspan="1" rowspan="1">Send NDP Count</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">8</td>
            <td align="left" colspan="1" rowspan="1">Minimum Checksum Coverage</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">9</td>
            <td align="left" colspan="1" rowspan="1">Check Data Checksum</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">10</td>
            <td align="left" colspan="1" rowspan="1">Multipath Capable</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">11-127</td>
            <td align="left" colspan="1" rowspan="1">Reserved</td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">128-255</td>
            <td align="left" colspan="1" rowspan="1">CCID-specific features</td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
        </tbody>
      </table>
      <dl indent="3" newline="false" spacing="normal" pn="section-3-3">
        <dt pn="section-3-3.1">
Rec'n Rule:  </dt>
        <dd pn="section-3-3.2">
          <t indent="0" pn="section-3-3.2.1">The reconciliation rule used for the feature. SP means server-priority,
NN means non-negotiable.</t>
        </dd>
        <dt pn="section-3-3.3">
Initial Value:  </dt>
        <dd pn="section-3-3.4">
          <t indent="0" pn="section-3-3.4.1">The initial value for the feature. Every feature has a known initial value.</t>
        </dd>
        <dt pn="section-3-3.5">
Req'd:  </dt>
        <dd pn="section-3-3.6">
          <t indent="0" pn="section-3-3.6.1">This column is "Y" if and only if every DCCP implementation MUST
understand the feature. If it is "N", then the feature behaves like an extension
(see Section 15), and it is safe to respond to Change options for the feature
with empty Confirm options. Of course, a CCID might require the feature; a DCCP
that implements CCID 2 MUST support Ack Ratio and Send Ack Vector, for example.</t>
        </dd>
      </dl>
      <t indent="0" pn="section-3-4">The DCCP protocol options as defined in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> section 5.8) and (<xref target="RFC5634" format="default" sectionFormat="of" derivedContent="RFC5634"/> section 2.2.1) will be enhanced
by a new Multipath related variable-length option with option type 46, as
shown in <xref target="ref-option-list" format="default" sectionFormat="of" derivedContent="Table 2"/>.</t>
      <table anchor="ref-option-list" align="center" pn="table-2">
        <name slugifiedName="name-proposed-option-set">Proposed Option Set</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Type</th>
            <th align="center" colspan="1" rowspan="1">Option Length</th>
            <th align="center" colspan="1" rowspan="1">Meaning</th>
            <th align="center" colspan="1" rowspan="1">DCCP-Data?</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">Padding</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">Mandatory</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">2</td>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">Slow Receiver</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">3-31</td>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">Reserved</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">32</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Change L</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">33</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Confirm L</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">34</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Change R</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">35</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Confirm R</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">36</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Init Cookie</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">37</td>
            <td align="center" colspan="1" rowspan="1">3-8</td>
            <td align="center" colspan="1" rowspan="1">NDP Count</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">38</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Ack Vector [Nonce 0]</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">39</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Ack Vector [Nonce 1]</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">40</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Data Dropped</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">41</td>
            <td align="center" colspan="1" rowspan="1">6</td>
            <td align="center" colspan="1" rowspan="1">Timestamp</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">42</td>
            <td align="center" colspan="1" rowspan="1">6/8/10</td>
            <td align="center" colspan="1" rowspan="1">Timestamp Echo</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">43</td>
            <td align="center" colspan="1" rowspan="1">4/6</td>
            <td align="center" colspan="1" rowspan="1">Elapsed Time</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">44</td>
            <td align="center" colspan="1" rowspan="1">6</td>
            <td align="center" colspan="1" rowspan="1">Data Checksum</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">45</td>
            <td align="center" colspan="1" rowspan="1">8</td>
            <td align="center" colspan="1" rowspan="1">Quick-Start Response</td>
            <td align="center" colspan="1" rowspan="1">?</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">46</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Multipath</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">47-127</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Reserved</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">128-255</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">CCID-specific options</td>
            <td align="center" colspan="1" rowspan="1">-</td>
          </tr>
        </tbody>
      </table>
      <section anchor="mp_capable" numbered="true" toc="include" removeInRFC="false" pn="section-3.1">
        <name slugifiedName="name-multipath-capable-feature">Multipath Capable Feature</name>
        <t indent="0" pn="section-3.1-1">DCCP endpoints are multipath-disabled by default and multipath
capability can be negotiated with the Multipath Capable Feature.</t>
        <t indent="0" pn="section-3.1-2">Multipath Capable has feature number 10 and has length of one-byte.
The leftmost four bits are used to specify a compatible version of the
MP-DCCP implementation (0 for this specification).
The following four bits are reserved for further use.</t>
        <artwork name="" type="" align="left" alt="" pn="section-3.1-3"><![CDATA[
    0  1  2  3   4  5  6  7
   +------------------------+
   |  Version  |  Reserved  |
   +------------------------+
    '0000'->v0
    '0001'->v1
    ........
]]></artwork>
        <t indent="0" pn="section-3.1-4">Multipath Capable follows the server-priority reconciliation rule described
in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> section 6.3.1), which allows multiple versions to be
specified in order of priority.</t>
        <t indent="0" pn="section-3.1-5">The negotiation MUST be done as part of the initial handshake procedure
as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>, and no subsequent re-negotiation of
the Multipath Capable feature is allowed on the same MP connection.</t>
        <t indent="0" pn="section-3.1-6">Client MUST include a Change R option during the initial handshake request to
supply a list of supported protocol versions, ordered by preference.</t>
        <t indent="0" pn="section-3.1-7">Server MUST include a Confirm L option in the subsequent response to agree on
a version to be used chosen from the Client list, followed by its own
supported version(s) ordered by preference.</t>
        <t indent="0" pn="section-3.1-8">For example:</t>
        <artwork name="" type="" align="left" alt="" pn="section-3.1-9"><![CDATA[
      Client                                             Server
      ------                                             ------
      DCCP-Req + Change R(CAPABLE, 1 0)
                     ----------------------------------->

                      DCCP-Resp + Confirm L(CAPABLE, 1, 2 1 0)
            <-----------------------------------

                 * agreement on version = 1 *
]]></artwork>
        <ol spacing="normal" type="1" indent="adaptive" start="1" pn="section-3.1-10"><li pn="section-3.1-10.1" derivedCounter="1.">Client indicates support for both versions 1 and 0, with preference
for version 1</li>
          <li pn="section-3.1-10.2" derivedCounter="2.">Server agrees on using version 1, and supply its own preference list.</li>
        </ol>
        <t indent="0" pn="section-3.1-11">If no agreement can be found, the Server MUST reply with an empty Confirm L option
with feature number 10 and no values.</t>
        <t indent="0" pn="section-3.1-12">Any subflow addition to an existing MP connection MUST use the same
version negotiated for the first flow.</t>
      </section>
      <section anchor="MP_OPT" numbered="true" toc="include" removeInRFC="false" pn="section-3.2">
        <name slugifiedName="name-multipath-option">Multipath Option</name>
        <artwork name="" type="" align="left" alt="" pn="section-3.2-1"><![CDATA[
+--------+--------+--------+--------+--------
|00101110| Length | MP_OPT | Value(s) ...
+--------+--------+--------+--------+--------
 Type=46
]]></artwork>
        <table anchor="ref-mp-option-list" align="center" pn="table-3">
          <name slugifiedName="name-mp_opt-option-types">MP_OPT Option Types</name>
          <thead>
            <tr>
              <th align="left" colspan="1" rowspan="1">Type</th>
              <th align="left" colspan="1" rowspan="1">Option Length</th>
              <th align="left" colspan="1" rowspan="1">MP_OPT</th>
              <th align="left" colspan="1" rowspan="1">Meaning</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">0 =MP_CONFIRM</td>
              <td align="left" colspan="1" rowspan="1">Confirm reception and processing of an MP_OPT option</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">12</td>
              <td align="left" colspan="1" rowspan="1">1 =MP_JOIN</td>
              <td align="left" colspan="1" rowspan="1">Join path to an existing MP-DCCP flow</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">3</td>
              <td align="left" colspan="1" rowspan="1">2 =MP_FAST_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close MP-DCCP flow unconditionally</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">3 =MP_KEY</td>
              <td align="left" colspan="1" rowspan="1">Exchange key material for MP_HMAC</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">7</td>
              <td align="left" colspan="1" rowspan="1">4 =MP_SEQ</td>
              <td align="left" colspan="1" rowspan="1">Multipath Sequence Number</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">23</td>
              <td align="left" colspan="1" rowspan="1">5 =MP_HMAC</td>
              <td align="left" colspan="1" rowspan="1">HMA Code for authentication</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">12</td>
              <td align="left" colspan="1" rowspan="1">6 =MP_RTT</td>
              <td align="left" colspan="1" rowspan="1">Transmit RTT values</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">7 =MP_ADDADDR</td>
              <td align="left" colspan="1" rowspan="1">Advertise additional Address</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">8 =MP_REMOVEADDR</td>
              <td align="left" colspan="1" rowspan="1">Remove Address</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">4</td>
              <td align="left" colspan="1" rowspan="1">9 =MP_PRIO</td>
              <td align="left" colspan="1" rowspan="1">Change Subflow Priority</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">3</td>
              <td align="left" colspan="1" rowspan="1">10 =MP_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close MP-DCCP flow</td>
            </tr>
          </tbody>
        </table>
        <section anchor="MP_CONFIRM" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.1">
          <name slugifiedName="name-mp_confirm">MP_CONFIRM</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.1-1"><![CDATA[
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110| Length |00000000| List of options ...
  +--------+--------+--------+--------+--------+--------+--------+
   Type=46           MP_OPT=0
]]></artwork>
          <t indent="0" pn="section-3.2.1-2">MP_CONFIRM is used to send confirmation of reception and processing of the multipath 
options that require it (see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>). Such options will be retransmitted by the sender 
until this receives the corresponding MP_CONFIRM. The length and sending path of the MP_CONFIRM are dependent 
on the confirmed options, which will be copied verbatim and appended as list of options.</t>
          <table anchor="ref-mp-option-confirm" align="center" pn="table-4">
            <name slugifiedName="name-multipath-options-requiring">Multipath options requiring confirmation</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Type</th>
                <th align="left" colspan="1" rowspan="1">Option Length</th>
                <th align="left" colspan="1" rowspan="1">MP_OPT</th>
                <th align="left" colspan="1" rowspan="1">MP_CONFIRM Sending path</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">var</td>
                <td align="left" colspan="1" rowspan="1">7 =MP_ADDADDR</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">var</td>
                <td align="left" colspan="1" rowspan="1">8 =MP_REMOVEADDR</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">4</td>
                <td align="left" colspan="1" rowspan="1">9 =MP_PRIO</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
            </tbody>
          </table>
        </section>
        <section anchor="MP_JOIN" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.2">
          <name slugifiedName="name-mp_join">MP_JOIN</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.2-1"><![CDATA[
  +--------+--------+--------+--------+
  |00101110|00001011|00000001| Addr ID|
  +--------+--------+--------+--------+
  | Path Token                        |
  +--------+--------+--------+--------+
  | Nonce                             |
  +--------+--------+--------+--------+
   Type=46  Length=12 MP_OPT=1
]]></artwork>
          <t indent="0" pn="section-3.2.2-2">The MP_JOIN option is used to add a new path to an existing MP-DCCP
flow. The Path Token is the SHA256 hash of the derived key (d-key),
which was previously exchanged with the MP_KEY option.
MP_HMAC MUST be set when using MP_JOIN to provide authentication (See
MP_HMAC for details). Also MP_KEY MUST be set to provide key material
for authentication purposes.</t>
          <t indent="0" pn="section-3.2.2-3">The Address IDs of the subflow used in the initial DCCP Request/Response exchange of
the first subflow in the connection are implicit, and have the value
zero.  A host MUST store the mappings between Address IDs and
addresses both for itself and the remote host.  An implementation
will also need to know which local and remote Address IDs are
associated with which established subflows, for when addresses are
removed from a local or remote host. An Address ID has always to be unique
over the lifetime of a subflow and can only be re-assigned if sender and
receiver no longer have them in use.</t>
          <t indent="0" pn="section-3.2.2-4">The Nonce is a 32-bit random value locally generated for every MP_JOIN option.
Together with the Token, the Nonce value builds the basis to calculate the
HMAC used in the handshaking process as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>.</t>
        </section>
        <section anchor="MP_FAST_CLOSE" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.3">
          <name slugifiedName="name-mp_fast_close">MP_FAST_CLOSE</name>
          <t indent="0" pn="section-3.2.3-1">Regular DCCP has the means of sending a Close or Reset signal to abruptly close a
connection.  With MP-DCCP, a regular Close or Reset only has the scope of the
subflow; it will only close the applicable subflow and will not
affect the remaining subflows concurrently in use on other paths.  MP-DCCP's connection will stay alive at
the data level, in order to permit break-before-make handover between
subflows.  It is therefore necessary to provide an MP-DCCP-level
"Reset" to allow the abrupt closure of the whole MP-DCCP connection;
this is done via the MP_FAST_CLOSE option.</t>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.3-2"><![CDATA[
  +--------+--------+--------+--------+--------+
  |00101110| Length |00000010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46           MP_OPT=2
]]></artwork>
          <t indent="0" pn="section-3.2.3-3">For being effective, the MP_FAST_CLOSE must be sent from an initiating host on all subflows as part of a DCCP-Reset packet with Reset Code 12. To protect unauthorized shutdown of a multi-path connection, the selected Key Data of the peer host during the handshaking procedure is carried by the MP_FAST_CLOSE option. With completion of this step, the initiating host can tear down the subflows and the multi-path connection immediately terminates.
Upon reception of the MP_FAST_CLOSE and validation of the Key Data at the peer host, a DCCP Reset packet is replied on all subflows to the initiating host again with Reset Code 12. The peer host can now close the whole MP-DCCP connection (it transitions directly to CLOSED state).</t>
        </section>
        <section anchor="MP_KEY" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.4">
          <name slugifiedName="name-mp_key">MP_KEY</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.4-1"><![CDATA[
  +--------+--------+--------+-----------+-------------+
  |00101110| Length |00000011|Key Type(1)| Key Data(1) | ->
  +--------+--------+--------+-----------+-------------+
   Type=46           MP_OPT=3
   
                             +-----------+-------------+-----
                          -> |Key Type(2)| Key Data(2) | ....
                             +-----------+-------------+-----
]]></artwork>
          <t indent="0" pn="section-3.2.4-2">The MP_KEY suboption is used to exchange key material between
hosts. The Length varies between 12 and 68 Bytes for a single-key message, and up to
110 Bytes when all specified Key Types 0-2 are provided. The Key Type field is used to
specify the type of the following key data. Key types are shown in <xref target="ref-key-type-list" format="default" sectionFormat="of" derivedContent="Table 5"/>.</t>
          <table anchor="ref-key-type-list" align="center" pn="table-5">
            <name slugifiedName="name-mp_key-key-types">MP_KEY Key Types</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Key  Type</th>
                <th align="left" colspan="1" rowspan="1">Key Length (Bytes)</th>
                <th align="left" colspan="1" rowspan="1">Meaning</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">0 =Plain Text</td>
                <td align="left" colspan="1" rowspan="1">8</td>
                <td align="left" colspan="1" rowspan="1">Plain Text Key</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">1 =ECDHE-C25519-SHA256</td>
                <td align="left" colspan="1" rowspan="1">32</td>
                <td align="left" colspan="1" rowspan="1">ECDHE with SHA256 and Curve25519</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">2 =ECDHE-C25519-SHA512</td>
                <td align="left" colspan="1" rowspan="1">64</td>
                <td align="left" colspan="1" rowspan="1">ECDHE with SHA512 and Curve25519</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">3-255</td>
                <td align="left" colspan="1" rowspan="1"> </td>
                <td align="left" colspan="1" rowspan="1">Reserved</td>
              </tr>
            </tbody>
          </table>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-4">
            <dt pn="section-3.2.4-4.1">
Plain Text  </dt>
            <dd pn="section-3.2.4-4.2">
              <t indent="0" pn="section-3.2.4-4.2.1">Key Material is exchanged in plain text between hosts, and the key
parts (key-a, key-b) are used by each host to generate the derived
key (d-key) by concatenating the two parts with the local key
in front (e.g. hostA d-key(A)=(key-a+key-b), hostB d-key(B)=(key-b+key-a)).</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-5">
            <dt pn="section-3.2.4-5.1">
ECDHE-SHA256-C25519  </dt>
            <dd pn="section-3.2.4-5.2">
              <t indent="0" pn="section-3.2.4-5.2.1">Key Material is exchanged via ECDHE key exchange with SHA256 and
Curve 25519 to generate the derived key (d-key).</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-6">
            <dt pn="section-3.2.4-6.1">
ECDHE-SHA512-C25519  </dt>
            <dd pn="section-3.2.4-6.2">
              <t indent="0" pn="section-3.2.4-6.2.1">Key Material is exchanged via ECDHE key exchange with SHA512 and
Curve 25519 to generate the derived key (d-key).</t>
            </dd>
          </dl>
          <t indent="0" pn="section-3.2.4-7">Providing multiple keys is only permitted in the DCCP-Request message
of the handshake procedure for the first flow, and allows the hosts to agree
on a single key type to be used as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
        </section>
        <section anchor="MP_SEQ" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.5">
          <name slugifiedName="name-mp_seq">MP_SEQ</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.5-1"><![CDATA[
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|00000111|00000100| Multipath Sequence Number         |
  +--------+--------+--------+--------+--------+--------+--------+
   Type=46  Length=7 MP_OPT=4
]]></artwork>
          <t indent="0" pn="section-3.2.5-2">The MP_SEQ option is used for end-to-end datagram-based sequence
numbers of an MP-DCCP connection. The initial data sequence
number (IDSN) SHOULD be set randomly. The MP_SEQ number space is
different from the path individual sequence number space and MUST be
sent with any DCCP-Data and DCCP-DataACK packet.</t>
        </section>
        <section anchor="MP_HMAC" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.6">
          <name slugifiedName="name-mp_hmac">MP_HMAC</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.6-1"><![CDATA[
  +--------+--------+--------+--------+--------+--------+
  |00101110|00001011|00000101| HMAC-SHA256 (20 bytes) ...
  +--------+--------+--------+--------+--------+--------+
   Type=46  Length=23 MP_OPT=5
]]></artwork>
          <t indent="0" pn="section-3.2.6-2">The MP_HMAC option is used to provide authentication for the MP_JOIN
option. The HMAC code is generated according to <xref target="RFC2104" format="default" sectionFormat="of" derivedContent="RFC2104"/> in combination
with the SHA256 hash algorithm described in <xref target="RFC6234" format="default" sectionFormat="of" derivedContent="RFC6234"/>, with the output
truncated to the leftmost 160 bits (20 bytes).</t>
          <t indent="0" pn="section-3.2.6-3">The "Key" used for the HMAC computation is the derived key (d-key)
described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>, while the HMAC "Message" is a concatenation of
the token and nonce of the MP_JOIN for which authentication shall be performed.</t>
        </section>
        <section anchor="MP_RTT" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.7">
          <name slugifiedName="name-mp_rtt">MP_RTT</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.7-1"><![CDATA[
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|00001100|00000110|RTT Type| RTT
  +--------+--------+--------+--------+--------+--------+--------+
  |        | Age                               |
  +--------+--------+--------+--------+--------+
   Type=46  Length=12 MP_OPT=6
]]></artwork>
          <t indent="0" pn="section-3.2.7-2">The MP_RTT option is used to transmit RTT values in milliseconds and
MUST belong to the path over which this information is transmitted.
Additionally, the age of the measurement is specified in milliseconds.</t>
          <t indent="0" pn="section-3.2.7-3">The RTT and Age information is a 32-bit integer, which allows to cover a period of
approximately 1193 hours.</t>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-4">
            <dt pn="section-3.2.7-4.1">
Raw RTT (=0)  </dt>
            <dd pn="section-3.2.7-4.2">
              <t indent="0" pn="section-3.2.7-4.2.1">Raw RTT value of the last Datagram Round-Trip. The Age
parameter MUST be set to 0.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-5">
            <dt pn="section-3.2.7-5.1">
Min RTT (=1)  </dt>
            <dd pn="section-3.2.7-5.2">
              <t indent="0" pn="section-3.2.7-5.2.1">Min RTT value. The period for computing the Minimum can be specified
by the Age parameter.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-6">
            <dt pn="section-3.2.7-6.1">
Max RTT (=2)  </dt>
            <dd pn="section-3.2.7-6.2">
              <t indent="0" pn="section-3.2.7-6.2.1">Max RTT value. The period for computing the Maximum can be specified
by the Age parameter.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-7">
            <dt pn="section-3.2.7-7.1">
Smooth RTT (=3)  </dt>
            <dd pn="section-3.2.7-7.2">
              <t indent="0" pn="section-3.2.7-7.2.1">Averaged RTT value. The period for computing the smoothed RTT can be specified
by the Age parameter.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-8">
            <dt pn="section-3.2.7-8.1">
Age  </dt>
            <dd pn="section-3.2.7-8.2">
              <t indent="0" pn="section-3.2.7-8.2.1">The Age parameter is set to a time and<br/>
contains the periods for computing of derived<br/>
RTT values for the Minimum (=1), Maximum (=2)
as well as for the averaged smoothed RTT value (=3). An Age
parameter of zero MUST NOT be interpreted by the receiver.</t>
            </dd>
          </dl>
        </section>
        <section anchor="MP_ADDADDR" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.8">
          <name slugifiedName="name-mp_addaddr">MP_ADDADDR</name>
          <t indent="0" pn="section-3.2.8-1">The MP_ADDADDR option announces additional addresses (and, optionally,
ports) on which a host can be reached. This option can be used at any
time during an existing DCCP connection, when the sender wishes to
enable multiple paths and/or when additional paths become available.
Length is variable depending on IPv4 or IPv6 and whether port number is
used and is in range between 28 and 42 bytes.</t>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.8-2"><![CDATA[
                      1                   2                   3
  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
  +---------------+---------------+-------+-------+---------------+
  |     Type      |     Length    |Subtype| IPVer |  Address ID   |
  +---------------+---------------+-------+-------+---------------+
  |          Address (IPv4 - 4 bytes / IPv6 - 16 bytes)           |
  +-------------------------------+-------------------------------+
  |   Port (2 bytes, optional)    |                               |
  +-------------------------------+                               |
  |                       HMAC (20 bytes)                         |
  |                                                               |
  |                                                               |
  |                                                               |
  |                                                               |
  |                               +-------------------------------+
  |                               |
  +-------------------------------+
]]></artwork>
          <t indent="0" pn="section-3.2.8-3">Every address has an Address ID that can be used for uniquely
identifying the address within a connection for address removal. The
Address ID is also used to identify MP_JOIN options (see <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>)
relating to the same address, even when address translators are in use.
The Address ID MUST uniquely identify the address for the sender of the
option (within the scope of the connection); the mechanism for
allocating such IDs is implementation specific.</t>
          <t indent="0" pn="section-3.2.8-4">All Address IDs learned via either MP_JOIN or ADD_ADDR SHOULD be stored
by the receiver in a data structure that gathers all the
Address-ID-to-address mappings for a connection (identified by a token
pair). In this way, there is a stored mapping between the Address ID,
observed source address, and token pair for future processing of control
information for a connection.</t>
          <t indent="0" pn="section-3.2.8-5">Ideally, ADD_ADDR and REMOVE_ADDR options would be sent reliably, and in
order, to the other end. This would ensure that this address management
does not unnecessarily cause an outage in the connection when remove/add
addresses are processed in reverse order, and also to ensure that all
possible paths are used. Note, however, that losing reliability and
ordering will not break the multipath connections, it will just reduce
the opportunity to open new paths and to survive different
patterns of path failures.</t>
          <t indent="0" pn="section-3.2.8-6">Therefore, implementing reliability signals for these DCCP options is
not necessary.  In order to minimize the impact of the loss of these
options, however, it is RECOMMENDED that a sender should send these
options on all available subflows.  If these options need to be received
in-order, an implementation SHOULD only send one ADD_ADDR/REMOVE_ADDR
option per RTT, to minimize the risk of misordering. A host that
receives an ADD_ADDR but finds a connection set up to that IP address
and port number is unsuccessful SHOULD NOT perform further connection
attempts to this address/port combination for this connection. A sender
that wants to trigger a new incoming connection attempt on a previously
advertised address/port combination can therefore refresh ADD_ADDR
information by sending the option again.</t>
          <t indent="0" pn="section-3.2.8-7">[TBD/TBV]</t>
        </section>
        <section anchor="MP_REMOVEADDR" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.9">
          <name slugifiedName="name-mp_removeaddr">MP_REMOVEADDR</name>
          <t indent="0" pn="section-3.2.9-1">If, during the lifetime of an MP-DCCP connection, a previously announced
address becomes invalid (e.g., if the interface disappears), the
affected host SHOULD announce this so that the peer can remove subflows
related to this address.</t>
          <t indent="0" pn="section-3.2.9-2">This is achieved through the Remove Address (REMOVE_ADDR) option which
will remove a previously added address (or list of addresses) from a
connection and terminate any subflows currently using that address.</t>
          <t indent="0" pn="section-3.2.9-3">For security purposes, if a host receives a REMOVE_ADDR option, it must
ensure the affected path(s) are no longer in use before it instigates
closure. Typical DCCP validity tests on the subflow (e.g., packet type
specific sequence and acknowledgement number check) MUST also be
undertaken. An implementation can use indications of these test failures
as part of intrusion detection or error logging.</t>
          <t indent="0" pn="section-3.2.9-4">The sending and receipt of this message SHOULD trigger the sending of
DCCP-Close and DCCP-Reset by client and server, respectively on the
affected subflow(s) (if possible), as a courtesy to cleaning up
middlebox state, before cleaning up any local state.</t>
          <t indent="0" pn="section-3.2.9-5">Address removal is undertaken by ID, so as to permit the use of NATs and
other middleboxes that rewrite source addresses.  If there is no address
at the requested ID, the receiver will silently ignore the request.</t>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.9-6"><![CDATA[
                     1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+---------------+---------------+-------+-------+---------------+
|     Type      |  Length = 3+n |Subtype|(resvd)|   Address ID  |...
+---------------+---------------+-------+-------+---------------+
                          (followed by n-1 Address IDs, if required)
]]></artwork>
          <t indent="0" pn="section-3.2.9-7">Minimum length of this option is 4 bytes (for one address to remove).</t>
          <t indent="0" pn="section-3.2.9-8">[TBD/TBV]</t>
        </section>
        <section anchor="MP_PRIO" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.10">
          <name slugifiedName="name-mp_prio">MP_PRIO</name>
          <t indent="0" pn="section-3.2.10-1">In the event that a single specific path out of the set of available
paths shall be treated with higher priority compared to the others, a
host may wish to signal such change in priority  to the peer.
One reason for such behavior is due to the different costs involved in
using different paths (e.g., WiFi is free while cellular has limit on
volume, 5G has higher energy consumption). Also, the priority of a path
may be subject to dynamic changes, for example when the mobile runs out
of battery only a single path may be preferred. Therefore, the path
priority should be considered as hints for the packet scheduler when
making decisions which path to use for user plane traffic.</t>
          <t indent="0" pn="section-3.2.10-2">The MP_PRIO option, shown below, can be used to set a priority flag
for the path which is specified by the AddrID field that uniquely
identifies the path. The option can be sent over any path.</t>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.10-3"><![CDATA[
                        1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +---------------+---------------+-------+-------+--------------+
   |     Type      |     Length    |Subtype| Prio  | AddrID       |
   +---------------+---------------+-------+-------+--------------+
]]></artwork>
          <t indent="0" pn="section-3.2.10-4">The following values are available for Prio field:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.10-5">
            <li pn="section-3.2.10-5.1">0: Do not use. The path is not available.</li>
            <li pn="section-3.2.10-5.2">1: Standby: do not use this path for traffic scheduling, if another
   path (secondary or primary) is available.</li>
            <li pn="section-3.2.10-5.3">2: Secondary: do not use this path for traffic scheduling, if the other
   paths are good enough. The path will be used occasionally, e.g. when
   primary paths are congested or become not available.</li>
            <li pn="section-3.2.10-5.4">3: Primary: can use the path in any way deemed reasonable by peer. Will
   always be used for packet scheduling decisions.</li>
            <li pn="section-3.2.10-5.5">4 - 15: relative priority of one path over the other to give relative
   path priority for primary paths. The peer should consider sending 
   more traffic over higher priority path. Higher numbers indicate 
   higher priority.</li>
          </ul>
          <t indent="0" pn="section-3.2.10-6">Example use cases include:
1) Setting Wi-Fi path to Primary and Cellular paths to Secondary. In this case
   Wi-Fi will be used and Cellular only if the Wi-Fi path is congested or not
   available. Such setting results in using the Cellular path only temporally, 
   if more capacity is needed than the WiFi path can provide, indicating a 
   clear priority of the Wi-Fi path over the Cellular due to e.g. cost reasons.</t>
          <t indent="0" pn="section-3.2.10-7">2) Setting Wi-Fi path to Primary and Cellular to Standby. In this case Wi-Fi
   will be used and Cellular only, if the Wi-Fi path is not available. 
3) Setting Wi-Fi path to Primary and Cellular path to Primary. In this case,
   all packets can be scheduled  over all paths at all time.</t>
          <t indent="0" pn="section-3.2.10-8">The default behavior is, that a path can always be used for packet scheduling 
decisions (MP_PRIO=3), if the path has been established and added to an 
existing MP-DCCP connection. At least one path should have a MP_PRIO value
greater or equal to one for it to be allowed to send on the connection. 
MP_PRIO is assumed to be exchanged reliably using the MP_CONFIRM mechanisms 
(see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>).</t>
        </section>
        <section anchor="MP_CLOSE" numbered="true" toc="include" removeInRFC="false" pn="section-3.2.11">
          <name slugifiedName="name-mp_close">MP_CLOSE</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.11-1"><![CDATA[
  +--------+--------+--------+--------+--------+
  |00101110| Length |00001010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46           MP_OPT=2
]]></artwork>
          <t indent="0" pn="section-3.2.11-2">If the MP_CLOSE is present in a DCCP-CloseReq or DCCP-Close, the MP-DCCP connection is closed using the regular procedure of single-path DCCP termination on all subflows. Only in case all subflows are successfully terminated, the overall MP-DCCP connection passes to a closed state.</t>
          <t indent="0" pn="section-3.2.11-3">Contrary to a MP_FAST_CLOSE <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>, no single-sided abrupt termination is applied.</t>
        </section>
      </section>
      <section anchor="handshaking" numbered="true" toc="include" removeInRFC="false" pn="section-3.3">
        <name slugifiedName="name-mp-dccp-handshaking-procedu">MP-DCCP Handshaking Procedure</name>
        <figure anchor="ref-mp-dccp-handshaking" align="left" suppress-title="false" pn="figure-3">
          <name slugifiedName="name-example-mp-dccp-handshake">Example MP-DCCP Handshake</name>
          <artwork name="" type="" align="left" alt="" pn="section-3.3-1.1"><![CDATA[
          Host A                                         Host B 
------------------------                              ----------
Address A1    Address A2                              Address B1
----------    ----------                              ----------
     |             |                                       |
     |             DCCP-Request + MP_CAPABLE               |
     |------- MP_KEY(Key-A(1), Key-A(2),...) ------------->|
     |<---------------------- MP_KEY(Key-B) ---------------|
     |             DCCP-Response +  MP_CAPABLE             |
     |             |                                       |
     |   DCCP-Ack  |                                       |
     |--------- MP_KEY(Key-A) + MP_KEY(Key-B) ------------>|
     |<----------------------------------------------------|
     |   DCCP-Ack  |                                       |
     |             |                                       |
     |             |          DCCP-Request + MP_CAPABLE    |
     |             |--- MP_JOIN(TB,RA) ------------------->|
     |             |<------MP_JOIN(TB,RB) + MP_HMAC(A)-----|
     |             |DCCP-Response  + MP_CAPABLE            |
     |             |                                       |
     |             |DCCP-Ack                               |
     |             |-------- MP_HMAC(B) ------------------>|
     |             |<--------------------------------------|
     |             |DCCP-ACK                               |
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.3-2">The basic initial handshake for the first flow is as follows:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.3-3">
          <li pn="section-3.3-3.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_KEY option with an Host-specific Key-A for
each of supported types as described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></li>
          <li pn="section-3.3-3.2">Host B sends a DCCP-Response with Confirm feature for
MP-Capable and the MP_Key option with a single Host-specific Key-B.
The type of the key MUST be chosen from the list of supported types
from the previous request</li>
          <li pn="section-3.3-3.3">Host A sends a DCCP-Ack with both Keys echoed to Host B.</li>
          <li pn="section-3.3-3.4">Host B sends a DCCP-Ack to confirm both keys and conclude the handshaking.</li>
        </ul>
        <t indent="0" pn="section-3.3-4">Host A MUST wait the final DCCP-Ack from host B before starting any
establishment of additional subflow connections.</t>
        <t indent="0" pn="section-3.3-5">The handshake for subsequent flows based on a successful initial
handshake is as follows:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.3-6">
          <li pn="section-3.3-6.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_JOIN option with Host B's Token TB, generated from
the derived key by applying a SHA256 hash and truncating to the first
32 bits. Additionally, an own random nonce RA is transmitted with the
MP_JOIN.</li>
          <li pn="section-3.3-6.2">
            <t indent="0" pn="section-3.3-6.2.1">Host B computes the HMAC of the DCCP-Request and sends a DCCP-Response
with Confirm feature option for MP-Capable and the MP_JOIN option with
the Token TB and a random nonce RB together with the computed MP_HMAC.
The HMAC is calculated by taking the leftmost 20 bytes from the SHA256 hash
of a HMAC code created by using token and nonce received with MP_JOIN(A) as message
and the derived key described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> as key:  </t>
            <t indent="0" pn="section-3.3-6.2.2">
MP_HMAC(A) = HMAC-SHA256(Key=d-key(B), Msg=TB+RA)</t>
          </li>
          <li pn="section-3.3-6.3">
            <t indent="0" pn="section-3.3-6.3.1">Host A sends a DCCP-Ack with the HMAC computed for the DCCP-Response.
The HMAC is calculated by taking the leftmost 20 bytes from the SHA256 hash
of a HMAC code created by using token and nonce received with MP_JOIN(B) as message
and the derived key described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> as key:  </t>
            <t indent="0" pn="section-3.3-6.3.2">
MP_HMAC(A) = HMAC-SHA256(Key=d-key(A), Msg=TB+RB)</t>
          </li>
          <li pn="section-3.3-6.4">Host B sends a DCCP-Ack to confirm the HMAC and to conclude the
handshaking.</li>
        </ul>
      </section>
      <section anchor="close-a-mp-dccp-connection" numbered="true" toc="include" removeInRFC="false" pn="section-3.4">
        <name slugifiedName="name-close-a-mp-dccp-connection">Close a MP-DCCP connection</name>
        <t indent="0" pn="section-3.4-1">[tbd]</t>
      </section>
      <section anchor="fallback" numbered="true" toc="include" removeInRFC="false" pn="section-3.5">
        <name slugifiedName="name-fallback">Fallback</name>
        <t indent="0" pn="section-3.5-1">When a subflow fails to operate within the MP-DCCP requirements, it is 
necessary to fall back to the safe operation. This may be either falling back 
to regular DCCP, or removing a problematic subflow. The main reason for 
subflow failing is loss of MP-DCCP options.</t>
        <t indent="0" pn="section-3.5-2">At the start of the MP-DCCP connection, the handshake ensures exchange of MP-DCCP
options and thus ensures that the path is fully MP-DCCP capable. If during the
handshake procedure it appears that DCCP-Request or DCCP-Response or DCCP-Ack
messages don't have the MP-DCCP options, the MP-DCCP connection will not be 
established and the handshake should fall back to regular DCCP. The same
fallback should take place if the endpoints fail to agree on a protocol
version to use during the Multipath Capable feature negotiation.</t>
        <t indent="0" pn="section-3.5-3">If a subflow attempts to join an existing MP-DCCP connection, but MP-DCCP options 
are not present in the handshake messages or the protocol version doesn't
match the value negotiated for the first flow, that subflow will be closed.</t>
      </section>
      <section anchor="congestion-control-considerations" numbered="true" toc="include" removeInRFC="false" pn="section-3.6">
        <name slugifiedName="name-congestion-control-consider">Congestion Control Considerations</name>
        <t indent="0" pn="section-3.6-1">Senders MUST manage per-path congestion status, and SHOULD avoid to send
more data on a given path than congestion control on that path
allows.</t>
        <t indent="0" pn="section-3.6-2">When a Multipath DCCP 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
path connections.  Multipath TCP uses the coupled congestion control
Linked Increases Algorithm (LIA) specified in <xref target="RFC6356" format="default" sectionFormat="of" derivedContent="RFC6356"/> to
solve this problem.  This scheme can be adapted also for Multipath DCCP.
The same applies to other coupled congestion control schemes, which
have been proposed for Multipath TCP such as Opportunistic Linked
Increases Algorithm <xref target="OLIA" format="default" sectionFormat="of" derivedContent="OLIA"/>.</t>
      </section>
      <section anchor="maximum-packet-size-considerations" numbered="true" toc="include" removeInRFC="false" pn="section-3.7">
        <name slugifiedName="name-maximum-packet-size-conside">Maximum Packet Size Considerations</name>
        <t indent="0" pn="section-3.7-1">A DCCP implementation MUST maintain the maximum packet size (MPS) during operation of a DCCP session. This procedure is specified for single-path DCCP in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 14. Without any restrictions, this is adopted for MP-DCCP operations, in particular the PMTU measurement and the Sender Behaviour. As per this definition a DCCP application interface SHOULD let the application discover the current MPS, this is subject to ambiguity with potential different path MPS in a multi-path system. For compatibility reasons, a MP-DCCP implementation SHOULD always announce the minimum MPS across all paths.</t>
      </section>
    </section>
    <section anchor="security" numbered="true" toc="include" removeInRFC="false" pn="section-4">
      <name slugifiedName="name-security-considerations">Security Considerations</name>
      <t indent="0" pn="section-4-1">Similar to DCCP, MP-DCCP does not provide cryptographic security
guarantees inherently. Thus, if applications need cryptographic security
(integrity, authentication, confidentiality, access control, and
anti-replay protection) the use of IPsec or some other kind of
end-to-end security is recommended;
Secure Real-time Transport Protocol (SRTP) <xref target="RFC3711" format="default" sectionFormat="of" derivedContent="RFC3711"/> is one candidate
protocol for authentication. Together with Encryption of Header
Extensions in SRTP, as provided by <xref target="RFC6904" format="default" sectionFormat="of" derivedContent="RFC6904"/>, also integrity would
be provided.</t>
      <t indent="0" pn="section-4-2">As described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, DCCP provides protection against hijacking
and limits the potential impact of some denial-of-service attacks, but
DCCP provides no inherent protection against attackers' snooping on data
packets. Regarding the security of MP-DCCP no additional risks should be
introduced compared to regular DCCP of today. Thereof derived are the
following key security requirements to be fulfilled by MP-DCCP:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-4-3">
        <li pn="section-4-3.1">Provide a mechanism to confirm that parties involved in a subflow
handshake are identical to those in the original connection setup.</li>
        <li pn="section-4-3.2">Provide verification that the new address to be included in a MP
connection is valid for a peer to receive traffic at before using it.</li>
        <li pn="section-4-3.3">Provide replay protection, i.e., ensure that a request to add/remove a
subflow is 'fresh'.</li>
      </ul>
      <t indent="0" pn="section-4-4">In order to achieve these goals, MP-DCCP includes a hash-based handshake
algorithm documented in Sections <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> and <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. The
security of the MP-DCCP connection depends on the use of keys that are
shared once at the start of the first subflow and are never sent again
over the network. To ease demultiplexing while not giving away any
cryptographic material, future subflows use a truncated cryptographic
hash of this key as the connection identification "token". The keys are
concatenated and used as keys for creating Hash-based Message
Authentication Codes (HMACs) used on subflow setup, in order to verify
that the parties in the handshake are the same as in the original
connection setup. It also provides verification that the peer can
receive traffic at this new address. Replay attacks would still be
possible when only keys are used;
therefore, the handshakes use single-use random numbers (nonces) at both
ends -- this ensures that the HMAC will never be the same on two handshakes.
Guidance on generating random numbers suitable for use as keys is given
in <xref target="RFC4086" format="default" sectionFormat="of" derivedContent="RFC4086"/>. During normal operation, regular DCCP protection
mechanisms (such as header checksum to protect DCCP headers against
corruption) will provide the same level of protection against attacks on
individual DCCP subflows as exists for regular DCCP today.</t>
    </section>
    <section anchor="middlebox" numbered="true" toc="include" removeInRFC="false" pn="section-5">
      <name slugifiedName="name-interactions-with-middlebox">Interactions with Middleboxes</name>
      <t indent="0" pn="section-5-1">Issues from interaction with on-path middleboxes such as NATs, firewalls, proxies,
intrusion detection systems (IDSs), and others have to be considered for all
extensions to standard protocols since otherwise unexpected reactions of
middleboxes may hinder its deployment. DCCP already provides means to
mitigate the potential impact of middleboxes, also in comparison to TCP (see
<xref target="RFC4043" format="default" sectionFormat="of" derivedContent="RFC4043"/>, sect. 16). In case, however, both hosts are located behind a NAT or
firewall entity, specific measures have to be applied such as the <xref target="RFC5596" format="default" sectionFormat="of" derivedContent="RFC5596"/>-specified
simultaneous-open technique that update the (traditionally asymmetric)
connection-establishment procedures for DCCP.  Further standardized technologies
addressing NAT type middleboxes are covered by <xref target="RFC5597" format="default" sectionFormat="of" derivedContent="RFC5597"/>.</t>
      <t indent="0" pn="section-5-2"><xref target="RFC6773" format="default" sectionFormat="of" derivedContent="RFC6773"/> specifies UDP Encapsulation for NAT Traversal of DCCP sessions,
similar to other UDP encapsulations such as for SCTP <xref target="RFC6951" format="default" sectionFormat="of" derivedContent="RFC6951"/>. The alternative
U-DCCP approach proposed in <xref target="I-D.amend-tsvwg-dccp-udp-header-conversion" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-dccp-udp-header-conversion"/> would
reduce tunneling overhead. The handshaking procedure for DCCP-UDP
header conversion or use of a DCCP-UDP negotiation procedure to signal support
for DCCP-UDP header conversion would require encapsulation during the handshakes
and use of two additional port numbers out of the UDP port number space, but
would require zero overhead afterwards.</t>
    </section>
    <section anchor="implementation" numbered="true" toc="include" removeInRFC="false" pn="section-6">
      <name slugifiedName="name-implementation">Implementation</name>
      <t indent="0" pn="section-6-1">The approach described above has been implemented in open source across different testbeds and a new scheduling algorithm has been extensively tested. Also 
demonstrations of a laboratory setup have been executed and have been published at <xref target="website" format="default" sectionFormat="of" derivedContent="website"/>.</t>
    </section>
    <section anchor="acknowledgments" numbered="true" toc="include" removeInRFC="false" pn="section-7">
      <name slugifiedName="name-acknowledgments">Acknowledgments</name>
      <t indent="0" pn="section-7-1">Due to the great spearheading work of the Multipath TCP authors in <xref target="RFC6824" format="default" sectionFormat="of" derivedContent="RFC6824"/>/<xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, some text
passages for the -00 version of the draft were copied almost unmodified.</t>
      <t indent="0" pn="section-7-2">The authors gratefully acknowledge significant input into this document from Dirk von Hugo.</t>
    </section>
    <section anchor="iana-considerations" numbered="true" toc="include" removeInRFC="false" pn="section-8">
      <name slugifiedName="name-iana-considerations">IANA Considerations</name>
      <t indent="0" pn="section-8-1">This document defines one new value to DCCP feature list and one new
DCCP Option with ten corresponding Subtypes as follows. 
This document defines a new DCCP feature parameter for negotiating
the support of multipath capability for DCCP sessions between hosts
as described in Section 3. The following entry in <xref target="ref-add-feature-list" format="default" sectionFormat="of" derivedContent="Table 6"/> should be
added to the "Feature Numbers Registry" according to <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 19.4. under the "DCCP Protocol" heading.</t>
      <table anchor="ref-add-feature-list" align="center" pn="table-6">
        <name slugifiedName="name-addition-to-dccp-feature-li">Addition to DCCP Feature list Entries</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Feature Name</th>
            <th align="center" colspan="1" rowspan="1">Specification</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">0x10</td>
            <td align="center" colspan="1" rowspan="1">MP-DCCP capability feature</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/></td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-3">This document defines a new DCCP protocol option of type=46 as described in Section 3.2 together with 10 additional sub-options.
The following entries in <xref target="ref-add-proto-opt-list" format="default" sectionFormat="of" derivedContent="Table 7"/> should be added to the "DCCP
Protocol options" and assigned as "MP-DCCP sub-options", respectively.</t>
      <table anchor="ref-add-proto-opt-list" align="center" pn="table-7">
        <name slugifiedName="name-addition-to-dccp-protocol-o">Addition to DCCP Protocol options and corresponding sub-options</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Symbol</th>
            <th align="center" colspan="1" rowspan="1">Name</th>
            <th align="center" colspan="1" rowspan="1">Reference</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or Type=46</td>
            <td align="center" colspan="1" rowspan="1">MP_OPT</td>
            <td align="center" colspan="1" rowspan="1">DCCP Multipath option</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=0</td>
            <td align="center" colspan="1" rowspan="1">MP_CONFIRM</td>
            <td align="center" colspan="1" rowspan="1">Confirm reception/processing of an MP_OPT option</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=1</td>
            <td align="center" colspan="1" rowspan="1">MP_JOIN</td>
            <td align="center" colspan="1" rowspan="1">Join path to existing MP-DCCP flow</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=2</td>
            <td align="center" colspan="1" rowspan="1">MP_FAST_CLOSE</td>
            <td align="center" colspan="1" rowspan="1">Close MP-DCCP flow</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=3</td>
            <td align="center" colspan="1" rowspan="1">MP_KEY</td>
            <td align="center" colspan="1" rowspan="1">Exchange key material for MP_HMAC</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=4</td>
            <td align="center" colspan="1" rowspan="1">MP_SEQ</td>
            <td align="center" colspan="1" rowspan="1">Multipath Sequence Number</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=5</td>
            <td align="center" colspan="1" rowspan="1">MP_HMAC</td>
            <td align="center" colspan="1" rowspan="1">Hash-based Message Auth. Code for MP-DCCP</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=6</td>
            <td align="center" colspan="1" rowspan="1">MP_RTT</td>
            <td align="center" colspan="1" rowspan="1">Transmit RTT values and calculation parameters</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_RTT" format="default" sectionFormat="of" derivedContent="Section 3.2.7"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=7</td>
            <td align="center" colspan="1" rowspan="1">MP_ADDADDR</td>
            <td align="center" colspan="1" rowspan="1">Advertise additional Address(es)/Port(s)</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=8</td>
            <td align="center" colspan="1" rowspan="1">MP_REMOVEADDR</td>
            <td align="center" colspan="1" rowspan="1">Remove Address(es)/ Port(s)</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=9</td>
            <td align="center" colspan="1" rowspan="1">MP_PRIO</td>
            <td align="center" colspan="1" rowspan="1">Change Subflow Priority</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_PRIO" format="default" sectionFormat="of" derivedContent="Section 3.2.10"/></td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-5">According to the definition of the MP_FAST_CLOSE option in <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>, a new Reset Code value 12 with the name "Abrupt MP termination" should be added.</t>
      <t indent="0" pn="section-8-6">[Tbd], must include options for:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-8-7">
        <li pn="section-8-7.1">handshaking procedure to indicate MP support</li>
        <li pn="section-8-7.2">handshaking procedure to indicate JOINING of an existing MP
connection</li>
        <li pn="section-8-7.3">signaling of new or changed addresses</li>
        <li pn="section-8-7.4">setting handover or aggregation mode</li>
        <li pn="section-8-7.5">MP-specific congestion mechanisms</li>
      </ul>
      <t indent="0" pn="section-8-8">should include options carrying:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-8-9">
        <li pn="section-8-9.1">overall sequence number for restoring/re-assembly/re-ordering purposes</li>
        <li pn="section-8-9.2">sender time measurements for restoring/re-assembly/re-ordering purposes</li>
      </ul>
    </section>
  </middle>
  <back>
    <references pn="section-9">
      <name slugifiedName="name-informative-references">Informative References</name>
      <reference anchor="I-D.amend-iccrg-multipath-reordering" target="https://www.ietf.org/archive/id/draft-amend-iccrg-multipath-reordering-03.txt" quoteTitle="true" derivedAnchor="I-D.amend-iccrg-multipath-reordering">
        <front>
          <title>Multipath sequence maintenance</title>
          <author fullname="Markus Amend">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Dirk von Hugo">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <date day="25" month="October" year="2021"/>
          <abstract>
            <t indent="0">   This document discusses the issue of packet reordering which occurs
   as a specific problem in multi-path connections without reliable
   transport protocols such as TCP.  The topic is relevant for devices
   connected via multiple accesses technologies towards the network as
   is foreseen, e.g., within Access Traffic Selection, Switching, and
   Splitting (ATSSS) service of 3rd Generation Partnership Project
   (3GPP) enabling fixed mobile converged (FMC) scenario.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-amend-iccrg-multipath-reordering-03"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="I-D.amend-tsvwg-dccp-udp-header-conversion" target="https://www.ietf.org/archive/id/draft-amend-tsvwg-dccp-udp-header-conversion-01.txt" quoteTitle="true" derivedAnchor="I-D.amend-tsvwg-dccp-udp-header-conversion">
        <front>
          <title>Lossless and overhead free DCCP - UDP header conversion (U-DCCP)</title>
          <author fullname="Markus Amend">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Anna Brunstrom">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Andreas Kassler">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Veselin Rakocevic">
            <organization showOnFrontPage="true">City University of London</organization>
          </author>
          <date day="8" month="July" year="2019"/>
          <abstract>
            <t indent="0">   The Datagram Congestion Control Protocol (DCCP) is a transport-layer
   protocol that provides upper layers with the ability to use non-
   reliable congestion-controlled flows.  DCCP is not widely deployed in
   the Internet, and the reason for that can be defined as a typical
   example of a chicken-egg problem.  Even if an application developer
   decided to use DCCP, the middle-boxes like firewalls and NATs would
   prevent DCCP end-to-end since they lack support for DCCP.  Moreover,
   as long as the protocol penetration of DCCP does not increase, the
   middle-boxes will not handle DCCP properly.  To overcome this
   challenge, NAT/NATP traversal and UDP encapsulation for DCCP is
   already defined.  However, the former requires special middle-box
   support and the latter introduces overhead.  The recent proposal of a
   multipath extension for DCCP further underlines the challenge of
   efficient middle-box passing as its main goal is to be applied over
   the Internet, traversing numerous uncontrolled middle-boxes.  This
   document introduces a new solution which disguises DCCP during
   transmission as UDP without requiring middle-box modification or
   introducing any overhead.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-amend-tsvwg-dccp-udp-header-conversion-01"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="I-D.amend-tsvwg-multipath-framework-mpdccp" target="https://www.ietf.org/archive/id/draft-amend-tsvwg-multipath-framework-mpdccp-01.txt" quoteTitle="true" derivedAnchor="I-D.amend-tsvwg-multipath-framework-mpdccp">
        <front>
          <title>A multipath framework for UDP traffic over heterogeneous access networks</title>
          <author fullname="Markus Amend">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Eckard Bogenfeld">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Anna Brunstrom">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Andreas Kassler">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Veselin Rakocevic">
            <organization showOnFrontPage="true">City University of London</organization>
          </author>
          <date day="8" month="July" year="2019"/>
          <abstract>
            <t indent="0">   More and more of today's devices are multi-homing capable, in
   particular 3GPP user equipment like smartphones.  In the current
   standardization of the next upcoming mobile network generation 5G
   Rel.16, this is especially targeted in the study group Access Traffic
   Steering Switching Splitting [TR23.793].  ATSSS describes the
   flexible selection or combination of 3GPP untrusted access like Wi-Fi
   and cellular access, overcoming the single-access limitation of
   today's devices and services.  Another multi-connectivity scenario is
   the Hybrid Access [I-D.lhwxz-hybrid-access-network-architecture][I-D.
   muley-network-based-bonding-hybrid-access], providing multiple access
   for CPEs, which extends the traditional way of single access
   connectivity at home to dual-connectivity over 3GPP and fixed access.
   A missing piece in the ATSSS and Hybrid Access is the access and path
   measurement, which is required for efficient and beneficial traffic
   steering decisions.  This becomes particularly important in
   heterogeneous access networks with a multitude of volatile access
   paths.  While MP-TCP has been proposed to be used within ATSSS, there
   are drawbacks when being used to encapsulate unreliable traffic as it
   blindly retransmits each lost frame leading to excessive delay and
   potential head-of-line blocking.  A decision for MP-TCP though leaves
   the increasing share of UDP in today's traffic mix
   (&lt;https://arxiv.org/abs/1801.05168&gt;) unconsidered.  In this document,
   a multi-access framework is proposed leveraging the MP-DCCP network
   protocol, which enables flexible traffic steering, switching and
   splitting also for unreliable traffic.  A benefit is the support for
   pluggable congestion control which enables our framework to be used
   either independent or complementary to MP-TCP.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-amend-tsvwg-multipath-framework-mpdccp-01"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="I-D.lhwxz-hybrid-access-network-architecture" target="https://www.ietf.org/archive/id/draft-lhwxz-hybrid-access-network-architecture-02.txt" quoteTitle="true" derivedAnchor="I-D.lhwxz-hybrid-access-network-architecture">
        <front>
          <title>Hybrid Access Network Architecture</title>
          <author fullname="Nicolai Leymann">
	 </author>
          <author fullname="Cornelius Heidemann">
	 </author>
          <author fullname="Margaret Wesserman">
	 </author>
          <author fullname="Li Xue">
	 </author>
          <author fullname="Mingui Zhang">
	 </author>
          <date day="13" month="January" year="2015"/>
          <abstract>
            <t indent="0">   Residential and Enterprise customers require continuously increasing
   bandwidth, however it may be difficult for operators to update or
   rebuild existing fixed access networks, especially when they are
   deployed in certain areas.  This document discusses a general way to
   address this problem by bundling together multiple heterogeneous
   access networks according to certain management policies.


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-lhwxz-hybrid-access-network-architecture-02"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="I-D.muley-network-based-bonding-hybrid-access" target="https://www.ietf.org/archive/id/draft-muley-network-based-bonding-hybrid-access-03.txt" quoteTitle="true" derivedAnchor="I-D.muley-network-based-bonding-hybrid-access">
        <front>
          <title>Network based Bonding solution for Hybrid Access</title>
          <author fullname="Praveen Muley">
            <organization showOnFrontPage="true">Nokia</organization>
          </author>
          <author fullname="Wim Henderickx">
            <organization showOnFrontPage="true">Nokia</organization>
          </author>
          <author fullname="Geng Liang">
            <organization showOnFrontPage="true">China Mobile</organization>
          </author>
          <author fullname="Hans Liu">
            <organization showOnFrontPage="true">D-Link Corp</organization>
          </author>
          <author fullname="Loris Cardullo">
            <organization showOnFrontPage="true">Vodafone</organization>
          </author>
          <author fullname="Jonathan Newton">
            <organization showOnFrontPage="true">Vodafone</organization>
          </author>
          <author fullname="SungHoon Seo">
            <organization showOnFrontPage="true">Korea Telecom</organization>
          </author>
          <author fullname="Sagiv Draznin">
            <organization showOnFrontPage="true">Verizon Wireless</organization>
          </author>
          <author fullname="Basavaraj Patil">
            <organization showOnFrontPage="true">AT&amp;T</organization>
          </author>
          <date day="22" month="October" year="2018"/>
          <abstract>
            <t indent="0">   In order to address increasing bandwidth demands, operators are
   considering bundling of multiple heterogeneous access networks
   (Hybrid access) for residential and enterprise customers. This
   document describes a solution for Hybrid access and covers the use
   case scenarios.


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-muley-network-based-bonding-hybrid-access-03"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="OLIA" quoteTitle="true" derivedAnchor="OLIA">
        <front>
          <title>MPTCP is not pareto-optimal: performance issues and a possible solution</title>
          <author initials="R." surname="Khalili">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="N." surname="Gast">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="M." surname="Popovic">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="U." surname="Upadhyay">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="J.-Y." surname="Le Boudec">
            <organization showOnFrontPage="true"/>
          </author>
          <date year="2012"/>
        </front>
        <seriesInfo name="Proceedings of the 8th international conference on Emerging networking experiments and technologies, ACM" value=""/>
      </reference>
      <reference anchor="paper" quoteTitle="true" target="https://doi.org/10.1109/LCN44214.2019.8990746" derivedAnchor="paper">
        <front>
          <title>A Framework for Multiaccess Support for Unreliable Internet Traffic using Multipath DCCP</title>
          <author initials="M." surname="Amend" fullname="Markus Amend">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="E." surname="Bogenfeld" fullname="Eckard Bogenfeld">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="M." surname="Cvjetkovic" fullname="Milan Cvjetkovic">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="V." surname="Rakocevic" fullname="Veselin Rakocevic">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="M." surname="Pieska" fullname="Marcus Pieska">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="A." surname="Kassler" fullname="Andreas Kassler">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="A." surname="Brunstrom" fullname="Anna Brunstrom">
            <organization showOnFrontPage="true"/>
          </author>
          <date year="2019" month="October"/>
        </front>
        <seriesInfo name="DOI" value="10.1109/LCN44214.2019.8990746"/>
      </reference>
      <reference anchor="RFC0793" target="https://www.rfc-editor.org/info/rfc793" quoteTitle="true" derivedAnchor="RFC0793">
        <front>
          <title>Transmission Control Protocol</title>
          <author fullname="J. Postel" initials="J." surname="Postel">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="1981"/>
        </front>
        <seriesInfo name="STD" value="7"/>
        <seriesInfo name="RFC" value="793"/>
        <seriesInfo name="DOI" value="10.17487/RFC0793"/>
      </reference>
      <reference anchor="RFC2104" target="https://www.rfc-editor.org/info/rfc2104" quoteTitle="true" derivedAnchor="RFC2104">
        <front>
          <title>HMAC: Keyed-Hashing for Message Authentication</title>
          <author fullname="H. Krawczyk" initials="H." surname="Krawczyk">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Bellare" initials="M." surname="Bellare">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="R. Canetti" initials="R." surname="Canetti">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="February" year="1997"/>
          <abstract>
            <t indent="0">This document describes HMAC, a mechanism for message authentication using cryptographic hash functions. HMAC can be used with any iterative cryptographic hash function, e.g., MD5, SHA-1, in combination with a secret shared key.  The cryptographic strength of HMAC depends on the properties of the underlying hash function.  This memo provides information for the Internet community.  This memo does not specify an Internet standard of any kind</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="2104"/>
        <seriesInfo name="DOI" value="10.17487/RFC2104"/>
      </reference>
      <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119" quoteTitle="true" derivedAnchor="RFC2119">
        <front>
          <title>Key words for use in RFCs to Indicate Requirement Levels</title>
          <author fullname="S. Bradner" initials="S." surname="Bradner">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="1997"/>
          <abstract>
            <t indent="0">In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="2119"/>
        <seriesInfo name="DOI" value="10.17487/RFC2119"/>
      </reference>
      <reference anchor="RFC3124" target="https://www.rfc-editor.org/info/rfc3124" quoteTitle="true" derivedAnchor="RFC3124">
        <front>
          <title>The Congestion Manager</title>
          <author fullname="H. Balakrishnan" initials="H." surname="Balakrishnan">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Seshan" initials="S." surname="Seshan">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2001"/>
          <abstract>
            <t indent="0">This document describes the Congestion Manager (CM), an end-system module that enables an ensemble of multiple concurrent streams from a sender destined to the same receiver and sharing the same congestion properties to perform proper congestion avoidance and control, and allows applications to easily adapt to network congestion.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="3124"/>
        <seriesInfo name="DOI" value="10.17487/RFC3124"/>
      </reference>
      <reference anchor="RFC3711" target="https://www.rfc-editor.org/info/rfc3711" quoteTitle="true" derivedAnchor="RFC3711">
        <front>
          <title>The Secure Real-time Transport Protocol (SRTP)</title>
          <author fullname="M. Baugher" initials="M." surname="Baugher">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="D. McGrew" initials="D." surname="McGrew">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Naslund" initials="M." surname="Naslund">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="E. Carrara" initials="E." surname="Carrara">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="K. Norrman" initials="K." surname="Norrman">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2004"/>
          <abstract>
            <t indent="0">This document describes the Secure Real-time Transport Protocol (SRTP), a profile of the Real-time Transport Protocol (RTP), which can provide confidentiality, message authentication, and replay protection to the RTP traffic and to the control traffic for RTP, the Real-time Transport Control Protocol (RTCP).   [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="3711"/>
        <seriesInfo name="DOI" value="10.17487/RFC3711"/>
      </reference>
      <reference anchor="RFC4043" target="https://www.rfc-editor.org/info/rfc4043" quoteTitle="true" derivedAnchor="RFC4043">
        <front>
          <title>Internet X.509 Public Key Infrastructure Permanent Identifier</title>
          <author fullname="D. Pinkas" initials="D." surname="Pinkas">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Gindin" initials="T." surname="Gindin">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2005"/>
          <abstract>
            <t indent="0">This document defines a new form of name, called permanent identifier, that may be included in the subjectAltName extension of a public key certificate issued to an entity.</t>
            <t indent="0">The permanent identifier is an optional feature that may be used by a CA to indicate that two or more certificates relate to the same entity, even if they contain different subject name (DNs) or different names in the subjectAltName extension, or if the name or the affiliation of that entity stored in the subject or another name form in the subjectAltName extension has changed.</t>
            <t indent="0">The subject name, carried in the subject field, is only unique for each subject entity certified by the one CA as defined by the issuer name field.  However, the new name form can carry a name that is unique for each subject entity certified by a CA.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4043"/>
        <seriesInfo name="DOI" value="10.17487/RFC4043"/>
      </reference>
      <reference anchor="RFC4086" target="https://www.rfc-editor.org/info/rfc4086" quoteTitle="true" derivedAnchor="RFC4086">
        <front>
          <title>Randomness Requirements for Security</title>
          <author fullname="D. Eastlake 3rd" initials="D." surname="Eastlake 3rd">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="J. Schiller" initials="J." surname="Schiller">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Crocker" initials="S." surname="Crocker">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2005"/>
          <abstract>
            <t indent="0">Security systems are built on strong cryptographic algorithms that foil pattern analysis attempts.  However, the security of these systems is dependent on generating secret quantities for passwords, cryptographic keys, and similar quantities.  The use of pseudo-random processes to generate secret quantities can result in pseudo-security. A sophisticated attacker may find it easier to reproduce the environment that produced the secret quantities and to search the resulting small set of possibilities than to locate the quantities in the whole of the potential number space.</t>
            <t indent="0">Choosing random quantities to foil a resourceful and motivated adversary is surprisingly difficult.  This document points out many pitfalls in using poor entropy sources or traditional pseudo-random number generation techniques for generating such quantities.  It recommends the use of truly random hardware techniques and shows that the existing hardware on many systems can be used for this purpose. It provides suggestions to ameliorate the problem when a hardware solution is not available, and it gives examples of how large such quantities need to be for some applications.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="106"/>
        <seriesInfo name="RFC" value="4086"/>
        <seriesInfo name="DOI" value="10.17487/RFC4086"/>
      </reference>
      <reference anchor="RFC4340" target="https://www.rfc-editor.org/info/rfc4340" quoteTitle="true" derivedAnchor="RFC4340">
        <front>
          <title>Datagram Congestion Control Protocol (DCCP)</title>
          <author fullname="E. Kohler" initials="E." surname="Kohler">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Floyd" initials="S." surname="Floyd">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2006"/>
          <abstract>
            <t indent="0">The Datagram Congestion Control Protocol (DCCP) is a transport protocol that provides bidirectional unicast connections of congestion-controlled unreliable datagrams.  DCCP is suitable for applications that transfer fairly large amounts of data and that can benefit from control over the tradeoff between timeliness and reliability.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4340"/>
        <seriesInfo name="DOI" value="10.17487/RFC4340"/>
      </reference>
      <reference anchor="RFC5595" target="https://www.rfc-editor.org/info/rfc5595" quoteTitle="true" derivedAnchor="RFC5595">
        <front>
          <title>The Datagram Congestion Control Protocol (DCCP) Service Codes</title>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document describes the usage of Service Codes by the Datagram Congestion Control Protocol, RFC 4340.  It motivates the setting of a Service Code by applications.  Service Codes provide a method to identify the intended service/application to process a DCCP connection request.  This provides improved flexibility in the use and assignment of port numbers for connection multiplexing.  The use of a DCCP Service Code can also enable more explicit coordination of services with middleboxes (e.g., network address translators and firewalls).  This document updates the specification provided in RFC 4340.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5595"/>
        <seriesInfo name="DOI" value="10.17487/RFC5595"/>
      </reference>
      <reference anchor="RFC5596" target="https://www.rfc-editor.org/info/rfc5596" quoteTitle="true" derivedAnchor="RFC5596">
        <front>
          <title>Datagram Congestion Control Protocol (DCCP) Simultaneous-Open Technique to Facilitate NAT/Middlebox Traversal</title>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document specifies an update to the Datagram Congestion Control Protocol (DCCP), a connection-oriented and datagram-based transport protocol.  The update adds support for the DCCP-Listen packet.  This assists DCCP applications to communicate through middleboxes (e.g., a Network Address Port Translator or a DCCP server behind a firewall), where peering endpoints need to initiate communication in a near- simultaneous manner to establish necessary middlebox state.   [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5596"/>
        <seriesInfo name="DOI" value="10.17487/RFC5596"/>
      </reference>
      <reference anchor="RFC5597" target="https://www.rfc-editor.org/info/rfc5597" quoteTitle="true" derivedAnchor="RFC5597">
        <front>
          <title>Network Address Translation (NAT) Behavioral Requirements for the Datagram Congestion Control Protocol</title>
          <author fullname="R. Denis-Courmont" initials="R." surname="Denis-Courmont">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document defines a set of requirements for NATs handling the Datagram Congestion Control Protocol (DCCP).  These requirements allow DCCP applications, such as streaming applications, to operate consistently, and they are very similar to the TCP requirements for NATs, which have already been published by the IETF.  Ensuring that NATs meet this set of requirements will greatly increase the likelihood that applications using DCCP will function properly.  This  document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="150"/>
        <seriesInfo name="RFC" value="5597"/>
        <seriesInfo name="DOI" value="10.17487/RFC5597"/>
      </reference>
      <reference anchor="RFC5634" target="https://www.rfc-editor.org/info/rfc5634" quoteTitle="true" derivedAnchor="RFC5634">
        <front>
          <title>Quick-Start for the Datagram Congestion Control Protocol (DCCP)</title>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="A. Sathiaseelan" initials="A." surname="Sathiaseelan">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="August" year="2009"/>
          <abstract>
            <t indent="0">This document specifies the use of the Quick-Start mechanism by the Datagram Congestion Control Protocol (DCCP).  DCCP is a transport protocol that allows the transmission of congestion-controlled, unreliable datagrams.  DCCP is intended for applications such as streaming media, Internet telephony, and online games.  In DCCP, an application has a choice of congestion control mechanisms, each specified by a Congestion Control Identifier (CCID).  This document specifies general procedures applicable to all DCCP CCIDs and specific procedures for the use of Quick-Start with DCCP CCID 2, CCID 3, and CCID 4.  Quick-Start enables a DCCP sender to cooperate with Quick-Start routers along the end-to-end path to determine an allowed sending rate at the start of a connection and, at times, in the middle of a DCCP connection (e.g., after an idle or application- limited period).  The present specification is provided for use in controlled environments, and not as a mechanism that would be intended or appropriate for ubiquitous deployment in the global Internet.  This memo defines an Experimental Protocol for the  Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5634"/>
        <seriesInfo name="DOI" value="10.17487/RFC5634"/>
      </reference>
      <reference anchor="RFC6234" target="https://www.rfc-editor.org/info/rfc6234" quoteTitle="true" derivedAnchor="RFC6234">
        <front>
          <title>US Secure Hash Algorithms (SHA and SHA-based HMAC and HKDF)</title>
          <author fullname="D. Eastlake 3rd" initials="D." surname="Eastlake 3rd">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Hansen" initials="T." surname="Hansen">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2011"/>
          <abstract>
            <t indent="0">Federal Information Processing Standard, FIPS</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6234"/>
        <seriesInfo name="DOI" value="10.17487/RFC6234"/>
      </reference>
      <reference anchor="RFC6356" target="https://www.rfc-editor.org/info/rfc6356" quoteTitle="true" derivedAnchor="RFC6356">
        <front>
          <title>Coupled Congestion Control for Multipath Transport Protocols</title>
          <author fullname="C. Raiciu" initials="C." surname="Raiciu">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="D. Wischik" initials="D." surname="Wischik">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="October" year="2011"/>
          <abstract>
            <t indent="0">Often endpoints are connected by multiple paths, but communications are usually restricted to a single path per connection.  Resource usage within the network would be more efficient were it possible for these multiple paths to be used concurrently.  Multipath TCP is a proposal to achieve multipath transport in TCP.</t>
            <t indent="0">New congestion control algorithms are needed for multipath transport protocols such as Multipath TCP, as single path algorithms have a series of issues in the multipath context.  One of the prominent problems is that running existing algorithms such as standard TCP independently on each path would give the multipath flow more than its fair share at a bottleneck link traversed by more than one of its subflows.  Further, it is desirable that a source with multiple paths available will transfer more traffic using the least congested of the paths, achieving a property called "resource pooling" where a bundle of links effectively behaves like one shared link with bigger capacity.  This would increase the overall efficiency of the network and also its robustness to failure.</t>
            <t indent="0">This document presents a congestion control algorithm that couples the congestion control algorithms running on different subflows by linking their increase functions, and dynamically controls the overall aggressiveness of the multipath flow.  The result is a practical algorithm that is fair to TCP at bottlenecks while moving traffic away from congested links.  This document defines an Experimental  Protocol for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6356"/>
        <seriesInfo name="DOI" value="10.17487/RFC6356"/>
      </reference>
      <reference anchor="RFC6773" target="https://www.rfc-editor.org/info/rfc6773" quoteTitle="true" derivedAnchor="RFC6773">
        <front>
          <title>DCCP-UDP: A Datagram Congestion Control Protocol UDP Encapsulation for NAT Traversal</title>
          <author fullname="T. Phelan" initials="T." surname="Phelan">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Perkins" initials="C." surname="Perkins">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="November" year="2012"/>
          <abstract>
            <t indent="0">This document specifies an alternative encapsulation of the Datagram Congestion Control Protocol (DCCP), referred to as DCCP-UDP.  This encapsulation allows DCCP to be carried through the current generation of Network Address Translation (NAT) middleboxes without modification of those middleboxes.  This document also updates the Session Description Protocol (SDP) information for DCCP defined in RFC 5762.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6773"/>
        <seriesInfo name="DOI" value="10.17487/RFC6773"/>
      </reference>
      <reference anchor="RFC6824" target="https://www.rfc-editor.org/info/rfc6824" quoteTitle="true" derivedAnchor="RFC6824">
        <front>
          <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
          <author fullname="A. Ford" initials="A." surname="Ford">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Raiciu" initials="C." surname="Raiciu">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="O. Bonaventure" initials="O." surname="Bonaventure">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="January" year="2013"/>
          <abstract>
            <t indent="0">TCP/IP communication is currently restricted to a single path per connection, yet multiple paths often exist between peers.  The simultaneous use of these multiple paths for a TCP/IP session would improve resource usage within the network and, thus, improve user experience through higher throughput and improved resilience to network failure.</t>
            <t indent="0">Multipath TCP provides the ability to simultaneously use multiple paths between peers.  This document presents a set of extensions to traditional TCP to support multipath operation.  The protocol offers the same type of service to applications as TCP (i.e., reliable bytestream), and it provides the components necessary to establish and use multiple TCP flows across potentially disjoint paths.  This  document defines an Experimental Protocol for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6824"/>
        <seriesInfo name="DOI" value="10.17487/RFC6824"/>
      </reference>
      <reference anchor="RFC6904" target="https://www.rfc-editor.org/info/rfc6904" quoteTitle="true" derivedAnchor="RFC6904">
        <front>
          <title>Encryption of Header Extensions in the Secure Real-time Transport Protocol (SRTP)</title>
          <author fullname="J. Lennox" initials="J." surname="Lennox">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="April" year="2013"/>
          <abstract>
            <t indent="0">The Secure Real-time Transport Protocol (SRTP) provides authentication, but not encryption, of the headers of Real-time Transport Protocol (RTP) packets.  However, RTP header extensions may carry sensitive information for which participants in multimedia sessions want confidentiality.  This document provides a mechanism, extending the mechanisms of SRTP, to selectively encrypt RTP header extensions in SRTP.</t>
            <t indent="0">This document updates RFC 3711, the Secure Real-time Transport Protocol specification, to require that all future SRTP encryption transforms specify how RTP header extensions are to be encrypted.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6904"/>
        <seriesInfo name="DOI" value="10.17487/RFC6904"/>
      </reference>
      <reference anchor="RFC6951" target="https://www.rfc-editor.org/info/rfc6951" quoteTitle="true" derivedAnchor="RFC6951">
        <front>
          <title>UDP Encapsulation of Stream Control Transmission Protocol (SCTP) Packets for End-Host to End-Host Communication</title>
          <author fullname="M. Tuexen" initials="M." surname="Tuexen">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="R. Stewart" initials="R." surname="Stewart">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2013"/>
          <abstract>
            <t indent="0">This document describes a simple method of encapsulating Stream Control Transmission Protocol (SCTP) packets into UDP packets and its limitations.  This allows the usage of SCTP in networks with legacy NATs that do not support SCTP.  It can also be used to implement SCTP on hosts without directly accessing the IP layer, for example, implementing it as part of the application without requiring special privileges.</t>
            <t indent="0">Please note that this document only describes the functionality required within an SCTP stack to add on UDP encapsulation, providing only those mechanisms for two end-hosts to communicate with each other over UDP ports.  In particular, it does not provide mechanisms to determine whether UDP encapsulation is being used by the peer, nor the mechanisms for determining which remote UDP port number can be used.  These functions are out of scope for this document.</t>
            <t indent="0">This document covers only end-hosts and not tunneling (egress or ingress) endpoints.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6951"/>
        <seriesInfo name="DOI" value="10.17487/RFC6951"/>
      </reference>
      <reference anchor="RFC8684" target="https://www.rfc-editor.org/info/rfc8684" quoteTitle="true" derivedAnchor="RFC8684">
        <front>
          <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
          <author fullname="A. Ford" initials="A." surname="Ford">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Raiciu" initials="C." surname="Raiciu">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="O. Bonaventure" initials="O." surname="Bonaventure">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Paasch" initials="C." surname="Paasch">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2020"/>
          <abstract>
            <t indent="0">TCP/IP communication is currently restricted to a single path per connection, yet multiple paths often exist between peers. The simultaneous use of these multiple paths for a TCP/IP session would improve resource usage within the network and thus improve user experience through higher throughput and improved resilience to network failure.</t>
            <t indent="0">Multipath TCP provides the ability to simultaneously use multiple paths between peers. This document presents a set of extensions to traditional TCP to support multipath operation. The protocol offers the same type of service to applications as TCP (i.e., a reliable bytestream), and it provides the components necessary to establish and use multiple TCP flows across potentially disjoint paths.</t>
            <t indent="0">This document specifies v1 of Multipath TCP, obsoleting v0 as specified in RFC 6824, through clarifications and modifications primarily driven by deployment experience.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8684"/>
        <seriesInfo name="DOI" value="10.17487/RFC8684"/>
      </reference>
      <reference anchor="slide" target="https://datatracker.ietf.org/meeting/105/materials/slides-105-tsvwg-sessa-62-dccp-extensions-for-multipath-operation-00" quoteTitle="true" derivedAnchor="slide">
        <front>
          <title>MP-DCCP for enabling transfer of UDP/IP traffic over multiple data paths in multi-connectivity networks</title>
          <author initials="M." surname="Amend" fullname="Markus Amend">
            <organization showOnFrontPage="true"/>
          </author>
          <date>n.d.</date>
        </front>
        <seriesInfo name="IETF105" value=""/>
      </reference>
      <reference anchor="TS23.501" target="https://www.3gpp.org/ftp//Specs/archive/23_series/23.501/23501-g70.zip" quoteTitle="true" derivedAnchor="TS23.501">
        <front>
          <title>System architecture for the 5G System; Stage 2; Release 16</title>
          <author>
            <organization showOnFrontPage="true">3GPP</organization>
          </author>
          <date year="2020" month="December"/>
        </front>
      </reference>
      <reference anchor="website" target="https://multipath-dccp.org/" quoteTitle="true" derivedAnchor="website">
        <front>
          <title>Multipath extension for DCCP</title>
          <author>
            <organization showOnFrontPage="true"/>
          </author>
          <date>n.d.</date>
        </front>
      </reference>
    </references>
    <section anchor="diff_mptcp" numbered="true" toc="include" removeInRFC="false" pn="section-appendix.a">
      <name slugifiedName="name-differences-from-multipath-">Differences from Multipath TCP</name>
      <t indent="0" pn="section-appendix.a-1">Multipath DCCP is similar to Multipath TCP <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, in that it
extends the related basic DCCP transport protocol <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> with
multipath capabilities in the same way as Multipath TCP extends TCP
<xref target="RFC0793" format="default" sectionFormat="of" derivedContent="RFC0793"/>.
However, because of the differences between the underlying TCP and DCCP
protocols, the transport characteristics of MPTCP and MP-DCCP are
different.</t>
      <t indent="0" pn="section-appendix.a-2"><xref target="table_tcp_dccp_comp" format="default" sectionFormat="of" derivedContent="Table 8"/> compares the protocol characteristics of TCP
and DCCP, which are by nature inherited by their respective multipath
extensions.  A major difference lies in the delivery of payload, which
is for TCP an exact copy of the generated byte-stream. DCCP behaves
in a different way and does not guarantee to deliver any payload nor the
order of delivery.
Since this is mainly affecting the receiving endpoint of a TCP or
DCCP communication, many similarities on the sender side can be identified.
Both transport protocols share the 3-way initiation of a
communication and both employ congestion control to adapt the sending
rate to the path characteristics.</t>
      <table anchor="table_tcp_dccp_comp" align="center" pn="table-8">
        <name slugifiedName="name-tcp-and-dccp-protocol-compa">TCP and DCCP protocol comparison</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Feature</th>
            <th align="center" colspan="1" rowspan="1">TCP</th>
            <th align="center" colspan="1" rowspan="1">DCCP</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">Full-Duplex</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Connection-Oriented</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Header option space</td>
            <td align="center" colspan="1" rowspan="1">40 bytes</td>
            <td align="center" colspan="1" rowspan="1">&lt; 1008 bytes or PMTU</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Data transfer</td>
            <td align="center" colspan="1" rowspan="1">reliable</td>
            <td align="center" colspan="1" rowspan="1">unreliable</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Packet-loss handling</td>
            <td align="center" colspan="1" rowspan="1">re-transmission</td>
            <td align="center" colspan="1" rowspan="1">report only</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Ordered data delivery</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Sequence numbers</td>
            <td align="center" colspan="1" rowspan="1">one per byte</td>
            <td align="center" colspan="1" rowspan="1">one per PDU</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Flow control</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Congestion control</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">ECN support</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Selective ACK</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">depends on congestion control</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Fix message boundaries</td>
            <td align="center" colspan="1" rowspan="1">no</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Path MTU discovery</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Fragmentation</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">SYN flood protection</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Half-open connections</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-appendix.a-4">Consequently, the multipath features, shown in
<xref target="table_mptcp_mpdccp_comp" format="default" sectionFormat="of" derivedContent="Table 9"/>, are the same, supporting volatile paths
having varying capacity and latency, session handover and path
aggregation capabilities. All of them profit by the existence of
congestion control.</t>
      <table anchor="table_mptcp_mpdccp_comp" align="center" pn="table-9">
        <name slugifiedName="name-mptcp-and-mp-dccp-protocol-">MPTCP and MP-DCCP protocol comparison</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Feature</th>
            <th align="center" colspan="1" rowspan="1">MPTCP</th>
            <th align="center" colspan="1" rowspan="1">MP-DCCP</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">Volatile paths</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Session handover</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Path aggregation</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Data reordering</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">optional</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Expandability</td>
            <td align="center" colspan="1" rowspan="1">limited by TCP header</td>
            <td align="center" colspan="1" rowspan="1">flexible</td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-appendix.a-6">Therefore, the sender logic is not much different between MP-DCCP and
MPTCP.</t>
      <t indent="0" pn="section-appendix.a-7">The receiver side for MP-DCCP has to deal with the unreliable transport 
character of DCCP. The multipath sequence numbers included in MP-DCCP (see <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>) facilitates
adding optional mechanisms for data stream packet reordering 
at the receiver.  Information from the MP_RTT multipath option (<xref target="MP_RTT" format="default" sectionFormat="of" derivedContent="Section 3.2.7"/>), 
DCCP path sequencing and the DCCP Timestamp Option provide further means 
for advanced reordering approaches, e.g., as described in <xref target="I-D.amend-iccrg-multipath-reordering" format="default" sectionFormat="of" derivedContent="I-D.amend-iccrg-multipath-reordering"/>.
Such mechanisms do, however, not affect interoperability
and are not part of the MP-DCCP protocol.  Many 
applications that use unreliable transport protocols can also inherently deal 
with out-of-sequence data (e.g., through adaptive audio and video buffers), 
and so additional reordering support may not be necessary. The addition of optional 
reordering mechanisms are most likely to be needed when the 
different DCCP subflows are routed across paths with different latencies. 
In theory, applications using DCCP are aware that packet reordering might 
happen, since DCCP has no mechanisms to prevent it.</t>
      <t indent="0" pn="section-appendix.a-8">The receiving process for MPTCP is on the other hand a rigid
"just wait" approach, since TCP guarantees reliable delivery.</t>
    </section>
    <section anchor="authors-addresses" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.b">
      <name slugifiedName="name-authors-addresses">Authors' Addresses</name>
      <author initials="M." surname="Amend" fullname="Markus Amend" role="editor">
        <organization abbrev="DT" showOnFrontPage="true">Deutsche Telekom</organization>
        <address>
          <postal>
            <street>Deutsche-Telekom-Allee 9</street>
            <city>Darmstadt</city>
            <code>64295</code>
            <country>Germany</country>
          </postal>
          <email>Markus.Amend@telekom.de</email>
        </address>
      </author>
      <author initials="A." surname="Brunstrom" fullname="Anna Brunstrom">
        <organization showOnFrontPage="true">Karlstad University</organization>
        <address>
          <postal>
            <street>Universitetsgatan 2</street>
            <city>Karlstad</city>
            <code>651 88</code>
            <country>Sweden</country>
          </postal>
          <email>anna.brunstrom@kau.se</email>
        </address>
      </author>
      <author initials="A." surname="Kassler" fullname="Andreas Kassler">
        <organization showOnFrontPage="true">Karlstad University</organization>
        <address>
          <postal>
            <street>Universitetsgatan 2</street>
            <city>Karlstad</city>
            <code>651 88</code>
            <country>Sweden</country>
          </postal>
          <email>andreas.kassler@kau.se</email>
        </address>
      </author>
      <author initials="V." surname="Rakocevic" fullname="Veselin Rakocevic">
        <organization showOnFrontPage="true">City University of London</organization>
        <address>
          <postal>
            <street>Northampton Square</street>
            <city>London</city>
            <country>United Kingdom</country>
          </postal>
          <email>veselin.rakocevic.1@city.ac.uk</email>
        </address>
      </author>
      <author initials="S." surname="Johnson" fullname="Stephen Johnson">
        <organization showOnFrontPage="true">BT</organization>
        <address>
          <postal>
            <street>Adastral Park</street>
            <city>Martlesham Heath</city>
            <code>IP5 3RE</code>
            <country>United Kingdom</country>
          </postal>
          <email>stephen.h.johnson@bt.com</email>
        </address>
      </author>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIADVeJmIAA+V963LbSLLmfzwFQv7R0jRJi7rZVp+eHVmyuzXti46l7o6J
2QkHREIUWiTAAUDJmrY39jX29fZJNr+8VBVAUJLtnrMbsT4npikSqMrKysp7
ZvX7/ajO6mm6Hx8dHp7ELz7UaV5lRV7FF0UZv15M62ye1Jfx23laJjX9EN9k
9Kf8ME3jg/G4TKsqraLk/LxMr/eDdzBiNC5GeTKj8cdlclH3s7S+6NfV9c2k
P7MH++PRaN7f3InGSU0Pbm1ubfU3t/ubT6JRUu/H6Yd5FGXzcj+uy0VVb21u
PtvciqKkTBN8leTVvCjr6GayH5/ZX/EB/Rr/WpRXWT6JfyiLxTy6Sm9vinK8
Hx/ndVrmad0/AkhRtTifZRUWXd/Oaf7jF2cvo2hUjOnV/XhR9ZNqlGVRVSf5
+H0yLfKUIUmjaJ7tx3+vi1EvrmjOMr2o6NPtDB/+QQAu6sui3I/ifhTHWV4R
agbxwSzNx/S34OR1Ul4tKvdlUdKER+mirkaXaXyWTtOrYkbfG2qPzuiPiiZK
a/9cX5/rH0ynaRo/o0dGWX1LDyTljIAe1/imGNN0eztbz3b5r0Vel/TID2k5
S/Jb+iqdJdnUABowQH+pZeDBOKUHygJEko6zuiiDJR0M4uflIiegGFJZ1kGe
J42veWE/JeUU8MQ/59l1WlYEZLAc92VaV5OEcB1vuZXYm34hu8P46dNwJac3
6TjN/UISAmFwbiD85SpZDKq0CfdPSVVN0zKAmkg5qYLv/2+AzTAMrgSGZbh/
GcTvkqtilF5nIwf5L2mVTrO88QvDfkhwBHDHxUX8qsjHRR6s4A2R7mUym9d0
tk//uaBj5RbgnnXw0lh1Oo5/oqMx5p1VuK8FgkFpEAyGf8EYg2Q0WFwF8J8O
4r8Wl3nFwwr0p3U6v0zz4HuG/XlI7AfjhD4m0/iECNTBR9RKrKsi6OMfU2Ik
DtHHJ7vx9rsXD4G8ktkHl4PfZP6/nNeDET8RZTkxwRmxveuUjnF83D8aJDgZ
SwzsoqTviblc9WdzMDN7enp58+Ff/cvb8zIb95PRiDhlnxgPP5mUo0sCaVQv
Sjc6jZjeuifOkyod989pEwjo5ihd4DAXXYzn/cs0Gadlf1TkvO9F3nw6G43K
EPgyJa6YluB29Ny7l4ebT55t68et4eaO+zh8ph+3h1v27faT4VA/7mzubLuP
T/fs4/bOpn7c3X226z/u+Y9P7OPeto27t+U/bu/as3tPntgUe08dDHvPNv3H
XQPn6d5T/vbsdGt7sLvJX8exCrvTW9r3WRzuAQu8mvju7g/683dEmskkjbe+
i98RK6TdiId7PIpj7fyPyXX7h5MT/luE2DckxTb7w63+8Mk3MnFSTkDJl3U9
r/YfP765uRlsT+bzAb39+KKeP358Ok9H1WMG6Tp9vLX9vqJNSavHAj79h/63
P3myOfhXNqchb9JzsJ39OFyXF76pSXJeF4viLjCaQpiBoefmCYn7BsIO4pdG
414zEFqMTxdzlrn4/ue8JEaQnJNqYGIWUvniIhuRKIUwbukHy+js63/jZamp
/zqFZ9erL0g6FZM0v0inS6+/GF0l5Xjp947ZD69/S+urQvhqE4RsShx/6ff2
GC2m3Riii3evgOOEqOEq6UDDiNDQ+LH9ckPaNd5eFnor3g/FeWuElrAPjsDw
WX9Ip2BHjoDQM5iqbfXR2+P9eLg5GA43nz1+dfhmZ2druDPAe4Onz55tPtnB
caum2ThtEOPrkz5rqyC4NCdiA12xJniRlhByPx+dPD4+wVdMeAXxwXhmKitB
l8QgwIoWJ1+DV+bEBrJrSEnlv9UfSZvB2lnBHG7udp5HAEdgj67ScgBdmU/k
jGQgLfExvfSYxBENlUyrx4yXihC8qwKAtPAq6e9tiSRwDKDqE54Cfl+YKt/f
3IwIiLevjg8a6F17fXJG2M2qOC9qwlSZ1gW9VWezhAQmvc1SMR+l9Ei1SCto
LRGhtCAlGge/KqYLjL8WEMMaberW2hIq1k5KovoUAq7CxoH/PiXWkDHvYChJ
6NPu0MammJH0gxeztJxgx3Wf8JFsBBqVsF0zNDHx9Mu8mBYTmqkXHxy+Xlva
TNtK3sd3dEAuk2k2zZZ/ezOIfyDtY/kHHMli7s5947efB/HP82R8eZvcLv/4
10H/b4P4VUrMZzFO5e2o3++Tog8tZ1RHUcQETnrIbJFnI7G8aENGi5LwUE9v
Y7K66jIbQaepiziJwVsJ98xYCReRUXSR9+JbYsKO/IXyiwuiDkJbVtXxOeEx
pb/mKakLA5KYl2lUZXghydOCyHhBkk82hz60BsIZTMR4BP0BTtK5iJ1ms3lJ
Bw+AFouStm5RQZjCfKRjh43W/cOG9eiLBe2UvUQzlpFsKm97fUkm3OQyvswm
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
KqdRh5Zn/XXU1WU6zvGRSxkzA3FR+QppcwmxMvFOvEGPnc88zMT3dqCrhnHM
3pXMltLQLRtldU+ds9diYrLGGP0rLQtUfEgdgwRh60JDt1qNWy3V1WAN3E7I
pcexqQ8kSA8Flx6NTLU6jaWsFnVdTa9txPKHE2jzVMgO4XYVTlzL6xLe6iYO
E3b9VcUo8GLLa2H1la9WBnBMHUF1Dg3BqXRWfJLolPRoA/CDcOmSFjDl9obq
BeNa46iwXNwwBS7xbgDoKEkuaQGsJiCbV/pZZBdBamzk8n/zggDKkVNu2zbD
Jot3GkQlLIOrqLe3+uekspTo9zTT/AYrhpbqWXMgSD5C8+APorNikrLv2x03
PsviJpF5ZFBkyI/lgJ8nVcZIoGlGiykXLF2mEZ+nkKiXyvSq+4vxHOf3tqfw
f/83p5UEdSLYGKZbTggpLpyulKiSTouHC77W3FnmaeflYo5uoiN+IonCBMX4
1yD5sBfU07eG4y212cNkZStl+A7aJNM6PypzBSms5760gOmEH82LOkqkLFuP
UpKxB8QnYLrMTPjBcmnZkFspmBaKKfjfVM1KCeQY11znjtKmpI5cQj1n4/e8
2x48D6UydXxepslV/zwlKkr73CTC2osZi4h8PyRtKANY+IVmP0THkl2Fu5Tb
RGuM0jXeG87bYzTxLjHe4HdT/nlzWUy7Em+/kz4PXPyUp5ytr+IjoCWj+y8z
mu4ykfDNTyQcOGj6JbbRnZbQlgpv+MWl6k5K92kXex3LnC24vS2Ogu//GbQb
kHYFueWca3FL2I/CnM5prSnPwiHkG3ZxDLdIA+AtRYM7YofSZJjr66vLRT2G
e5bHkmZ8rRLknhpIU+kM61Cnu4ySOAEziJx0Fv5ye+CkLDNvdnXuuRxrRBin
qVmLEjes03kvEMMeQ2DcNWpbeS2B8PaVQJ1rI3lHVhdEFJ1QV3CGPrxzxN2c
ieoNuQBcjEw8Nxsn4TMOP9oEyuGnZ9Uvjc1iQ1MaBra3WdPo22tNJmic0LnJ
je2QgqWbgJutOpDxeqZ9MDPN3+aqgSlzAl7rkXTJ2xh4jR+qFzN8+vCZ+n7r
833ndfgROMWJWx9u+LNLf5BW3v/z10y6+hxv49eH95hqDc3/e8fb/T/HflFb
4aK2sKiBsKWvmbthQmCviKyWjYi005VrwsL3grEtQeZF6hXOoZQm7z2Nn9/W
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
CY6QvN0dBU6p/wM6d8f1lOgAAA==

-->

</rfc>
