<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" ipr="trust200902" docName="draft-ietf-tsvwg-multipath-dccp-10" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" prepTime="2023-07-26T15:32:13" indexInclude="true" scripts="Common,Latin" tocDepth="3">
  <!-- xml2rfc v2v3 conversion 3.17.4 -->
  <front>
    <title abbrev="Multipath DCCP">DCCP Extensions for Multipath Operation with Multiple Addresses</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-multipath-dccp-10" 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="2023" day="26"/>
    <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 communications as defined in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> are restricted to a single path per
connection, yet multiple paths often exist between peers.  The
simultaneous use of available 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 (e.g., handsets, vehicles) and residential home gateways simultaneously connected to distinct networks as, e.g., 
a cellular and a Wireless Local Area (WLAN) networks
or a cellular and a fixed access networks. Compared to existing multipath protocols, such as MPTCP, MP-DCCP provides specific support for non-TCP user
traffic (e.g., UDP or plain IP).  More details on potential use cases are provided in <xref target="multipath-dccp.org" format="default" sectionFormat="of" derivedContent="multipath-dccp.org"/>, <xref target="IETF115.Slides" format="default" sectionFormat="of" derivedContent="IETF115.Slides"/>, and <xref target="MP-DCCP.Paper" format="default" sectionFormat="of" derivedContent="MP-DCCP.Paper"/>.
All these use cases profit from an Open Source Linux reference implementation provided under <xref target="multipath-dccp.org" format="default" sectionFormat="of" derivedContent="multipath-dccp.org"/>.</t>
      <t indent="0" pn="section-abstract-2">This document specifies a set of extensions to
DCCP to support multipath operations.  Multipath DCCP provides 
the ability to simultaneously use multiple
paths between peers.  The protocol offers
the same type of service to applications as DCCP and it provides the
components necessary to establish and use multiple DCCP flows across
different paths simultaneously.</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 27 January 2024.
        </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) 2023 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 Revised BSD License text as described in
            Section 4.e of the Trust Legal Provisions and are provided without
            warranty as described in the Revised BSD License.
        </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>
                  <li pn="section-toc.1-1.3.2.2.2.12">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.12.1"><xref derivedContent="3.2.12" format="counter" sectionFormat="of" target="section-3.2.12"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-experimental-mp-dccp-sub-op">Experimental MP-DCCP Sub-Option MP_EXP for private use</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-address-knowledge-exchange">Address knowledge exchange</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2.4.2">
                  <li pn="section-toc.1-1.3.2.4.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.4.2.1.1"><xref derivedContent="3.4.1" format="counter" sectionFormat="of" target="section-3.4.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-advertising-a-new-path-mp_a">Advertising a new path (MP_ADDADDR)</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.4.2.2">
                    <t indent="0" pn="section-toc.1-1.3.2.4.2.2.1"><xref derivedContent="3.4.2" format="counter" sectionFormat="of" target="section-3.4.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-removing-a-path-mp_removead">Removing a path (MP_REMOVEADDR)</xref></t>
                  </li>
                </ul>
              </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-close-a-mp-dccp-connection">Close a MP-DCCP connection</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-fallback">Fallback</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-congestion-control-consider">Congestion Control Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.8">
                <t indent="0" pn="section-toc.1-1.3.2.8.1"><xref derivedContent="3.8" format="counter" sectionFormat="of" target="section-3.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-maximum-packet-size-conside">Maximum Packet Size Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.9">
                <t indent="0" pn="section-toc.1-1.3.2.9.1"><xref derivedContent="3.9" format="counter" sectionFormat="of" target="section-3.9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-path-usage-strategies">Path usage strategies</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2.9.2">
                  <li pn="section-toc.1-1.3.2.9.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.9.2.1.1"><xref derivedContent="3.9.1" format="counter" sectionFormat="of" target="section-3.9.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-path-mobility">Path mobility</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.9.2.2">
                    <t indent="0" pn="section-toc.1-1.3.2.9.2.2.1"><xref derivedContent="3.9.2" format="counter" sectionFormat="of" target="section-3.9.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-concurrent-path-usage">Concurrent path usage</xref></t>
                  </li>
                </ul>
              </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-references">References</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.9.2">
              <li pn="section-toc.1-1.9.2.1">
                <t indent="0" pn="section-toc.1-1.9.2.1.1"><xref derivedContent="9.1" format="counter" sectionFormat="of" target="section-9.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-normative-references">Normative References</xref></t>
              </li>
              <li pn="section-toc.1-1.9.2.2">
                <t indent="0" pn="section-toc.1-1.9.2.2.1"><xref derivedContent="9.2" format="counter" sectionFormat="of" target="section-9.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
              </li>
            </ul>
          </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" removeInRFC="false" toc="include" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">Datagram Congestion Control Protocol (DCCP) <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> is a
transport protocol that provides bidirectional unicast connections of
congestion-controlled unreliable datagrams. DCCP communications are restricted to one single path. 
Multipath DCCP (MP-DCCP) is a set of extensions to DCCP to
enable DCCP flows to be established across multiple paths
simultaneously. Such extensions are beneficial to applications that transfer
large amounts of data, due to the possibility to aggregate capacity of the
multiple paths. In addition, the multipath extensions enable to tradeoff timeliness and reliability,
which is important for low-latency applications that do not require
guaranteed delivery services, such as Audio/Video streaming.</t>
      <t indent="0" pn="section-1-2">MP-DCCP has been first suggested
in the context of the 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"/>.
MP-DCCP can be applied for load-balancing, seamless session handover, and bandwidth
aggregation purposes (referred to as Access Traffic Steering, Switching, and Splitting (ATSSS)
in the 3GPP terminology <xref target="TS23.501" format="default" sectionFormat="of" derivedContent="TS23.501"/>).</t>
      <t indent="0" pn="section-1-3">This document presents the protocol changes required to add multipath
support to DCCP; specifically, those for signaling and setting up
multiple paths (a.k.a, "subflows"), managing these subflows, reordering of
data, and termination of sessions.</t>
      <t indent="0" pn="section-1-4">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-5">In the following, the term subflow refers to DCCP subflows transmitted
via different paths (4-tuple of source and destination address/port
pairs), not to be mixed up with the "application sub-flows" mentioned in
Section 17.2 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>.
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 the 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 (Section 2.4 of <xref target="RFC5595" format="default" sectionFormat="of" derivedContent="RFC5595"/>).
Application subflows can co-exist with MP-DCCP operation as defined in this document.</t>
      <t indent="0" pn="section-1-6">As pointed out in <xref target="I-D.amend-tsvwg-multipath-framework-mpdccp" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-multipath-framework-mpdccp"/> the proposed encapsulation in terms of 
lightweight DCCP flow headers is more appropriate for unreliable 
IP traffic in terms of UDP and other non-TCP packets in comparison to MPTCP.
Such considerations are not detailed in the present specification.</t>
      <section anchor="mpdccp_network_stack" numbered="true" removeInRFC="false" toc="include" 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 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 align="left" 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" removeInRFC="false" toc="include" 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.</t>
        <t indent="0" pn="section-1.2-7">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" removeInRFC="false" toc="include" 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 in 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 align="left" 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 MP-DCCP 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 
