<?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-05" indexInclude="true" ipr="trust200902" prepTime="2022-07-08T05:00:26" 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-05" 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="07" year="2022" day="08"/>
    <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 as defined in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> is 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 subflows 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 9 January 2023.
        </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 has been suggested
in the context of 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 application subflows 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 application 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. The term subflow
can also be used to refer to an MP-DCCP connection with a single path.</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. The MP-DCCP connection is
exposed as single DCCP socket to the application.</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 subflow setup)       |             |
  |----------------------------------->|             |
  |<-----------------------------------|             |
  |             |                      |             |
  |             |  (DCCP subflow setup)|             |
  |             |--------------------->|             |
  |             |<---------------------|             |
  | merge individual DCCP subflows 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 MP-DCCP 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 MP-DCCP 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 MP-DCCP 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">MP-DCCP 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">MP-DCCP 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 MP-DCCP 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 subflow.</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[
            1          2          3         
 01234567 89012345 67890123 45678901 23456789
+--------+--------+--------+--------+--------+
|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 connection</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 connection 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">4</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 subflow</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[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |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[
              1          2          3
   01234567 89012345 67890123 45678901
  +--------+--------+--------+--------+
  |00101110|00001100|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 subflow to an existing MP-DCCP
connection. 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 MP_JOIN option includes an "Address ID".  This is an identifier
generated by the sender of the option, used to identify the source
address of this packet, even if the IP header has been changed in
transit by a middlebox.  The numeric value of this field is generated
by the sender and must map uniquely to a source IP address for the
sending host.  The Address ID allows address removal (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>)
without needing to know what the source address at the receiver is,
thus allowing address removal through NATs.  The Address ID also
allows correlation between new subflow setup attempts and address
signaling (<xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>), to prevent setting up duplicate subflows
on the same path, if an MP_JOIN and MP_ADDADDR are sent at the same
time.</t>
          <t indent="0" pn="section-3.2.2-4">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 always has 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-5">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[
              1          2          3
   01234567 89012345 67890123 45678901 23456789
  +--------+--------+--------+--------+--------+
  |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 13. 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 13. 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[
                       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
  +---------------+---------------+---------------+---------------+
  |0 0 1 0 1 1 1 0|     Length    |0 0 0 0 0 0 1 1| Key Type (1)  | 
  +---------------+---------------+---------------+---------------+
  |  Key Data (1) |  Key Type (2) |  Key Data (2) | ....
  +---------------+---------------+---------------+---------------+
      Type=46                         MP_OPT=3
]]></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">Public Key Material is exchanged via ECDHE key exchange with SHA256 and
Curve 25519 to generate the derived key (d-key) from the shared secret.</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">Public Key Material is exchanged via ECDHE key exchange with SHA512 and
Curve 25519 to generate the derived key (d-key) from the shared secret.</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 subflow, 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[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|00001001|00000100| Multipath Sequence Number         
  +--------+--------+--------+--------+--------+--------+--------+
  |                 |
  +--------+--------+
   Type=46  Length=9 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[
              1          2          3           4
   01234567 89012345 67890123 45678901 23456789 01234567
  +--------+--------+--------+--------+--------+--------+
  |00101110|00010111|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,
MP_ADDADDR and MP_REMOVEADDR 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</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-4">
            <li pn="section-3.2.6-4.1">MP_JOIN: The token and nonce of the MP_JOIN for which authentication
   shall be performed.</li>
            <li pn="section-3.2.6-4.2">MP_ADDADDR: The Address ID with associated IP address
   and if defined port, otherwise two octets of value 0.</li>
            <li pn="section-3.2.6-4.3">MP_REMOVEADDR: Solely the Address ID.</li>
          </ul>
        </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[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |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 preferably provided by the CCID in use.</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 over a given period preferably provided by the CCID in use.</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 over a given period preferably provided by the CCID in use.</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 over a given period preferably provided by the CCID in use.</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 defines the time difference between now - creation of the MP_RTT option -
 and the conducted RTT measurement in milliseconds. If no previous measurement
 exists, e.g., when initialized, the value is 0.</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.
Multiple instances of this option within a packet advertise simultaneously
new addresses.</t>
          <t indent="0" pn="section-3.2.8-2">Length is variable depending on IPv4 or IPv6 and whether port number is
used and is in range between 8 and 22 bytes.</t>
          <t indent="0" pn="section-3.2.8-3">The presence of the final 2 octets, specifying the DCCP port number to
use, are optional and can be inferred from the length of the option.
Although it is expected that the majority of use cases will use the
same port pairs as used for the initial subflow (e.g., port 80
remains port 80 on all subflows, as does the ephemeral port at the
client), there may be cases (such as port-based load balancing) where
the explicit specification of a different port is required.  If no
port is specified, MP-DCCP SHOULD attempt to connect to the specified
address on the same port as is already in use by the subflow on which
the MP_ADDADDR signal was sent.</t>
          <t indent="0" pn="section-3.2.8-4">Along with the MP_ADDADDR option a MP_HMAC option MUST be sent for
authentication. The truncated HMAC parameter present in this MP_HMAC
option is the leftmost 20 bytes of an HMAC, negotiated and calculated
as described in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>. In the same way as for MP_JOIN,
the key for the HMAC algorithm, in the case of the message transmitted
by Host A, will be Key-A followed by Key-B, and in the case of Host B,
Key-B followed by Key-A.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID, IP address, and port that precede the HMAC in the
MP_ADDADDR option.  If the port is not present in the MP_ADDADDR option,
the HMAC message will nevertheless include 2 octets of value zero.
The rationale for the HMAC is to prevent unauthorized entities from
injecting MP_ADDADDR signals in an attempt to hijack a connection.
Note that, additionally, the presence of this HMAC prevents the
address from being changed in flight unless the key is known by an
intermediary.  If a host receives an MP_ADDADDR option for which it
cannot validate the HMAC, it SHOULD silently ignore the option.</t>
          <artwork name="" type="" align="left" alt="" pn="section-3.2.8-5"><![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    |0 0 0 0 0 1 1 1|  Address ID   |
  +---------------+---------------+-------+-------+---------------+
  |          Address (IPv4 - 4 bytes / IPv6 - 16 bytes)           |
  +-------------------------------+-------------------------------+
  |   Port (2 bytes, optional)    | + MP_HMAC option
  +-------------------------------+
       Type=46       Length=var       MP_OPT=7
]]></artwork>
          <t indent="0" pn="section-3.2.8-6">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-7">All Address IDs learned via either MP_JOIN or MP_ADDADDR 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. Note that an implementation
MAY discard incoming address advertisements at will, for example, for
avoiding the required mapping state, or because advertised addresses
are of no use to it (for example, IPv6 addresses when it has IPv4
only).  Therefore, a host MUST treat address advertisements as soft
state, and it MAY choose to refresh advertisements periodically.</t>
          <t indent="0" pn="section-3.2.8-8">Due to the proliferation of NATs, it is reasonably likely that one
host may attempt to advertise private addresses.  It is not
desirable to prohibit this, since there may be cases where both hosts
have additional interfaces on the same private network, and a host
MAY want to advertise such addresses. The MP_JOIN handshake to
create a new subflow (<xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>) provides mechanisms to minimize
security risks.  The MP_JOIN message contains a 32-bit token that
uniquely identifies the connection to the receiving host. If the
token is unknown, the host will return with a DCCP-Reset. In the unlikely
event that the token is known, subflow setup will continue, but the
HMAC exchange must occur for authentication.  This will fail, and
will provide sufficient protection against two unconnected hosts
accidentally setting up a new subflow upon the signal of a private
address.  Further security considerations around the issue of
MP_ADDADDR messages that accidentally misdirect, or maliciously direct,
new MP_JOIN attempts are discussed in <xref target="security" format="default" sectionFormat="of" derivedContent="Section 4"/>.</t>
          <t indent="0" pn="section-3.2.8-9">The reception of an MP_ADDADDR message is acknowledged using MP_CONFIRM
(<xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>). Using this mechanism reliable exchange of address
information is ensured.</t>
          <t indent="0" pn="section-3.2.8-10">A host can send an MP_ADDADDR message with an already assigned Address
ID, but the Address MUST be the same as previously assigned to this
Address ID, and the Port MUST be different from one already in use
for this Address ID.  If these conditions are not met, the receiver
SHOULD silently ignore the MP_ADDADDR.  A host wishing to replace an
existing Address ID MUST first remove the existing one (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>).</t>
          <t indent="0" pn="section-3.2.8-11">A host that receives an MP_ADDADDR 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. However, a sender that wants to trigger a new incoming
connection attempt on a previously advertised address/port combination
can therefore refresh MP_ADDADDR information by sending the option again.</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 (MP_REMOVEADDR) option which
will remove a previously added address with an Address ID from a
connection and terminate any subflows currently using that address.</t>
          <t indent="0" pn="section-3.2.9-3">Along with the MP_REMOVEADDR option a MP_HMAC option MUST be sent for
authentication. The truncated HMAC parameter present in this MP_HMAC
option is the leftmost 20 bytes of an HMAC, negotiated and calculated
as described in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>. In the same way as for MP_JOIN,
the key for the HMAC algorithm, in the case of the message transmitted
by Host A, will be Key-A followed by Key-B, and in the case of Host B,
Key-B followed by Key-A.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID.
The rationale for the HMAC is to prevent unauthorized entities from
injecting MP_REMOVEADDR signals in an attempt to hijack a connection.
Note that, additionally, the presence of this HMAC prevents the
address from being removed in flight unless the key is known by an
intermediary.  If a host receives an MP_REMOVEADDR option for which it
cannot validate the HMAC, it SHOULD silently ignore the option.</t>
          <t indent="0" pn="section-3.2.9-4">The reception of an MP_REMOVEADDR message is acknowledged using MP_CONFIRM
(<xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>). Using this mechanism reliable exchange of address
information is ensured.</t>
          <t indent="0" pn="section-3.2.9-5">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-6">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-7"><![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 = 46   |  Length = 4   |   MP_OPT = 8  |   Address ID  |
+---------------+---------------+-------+-------+---------------+
+ MP_HMAC option
]]></artwork>
          <t indent="0" pn="section-3.2.9-8">A subflow that is still functioning MUST be closed with a DCCP-Close or
exchange as in regular DCCP, rather than using this option. For more
information, see Section <xref target="closing" format="default" sectionFormat="of" derivedContent="Section 3.4"/>.</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
when making scheduling decisions for user plane traffic, 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, the usage of only a single path may be the preferred choice
of the user. 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 = 46   |  Length = 4   |   MP_OPT = 9  |    AddrID    |
   +---------------+---------------+-------+-------+--------------+
   |(resvd)|  Prio |
   +---------------+
]]></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. The path will only be used if 
   other secondary or primary paths are not established.</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 for increasing 
   temporarily the available capacity, e.g. when primary paths are 
   congested or are not available. This is the recommended setting for
   paths that have costs or data caps as these paths will be used less
   frequently then primary paths.</li>
            <li pn="section-3.2.10-5.4">3 - 15: Primary: can use the path in any way deemed reasonable by peer. 
   The path will always be used for packet scheduling decisions. The 
   priority number indicates the relative priority of one path over the 
   other for primary paths. Higher numbers indicate higher priority. 
   The peer should consider sending more traffic over higher priority paths. 
   This is the recommended setting for paths that do not have a cost or 
   data caps associated with them as these paths will be frequently used.</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.
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-7">If not specified, 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[
              1          2          3           
   01234567 89012345 67890123 45678901 23456789 
  +--------+--------+--------+--------+--------+
  |00101110| Length |00001010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46           MP_OPT=10
]]></artwork>
          <t indent="0" pn="section-3.2.11-2">For a graceful shutdown of a MP-DCCP connection, MP_CLOSE is used to communicate this to a peer host. On all subflows, the regular termination procedure as described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> MUST be initiated using MP_CLOSE in the initial packet (either a DCCP-CloseReq or a DCCP-Close). In the case where a DCCP-CloseReq is used, the following DCCP-Close MUST carry the MP_CLOSE as well. At the initiator of the DCCP-CloseReq all sockets, including the MP-DCCP connection socket, transition to CLOSEREQ state. To protect unauthorized shutdown of a multi-path connection, the selected Key Data of the peer host during the handshaking procedure MUST be carried by the MP_CLOSE option and validated by the peer host. Note, Key Data is different between MP_CLOSE option carried by DCCP-CloseReq or DCCP-Close.</t>
          <t indent="0" pn="section-3.2.11-3">On reception of a first DCCP-CloseReq carrying a MP_CLOSE with valid Key Data, or due to a local decision, all subflows transition to the CLOSING state before transmitting a DCCP-Close carrying MP_CLOSE. In this case, the MP-DCCP connection socket on the host sending the DCCP-Close reflects the state of the initial subflow used during handshake with MP_KEY option. If the initial subflow no longer exists, the state moves immediately to CLOSED.</t>
          <t indent="0" pn="section-3.2.11-4">Upon reception of the first DCCP-Close carrying a MP_CLOSE with valid Key Data at the peer host, all subflows, as well as the MP-DCCP connection socket, move to the CLOSED state. After this, a DCCP-Reset with Reset Code 1 MUST be sent on any subflow in response to a received DCCP-Close containing a valid MP_CLOSE option.</t>
          <t indent="0" pn="section-3.2.11-5">When the MP-DCCP connection socket is in CLOSEREQ or CLOSE state, new subflow requests using MP_JOIN MUST be ignored.</t>
          <t indent="0" pn="section-3.2.11-6">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(B)-----|
     |             |DCCP-Response  + MP_CAPABLE            |
     |             |                                       |
     |             |DCCP-Ack                               |
     |             |-------- MP_HMAC(A) ------------------>|
     |             |<--------------------------------------|
     |             |DCCP-ACK                               |
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.3-2">The basic initial handshake for the first subflow 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 subflows 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(B) = HMAC-SHA256(Key=d-key(B), Msg=RB+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=RA+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="closing" 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">When a host wants to close an existing subflow but not the whole
connection, it can initiate the regular DCCP connection termination procedure 
as described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, by using a DCCP-Close/DCCP-Reset on the subflow. This
can optionally be preceded by a DCCP-CloseReq.</t>
        <t indent="0" pn="section-3.4-2">When a host wants to terminate the MP-DCCP connection, the recommended approach is to