two 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. It should be noted that MP-DCCP does not require the presence of 
more than one address in both peers.</li>
          <li pn="section-1.3-3.2">In case extra paths and corresponding addresses/ports 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/ports at hosts.  Combinations of these multiple addresses/ports
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 subflow 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 including the logic and details of the procedures for adding/removing subflows;
this document describes supportive measures by which a host can initiate new subflows and signal available addresses 
between peers. The definition of a path management method is, however, out of scope of this document and subject to a 
corresponding policy and the specifics of the implementation. In the same context, if any of the MP-DCCP peer hosts has a limit on the maximum number of paths that can be maintained (e.g., similar to what is discussed in Section 3.4 of <xref target="RFC8041" format="default" sectionFormat="of" derivedContent="RFC8041"/>, the creation of new subflows from that peer host should be avoided and incoming subflow requests should be terminated.</li>
          <li pn="section-1.3-3.5">MP-DCCP adds connection-level sequence numbers and exchange of
Round-Trip Time (RTT) information to enable optional reordering features.</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" removeInRFC="false" toc="include" 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", "NOT RECOMMENDED", "MAY", and
   "OPTIONAL" in this document are to be interpreted as described in
   BCP 14 <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/> <xref target="RFC8174" format="default" sectionFormat="of" derivedContent="RFC8174"/> when, and only when, they appear in all
   capitals, as shown here.</t>
      </section>
    </section>
    <section anchor="op_overview" numbered="true" removeInRFC="false" toc="include" pn="section-2">
      <name slugifiedName="name-operation-overview">Operation Overview</name>
      <t indent="0" pn="section-2-1">DCCP (Section 17.2 of <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 managing multiple subflows within one DCCP connection.
Various congestion control mechanisms have been specified to optimize
DCCP performance for specific traffic types in terms of profiles denoted
by a Congestion Control IDentifier (CCID).</t>
      <t indent="0" pn="section-2-2">The 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 of the MP-DCCP operation, 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 originally transmitted order to the 
recipient application. This may be necessary because DCCP does not guarantee in-order delivery.
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 this document.</t>
      <t indent="0" pn="section-2-4">The following sections define MP-DCCP behavior in detail.</t>
      <t indent="0" pn="section-2-5">A Multipath DCCP connection provides a bidirectional connection of datagrams 
between two hosts exchanging data as in DCCP, 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 an 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 the exchange of performance 
parameters.</t>
      <t indent="0" pn="section-2-6">The Multipath Capability for MP-DCCP can be negotiated with a new DCCP 
feature, as specified in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>. Once 
negotiated, all subsequent MP-DCCP operations for that connection are signalled with a 
variable length multipath-related option, as described in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.
All MP-DCCP operations are signaled with MP-DCCP suboptions described in {#MP_OPT}.</t>
      <t indent="0" pn="section-2-7">The number of DCCP subflows can vary during the 
lifetime of a Multipath DCCP connection. The details of the path management decisions for
when to add or remove subflows are outside the scope of this document.</t>
    </section>
    <section anchor="protocol" numbered="true" removeInRFC="false" toc="include" 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) are
enriched with a new Multipath related feature with Feature number THIS-FEATURE, 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-multipath-feature">Multipath Feature</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">THIS-FEATURE</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>
        </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, and it is safe to respond to Change options for the feature
with empty Confirm options.</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) are enriched with 
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-multipath-option-set">Multipath 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">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>
        </tbody>
      </table>
      <section anchor="mp_capable" numbered="true" removeInRFC="false" toc="include" pn="section-3.1">
        <name slugifiedName="name-multipath-capable-feature">Multipath Capable Feature</name>
        <t indent="0" pn="section-3.1-1">DCCP endpoints negotiates the Multipath Capable Feature to decide whether multipath extensions can be enabled for a DCCP connection.</t>
        <t indent="0" pn="section-3.1-2">Multipath Capable feature (MP_CAPABLE) has feature number THIS-FEATURE and has length of one-byte.
The leftmost four bits are used to specify a compatible version of the
MP-DCCP implementation (THIS-VER for this specification). The following four bits are unassigned in version THIS-VER. The unassigned bits MUST be set to zero by the sender and MUST be ignored by the receiver.</t>
        <figure anchor="ref-mp-capable-format" align="left" suppress-title="false" pn="figure-3">
          <name slugifiedName="name-format-of-the-multipath-cap">Format of the Multipath Capable feature</name>
          <artwork align="left" pn="section-3.1-3.1"><![CDATA[
    0  1  2  3   4  5  6  7
   +-----------+------------+
   | THIS-VER  | Unassigned |
   +-----------+------------+
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.1-4">The setting of the MP_CAPABLE feature MUST follow 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 MP_CAPABLE feature is allowed on the same MP-DCCP connection.</t>
        <t indent="0" pn="section-3.1-6">Clients MUST include a Change R option during the initial handshake request to
supply a list of supported MP-DCCP protocol versions, ordered by preference.</t>
        <t indent="0" pn="section-3.1-7">Servers MUST include a Confirm L option in the subsequent response to agree on
an MP-DCCP version to be used from the Client list, followed by its own
supported version(s) ordered by preference. Any subflow addition to an existing MP-DCCP connection MUST use the same
version negotiated for the first subflow.</t>
        <t indent="0" pn="section-3.1-8">If no agreement is found, the Server MUST reply with an empty Confirm L option
with feature number THIS-FEATURE and no values.</t>
        <t indent="0" pn="section-3.1-9">An example of successful version negotiation is shown hereafter:</t>
        <figure anchor="ref-mp-capable-example" align="left" suppress-title="false" pn="figure-4">
          <name slugifiedName="name-example-of-mp-dccp-support-">Example of MP-DCCP support negotiation using MP_CAPABLE</name>
          <artwork align="left" pn="section-3.1-10.1"><![CDATA[
      Client                                             Server
      ------                                             ------
      DCCP-Req + Change R(MP_CAPABLE, 1 0)
                     ----------------------------------->

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

                 * agreement on version = 1 *
]]></artwork>
        </figure>
        <ol spacing="normal" type="1" indent="adaptive" start="1" pn="section-3.1-11"><li pn="section-3.1-11.1" derivedCounter="1.">The Client indicates support for both MP-DCCP versions 1 and 0, with a preference
for version 1.</li>
          <li pn="section-3.1-11.2" derivedCounter="2.">Server agrees on using MP-DCCP version 1, and supplies its own preference list.</li>
          <li pn="section-3.1-11.3" derivedCounter="3.">MP-DCCP is then enabled between the Client and Server with version 1.</li>
        </ol>
        <t indent="0" pn="section-3.1-12">If the version negotiation fails or the MP_CAPABLE feature is not present in the DCCP-Request or DCCP-Response packets of the initial handshake procedure, the MP-DCCP connection SHOULD fallback to regular DCCP or MUST be closed. Further details are specified in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/></t>
      </section>
      <section anchor="MP_OPT" numbered="true" removeInRFC="false" toc="include" pn="section-3.2">
        <name slugifiedName="name-multipath-option">Multipath Option</name>
        <t indent="0" pn="section-3.2-1">MP-DCCP uses one single option to signal various multipath-related operations. The format of this option is shown in <xref target="ref-mp-option-format" format="default" sectionFormat="of" derivedContent="Figure 5"/>.</t>
        <figure anchor="ref-mp-option-format" align="left" suppress-title="false" pn="figure-5">
          <name slugifiedName="name-multipath-option-format">Multipath Option Format</name>
          <artwork align="left" pn="section-3.2-2.1"><![CDATA[
            1          2          3         
 01234567 89012345 67890123 45678901 23456789
+--------+--------+--------+--------+--------+
|00101110| Length | MP_OPT | Value(s) ...
+--------+--------+--------+--------+--------+
 Type=46
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.2-3">The description of the fields of the multipath option is shown in <xref target="ref-mp-option-list" format="default" sectionFormat="of" derivedContent="Table 3"/>. MP_OPT refers to an MP-DCCP suboption.</t>
        <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">var</td>
              <td align="left" colspan="1" rowspan="1">2 =MP_FAST_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close an 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">9</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">var</td>
              <td align="left" colspan="1" rowspan="1">10 =MP_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close an MP-DCCP subflow</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">TBD</td>
              <td align="left" colspan="1" rowspan="1">&gt;10</td>
              <td align="left" colspan="1" rowspan="1">Reserved for future MP suboptions defined in Version &gt; 0 or extension</td>
            </tr>
          </tbody>
        </table>
        <t indent="0" pn="section-3.2-5">These operations are largely inspired by the signals defined in <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>.</t>
        <section anchor="MP_CONFIRM" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.1">
          <name slugifiedName="name-mp_confirm">MP_CONFIRM</name>
          <figure anchor="ref-mp-confirm-format" align="left" suppress-title="false" pn="figure-6">
            <name slugifiedName="name-format-of-the-mp_confirm-su">Format of the MP_CONFIRM suboption</name>
            <artwork align="left" pn="section-3.2.1-1.1"><![CDATA[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|  var   |00000000| List of confirmations ...
  +--------+--------+--------+--------+--------+--------+--------+
   Type=46   Length  MP_OPT=0
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.1-2">Some multipath options require confirmation from the remote peer (see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>). Such options will be retransmitted by the sender 
until a MP_CONFIRM is received or confirmation of options is identified outdated. The further processing of the multipath options in the
receiving host is not the subject of MP_CONFIRM.</t>
          <t indent="0" pn="section-3.2.1-3">As multipath suboptions could arrive out-of-order, suboptions defined in <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>
MUST be sent in a DCCP datagram with MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>. This allows suboptions to be identified with obsolete datasets that would otherwise conflict with newer datasets. In case of MP_ADDADDR or MP_REMOVEADDR the same dataset is identified based on AddressID, whereas the same dataset for MP_PRIO is identified by the subflow in use. An outdated
suboption is detected at the receiver if a previous suboption referring to the same dataset contained a higher sequence number
carried by MP_SEQ. AN MP_CONFIRM MAY be generated for suboptions that are identified outdated.</t>
          <t indent="0" pn="section-3.2.1-4">Similarly an MP_CONFIRM could arrive out of order. To ensure that the most recent suboption is confirmed the associated
MP_SEQ received MUST be echoed. Otherwise inconsistencies could occur, e.g. if three MP_PRIO options are sent one after
the other on one path in order to first set the path priority to 0, then to 1 and finally to 0 again. Without an associated
MP_SEQ, a loss of the third MP_PRIO option and a loss of the MP_CONFIRM of the second update and the third update would
cause the sender to incorrectly believe that the priority value is set to 0 without recognizing that the receiver has applied
priority value 1.</t>
          <t indent="0" pn="section-3.2.1-5">The length of the MP_CONFIRM option and the path over which the option is sent depend on the confirmed suboptions and the received
MP_SEQ, which is both copied verbatim and appended as a list of confirmations. The list structures by first listing the received
MP_SEQ followed by the confirmed suboption or suboptions. The same rules apply when suboptions with different MP_SEQs are confirmed at
once. This might happen if a datagram with MP_PRIO and a first MP_SEQ_1 and another datagram with MP_ADDADDR and a second MP_SEQ_2 are
received in short succession. In this case, the structure described above is concatenated resulting in  MP_SEQ_1 + MP_PRIO + MP_SEQ_2 + MP_ADDADDR.</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">4</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>
          <t indent="0" pn="section-3.2.1-7">An example to illustrate the MP-DCCP confirm procedure for the MP_PRIO option is shown in <xref target="ref-mp-dccp-confirm-good" format="default" sectionFormat="of" derivedContent="Figure 7"/>. The host A sends a 
DCCP-Request on path A2-B2 with an MP_PRIO option with value 1 and associated sequence number of 1. Host B replies on the same path in 
this instance (but could be any path) with a DCCP-Response containing the MP_CONFIRM option and a list containing the original sequence number (1)
together with the associated option (MP_PRIO)</t>
          <figure anchor="ref-mp-dccp-confirm-good" align="left" suppress-title="false" pn="figure-7">
            <name slugifiedName="name-example-mp-dccp-confirm-pro">Example MP-DCCP CONFIRM procedure</name>
            <artwork align="left" pn="section-3.2.1-8.1"><![CDATA[
          Host A                                     Host B 
------------------------                     ------------------------
Address A1    Address A2                     Address B1    Address B2
----------    ----------                     ----------    ----------
     |             |                                   |       |
     |             | DCCP-Request(seqno 1) + MP_PRIO(1)|       |
     |             |------------------------------------------>|
     |             |                                   |       |
     |             | DCCP-Response +                   |       |
     |             |<---- MP_CONFIRM(seqno 1, MP_PRIO) --------|
     |             |                                   |       |
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.1-9">A second example to illustrate the same MP-DCCP confirm procedure but where an out of date option is also delivered is shown in (<xref target="ref-mp-dccp-confirm-outdated" format="default" sectionFormat="of" derivedContent="Figure 8"/>.
Here, a first DCCP-Data is sent from Host A to Host B with option MP_PRIO set to 4. Host A subsequently issues a second DCCP-Data with option MP_PRIO
set to 1. The delivery of the first MP_PRIO is delayed in the network between Host A and Host B and arrives after the second MP_PRIO. Host B
ignores this second MP_PRIO as the associated sequence number is earlier than the first. Host B sends a DCCP-Ack confirming receipt of the MP_PRIO(1) with sequence number 2.</t>
          <figure anchor="ref-mp-dccp-confirm-outdated" align="left" suppress-title="false" pn="figure-8">
            <name slugifiedName="name-example-mp-dccp-confirm-proc">Example MP-DCCP CONFIRM procedure with outdated suboption</name>
            <artwork align="left" pn="section-3.2.1-10.1"><![CDATA[
          Host A                                     Host B 
------------------------                     ------------------------
Address A1    Address A2                     Address B1    Address B2
----------    ----------                     ----------    ----------
     |             |                                   |       |
     |             | DCCP-Data(seqno 1) +  MP_PRIO(4)  |       |
     |             |------------                       |       |
     |             |            \                      |       |
     |             | DCCP-Data(seqno 2) +  MP_PRIO(1)  |       |
     |             |--------------\--------------------------->|
     |             |               \                   |       |
     |             |                -------------------------->|
     |             |                                   |       |
     |             | DCCP-Ack +                        |       |
     |             |<---- MP_CONFIRM(seqno 2, MP_PRIO) --------|
     |             |                                   |       |
]]></artwork>
          </figure>
        </section>
        <section anchor="MP_JOIN" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.2">
          <name slugifiedName="name-mp_join">MP_JOIN</name>
          <figure anchor="ref-MP_JOIN" align="left" suppress-title="false" pn="figure-9">
            <name slugifiedName="name-format-of-the-mp_join-subop">Format of the MP_JOIN Suboption</name>
            <artwork align="left" pn="section-3.2.2-1.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>
          </figure>
          <t indent="0" pn="section-3.2.2-2">The MP_JOIN option is used by a host to add a new subflow to an existing MP-DCCP
connection and REQUIRES a successful establishment of the first subflow using MP_KEY.
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
<xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/> for details).</t>
          <t indent="0" pn="section-3.2.2-3">The MP_JOIN option includes an "Addr ID" (Address ID) 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 MUST 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>
          <t indent="0" pn="section-3.2.2-6">If the path token can not be verified by the receiving host during a handshake negotiation, 
the new subflow MUST be closed, as specified in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/>.</t>
        </section>
        <section anchor="MP_FAST_CLOSE" numbered="true" removeInRFC="false" toc="include" 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 signals to abruptly close a
connection.  With MP-DCCP, a regular Close or Reset only has the scope of the
subflow over which the signal was received. As such, it will only close the applicable subflow and will not
affect the remaining subflows in use on other paths.  An MP-DCCP 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 suboption.</t>
          <figure anchor="ref-MP_FAST_CLOSE" align="left" suppress-title="false" pn="figure-10">
            <name slugifiedName="name-format-of-the-mp_fast_close">Format of the MP_FAST_CLOSE Suboption</name>
            <artwork align="left" pn="section-3.2.3-2.1"><![CDATA[
              1          2          3
   01234567 89012345 67890123 45678901 23456789
  +--------+--------+--------+--------+--------+
  |00101110|  var   |00000010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46   Length  MP_OPT=2
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.3-3">For being effective, the MP_FAST_CLOSE suboption MUST be sent from an initiating host on all subflows as part of a DCCP-Reset packet with Reset Code THIS-RESET-CODE. To protect unauthorized shutdown of a multipath DCCP connection, the selected Key Data of the peer host during the handshaking procedure is carried by the MP_FAST_CLOSE option.</t>
          <t indent="0" pn="section-3.2.3-4">With completion of this step, the initiating host can tear down the subflows and the multipath DCCP connection immediately terminates.</t>
          <t indent="0" pn="section-3.2.3-5">Upon reception of the MP_FAST_CLOSE and successful validation of the Key Data at the peer host, a DCCP Reset packet is replied on all subflows to the initiating host with Reset Code THIS-RESET-CODE. The peer host can now close the whole MP-DCCP connection (i.e., it transitions the connection state directly to CLOSED).</t>
        </section>
        <section anchor="MP_KEY" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.4">
          <name slugifiedName="name-mp_key">MP_KEY</name>
          <figure anchor="ref-MP_KEY" align="left" suppress-title="false" pn="figure-11">
            <name slugifiedName="name-format-of-the-mp_key-subopt">Format of the MP_KEY Suboption</name>
            <artwork align="left" pn="section-3.2.4-1.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|      var      |0 0 0 0 0 0 1 1| Key Type (1)  | 
  +---------------+---------------+---------------+---------------+
  |  Key Data (1) |  Key Type (2) |  Key Data (2) | ....
  +---------------+---------------+---------------+---------------+
      Type=46          Length         MP_OPT=3
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.4-2">The MP_KEY suboption is used to exchange key material between
hosts for a given connection. 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">Unassigned</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>
          <t indent="0" pn="section-3.2.4-8">If the key type can not be agreed when the MP_KEY option is sent as part of the 
handshake procedure, the MP-DCCP connection MUST fallback to regular DCCP as 
indicated in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/></t>
        </section>
        <section anchor="MP_SEQ" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.5">
          <name slugifiedName="name-mp_seq">MP_SEQ</name>
          <figure anchor="ref-MP_SEQ" align="left" suppress-title="false" pn="figure-12">
            <name slugifiedName="name-format-of-the-mp_seq-subopt">Format of the MP_SEQ Suboption</name>
            <artwork align="left" pn="section-3.2.5-1.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>
          </figure>
          <t indent="0" pn="section-3.2.5-2">The MP_SEQ suboption 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 <xref target="RFC4086" format="default" sectionFormat="of" derivedContent="RFC4086"/>.</t>
          <t indent="0" pn="section-3.2.5-3">The MP_SEQ number space is
different from the path individual sequence number space and MUST be
sent with all DCCP-Data and DCCP-DataACK packet.</t>
        </section>
        <section anchor="MP_HMAC" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.6">
          <name slugifiedName="name-mp_hmac">MP_HMAC</name>
          <figure anchor="ref-MP_HMAC" align="left" suppress-title="false" pn="figure-13">
            <name slugifiedName="name-format-of-the-mp_hmac-subop">Format of the MP_HMAC Suboption</name>
            <artwork align="left" pn="section-3.2.6-1.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>
          </figure>
          <t indent="0" pn="section-3.2.6-2">The MP_HMAC suboption is used to provide authentication for the MP_JOIN,
MP_ADDADDR, and MP_REMOVEADDR suboptions. 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>
          <t indent="0" pn="section-3.2.6-5">MP_JOIN, MP_ADDADDR and MP_REMOVEADDR can co-exist or be used multiple times
within a single DCCP packet. All these multipath options include an individual
MP_HASH option. This ensures the MP_HASH is correctly associated.
Otherwise, the receiver cannot validate multiple MP_JOIN, MP_ADDADDR or
MP_REMOVEADDR. Therefore, a MP_HASH MUST directly follow its associated multipath
option. In the likely case of sending a MP_JOIN together with a MP_ADDADDR, this
results in concatenating MP_JOIN + MP_HMAC_1 + MP_ADDADDR + MP_HMAC_2, whereas the
first MP_HMAC_1 is associated with the MP_JOIN and the second MP_HMAC_2 with the
MP_ADDADDR suboption.</t>
          <t indent="0" pn="section-3.2.6-6">If the HMAC can not be validated by a receiving host, the subsequent handling depends
on which suboption was being authenticated. If the suboption to be authenticated was either
MP_ADDADDR or MP_REMOVEADDR, the receiving host MUST silently ignore it (see <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/> and <xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>). 
If the suboption to be authenticated was MP_JOIN, the subflow MUST be closed (see <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/>)</t>
        </section>
        <section anchor="MP_RTT" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.7">
          <name slugifiedName="name-mp_rtt">MP_RTT</name>
          <figure anchor="ref-MP_RTT" align="left" suppress-title="false" pn="figure-14">
            <name slugifiedName="name-format-of-the-mp_rtt-subopt">Format of the MP_RTT Suboption</name>
            <artwork align="left" pn="section-3.2.7-1.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>
          </figure>
          <t indent="0" pn="section-3.2.7-2">The MP_RTT suboption 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.
This information is in particular useful for the receiving host to
calculate the RTT difference between the subflows and to estimate whether
missing data has been lost.</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>
          <t indent="0" pn="section-3.2.7-9">In <xref target="ref-MP_RTT_example" format="default" sectionFormat="of" derivedContent="Figure 15"/> an exemplary flow shows the exchange of path individual 
RTT information with RTT1 pointing to a first path and RTT2 to a second path. Those
RTT values might be extracted from the sender's Congestion Control procedure and
carried to the receiving host using MP_RTT suboption. With the reception of RTT1
and RTT2, the receiver is able to calculate the path_delta which corresponds to
the absolute difference of both values.
In the case that the path individual RTTs are symmetric in down- and uplink direction, packets
with missing sequence number MP_SEQ, e.g., in a reordering process, can be assumed
lost after path_delta/2.</t>
          <figure anchor="ref-MP_RTT_example" align="left" suppress-title="false" pn="figure-15">
            <name slugifiedName="name-exemplary-flow-of-mp_rtt-ex">Exemplary flow of MP_RTT exchange and usage</name>
            <artwork align="left" pn="section-3.2.7-10.1"><![CDATA[
   MP-DCCP                   MP-DCCP
   Sender                    Receiver
   +--------+  MP_RTT(RTT1)  +-------------+
   |   RTT1 |----------------|             |
   |        |                | path_delta= |
   |        |  MP_RTT(RTT2)  | |RTT1-RTT2| |
   |   RTT2 |----------------|             |
   +--------+                +-------------+
]]></artwork>
          </figure>
        </section>
        <section anchor="MP_ADDADDR" numbered="true" removeInRFC="false" toc="include" 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 suboption announces additional addresses (and, optionally,
port numbers) 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 suboption within a packet advertise simultaneously
new addresses.</t>
          <t indent="0" pn="section-3.2.8-2">Length is variable depending on the address family (IPv4 or IPv6) and whether a port number is
used. This field 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 could be cases (such as port-based load balancing) where
the explicit specification of a different port is required.  If no
port is specified, the receiving peer MUST assume that any attempt to
connect to the specified address uses the port already used 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>
          <t indent="0" pn="section-3.2.8-5">The presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_ADDADDR is sent, as described in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
          <figure anchor="ref-MP_ADDADDR" align="left" suppress-title="false" pn="figure-16">
            <name slugifiedName="name-format-of-the-mp_addaddr-su">Format of the MP_ADDADDR Suboption</name>
            <artwork align="left" pn="section-3.2.8-6.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|      var      |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         MP_OPT=7
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.8-7">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-8">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, 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 the sender MAY choose to refresh advertisements periodically.</t>
          <t indent="0" pn="section-3.2.8-9">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. A host
MAY advertise a private 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 MUST 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"/>.
If a sending host of an MP_ADDADDR knows that no incoming subflows can
be established at a particular address, an MP_ADDADDR SHOULD NOT
announce that address unless the sending host has new knowledge about
the possibility to do so. Such ability information can be obtained from local
firewall or routing settings, knowledge about availability of external
NAT or firewall, or from connectivity checks performed by the
host/application.</t>
          <t indent="0" pn="section-3.2.8-10">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-11">A host MAY 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-12">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" removeInRFC="false" toc="include" 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 an 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) suboption 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 suboption 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 presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_REMOVEADDR is sent. Further details are given in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
          <t indent="0" pn="section-3.2.9-5">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. To avoid inconsistent states, it is recommended to
release the sender address ID only after MP_REMOVEADDR has been confirmed.</t>
          <t indent="0" pn="section-3.2.9-6">The sending and receipt of this message SHOULD trigger the closing procedure
described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> between 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-7">Address removal is done by Address ID to allow the use of NATs and other
middleboxes that rewrite source addresses.  If there is no address
at the requested Address ID, the receiver will silently ignore the request.</t>
          <figure anchor="refMP_REMOVEADDR" align="left" suppress-title="false" pn="figure-17">
            <name slugifiedName="name-format-of-the-mp_removeaddr">Format of the MP_REMOVEADDR Suboption</name>
            <artwork align="left" pn="section-3.2.9-8.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|0 0 0 0 0 1 0 0|0 0 0 0 1 0 0 0|   Address ID  |
+---------------+---------------+---------------+---------------+
     Type=46        Length=4         MP_OPT=8

-> followed by MP_HMAC option
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.9-9">A subflow that is still functioning MUST be closed with a DCCP-Close
exchange as in regular DCCP, rather than using this option. For more
information, see <xref target="closing" format="default" sectionFormat="of" derivedContent="Section 3.5"/>.</t>
        </section>
        <section anchor="MP_PRIO" numbered="true" removeInRFC="false" toc="include" 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 payload 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
could change, 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 
payload traffic.</t>
          <t indent="0" pn="section-3.2.10-2">The MP_PRIO suboption, shown below, can be used to set a priority flag
for the path over which the suboption is received.</t>
          <figure anchor="ref-MP_PRIO" align="left" suppress-title="false" pn="figure-18">
            <name slugifiedName="name-format-of-the-mp_prio-subop">Format of the MP_PRIO Suboption</name>
            <artwork align="left" pn="section-3.2.10-3.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|0 0 0 0 0 1 0 0|0 0 0 0 1 0 0 1|(resvd)| prio |
   +---------------+---------------+---------------+--------------+
       Type=46         Length=4        MP_OPT=9
]]></artwork>
          </figure>
          <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: The path can 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 traffic first 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,
   both paths can be used when making packet scheduling decisions.</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. It is RECOMMENDED to update at least one path to a non-zero MP_PRIO
value when an MP-DCCP connection enters a state where all paths remain with an
MP_PRIO value of zero. This helps an MP-DCCP connection to continue to be used 
scheduling in case the multipath scheduler strictly respects MP_PRIO value 0.
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>
          <t indent="0" pn="section-3.2.10-8">The presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_PRIO is sent. Further details are given in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
        </section>
        <section anchor="MP_CLOSE" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.11">
          <name slugifiedName="name-mp_close">MP_CLOSE</name>
          <figure anchor="ref-MP_CLOSE" align="left" suppress-title="false" pn="figure-19">
            <name slugifiedName="name-format-of-the-mp_close-subo">Format of the MP_CLOSE Suboption</name>
            <artwork align="left" pn="section-3.2.11-1.1"><![CDATA[
              1          2          3           
   01234567 89012345 67890123 45678901 23456789 
  +--------+--------+--------+--------+--------+
  |00101110|  var   |00001010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46   Length  MP_OPT=10
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.11-2">An MP-DCCP connection can be gracefully closed by sending and MP_CLOSE to the 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 to avoid keeping a state in the sender of the DCCP-CloseReq. 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 anchor="MP_EXP" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.12">
          <name slugifiedName="name-experimental-mp-dccp-sub-op">Experimental MP-DCCP Sub-Option MP_EXP for private use</name>
          <t indent="0" pn="section-3.2.12-1">This section reserves a MP-DCCP sub-option to define and specify any experimental additional feature for improving and optimization of MP-DCCP protocol. This
option may be applicable to specific environments or scenarios according to potential new requirements and meant for private use only. MP_OPT 
feature number 11 is specified with an exemplary description as below:</t>
          <figure anchor="ref-MP_EXP" align="left" suppress-title="false" pn="figure-20">
            <name slugifiedName="name-format-of-the-mp_exp-subopt">Format of the MP_EXP Suboption</name>
            <artwork align="left" pn="section-3.2.12-2.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|      var      |0 0 0 0 1 0 1 1|   Data TBD    |
+---------------+---------------+---------------+---------------+
|   ...                                                         
+---------------------------------------------------------------+
     Type=46         Length         MP_OPT=11
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.12-3">The Data field can carry any data according to the foreseen use by the experimenters with a maximum length of 252 Bytes.</t>
        </section>
      </section>
      <section anchor="handshaking" numbered="true" removeInRFC="false" toc="include" pn="section-3.3">
        <name slugifiedName="name-mp-dccp-handshaking-procedu">MP-DCCP Handshaking Procedure</name>
        <t indent="0" pn="section-3.3-1">An example to illustrate the MP-DCCP handshake procedure is shown in <xref target="ref-mp-dccp-handshaking" format="default" sectionFormat="of" derivedContent="Figure 21"/>.</t>
        <figure anchor="ref-mp-dccp-handshaking" align="left" suppress-title="false" pn="figure-21">
          <name slugifiedName="name-example-mp-dccp-handshake">Example MP-DCCP Handshake</name>
          <artwork align="left" pn="section-3.3-2.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-3">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-4">
          <li pn="section-3.3-4.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-4.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 is chosen from the list of supported types
from the previous request.</li>
          <li pn="section-3.3-4.3">Host A sends a DCCP-Ack with both Keys echoed to Host B.</li>
          <li pn="section-3.3-4.4">Host B sends a DCCP-Ack to confirm both keys and conclude the handshaking.</li>
        </ul>
        <t indent="0" pn="section-3.3-5">Host A waits for the final DCCP-Ack from host B before starting any
establishment of additional subflow connections.</t>
        <t indent="0" pn="section-3.3-6">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-7">
          <li pn="section-3.3-7.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-7.2">
            <t indent="0" pn="section-3.3-7.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 the nonce received with MP_JOIN(A) and the
local nonce RB 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-7.2.2">
MP_HMAC(B) = HMAC-SHA256(Key=d-key(B), Msg=RB+RA)</t>
          </li>
          <li pn="section-3.3-7.3">
            <t indent="0" pn="section-3.3-7.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 the local nonce RA and the 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-7.3.2">
MP_HMAC(A) = HMAC-SHA256(Key=d-key(A), Msg=RA+RB)</t>
          </li>
          <li pn="section-3.3-7.4">Host B sends a DCCP-Ack to confirm the HMAC and to conclude the
handshaking.</li>
        </ul>
      </section>
      <section anchor="address-knowledge-exchange" numbered="true" removeInRFC="false" toc="include" pn="section-3.4">
        <name slugifiedName="name-address-knowledge-exchange">Address knowledge exchange</name>
        <section anchor="advertising-a-new-path-mpaddaddr" numbered="true" removeInRFC="false" toc="include" pn="section-3.4.1">
          <name slugifiedName="name-advertising-a-new-path-mp_a">Advertising a new path (MP_ADDADDR)</name>
          <t indent="0" pn="section-3.4.1-1">When a host (Host A) wants to advertise the availability of a new path, it should use the MP_ADDADDR option (<xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>) as
shown in the example in <xref target="ref-mp-dccp-add-address" format="default" sectionFormat="of" derivedContent="Figure 22"/>. The MP_ADDADDR option passed in the DCCP-Data contains the following parameters:
* an identifier (id 2) for the new IP address which is used as a reference in subsequent control exchanges.
* the IP address of the new path (A2_IP)
* A pair of octets specifying the port number associated with this IP address. The value of 00 here, indicates that the port number is the same
  as that used for the initial subflow address A1_IP</t>
          <t indent="0" pn="section-3.4.1-2">The following options MUST be included in a packet carrying MP_ADDADDR:
* the leftmost 20 bytes of the HMAC(A) generated during the initial handshaking procedure described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/> and <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>
* the MP_SEQ option with the sequence number (seqno 12) for this message according to <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>.</t>
          <t indent="0" pn="section-3.4.1-3">Host B acknowledges receipt of the MP_ADDADDR message with a DCCP-Ack containing the MP_CONFIRM option. The parameters supplied in this
response are as follows:
* an MP_CONFIRM containing the MP_SEQ number (seqno 12) of the packet carrying the option that we are confirming together with the MP_ADDADDR option
* the leftmost 20 bytes of the HMAC(B) generated during the initial handshaking procedure <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
          <figure anchor="ref-mp-dccp-add-address" align="left" suppress-title="false" pn="figure-22">
            <name slugifiedName="name-example-mp-dccp-addaddr-pro">Example MP-DCCP ADDADDR procedure</name>
            <artwork align="left" pn="section-3.4.1-4.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_ADDADDR(id 2, A2_IP, 00) +        |
     |------- MP_HMAC(A) + MP_SEQ(seqno 12) -------------->|
     |             |                                       |      
     |   DCCP-Ack + MP_HMAC(B) +                           |
     |<----- MP_CONFIRM(seqno 12, MP_ADDADDR) -------------|
]]></artwork>
          </figure>
        </section>
        <section anchor="removing-a-path-mpremoveaddr" numbered="true" removeInRFC="false" toc="include" pn="section-3.4.2">
          <name slugifiedName="name-removing-a-path-mp_removead">Removing a path (MP_REMOVEADDR)</name>
          <t indent="0" pn="section-3.4.2-1">When a host (Host A) wants to indicate that a path is no longer available, it should use the MP_REMOVEADDR option (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>) as
shown in the example in <xref target="ref-mp-dccp-remove-address" format="default" sectionFormat="of" derivedContent="Figure 23"/>. The MP_REMOVEADDR option passed in the DCCP-Data contains the following parameters:
* an identifier (id 2) for the IP address to remove (A2_IP) and which was specified in a previous MP_ADDADDR message.</t>
          <t indent="0" pn="section-3.4.2-2">The following options must be included in a packet carrying MP_REMOVEADDR
* the leftmost 20 bytes of the HMAC(A) generated during the initial handshaking procedure described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/> and <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>
* the MP_SEQ option with the sequence number (seqno 33) for this message according to <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>.</t>
          <t indent="0" pn="section-3.4.2-3">Host B acknowledges receipt of the MP_REMOVEADDR message with a DCCP-Ack containing the MP_CONFIRM option. The parameters supplied in this
response are as follows:
* an MP_CONFIRM containing the MP_SEQ number (seqno 33) of the packet carrying the option that we are confirming, together with the MP_REMOVEADDR option
* the leftmost 20 bytes of the HMAC(B) generated during the initial handshaking procedure <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
          <figure anchor="ref-mp-dccp-remove-address" align="left" suppress-title="false" pn="figure-23">
            <name slugifiedName="name-example-mp-dccp-removeaddr-">Example MP-DCCP REMOVEADDR procedure</name>
            <artwork align="left" pn="section-3.4.2-4.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_REMOVEADDR(id 2) +                |
     |------- MP_HMAC(A) + MP_SEQ(seqno 33) -------------->|
     |             |                                       |      
     |   DCCP-Ack + MP_HMAC(B) +                           |
     |<----- MP_CONFIRM(seqno 33, MP_REMOVEADDR) ----------|
]]></artwork>
          </figure>
        </section>
      </section>
      <section anchor="closing" numbered="true" removeInRFC="false" toc="include" pn="section-3.5">
        <name slugifiedName="name-close-a-mp-dccp-connection">Close a MP-DCCP connection</name>
        <t indent="0" pn="section-3.5-1">When a host wants to close an existing subflow but not the whole MP-DCCP
connection, it MUST initiate the regular DCCP connection termination procedure 
as described in Section 5.6 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, i.e., it sends a DCCP-Close/DCCP-Reset on the subflow. This
may be preceded by a DCCP-CloseReq. In the event of an irregular termination of a subflow,
e.g., during subflow establishment, it MUST use an appropriate DCCP reset code as specified in IANA <xref target="DCCP.Parameter" format="default" sectionFormat="of" derivedContent="DCCP.Parameter"/> for DCCP operations. This could be, for example, sending reset code 5 (Option Error) when an MP-DCCP
option provides invalid data or reset code 9 (Too Busy) when the maximum number of maintainable paths
is reached. Note that receiving a reset code 9 for secondary subflows SHOULD NOT impact already existing active
subflows. If necessary, these subflows are terminated in a subsequent step using the procedures described in
this section.</t>
        <t indent="0" pn="section-3.5-2">A host terminates an MP-DCCP connection using the DCCP connection termination specified in section 5.5 of
<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> on each subflow with the first packet on each subflow carrying MP_CLOSE (see <xref target="MP_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.11"/>).</t>
        <artwork align="left" pn="section-3.5-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.5-4">Additionally, an 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 align="left" pn="section-3.5-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" removeInRFC="false" toc="include" pn="section-3.6">
        <name slugifiedName="name-fallback">Fallback</name>
        <t indent="0" pn="section-3.6-1">When a subflow fails to operate following MP-DCCP intended behavior, it is 
necessary to proceed with a fallback. This may be either falling back 
to regular DCCP <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> 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 suboptions, faulty/non-supported MP-DCCP options or modification
of payload data.</t>
        <t indent="0" pn="section-3.6-2">At the start of an 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 do not carry the MP_CAPABLE feature, the MP-DCCP connection will not be 
established and the handshake SHOULD fallback to regular DCCP (if this is not 
possible it MUST be closed).</t>
        <t indent="0" pn="section-3.6-3">A connection SHOULD fallback to regular DCCP if the endpoints fail to agree on a
protocol version to use during the Multipath Capable feature negotiation. This 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 fallback to regular DCCP.</t>
        <t indent="0" pn="section-3.6-4">The fallback procedure to regular DCCP MUST be also applied if the MP_KEY <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> Key Type cannot be negotiated.</t>
        <t indent="0" pn="section-3.6-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. Reception of a non-verifiable MP_HMAC (<xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>) or an invalid
MP_JOIN Path Token <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/> during flow establishment MUST cause the
subflow to be closed.</t>
        <t indent="0" pn="section-3.6-6">The subflow closing procedure MUST be also applied if 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.6-7">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 data is dropped due to corruption for an MP-DCCP connection, the affected
subflow MAY be closed.</t>
      </section>
      <section anchor="congestion-control-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.7">
        <name slugifiedName="name-congestion-control-consider">Congestion Control Considerations</name>
        <t indent="0" pn="section-3.7-1">Senders MUST manage per-path congestion status, and avoid to
sending more data on a given path than congestion control
for each path allows.</t>
      </section>
      <section anchor="maximum-packet-size-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.8">
        <name slugifiedName="name-maximum-packet-size-conside">Maximum Packet Size Considerations</name>
        <t indent="0" pn="section-3.8-1">A DCCP implementation maintains 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. The DCCP application interface SHOULD allow the application to discover the current MPS. This reflects the current supported largest size for the data stream that can be used across the set of all active MP-DCCP subflows.</t>
      </section>
      <section anchor="path-usage-strategies" numbered="true" removeInRFC="false" toc="include" pn="section-3.9">
        <name slugifiedName="name-path-usage-strategies">Path usage strategies</name>
        <t indent="0" pn="section-3.9-1">MP-DCCP can be configured to realize one of several strategies for path usage, via selecting one DCCP subflow of the multiple DCCP subflows within a MP-DCCP connection for data transmission. This can be a dynamic process further facilitated by the means of DCCP and MP-DCCP defined options such as path preference using MP-PRIO, adding or removing DCCP subflows using MP_REMOVEADDR, MP_ADDADDR or DCCP-Close/DCCP-Reset and also path metrics such as packet-loss-rate, CWND or RTT provided by the Congestion Control Algorithm.
Selecting an appropriate method can allow MP-DCCP to realize different path utilization strategies that make MP-DCCP suitable for end-to-end implementation over the Internet or in controlled environments such as Hybrid Access or 5G ATSSS.</t>
        <section anchor="path_mobility" numbered="true" removeInRFC="false" toc="include" pn="section-3.9.1">
          <name slugifiedName="name-path-mobility">Path mobility</name>
          <t indent="0" pn="section-3.9.1-1">The path mobility strategy provides the use of a single path with a seamless handover function to continue the connection when the currently used path is deemed unsuitable for service delivery.
Some of the DCCP subflows of a MP-DCCP connection might become inactive due to either the occurrence of certain error conditions (e.g., DCCP timeout, packet loss threshold, RTT threshold, closed/removed) or adjustments from the MP-DCCP user.
When there is outbound data to send and the primary path becomes inactive (e.g., due to failures) or de-prioritized, the MP-DCCP endpoint SHOULD try to send the data through an alternate path with a different source or destination address (depending on the point of failure), if one exists. This process SHOULD respect the path priority configured by MP_PRIO or if not available pick the most divergent source-destination pair from the original used source-destination pair.
Note: Rules for picking the most appropriate source-destination pair are an implementation decision and are not specified within this document.
Path mobility is supported in the current Linux reference implementation <xref target="multipath-dccp.org" format="default" sectionFormat="of" derivedContent="multipath-dccp.org"/>.</t>
        </section>
        <section anchor="concurrent-path-usage" numbered="true" removeInRFC="false" toc="include" pn="section-3.9.2">
          <name slugifiedName="name-concurrent-path-usage">Concurrent path usage</name>
          <t indent="0" pn="section-3.9.2-1">Different to a path mobility strategy, the selection between MP-DCCP
subflows is here a per-packet decision that is a part of the multipath
scheduling process. This method would allow multiple subflows to be
simultaneously used to aggregate the path resources to obtain higher
connection throughput.</t>
          <t indent="0" pn="section-3.9.2-2">In this scenario, the selection of congestion control, per-packet scheduling
and potential re-ordering method determines a concurrent path utilization
strategy and result in a particular transport characteristic.</t>
          <t indent="0" pn="section-3.9.2-3">A concurrent path usage method uses a scheduling design that could seek to 
maximize reliability, throughput, minimizing latency, etc.</t>
          <t indent="0" pn="section-3.9.2-4">Concurrent path usage over the Internet can have implications. When a 
Multipath DCCP connection uses two or more paths, there is no guarantee 
that these paths are fully disjoint.  When two (or more) subflows share 
the same bottleneck, using a standard congestion control scheme could 
result in an unfair distribution of the capacity with the multipath 
connection using more capacity than competing single path connections.<br/>
Multipath TCP uses the coupled congestion control Linked Increases 
Algorithm (LIA) specified in the experimental specification <xref target="RFC6356" format="default" sectionFormat="of" derivedContent="RFC6356"/> to solve this problem.  This 
scheme could also be specified for Multipath DCCP.  The same applies to 
other coupled congestion control schemes that have been proposed for 
Multipath TCP such as Opportunistic Linked Increases Algorithm <xref target="OLIA" format="default" sectionFormat="of" derivedContent="OLIA"/>.</t>
          <t indent="0" pn="section-3.9.2-5">The specification of scheduling for concurrent multipath and related the 
congestion control algorithms and re-ordering methods for use in the general
Internet are outside the scope of this document. If and when the IETF
specifies a method for concurrent usage of multiple paths for use in the
general Internet, the framework specified in this document could be used to 
provide an IETF recommended method for MP-DCCP.</t>
        </section>
      </section>
    </section>
    <section anchor="security" numbered="true" removeInRFC="false" toc="include" 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, DTLS over DCCP <xref target="RFC5238" format="default" sectionFormat="of" derivedContent="RFC5238"/> or other
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 an on-path attacker 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" removeInRFC="false" toc="include" 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"/>, Section 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"/>. Future
specifications by the IETF could specify other methods for DCCP encapsulation.</t>
    </section>
    <section anchor="implementation" numbered="true" removeInRFC="false" toc="include" 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="multipath-dccp.org" format="default" sectionFormat="of" derivedContent="multipath-dccp.org"/>.</t>
    </section>
    <section anchor="acknowledgments" numbered="true" removeInRFC="false" toc="include" pn="section-7">
      <name slugifiedName="name-acknowledgments">Acknowledgments</name>
      <t indent="0" pn="section-7-1"><xref target="RFC6824" format="default" sectionFormat="of" derivedContent="RFC6824"/> and <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/> defined Multipath TCP and provided important
inputs for this specification</t>
      <t indent="0" pn="section-7-2">The authors gratefully acknowledge significant input into this document from Dirk von Hugo, Nathalie Romo Moreno, Omar Nassef, Mohamed Boucadair, Simone Ferlin, and Behcet Sarikaya.</t>
    </section>
    <section anchor="iana-considerations" numbered="true" removeInRFC="false" toc="include" 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 be added to the DCCP Feature Numbers registry and three new registries to be added to the DCCP registry group.</t>
      <t indent="0" pn="section-8-2">This document requests IANA to assign 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 in the DCCP registry group 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-nu">Addition to DCCP Feature Numbers registry</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">THIS-FEATURE (10 suggested)</td>
            <td align="center" colspan="1" rowspan="1">MP-DCCP capability feature</td>
            <td align="center" colspan="1" rowspan="1">[ThisDocument]</td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-4">As outlined in sect. <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/> the new 1-Byte entry above includes a 4-bit part to specify the version of the used MP-DCCP implementation. This document requests IANA to create a new 'MP-DCCP Versions' registry within the DCCP registry group to track the MP-DCCP version. The initial content of this registry is as follows:</t>
      <table anchor="ref-add-version-list" align="center" pn="table-7">
        <name slugifiedName="name-mp-dccp-versions-registry">MP-DCCP Versions Registry</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Version</th>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Specification</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">THIS-VER</td>
            <td align="center" colspan="1" rowspan="1">Suggested 0000</td>
            <td align="center" colspan="1" rowspan="1">[ThisDocument]</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Unassigned</td>
            <td align="center" colspan="1" rowspan="1">0001 - 1111</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-6">Future MP-DCCP versions 1 to 15 are assigned from this registry using the Specification Required policy (Section 4.6 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      <t indent="0" pn="section-8-7">This document requests IANA to assign a new DCCP protocol option THIS-DCCP-OPTION (suggested type=46) as described in <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/>. In this document, THIS-DCCP-OPTION is replaced by 46 for better readability.</t>
      <t indent="0" pn="section-8-8">IANA is requested to create a new 'MP-DCCP Suboptions' registry within the DCCP registry group. The following entries in <xref target="ref-add-proto-opt-list" format="default" sectionFormat="of" derivedContent="Table 8"/> should be added to the new 'MP-DCCP Suboptions' registry. The registry in <xref target="ref-add-proto-opt-list" format="default" sectionFormat="of" derivedContent="Table 8"/> has an upper boundary of 255 in the numeric value field.</t>
      <table anchor="ref-add-proto-opt-list" align="center" pn="table-8">
        <name slugifiedName="name-mp-dccp-suboptions-registry">MP-DCCP Suboptions registry</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">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">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">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">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">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">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">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">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">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">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">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">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_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.11"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=11</td>
            <td align="center" colspan="1" rowspan="1">MP_EXP</td>
            <td align="center" colspan="1" rowspan="1">Experimental Sub-Option for private use</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_EXP" format="default" sectionFormat="of" derivedContent="Section 3.2.12"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT&gt;11</td>
            <td align="center" colspan="1" rowspan="1">Unassigned</td>
            <td align="center" colspan="1" rowspan="1">Reserved for future MP-DCCP suboptions</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-10">Future MP-DCCP sub-options with MP_OPT&gt;11 are assigned from this registry using the Specification Required policy (Section 4.6 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      <t indent="0" pn="section-8-11">In addition IANA is requested to assign a new DCCP Reset Code value THIS-RESET-CODE (13 suggested) 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-12">In addition IANA is requested to assign for this version of the MP-DCCP protocol a new 'MP_KEY' registry containing 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 9"/> below. Values in range 3-255 (decimal) inclusive remain unassigned in this THIS-VER of the protocol and are assigned via Specification Required <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>
in potential future versions of the MP-DCCP protocol.</t>
      <table anchor="ref-mp_key-sub-opt-list" align="center" pn="table-9">
        <name slugifiedName="name-mp-dccp-mp_key-registry-wit">MP-DCCP MP_KEY registry with 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">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">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">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-references">References</name>
      <references pn="section-9.1">
        <name slugifiedName="name-normative-references">Normative References</name>
        <reference anchor="DCCP.Parameter" target="https://www.iana.org/assignments/dccp-parameters/dccp-parameters.xhtml" quoteTitle="true" derivedAnchor="DCCP.Parameter">
          <front>
            <title>IANA Datagram Congestion Control Protocol (DCCP) Parameters</title>
            <author>
              <organization showOnFrontPage="true"/>
            </author>
            <date>n.d.</date>
          </front>
        </reference>
        <reference anchor="RFC2119" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc2119" derivedAnchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t 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="RFC4340" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc4340" derivedAnchor="RFC4340">
          <front>
            <title>Datagram Congestion Control Protocol (DCCP)</title>
            <author fullname="E. Kohler" initials="E." surname="Kohler"/>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="S. Floyd" initials="S." surname="Floyd"/>
            <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>
      </references>
      <references pn="section-9.2">
        <name slugifiedName="name-informative-references">Informative References</name>
        <reference anchor="I-D.amend-iccrg-multipath-reordering" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-amend-iccrg-multipath-reordering-03" derivedAnchor="I-D.amend-iccrg-multipath-reordering">
          <front>
            <title>Multipath sequence maintenance</title>
            <author fullname="Markus Amend" initials="M." surname="Amend">
              <organization showOnFrontPage="true">Deutsche Telekom</organization>
            </author>
            <author fullname="Dirk Von Hugo" initials="D." surname="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-multipath-framework-mpdccp" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-amend-tsvwg-multipath-framework-mpdccp-01" 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" initials="M." surname="Amend">
              <organization showOnFrontPage="true">Deutsche Telekom</organization>
            </author>
            <author fullname="Eckard Bogenfeld" initials="E." surname="Bogenfeld">
              <organization showOnFrontPage="true">Deutsche Telekom</organization>
            </author>
            <author fullname="Anna Brunstrom" initials="A." surname="Brunstrom">
              <organization showOnFrontPage="true">Karlstad University</organization>
            </author>
            <author fullname="Andreas Kassler" initials="A." surname="Kassler">
              <organization showOnFrontPage="true">Karlstad University</organization>
            </author>
            <author fullname="Veselin Rakocevic" initials="V." surname="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" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-lhwxz-hybrid-access-network-architecture-02" derivedAnchor="I-D.lhwxz-hybrid-access-network-architecture">
          <front>
            <title>Hybrid Access Network Architecture</title>
            <author fullname="Nicolai Leymann" initials="N." surname="Leymann">
              <organization showOnFrontPage="true">Deutsche Telekom AG</organization>
            </author>
            <author fullname="Cornelius Heidemann" initials="C." surname="Heidemann">
              <organization showOnFrontPage="true">Deutsche Telekom AG</organization>
            </author>
            <author fullname="Margaret Cullen" initials="M." surname="Cullen">
              <organization showOnFrontPage="true">Painless Security</organization>
            </author>
            <author fullname="Li Xue" initials="L." surname="Xue">
              <organization showOnFrontPage="true">Huawei</organization>
            </author>
            <author fullname="Mingui Zhang" initials="M." surname="Zhang">
              <organization showOnFrontPage="true">Huawei</organization>
            </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" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-muley-network-based-bonding-hybrid-access-03" derivedAnchor="I-D.muley-network-based-bonding-hybrid-access">
          <front>
            <title>Network based Bonding solution for Hybrid Access</title>
            <author fullname="Praveen Muley" initials="P." surname="Muley">
              <organization showOnFrontPage="true">Nokia</organization>
            </author>
            <author fullname="Wim Henderickx" initials="W." surname="Henderickx">
              <organization showOnFrontPage="true">Nokia</organization>
            </author>
            <author fullname="Liang Geng" initials="L." surname="Geng">
              <organization showOnFrontPage="true">China Mobile</organization>
            </author>
            <author fullname="Hans Liu" initials="H." surname="Liu">
              <organization showOnFrontPage="true">D-Link Corp</organization>
            </author>
            <author fullname="Loris Cardullo" initials="L." surname="Cardullo">
              <organization showOnFrontPage="true">Vodafone</organization>
            </author>
            <author fullname="Jonathan Newton" initials="J." surname="Newton">
              <organization showOnFrontPage="true">Vodafone</organization>
            </author>
            <author fullname="SungHoon Seo" initials="S." surname="Seo">
              <organization showOnFrontPage="true">Korea Telecom</organization>
            </author>
            <author fullname="Sagiv Draznin" initials="S." surname="Draznin">
              <organization showOnFrontPage="true">Verizon Wireless</organization>
            </author>
            <author fullname="Basavaraj Patil" initials="B." surname="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="IETF115.Slides" target="https://datatracker.ietf.org/meeting/105/materials/slides-105-tsvwg-sessa-62-dccp-extensions-for-multipath-operation-00" quoteTitle="true" derivedAnchor="IETF115.Slides">
          <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="MP-DCCP.Paper" quoteTitle="true" target="https://doi.org/10.1109/LCN44214.2019.8990746" derivedAnchor="MP-DCCP.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="multipath-dccp.org" target="https://multipath-dccp.org/" quoteTitle="true" derivedAnchor="multipath-dccp.org">
          <front>
            <title>Multipath extension for DCCP</title>
            <author>
              <organization showOnFrontPage="true"/>
            </author>
            <date>n.d.</date>
          </front>
        </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." 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="RFC0793" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc793" derivedAnchor="RFC0793">
          <front>
            <title>Transmission Control Protocol</title>
            <author fullname="J. Postel" initials="J." surname="Postel"/>
            <date month="September" year="1981"/>
          </front>
          <seriesInfo name="RFC" value="793"/>
          <seriesInfo name="DOI" value="10.17487/RFC0793"/>
        </reference>
        <reference anchor="RFC2104" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc2104" derivedAnchor="RFC2104">
          <front>
            <title>HMAC: Keyed-Hashing for Message Authentication</title>
            <author fullname="H. Krawczyk" initials="H." surname="Krawczyk"/>
            <author fullname="M. Bellare" initials="M." surname="Bellare"/>
            <author fullname="R. Canetti" initials="R." surname="Canetti"/>
            <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="RFC3711" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc3711" derivedAnchor="RFC3711">
          <front>
            <title>The Secure Real-time Transport Protocol (SRTP)</title>
            <author fullname="M. Baugher" initials="M." surname="Baugher"/>
            <author fullname="D. McGrew" initials="D." surname="McGrew"/>
            <author fullname="M. Naslund" initials="M." surname="Naslund"/>
            <author fullname="E. Carrara" initials="E." surname="Carrara"/>
            <author fullname="K. Norrman" initials="K." surname="Norrman"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc4043" derivedAnchor="RFC4043">
          <front>
            <title>Internet X.509 Public Key Infrastructure Permanent Identifier</title>
            <author fullname="D. Pinkas" initials="D." surname="Pinkas"/>
            <author fullname="T. Gindin" initials="T." surname="Gindin"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc4086" derivedAnchor="RFC4086">
          <front>
            <title>Randomness Requirements for Security</title>
            <author fullname="D. Eastlake 3rd" initials="D." surname="Eastlake 3rd"/>
            <author fullname="J. Schiller" initials="J." surname="Schiller"/>
            <author fullname="S. Crocker" initials="S." surname="Crocker"/>
            <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="RFC5238" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5238" derivedAnchor="RFC5238">
          <front>
            <title>Datagram Transport Layer Security (DTLS) over the Datagram Congestion Control Protocol (DCCP)</title>
            <author fullname="T. Phelan" initials="T." surname="Phelan"/>
            <date month="May" year="2008"/>
            <abstract>
              <t indent="0">This document specifies the use of Datagram Transport Layer Security (DTLS) over the Datagram Congestion Control Protocol (DCCP). DTLS provides communications privacy for applications that use datagram transport protocols and allows client/server applications to communicate in a way that is designed to prevent eavesdropping and detect tampering or message forgery. DCCP is a transport protocol that provides a congestion-controlled unreliable datagram service. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5238"/>
          <seriesInfo name="DOI" value="10.17487/RFC5238"/>
        </reference>
        <reference anchor="RFC5595" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5595" derivedAnchor="RFC5595">
          <front>
            <title>The Datagram Congestion Control Protocol (DCCP) Service Codes</title>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5596" 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"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5597" 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"/>
            <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="RFC6234" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6234" 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"/>
            <author fullname="T. Hansen" initials="T." surname="Hansen"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6356" derivedAnchor="RFC6356">
          <front>
            <title>Coupled Congestion Control for Multipath Transport Protocols</title>
            <author fullname="C. Raiciu" initials="C." surname="Raiciu"/>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="D. Wischik" initials="D." surname="Wischik"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6773" 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"/>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst"/>
            <author fullname="C. Perkins" initials="C." surname="Perkins"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6824" derivedAnchor="RFC6824">
          <front>
            <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
            <author fullname="A. Ford" initials="A." surname="Ford"/>
            <author fullname="C. Raiciu" initials="C." surname="Raiciu"/>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="O. Bonaventure" initials="O." surname="Bonaventure"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6904" 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"/>
            <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" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6951" 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"/>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <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="RFC8041" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8041" derivedAnchor="RFC8041">
          <front>
            <title>Use Cases and Operational Experience with Multipath TCP</title>
            <author fullname="O. Bonaventure" initials="O." surname="Bonaventure"/>
            <author fullname="C. Paasch" initials="C." surname="Paasch"/>
            <author fullname="G. Detal" initials="G." surname="Detal"/>
            <date month="January" year="2017"/>
            <abstract>
              <t indent="0">This document discusses both use cases and operational experience with Multipath TCP (MPTCP) in real networks. It lists several prominent use cases where Multipath TCP has been considered and is being used. It also gives insight to some heuristics and decisions that have helped to realize these use cases and suggests possible improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8041"/>
          <seriesInfo name="DOI" value="10.17487/RFC8041"/>
        </reference>
        <reference anchor="RFC8126" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8126" derivedAnchor="RFC8126">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton"/>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <author fullname="T. Narten" initials="T." surname="Narten"/>
            <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="RFC8174" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8174" derivedAnchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t indent="0">RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC8684" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8684" derivedAnchor="RFC8684">
          <front>
            <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
            <author fullname="A. Ford" initials="A." surname="Ford"/>
            <author fullname="C. Raiciu" initials="C." surname="Raiciu"/>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="O. Bonaventure" initials="O." surname="Bonaventure"/>
            <author fullname="C. Paasch" initials="C." surname="Paasch"/>
            <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="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>
      </references>
    </references>
    <section anchor="diff_mptcp" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a">
      <name slugifiedName="name-differences-from-multipath-">Differences from Multipath TCP</name>
      <t indent="0" pn="section-appendix.a-1">This appendix is Informative.</t>
      <t indent="0" pn="section-appendix.a-2">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-3"><xref target="table_tcp_dccp_comp" format="default" sectionFormat="of" derivedContent="Table 10"/> 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-10">
        <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-5">Consequently, the multipath features, shown in
<xref target="table_mptcp_mpdccp_comp" format="default" sectionFormat="of" derivedContent="Table 11"/>, 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-11">
        <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-7">Therefore, the sender logic is not much different between MP-DCCP and
MPTCP.</t>
      <t indent="0" pn="section-appendix.a-8">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 proposed 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-9">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:
H4sIAAAAAAAAA+2963LbVpoo+n89Bcr5EbFD0qLke3d6Dy3LHU3HtralpHfX
zFQKIiERbRJgA6BlteVd5zXO650nOd91rW8BoCw5ztxq1DOxRALr+t2vo9HI
NXmzzJ4lLw4OjpPDD01W1HlZ1Ml5WSWvNssmX6fNInmzzqq0gS+Syxz+5C+W
WTKdz6usrrPapWdnVfb+mXkHR3TzclakKxh/XqXnzSjPmvNRU7+/vBit9MHR
fDZbjya7bp428ODe7t7+aPfxaO+Rm6XNs6Ru5s7l6+pZ0lSbutnb3X26u+dc
WmUpfpQW9bqsGnd58Sw51b+SKXyb/KWs3uXFRfKnqtys3bvs6rKs5s+So6LJ
qiJrRi9wSa7enK3yGjfdXK1h/qPD05fOzco5vPos2dSjtJ7luaubtJj/ki7L
IqOVZM6t82fJvzTlbJjUMGeVndfw29UKf/k3WOCmWZTVM5eMXJLkRQ1HM06m
q6yYw998Jq/S6t2m9h+WFUz4Its09WyRJafZMntXruBzPdoXp/BHDRNlTXhu
JM+NpstlliVP4ZFZ3lzBA2m1gkXPG/yknMN0jx7sPX1If22KpoJH/pRVq7S4
go+yVZovdUFjWtA/NTzweJ7BA1WJQJLN86aszJam4+R5tSlgUbRS3ta0KNLo
Y9rYn9NqietJfiry91lVwyLNdvyHWVNfpHDWyZ7fib4ZNvJwkjx5YndycpnN
syJsJIUljM90Cf/0Lt2M6yxe95/Tul5mlVk1gHJam8//I5ZNaxi/4zV01/3z
OHmbvitn2ft85lf+c1Zny7yIvqG1H8A6zLqT8jz5sSzmZWF28BpAd5Gu1g3g
9snfN4BWfgP+Wb9eGKvJ5smfATXmdLOy7ve8gnGlKxhP/gnHGKez8eadWf/J
OPnnclHUNCyv/qTJ1ousMJ/T2p9bYJ/OU/g1XSbHAKB+fQCtQLpqWH3yQwaE
xB/00fHDZP/t4W1WXvPs48X4bzz/P5014xk84YoSkKOBswMUTt6+PNibTJ7K
rw/2H+zir0jhxrAk2AeQFPwkSYScHk1fTwEFm/QCvk0OyuIiq4l+wq8AkrCT
qgTSAb/s4CiDxA9T8zBpdYE7XzTNun52//7l5eU4TwGo4XDuA3TkFwUgaVPf
J+K59i+3/x5/WDSrJRDQ4tzu52j0YpwilneI8Tm+CYTy3Wi1xrH06eXi8sM/
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
EmgBAA==

-->

</rfc>