initiate the standard DCCP connection termination on each subflow with the first packet on 
each subflow carrying MP_CLOSE, as described in <xref target="MP_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.11"/>.</t>
        <artwork name="" type="" align="left" alt="" pn="section-3.4-3"><![CDATA[
  Host A                                   Host B
  ------                                   ------
                                   <-      Optional DCCP-CloseReq +
                                           MP_CLOSE [A's key] 
                                           [on all subflows]
  DCCP-Close + MP_CLOSE            ->
  [B's key] [on all subflows]
                                   <-      DCCP-Reset
                                           [on all subflows]
]]></artwork>
        <t indent="0" pn="section-3.4-4">Additionally, a MP-DCCP connection may be closed abruptly using the "Fast Close"
procedure described in <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>, where a DCCP-Reset is sent on all
subflows, each carrying the MP_FAST_CLOSE option.</t>
        <artwork name="" type="" align="left" alt="" pn="section-3.4-5"><![CDATA[
  Host A                                   Host B
  ------                                   ------
  DCCP-Reset + MP_FAST_CLOSE       ->
  [B's key] [on all subflows]
                                   <-      DCCP-Reset
                                           [on all subflows]
]]></artwork>
      </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 reasons for 
subflow failing include: no MP support at peer host, failure to negotiate protocol
version, loss of MP-DCCP options, faulty/non-supported MP-DCCP options or modification
of payload data.</t>
        <t indent="0" pn="section-3.5-2">At the start of the MP-DCCP connection, the handshake ensures exchange of MP-DCCP feature and
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
messages don't carry the MP_CAPABLE feature, the MP-DCCP connection will not be 
established and the handshake SHOULD fall back to regular DCCP or MUST be closed.</t>
        <t indent="0" pn="section-3.5-3">The same fallback SHOULD take place if the endpoints fail to agree on a protocol
version to use during the Multipath Capable feature negotiation, which is described
in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>. The protocol version negotiation distinguishes between negotiation
for the initial connection establishment, and addition of subsequent subflows. If
protocol version negotiation is not successful during the initial connection establishment,
MP-DCCP connection will fall back to regular DCCP.</t>
        <t indent="0" pn="section-3.5-4">Similar procedure MUST be applied if the MP_KEY <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> Key Type cannot be negotiated,
a final ACK carrying MP_KEY with wrong Key-A/Key-B is received or MP_KEY option is malformed.</t>
        <t indent="0" pn="section-3.5-5">If a subflow attempts to join an existing MP-DCCP connection, but MP-DCCP options or MP_CAPABLE
feature are not present or are faulty in the handshake procedure, that subflow MUST be closed.
This is especially the case if a different MP_CAPABLE version than the originally negotiated
version is used. Also non-verifiable MP_HMAC <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/> or MP_JOIN Path Token <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/> MUST
lead to a subflow closing.</t>
        <t indent="0" pn="section-3.5-6">Another relevant case is when payload data is modified by middleboxes. DCCP uses 
checksum to protect the data, as described in section 9 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>. A checksum will 
fail if the data has been changed in any way. All data from the start of the segment that
failed the checksum onwards cannot be considered trustworthy. DCCP defines that if 
the checksum fails, the receiving endpoint MUST drop the application data and report 
that data as dropped due to corruption using a Data Dropped option (Drop Code 3, 
Corrupt). If this happens in an MP-DCCP connection, the affected subflow can either be closed or other action can be taken.</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. 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.</t>
      <t indent="0" pn="section-4-5">As discussed in <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>, a host may advertise its private
addresses, but these might point to different hosts in the receiver's
network.  The MP_JOIN handshake (<xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>) will ensure that this
does not succeed in setting up a subflow to the incorrect host.
However, it could still create unwanted DCCP handshake traffic.  This
feature of MP-DCCP could be a target for denial-of-service exploits,
with malicious participants in MP-DCCP connections encouraging the
recipient to target other hosts in the network.  Therefore,
implementations should consider heuristics at both the
sender and receiver to reduce the impact of this.</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, Nathalie Romo Moreno and Omar Nassef.</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 section provides guidance to the Internet Assigned Numbers Authority (IANA) regarding registration of values related to the MP extension of the DCCP protocol 
in accordance with <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>.  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 <xref target="protocol" format="default" sectionFormat="of" derivedContent="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 subflow to existing MP-DCCP connection</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 connection</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>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or MP_OPT=10</td>
            <td align="center" colspan="1" rowspan="1">MP_CLOSE</td>
            <td align="center" colspan="1" rowspan="1">Close MP-DCCP subflow</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/></td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-5">In addition IANA is requested to assign a new DCCP Reset Code value 13 (or TBD) in the DCCP Reset Codes Registry, with the short description "Abrupt MP termination".  Use of this reset code is defined in section <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>.</t>
      <t indent="0" pn="section-8-6">In addition IANA is requested to assign for this version of the MP-DCCP protocol three different sub options to the MP-KEY option to identify the 
MP_KEY Key types in terms of 8-bit values as specified in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> according to the entries in <xref target="ref-mp_key-sub-opt-list" format="default" sectionFormat="of" derivedContent="Table 8"/> below.
Values in range 3-255 remain unspecified and are reserved for use in potential future versions of the MP-DCCP protocol.</t>
      <table anchor="ref-mp_key-sub-opt-list" align="center" pn="table-8">
        <name slugifiedName="name-mp_key-key-type-sub-options">MP_KEY Key type sub-options for key data exchange on different paths</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Key Type</th>
            <th align="center" colspan="1" rowspan="1">Name or Meaning</th>
            <th align="left" colspan="1" rowspan="1">Reference</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">TBD or 0</td>
            <td align="center" colspan="1" rowspan="1">Plain Text</td>
            <td align="center" colspan="1" rowspan="1">Plain Text Key</td>
            <td align="left" 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 1</td>
            <td align="center" colspan="1" rowspan="1">ECDHE-C25519-SHA256</td>
            <td align="center" colspan="1" rowspan="1">ECDHE with SHA256 and Curve25519</td>
            <td align="left" 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 2</td>
            <td align="center" colspan="1" rowspan="1">ECDHE-C25519-SHA512</td>
            <td align="center" colspan="1" rowspan="1">ECDHE with SHA512 and Curve25519</td>
            <td align="left" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
        </tbody>
      </table>
    </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="RFC8126" target="https://www.rfc-editor.org/info/rfc8126" quoteTitle="true" derivedAnchor="RFC8126">
        <front>
          <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
          <author fullname="M. Cotton" initials="M." surname="Cotton">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="B. Leiba" initials="B." surname="Leiba">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Narten" initials="T." surname="Narten">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2017"/>
          <abstract>
            <t indent="0">Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
            <t indent="0">To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
            <t indent="0">This is the third edition of this document; it obsoletes RFC 5226.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="26"/>
        <seriesInfo name="RFC" value="8126"/>
        <seriesInfo name="DOI" value="10.17487/RFC8126"/>
      </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 9"/> 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-9">
        <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 10"/>, 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-10">
        <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:
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
Hxt7kWcWkJzcbTyd1P8HiP0h7IEXAQA=

-->

</rfc>
