<?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-23" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" prepTime="2025-04-10T15:39:07" indexInclude="true" scripts="Common,Latin" tocDepth="3">
  <!-- xml2rfc v2v3 conversion 3.28.1 -->
  <front>
    <title abbrev="Multipath DCCP">DCCP Extensions for Multipath Operation with Multiple Addresses</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-multipath-dccp-23" 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="04" year="2025" day="10"/>
    <area>transport</area>
    <workgroup>Transport Area Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">Datagram Congestion Control Protocol (DCCP) communications, as defined in RFC 4340, are inherently restricted to a single path per connection, despite the availability of multiple network paths between peers. The ability to utilize multiple paths simultaneously for a DCCP session can enhance network resource utilization, improve throughput, and increase resilience to network failures, ultimately enhancing the user experience.</t>
      <t indent="0" pn="section-abstract-2">Use cases for Multipath DCCP (MP-DCCP) include mobile devices (e.g., handsets, vehicles) and residential home gateways that maintain simultaneous connections to distinct network types, such as cellular and Wireless Local Area Networks (WLANs) or cellular and fixed access networks. Compared to existing multipath transport protocols, such as Multipath TCP (MPTCP), MP-DCCP is particularly suited for latency-sensitive applications with varying requirements for reliability and in-order delivery.</t>
      <t indent="0" pn="section-abstract-3">This document specifies a set of protocol extensions to DCCP that enable multipath operations. These extensions maintain the same service model as DCCP while introducing mechanisms to establish and utilize multiple concurrent DCCP flows across different network paths.</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
        This Internet-Draft is submitted in full conformance with the
        provisions of BCP 78 and BCP 79.
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
        Internet-Drafts are working documents of the Internet Engineering Task
        Force (IETF). Note that other groups may also distribute working
        documents as Internet-Drafts. The list of current Internet-Drafts is
        at <eref target="https://datatracker.ietf.org/drafts/current/" brackets="none"/>.
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
        Internet-Drafts are draft documents valid for a maximum of six months
        and may be updated, replaced, or obsoleted by other documents at any
        time. It is inappropriate to use Internet-Drafts as reference
        material or to cite them other than as "work in progress."
        </t>
        <t indent="0" pn="section-boilerplate.1-4">
        This Internet-Draft will expire on 12 October 2025.
        </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) 2025 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-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>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.2.2">
              <li pn="section-toc.1-1.2.2.1">
                <t indent="0" pn="section-toc.1-1.2.2.1.1"><xref derivedContent="2.1" format="counter" sectionFormat="of" target="section-2.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-concept">MP-DCCP Concept</xref></t>
              </li>
            </ul>
          </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-multipath-opti">Experimental Multipath 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-closing-an-mp-dccp-connecti">Closing an 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-state-diagram">State Diagram</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-congestion-control-consider">Congestion Control 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-maximum-packet-size-conside">Maximum Packet Size Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.10">
                <t indent="0" pn="section-toc.1-1.3.2.10.1"><xref derivedContent="3.10" format="counter" sectionFormat="of" target="section-3.10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-maximum-number-of-subflows-">Maximum number of Subflows Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.11">
                <t indent="0" pn="section-toc.1-1.3.2.11.1"><xref derivedContent="3.11" format="counter" sectionFormat="of" target="section-3.11"/>. <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.11.2">
                  <li pn="section-toc.1-1.3.2.11.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.11.2.1.1"><xref derivedContent="3.11.1" format="counter" sectionFormat="of" target="section-3.11.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-path-mobility">Path mobility</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.11.2.2">
                    <t indent="0" pn="section-toc.1-1.3.2.11.2.2.1"><xref derivedContent="3.11.2" format="counter" sectionFormat="of" target="section-3.11.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>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.8.2">
              <li pn="section-toc.1-1.8.2.1">
                <t indent="0" pn="section-toc.1-1.8.2.1.1"><xref derivedContent="8.1" format="counter" sectionFormat="of" target="section-8.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-multipath-capable-dccp-">New Multipath Capable DCCP feature</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.2">
                <t indent="0" pn="section-toc.1-1.8.2.2.1"><xref derivedContent="8.2" format="counter" sectionFormat="of" target="section-8.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-mp-dccp-version-registr">New MP-DCCP version registry</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.3">
                <t indent="0" pn="section-toc.1-1.8.2.3.1"><xref derivedContent="8.3" format="counter" sectionFormat="of" target="section-8.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-multipath-option-and-re">New Multipath option and registry</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.4">
                <t indent="0" pn="section-toc.1-1.8.2.4.1"><xref derivedContent="8.4" format="counter" sectionFormat="of" target="section-8.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-dccp-reset-code">New DCCP Reset Code</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.5">
                <t indent="0" pn="section-toc.1-1.8.2.5.1"><xref derivedContent="8.5" format="counter" sectionFormat="of" target="section-8.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-multipath-key-type-regi">New Multipath Key Type registry</xref></t>
              </li>
            </ul>
          </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. Other fundamentals of the DCCP protocol
are summarized in section 1 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, such as the reliable
handshake process in section 4.7 and the reliable negotiation of features
in section 4.5. These are an important basis for this document. This also
applies to the DCCP sequencing scheme, which is packet-based (section 4.2),
and the principles for loss and retransmission of features as described in
more detail in section 6.6.3.
This document specifies a set of protocol changes that add multipath
support to DCCP; specifically, support 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-2">Multipath DCCP (MP-DCCP) 
enables a DCCP connection to simultaneously establish a flow across multiple paths. This can be  beneficial to applications that transfer
large amounts of data, by utilizing the capacity/connectivity offered by 
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-3">In addition to the integration into DCCP services, implementers or future specification could choose MP-DCCP for other use cases like
3GPP 5G multi-access solutions (e.g., Access Traffic Steering, Switching, and Splitting (ATSSS) specified in <xref target="TS23.501" format="default" sectionFormat="of" derivedContent="TS23.501"/>) or hybrid access networks that either combine a 3GPP and a non-3GPP access or a fixed and cellular access between user-equipment/residential gateway and operator network. MP-DCCP can be used in these scenarios for load balancing, seamless session handover and bandwidth aggregation when non-DCCP traffic like IP, UDP or TCP is encapsulated into MP-DCCP.
More details on potential use cases for MP-DCCP are provided in <xref target="multipath-dccp.org" format="default" sectionFormat="of" derivedContent="multipath-dccp.org"/>, <xref target="IETF105.Slides" format="default" sectionFormat="of" derivedContent="IETF105.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-1-4">The encapsulation of non-DCCP traffic (e.g., UDP or IP) in MP-DCCP to enable the above-mentioned use cases is not considered in this specification.
Also out of scope is the encapsulation of DCCP traffic in UDP to pass middleboxes (e.g., NATs, firewalls, proxies, intrusion detection systems (IDSs), etc)  that do not support DCCP. A possible method is defined in <xref target="RFC6773" format="default" sectionFormat="of" derivedContent="RFC6773"/> or is considered in <xref target="I-D.amend-tsvwg-dccp-udp-header-conversion" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-dccp-udp-header-conversion"/> to achieve the same with less overhead.</t>
      <t indent="0" pn="section-1-5">MP-DCCP is based exclusively on the lean concept of DCCP. For traffic that is already encrypted or does not need encryption, MP-DCCP is an efficient choice as it does not apply its own encryption mechanisms. Also, the procedures defined by MP-DCCP, which allow subsequent reordering of traffic and efficient traffic scheduling, improve performance, as shown in <xref target="MP-DCCP.Paper" format="default" sectionFormat="of" derivedContent="MP-DCCP.Paper"/>, and take into account the interaction of the protocol with the further elements required for multi-path transport.</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 provides a set of features to 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>
        <t indent="0" pn="section-1.1-3">A CLI at the endpoint (or another method) could be used to configure and manage the DCCP Connections. This could be extended to also support MP-DCCP, but this specification does not define this.</t>
      </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">This document uses terms that are either specific
for multipath transport as defined in <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/> or are defined in the context of MP-DCCP, 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 and the source and destination ports. This definition follows <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/> and is illustrated in the following two examples for IPv6 and IPv4, which each show a pair of sender IP-address:port and a pair of receiver IP-address:port, which together form the 4-tuple:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-1.2-3">
          <li pn="section-1.2-3.1">
            <t indent="0" pn="section-1.2-3.1.1">IPv6: [2001:db8:3333:4444:5555:6666:7777:8888]:1234, [2001:db8:3333:4444:cccc:dddd:eeee:ffff]:4321</t>
          </li>
          <li pn="section-1.2-3.2">
            <t indent="0" pn="section-1.2-3.2.1">IPv4: 203.0.113.1:1234, 203.0.113.2:4321</t>
          </li>
        </ul>
        <t indent="0" pn="section-1.2-4">Subflow: A subflow refers to a DCCP flow transmitted using a specific path (4-tuple of source and destination address/port
pairs) that forms one of the multipath flows used by a single connection.</t>
        <t indent="0" pn="section-1.2-5">(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-6">Connection Identifier (CI): A unique identifier that is assigned to a multipath connection by the host to distinguish several multipath connections locally. The CIs must therefore be locally unique per host and do not have to be the same across the peers.</t>
        <t indent="0" pn="section-1.2-7">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-8">'+': The plus symbol means concatenation of values.</t>
        <t indent="0" pn="section-1.2-9">In addition to these
terms, within the 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="requirements-language" numbered="true" removeInRFC="false" toc="include" pn="section-1.3">
        <name slugifiedName="name-requirements-language">Requirements Language</name>
        <t indent="0" pn="section-1.3-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 transmits congestion-controlled unreliable datagrams over a single path.
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).
However, DCCP does not provide built-in
support for managing multiple subflows within one DCCP connection. The
extension of DCCP for 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-2">At a high level 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 paths, for example using paths via different links.
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-3">A Multipath DCCP connection provides a bidirectional connection of datagrams
between two hosts exchanging data using DCCP. It does not require
any change to the applications. Multipath DCCP enables the
hosts to use multiple paths with different 4-tuples 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.<br/>
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>
      <t indent="0" pn="section-2-4">The Multipath Capability for MP-DCCP is 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 by Multipath options described in <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/>. Options that 
require confirmation from the remote peer are retransmitted by the sender until confirmed or until 
confirmation is no longer considered relevant.</t>
      <t indent="0" pn="section-2-5">The following sections define MP-DCCP behavior in detail.</t>
      <section anchor="concept" numbered="true" removeInRFC="false" toc="include" pn="section-2.1">
        <name slugifiedName="name-mp-dccp-concept">MP-DCCP Concept</name>
        <t indent="0" pn="section-2.1-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-2.1-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-2.1-3">
          <li pn="section-2.1-3.1">
            <t indent="0" pn="section-2.1-3.1.1">An MP-DCCP connection begins with a 4-way handshake, between 
two hosts. 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. In the handshake, a Multipath Capable feature is used to negotiate multipath support for the connection. Host specific keys are also exchanged between Host A and Host B during the handshake. The details of the MP-DCCP handshaking procedure is described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. MP-DCCP does not require both peers to have 
more than one address.</t>
          </li>
          <li pn="section-2.1-3.2">
            <t indent="0" pn="section-2.1-3.2.1">When additional paths and corresponding addresses/ports are available, additional DCCP subflows can be created on 
these paths and attached to the existing MP-DCCP connection. An MP_JOIN option is used to connect a new DCCP subflow to an existing MP-DCCP connection. It contains a Connection Identifier during the setup of the initial subflow and is exchanged in the 4-way handshake for the subflow together with the Multipath Capable feature. The example in <xref target="ref-example-mp-dccp-usage-scenario" format="default" sectionFormat="of" derivedContent="Figure 2"/> illustrates creation of an additional DCCP subflow between Address A2 on Host A and Address B1 on Host B. The two subflows
continue to provide a single connection to the applications at both
endpoints.</t>
          </li>
          <li pn="section-2.1-3.3">
            <t indent="0" pn="section-2.1-3.3.1">MP-DCCP identifies multiple paths by the presence of multiple
addresses/ports at hosts.  Combinations of these multiple addresses/ports
indicate 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 the
additional subflow in the example is shown as being initiated from A2, an additional subflow could
alternatively have been initiated from B1 or B2.</t>
          </li>
          <li pn="section-2.1-3.4">
            <t indent="0" pn="section-2.1-3.4.1">The discovery and setup of additional subflows is achieved
through a path management method including the logic and details of the procedures for adding/removing subflows.
This document describes the procedures that enable a host to initiate new subflows or to signal available IP addresses between peers. However, the definition of a path management method, in which sequence and when subflows are created, is outside the scope of this document. This method is subject to a 
corresponding policy and the specifics of the implementation. If an MP-DCCP peer host wishes to limit the maximum number of paths that can be maintained (e.g. similar to that discussed in section 3.4 of <xref target="RFC8041" format="default" sectionFormat="of" derivedContent="RFC8041"/>), the creation of new subflows from that peer host is omitted when the threshold of maximum paths is exceeded and incoming subflow requests MUST be rejected.</t>
          </li>
          <li pn="section-2.1-3.5">
            <t indent="0" pn="section-2.1-3.5.1">Through the use of multipath options, MP-DCCP adds connection-level sequence numbers and exchange of
Round-Trip Time (RTT) information to enable optional reordering features. As a hint for scheduling decisions, a multipath option that allows a peer to indicate its priorities for what path to use is also defined.</t>
          </li>
          <li pn="section-2.1-3.6">
            <t indent="0" pn="section-2.1-3.6.1">Subflows are terminated in the same way as regular DCCP connections, as described
in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 8.3). MP-DCCP connections are closed by including an MP_CLOSE option in subflow DCCP-CloseReq or DCCP-Close messages. An MP-DCCP connection may also be reset through the use of an MP_FAST_CLOSE option. Key data from the initial handshake is included in the MP_CLOSE and MP_FAST_CLOSE to protect from unauthorized shutdown of MP-DCCP connections.</t>
          </li>
        </ul>
      </section>
    </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 section="6.4" sectionFormat="of" target="RFC4340" format="default" derivedLink="https://rfc-editor.org/rfc/rfc4340#section-6.4" derivedContent="RFC4340"/>) is
extended in this document by adding a new Multipath feature with Feature number 10, as
shown in <xref target="ref-feature-list" format="default" sectionFormat="of" derivedContent="Table 1"/>.</t>
      <table anchor="ref-feature-list" align="center" pn="table-1">
        <name slugifiedName="name-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">Rec'n Rule</th>
            <th align="center" colspan="1" rowspan="1">Initial Value</th>
            <th align="center" colspan="1" rowspan="1">Req'd</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">10</td>
            <td align="left" colspan="1" rowspan="1">Multipath Capable</td>
            <td align="center" colspan="1" rowspan="1">SP</td>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">N</td>
          </tr>
        </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 indicates the server-priority as defined in section 6.3 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>.</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">This specification adds a DCCP protocol option as defined in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 5.8) providing
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>
      <ul empty="true" bare="false" indent="3" spacing="normal" pn="section-3-6">
        <li pn="section-3-6.1">
          <t indent="0" pn="section-3-6.1.1">Note to the RFC Editor: The Feature Number and Option Type reflect the temporary assignment by IANA and must be verified once again.</t>
        </li>
      </ul>
      <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">A DCCP endpoint negotiates the Multipath Capable Feature to determine whether multipath extensions can be enabled for a DCCP connection.</t>
        <t indent="0" pn="section-3.1-2">The Multipath Capable feature (MP_CAPABLE) has feature number 10 and follows the structure for features given in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> Section 6. Beside the negotiation of the feature itself, also one or several values can be exchanged. The value field specified here for the Multipath Capable feature has a length of one-byte and can be repeated several times within the DCCP option for feature negotiation. This can be for example required to announce support of different versions of the protocol. For that, the leftmost four bits in <xref target="ref-mp-capable-format" format="default" sectionFormat="of" derivedContent="Figure 3"/> specify the compatible version of the
MP-DCCP implementation and MUST be set to 0 following this specification. The four bits following the Version field are unassigned in version 0 and 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 value field</name>
          <artwork align="left" pn="section-3.1-3.1"><![CDATA[
    0  1  2  3   4  5  6  7
   +-----------+------------+
   |  Version  | 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). This allows multiple versions to be
specified in order of priority.</t>
        <t indent="0" pn="section-3.1-5">The negotiation MUST be a part of the initial handshake procedure
 described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. No subsequent re-negotiation of
the MP_CAPABLE feature is allowed for the same MP-DCCP connection.</t>
        <t indent="0" pn="section-3.1-6">Clients MUST include a Change R (<xref section="6" sectionFormat="comma" target="RFC4340" format="default" derivedLink="https://rfc-editor.org/rfc/rfc4340#section-6" derivedContent="RFC4340"/>) 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 (<xref section="6" sectionFormat="comma" target="RFC4340" format="default" derivedLink="https://rfc-editor.org/rfc/rfc4340#section-6" derivedContent="RFC4340"/>) 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 added to an existing MP-DCCP connection MUST use the
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 10 and no values.</t>
        <t indent="0" pn="section-3.1-9">An example of successful version negotiation is shown hereafter and follows the negotiation example shown in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> Section 6.5. For better understanding, this example uses the unspecified MP-DCCP versions 1 and 2 in addition to the MP-DCCP version 0 specified in this document:</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.">
            <t indent="0" pn="section-3.1-11.1.1">The Client indicates support for both MP-DCCP versions 1 and 0, with a preference
for version 1.</t>
          </li>
          <li pn="section-3.1-11.2" derivedCounter="2.">
            <t indent="0" pn="section-3.1-11.2.1">Server agrees on using MP-DCCP version 1 indicated by the first value, and supplies its own preference list with the following values.</t>
          </li>
          <li pn="section-3.1-11.3" derivedCounter="3.">
            <t indent="0" pn="section-3.1-11.3.1">MP-DCCP is then enabled between the Client and Server with version 1.</t>
          </li>
        </ol>
        <t indent="0" pn="section-3.1-12">Unlike the example in <xref target="ref-mp-capable-example" format="default" sectionFormat="of" derivedContent="Figure 4"/>, this document only allows the
negotiation of MP-DCCP version 0.  Therefore, successful
negotiation of MP-DCCP as defined in this document, the client
and the server MUST both support MP-DCCP version 0.</t>
        <t indent="0" pn="section-3.1-13">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 MUST either fall back to regular DCCP or MUST close the connection. 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 multipath 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 fields used by the multipath option are described in <xref target="ref-mp-option-list" format="default" sectionFormat="of" derivedContent="Table 3"/>. MP_OPT refers to a Multipath option.</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">8</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">var</td>
              <td align="left" colspan="1" rowspan="1">11 =MP_EXP</td>
              <td align="left" colspan="1" rowspan="1">Experimental for private use</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;11</td>
              <td align="left" colspan="1" rowspan="1">Reserved for future MP options.</td>
            </tr>
          </tbody>
        </table>
        <t indent="0" pn="section-3.2-5">Future MP options could be defined in a later version or extension to this specification.</t>
        <t indent="0" pn="section-3.2-6">These operations are largely inspired by the signals defined in <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>. The procedures for handling faulty or unknown MP options are described in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/>.</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-op">Format of the MP_CONFIRM option</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 an MP_CONFIRM is received or the confirmation
of options is considered irrelevant because the data contained in the options has already been
replaced by newer information. This can happen, for example, with an MP_PRIO option if the path prioritization
is changed while the previous prioritization has not yet been confirmed. 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">Multipath options could arrive out-of-order, therefore multipath options 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; see <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>. This allows a receiver to identify whether
multipath options are associated with obsolete datasets (information carried in the option header) that would otherwise conflict with newer datasets. In the 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
multipath option is detected at the receiver if a previous multipath option referring to the same dataset contained a higher sequence number
in the MP_SEQ. An MP_CONFIRM MAY be generated for multipath options that are identified as outdated.</t>
          <t indent="0" pn="section-3.2.1-4">Similarly, an MP_CONFIRM could arrive out of order. The associated
MP_SEQ received MUST be echoed to ensure that the most recent multipath option is confirmed. This protects from inconsistencies that 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 interpret that the priority value was 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 multipath options and the received
MP_SEQ, which are both copied verbatim and appended as a list of confirmations. The list is structured by first listing the received
MP_SEQ followed by the related multipath option or options to confirm. The same rules apply when multipath options with different MP_SEQs are confirmed at
once. This could 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_2 + MP_ADDADDR + MP_SEQ_1 + MP_PRIO.
The order of the confirmed multipath options in the list of confirmations MUST reflect the incoming order at the host who sends the MP_CONFIRM, with the most
recent suboption received listed first. This could allow the host receiving the MP_CONFIRM to verify that the options were applied in the correct order
and to take countermeasures if they were not, e.g., if an MP_REMOVEADDR overtakes an MP_ADDADDR that refers to the same dataset.</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 (any path can be used) 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, the first DCCP-Data is sent from Host A to Host B with option MP_PRIO set to 4. Host A subsequently sends the second DCCP-Data with option MP_PRIO
set to 1. In this case, 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|
  +--------+--------+--------+--------+
  | Connection Identifier             |
  +--------+--------+--------+--------+
  | 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 to add a new subflow to an existing MP-DCCP
connection and REQUIRES a successful establishment of the first subflow using MP_KEY.
The Connection Identifier (CI) is the one from the peer host,
which was previously exchanged with the MP_KEY option.
MP_HMAC MUST be set when using MP_JOIN within a DCCP-Response packet; see
<xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/> for details. Similar to the setup of the first subflow, MP_JOIN also exchanges the Multipath Capable feature MP_CAPABLE as described in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>. This procedure includes the DCCP Confirm principle and thus ensures a reliable exchange of the MP_JOIN in accordance with section 6.6.4 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>.</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 was changed in
transit by a middlebox.  The 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 the need to know the source address at the receiver,
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 derived key from the both hosts Key Data described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>, 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"/> to avoid replay attacks.</t>
          <t indent="0" pn="section-3.2.2-6">If the CI cannot 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">DCCP can send a Close or Reset signal to abruptly close a
connection.  Using MP-DCCP, a regular Close or Reset only has the scope of the
subflow over which a signal was received. 
As such, it will only close the subflow and does not
affect other remaining subflows or the MP-DCCP connection (unless it is the last
subflow).
This permits break-before-make handover between
subflows.</t>
          <t indent="0" pn="section-3.2.3-2">In order to provide an MP-DCCP-level
"reset" and thus allow the abrupt closure of the MP-DCCP connection, the MP_FAST_CLOSE suboption can be used.</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-3.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-4">When Host A wants to abruptly close an MP-DCCP connection with Host B, it will send out the MP_FAST_CLOSE. The MP_FAST_CLOSE suboption MUST be sent from Host A on all subflows 
using a DCCP-Reset packet with Reset Code 13. The requirement to send the MP_FAST_CLOSE on all subflows increases the probability that Host B will receive the MP_FAST_CLOSE to take the same action. To protect from unauthorized shutdown of an MP-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-5">After sending the MP_FAST_CLOSE on all subflows, Host A MUST tear down all subflows 
and the multipath DCCP connection immediately terminates.</t>
          <t indent="0" pn="section-3.2.3-6">Upon reception of the first MP_FAST_CLOSE with successfully validated 
Key Data, Host B will send a DCCP-Reset packet response on all subflows to 
Host A with Reset Code 13 to clean potential middlebox states. 
Host B MUST then tear down all subflows and terminate the MP-DCCP connection.</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|     resvd     | 
  +---------------+---------------+---------------+---------------+
  |                     Connection Identifier                     |
  +---------------+---------------+---------------+---------------+
  |  Key Type (1) |  Key Data (1) |  Key Type (2) |  Key Data (2) |
  +---------------+---------------+---------------+---------------+
  |  Key Type (3) | ...
  +---------------+---------------+
      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 a Connection Identifier (CI) and key material between
hosts (host A, host B) for a given connection.
The CI is a unique number in the host for each multipath connection and is generated for inclusion in the first exchange of a connection with MP_KEY.  With the CI it is possible to connect other DCCP subflows to an MP-DCCP connection with MP_JOIN (<xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>). Its size of 32-bits also defines the maximum number of simultaneous MP-DCCP connections in a host to 2^32.
According to the Key related elements of the MP_KEY suboption, the Length varies between 17 and 73 bytes for a single-key message, and up to
82 bytes when all specified Key Types 0 and 255 are provided. The Key Type field 
specifies the type of the following key data. 
The set of 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-254</td>
                <td align="left" colspan="1" rowspan="1"> </td>
                <td align="left" colspan="1" rowspan="1">Reserved for future Key Types</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">255 =Experimental</td>
                <td align="left" colspan="1" rowspan="1">64</td>
                <td align="left" colspan="1" rowspan="1">For private use only</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 Data is exchanged in plain text between hosts (Host A, Host B), and the respective key
parts (KeyA, KeyB) are used by each host to generate the derived
key (d-key) by concatenating the two parts with the local key
in front. That is,
</t>
              <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.4-4.2.2">
                <li pn="section-3.2.4-4.2.2.1">
                  <t indent="0" pn="section-3.2.4-4.2.2.1.1">Host A: d-keyA=(KeyA+KeyB)</t>
                </li>
                <li pn="section-3.2.4-4.2.2.2">
                  <t indent="0" pn="section-3.2.4-4.2.2.2.1">Host B: d-keyB=(KeyB+KeyA)</t>
                </li>
              </ul>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-5">
            <dt pn="section-3.2.4-5.1">Experimental</dt>
            <dd pn="section-3.2.4-5.2">
              <t indent="0" pn="section-3.2.4-5.2.1">This Key Type allows to use other Key Data and can be used to validate other key exchange
mechanisms for a possible future specification.</t>
            </dd>
          </dl>
          <t indent="0" pn="section-3.2.4-6">Multiple keys are only permitted in the DCCP-Request message
of the handshake procedure for the first subflow. This 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-7">It is possible that not all hosts will support all key types and this specification does not
recommend or enforce the announcement of any particular Key Type within MP_KEY option as this could have security
implications. However, at least Key Type 0 (Plain Text) MUST be supported for interoperability tests
in implementations of MP-DCCP. If the key type cannot be agreed in the handshake procedure, the MP-DCCP connection
MUST fall back to not using MP-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 48-bit 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"/>. As with the standard DCCP
sequence number, the data sequence number should not start at zero, but at
a random value to make blind session hijacking more difficult, see also
section 7.2 in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>.</t>
          <t indent="0" pn="section-3.2.5-3">The MP_SEQ number space is
independent of the path individual sequence number space and MUST be
sent with all DCCP-Data and DCCP-DataACK packets.</t>
          <t indent="0" pn="section-3.2.5-4">When the sequence number space is exhausted, the sequence number MUST
be wrapped. <xref target="RFC7323" format="default" sectionFormat="of" derivedContent="RFC7323"/> provides guidance on selecting an appropriately
sized sequence number space according to the maximum segment lifetime of
TCP. 64 bits is the recommended size for TCP to avoid the sequence number
space going through within the segment lifetime. For DCCP, the Maximum
Segment Lifetime is the same as that of TCP as specified in <xref section="3.4" sectionFormat="of" target="RFC4340" format="default" derivedLink="https://rfc-editor.org/rfc/rfc4340#section-3.4" derivedContent="RFC4340"/>.
Compared to TCP, the sequence number for DCCP is incremented
per packet rather than per byte transmitted. For this reason, the 48 bits
chosen in MP_SEQ are considered sufficiently large considering the current
globally routable maximum packet size of 1500 bytes, which corresponds to
roughly 375 PiB of data within the sequence number space.</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_ADDADDR, and MP_REMOVEADDR suboptions. In addition, it provides
authentication for subflows joining an existing MP_DCCP connection,
as described in the second and third step of the handshake of a
subsequent subflow in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. For this specification of MP-DCCP,
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 in big-endian format truncated to the leftmost 160 bits (20 bytes). It is possible
that other versions of MP-DCCP will define other hash algorithms in the future.</t>
          <t indent="0" pn="section-3.2.6-3">The "Key" used for the HMAC computation is the derived key (d-keyA for Host A or d-KeyB for Host B)
described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>, while the HMAC "Message" for MP_JOIN, MP_ADDADDR and MP_REMOVEADDR must be calculated in both hosts in order to protect the multipath option when sending and to validate the multipath option when receiving, and 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">
              <t indent="0" pn="section-3.2.6-4.1.1">for MP_JOIN: The nonces of the MP_JOIN messages for which authentication
   shall be performed. Depending on whether Host A or Host B performs the HMAC-SHA256 calculation, it is carried out as follows:  </t>
              <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-4.1.2">
                <li pn="section-3.2.6-4.1.2.1">
                  <t indent="0" pn="section-3.2.6-4.1.2.1.1">MP_HMAC(A) = HMAC-SHA256(Key=d-keyA, Msg=RA+RB)</t>
                </li>
                <li pn="section-3.2.6-4.1.2.2">
                  <t indent="0" pn="section-3.2.6-4.1.2.2.1">MP_HMAC(B) = HMAC-SHA256(Key=d-keyB, Msg=RB+RA)</t>
                </li>
              </ul>
            </li>
          </ul>
          <t indent="0" pn="section-3.2.6-5">A usage example is shown in <xref target="ref-mp-dccp-handshaking" format="default" sectionFormat="of" derivedContent="Figure 21"/>.</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-6">
            <li pn="section-3.2.6-6.1">
              <t indent="0" pn="section-3.2.6-6.1.1">for MP_ADDADDR: The Address ID and Nonce with associated IP address and if defined port,
   otherwise two bytes of value 0. IP address and port MUST be used in network byte
   order (NBO). Depending on whether Host A or Host B performs the HMAC-SHA256 calculation,
   it is carried out as follows:  </t>
              <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-6.1.2">
                <li pn="section-3.2.6-6.1.2.1">
                  <t indent="0" pn="section-3.2.6-6.1.2.1.1">MP_HMAC(A) = HMAC-SHA256(Key=d-keyA, Msg=Address ID+Nonce+NBO(IP)+NBO(Port))</t>
                </li>
                <li pn="section-3.2.6-6.1.2.2">
                  <t indent="0" pn="section-3.2.6-6.1.2.2.1">MP_HMAC(B) = HMAC-SHA256(Key=d-keyB, Msg=Address ID+Nonce+NBO(IP)+NBO(Port))</t>
                </li>
              </ul>
            </li>
            <li pn="section-3.2.6-6.2">
              <t indent="0" pn="section-3.2.6-6.2.1">for MP_REMOVEADDR: Solely the Address ID.
   Depending on whether Host A or Host B performs the HMAC-SHA256 calculation,
   it is carried out as follows:  </t>
              <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-6.2.2">
                <li pn="section-3.2.6-6.2.2.1">
                  <t indent="0" pn="section-3.2.6-6.2.2.1.1">MP_HMAC(A) = HMAC-SHA256(Key=d-keyA, Msg=Address ID+Nonce)</t>
                </li>
                <li pn="section-3.2.6-6.2.2.2">
                  <t indent="0" pn="section-3.2.6-6.2.2.2.1">MP_HMAC(B) = HMAC-SHA256(Key=d-keyB, Msg=Address ID+Nonce)</t>
                </li>
              </ul>
            </li>
          </ul>
          <t indent="0" pn="section-3.2.6-7">MP_JOIN, MP_ADDADDR and MP_REMOVEADDR can co-exist or be used multiple times
within a single DCCP packet. All these multipath options require an individual
MP_HMAC option. This ensures that the MP_HMAC is correctly associated.
Otherwise, the receiver cannot validate multiple MP_JOIN, MP_ADDADDR or
MP_REMOVEADDR. Therefore, an MP_HMAC MUST directly follow its associated multipath
option. In the likely case of sending a MP_JOIN together with an 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 is associated with the
MP_ADDADDR suboption.</t>
          <t indent="0" pn="section-3.2.6-8">On the receiver side, the HMAC validation of the suboptions MUST be carried out according to
the sending sequence in which the associated MP_HMAC follows a suboption. If the suboption
cannot be validated by a receiving host because the HMAC validation fails (HMAC wrong or missing), the subsequent handling depends
on which suboption was being verified. 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>
          <t indent="0" pn="section-3.2.6-9">In the event that an MP_HMAC cannot be associated with a suboption this MP_HMAC MUST be ignored, unless
it is a single MP_HMAC that was sent in a DCCP-Ack corresponding to a DCCP response packet with MP_JOIN (penultimate arrow in <xref target="ref-mp-dccp-handshaking" format="default" sectionFormat="of" derivedContent="Figure 21"/>).</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 and age
(represented in milliseconds) that belong to the path over which this information is transmitted.
This information is 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. This covers a period of
approximately 1193 hours.</t>
          <t indent="0" pn="section-3.2.7-4">The Field RTT type indicates the type of RTT estimation, according to the following description:</t>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-5">
            <dt pn="section-3.2.7-5.1">Raw RTT (=0)</dt>
            <dd pn="section-3.2.7-5.2">
              <t indent="0" pn="section-3.2.7-5.2.1">Raw RTT value of the last Datagram Round-Trip</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-6">
            <dt pn="section-3.2.7-6.1">Min RTT (=1)</dt>
            <dd pn="section-3.2.7-6.2">
              <t indent="0" pn="section-3.2.7-6.2.1">Min RTT value over a given period</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-7">
            <dt pn="section-3.2.7-7.1">Max RTT (=2)</dt>
            <dd pn="section-3.2.7-7.2">
              <t indent="0" pn="section-3.2.7-7.2.1">Max RTT value over a given period</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-8">
            <dt pn="section-3.2.7-8.1">Smooth RTT (=3)</dt>
            <dd pn="section-3.2.7-8.2">
              <t indent="0" pn="section-3.2.7-8.2.1">Averaged RTT value over a given period</t>
            </dd>
          </dl>
          <t indent="0" pn="section-3.2.7-9">Each CCID specifies the algorithms and period applied for their corresponding RTT estimations.The availability of the above described types, to be used in the MP_RTT option, depends on the CCID implementation in place.</t>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-10">
            <dt pn="section-3.2.7-10.1">Age</dt>
            <dd pn="section-3.2.7-10.2">
              <t indent="0" pn="section-3.2.7-10.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-11">An example of a flow showing  the exchange of path individual 
RTT information is provided in
<xref target="ref-MP_RTT_example" format="default" sectionFormat="of" derivedContent="Figure 15"/>. 
RTT1 refers to the first path and RTT2 to the second path. The
RTT values could be extracted from the sender's Congestion Control procedure and are conveyed to the receiving host using the 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 the down-link and up-link directions and there is no jitter, 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-12.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) by which a host can be reached. This can be sent at any
time during an existing MP-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 
can simultaneously advertise new addresses.</t>
          <t indent="0" pn="section-3.2.8-2">The Length is variable depending on the address family (IPv4 or IPv6) and whether a port number is
used. This field is in range between 12 and 26 bytes.</t>
          <t indent="0" pn="section-3.2.8-3">The Nonce is a 32-bit random value that is generated locally for
each MP_ADDADDR option and is used in the HMAC calculation process
to prevent replay attacks.</t>
          <t indent="0" pn="section-3.2.8-4">The final 2 bytes, optionally specify the DCCP port number to
use, and their presence 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 host 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-5">Along with the MP_ADDADDR option an 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 d-KeyA, and in the case of Host B,
d-KeyB.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID, Nonce, IP address, and port number that precede the HMAC in the
MP_ADDADDR option.  If the port number is not present in the MP_ADDADDR option,
the HMAC message will include 2 bytes 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 MUST silently ignore the option.</t>
          <t indent="0" pn="section-3.2.8-6">The presence of an 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-7.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   |
  +---------------+---------------+-------+-------+---------------+
  |                             Nonce                             |
  +-------------------------------+-------------------------------+
  |          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-8">Each address has an Address ID that could be used for uniquely
identifying the address within a connection for address removal.
Each host maintains a list of unique Address IDs and it manages these as it wishes. 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-9">All Address IDs learned via either MP_JOIN or MP_ADDADDR can be stored
by the receiver in a data structure that gathers all the
Address-ID-to-address mappings for a connection (identified by a CI
pair). In this way, there is a stored mapping between the Address ID,
the observed source address, and the CI pair for future processing of control
information for a connection. Note that an implementation
MAY discard incoming address advertisements. Reasons for this are for example:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.8-10">
            <li pn="section-3.2.8-10.1">
              <t indent="0" pn="section-3.2.8-10.1.1">to avoid the required mapping state, or</t>
            </li>
            <li pn="section-3.2.8-10.2">
              <t indent="0" pn="section-3.2.8-10.2.1">because advertised addresses are of no use to it.</t>
            </li>
          </ul>
          <t indent="0" pn="section-3.2.8-11">Possible scenarios in which this applies are the lack of resources to store
a mapping or when IPv6 addresses are advertised even though the host only
supports IPv4. Therefore, a host MUST treat address announcements as soft state.
However, a sender MAY choose to update the announcements periodically to
overcome temporary limitations.</t>
          <t indent="0" pn="section-3.2.8-12">A host
MAY advertise private addresses, e.g., because there is a 
NAT on the path.  It is
desirable to allow this, since there could be cases where both hosts
have additional interfaces on the same private network. The advertisement
of broadcast or multicast IP addresses MUST be ignored by the recipient of
this option, as it is not permitted according to the unicast principle of the
basic DCCP.</t>
          <t indent="0" pn="section-3.2.8-13">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 CI that
uniquely identifies a connection to the receiving host. If the
CI is unknown, the host MUST send a DCCP-Reset.</t>
          <t indent="0" pn="section-3.2.8-14">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 MUST NOT
announce that address unless the sending host has new knowledge about
the possibility to do so. This 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-15">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"/>). This ensures reliable exchange of address
information.</t>
          <t indent="0" pn="section-3.2.8-16">A host that receives an MP_ADDADDR, but finds at connection set up
that the IP address and port number is unsuccessful, SHOULD NOT perform
further connection attempts to this address/port combination for this
connection to save resources. If a sender, however, wishes to trigger a new incoming
connection attempt on a previously advertised address/port combination
can therefore refresh the MP_ADDADDR information by sending the option again.</t>
          <t indent="0" pn="section-3.2.8-17">A host MAY send an MP_ADDADDR message with an already assigned Address
ID using the IP Address previously assigned to this Address ID. The new
MP_ADDADDR could have the same port number or a different port number. The
receiver MUST silently ignore the MP_ADDADDR if the IP Address is not the
same as that previously assigned to this Address ID. 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>
        </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. The peer can remove a previously 
added address with an Address ID from a connection
using the Remove Address (MP_REMOVEADDR) suboption. This
will terminate any subflows currently using that address.</t>
          <t indent="0" pn="section-3.2.9-2">MP_REMOVEADDR is only used to close already established subflows that
have an invalid address. Functional flows with a valid address MUST be
closed with a DCCP Close exchange (as with regular DCCP) instead of
using MP_REMOVEADDR. For more information see <xref target="closing" format="default" sectionFormat="of" derivedContent="Section 3.5"/>.</t>
          <t indent="0" pn="section-3.2.9-3">The Nonce is a 32-bit random value that is generated locally for
each MP_REMOVEADDR option and is used in the HMAC calculation process
to prevent replay attacks.</t>
          <t indent="0" pn="section-3.2.9-4">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 d-KeyA, and in the case of Host B,
d-KeyB.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID.</t>
          <t indent="0" pn="section-3.2.9-5">The rationale for using a 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 modified 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 MUST silently ignore the option.</t>
          <t indent="0" pn="section-3.2.9-6">A receiver MUST include an MP_SEQ (<xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>) in a DCCP datagram that sends
an MP_REMOVEADDR. 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-7">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"/>). This ensures reliable exchange of address
information. To avoid inconsistent states, the sender releases 
the address ID only after MP_REMOVEADDR has been confirmed.</t>
          <t indent="0" pn="section-3.2.9-8">The sending and receiving of this message SHOULD trigger the closing procedure
described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> between the client and the server on the affected
subflow(s), if possible. This helps remove middlebox state, before
removing any local state.</t>
          <t indent="0" pn="section-3.2.9-9">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-10.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  |
+---------------+---------------+---------------+---------------+
|                             Nonce                             |
+-------------------------------+-------------------------------+
     Type=46        Length=8         MP_OPT=8

-> followed by MP_HMAC option
]]></artwork>
          </figure>
        </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">The path priority signaled with the MP_PRIO option provides hints 
for the packet scheduler when making decisions about which path to use for 
payload traffic.
When a single specific path from the set of available
paths is treated with higher priority compared to the others
when making scheduling decisions for payload traffic, a host can 
signal such change in priority to the peer.
This could be used when there are different costs for
using different paths (e.g., Wi-Fi is free while cellular has limit on
volume, 5G has higher energy consumption). The priority of a path
could also change, for example, when a mobile host runs out
of battery, the usage of only a single path may be the preferred choice
of the user.</t>
          <t indent="0" pn="section-3.2.10-2">The MP_PRIO suboption, shown below, can be used to set a priority value
for the subflow 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 the 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">
              <t indent="0" pn="section-3.2.10-5.1.1">0: Do not use. The path is not available.</t>
            </li>
            <li pn="section-3.2.10-5.2">
              <t indent="0" pn="section-3.2.10-5.2.1">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.</t>
            </li>
            <li pn="section-3.2.10-5.3">
              <t indent="0" pn="section-3.2.10-5.3.1">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.</t>
            </li>
            <li pn="section-3.2.10-5.4">
              <t indent="0" pn="section-3.2.10-5.4.1">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.</t>
            </li>
          </ul>
          <t indent="0" pn="section-3.2.10-6">Example use cases include:</t>
          <ol spacing="normal" type="1" indent="adaptive" start="1" pn="section-3.2.10-7"><li pn="section-3.2.10-7.1" derivedCounter="1.">
              <t indent="0" pn="section-3.2.10-7.1.1">Setting Wi-Fi path to Primary and Cellular paths to Secondary. In this case
   Wi-Fi will be used and Cellular will be used 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 Wi-Fi path can provide, indicating a 
   clear priority of the Wi-Fi path over the Cellular due to, e.g., cost reasons.</t>
            </li>
            <li pn="section-3.2.10-7.2" derivedCounter="2.">
              <t indent="0" pn="section-3.2.10-7.2.1">Setting Wi-Fi path to Primary and Cellular to Standby. In this case Wi-Fi
   will be used and Cellular will be used only if the Wi-Fi path is not available.</t>
            </li>
            <li pn="section-3.2.10-7.3" derivedCounter="3.">
              <t indent="0" pn="section-3.2.10-7.3.1">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>
            </li>
          </ol>
          <t indent="0" pn="section-3.2.10-8">If not specified, the default behavior is to always use a path for 
packet scheduling decisions (MP_PRIO=3), when the path has been established and 
added to an existing MP-DCCP connection. At least one path ought to have an 
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 
schedule when the multipath scheduler strictly respects MP_PRIO value 0.
To ensure reliable transmission, the MP_PRIO suboption MUST be acknowledged via an MP_CONFIRM 
(see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>).</t>
          <t indent="0" pn="section-3.2.10-9">The relative ratio of the primary path values 3-15 depend on the path usage strategy, which is described in more detail in <xref target="path_usage_strategy" format="default" sectionFormat="of" derivedContent="Section 3.11"/>. In the case of path mobility (<xref target="path_mobility" format="default" sectionFormat="of" derivedContent="Section 3.11.1"/>), only one path can be used at a time and MUST be the appropriate one that has the highest available priority value including also the prio numbers 1 and 2. In the other case of concurrent path usage (<xref target="concurrent_usage" format="default" sectionFormat="of" derivedContent="Section 3.11.2"/>), the definition is up to the multipath scheduler logic.</t>
          <t indent="0" pn="section-3.2.10-10">An MP_SEQ (<xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>) MUST be present in a DCCP datagram
in which the MP_PRIO suboption 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). 
When  a DCCP-CloseReq is used, the following DCCP-Close MUST also carry the MP_CLOSE 
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 from unauthorized shutdown of a multi-path connection, the selected Key Data of 
the peer host during the handshaking procedure MUST be included in by the MP_CLOSE option 
and must be validated by the peer host. 
Note, the 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 the first DCCP-CloseReq carrying an 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. 
The MP-DCCP connection socket on the host sending the DCCP-Close reflects the state of 
the initial subflow 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 an 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 an 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-multipath-opti">Experimental Multipath option MP_EXP for private use</name>
          <t indent="0" pn="section-3.2.12-1">This section reserves a Multipath option to define and specify any experimental additional feature for improving and optimization of the MP-DCCP protocol. This
option could be applicable to specific environments or scenarios according to potential new requirements and is 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 + Change R (MP_CAPABLE,...)  |
     |----- MP_KEY(CI-A + KeyA(1), KeyA(2),...) ---------->|
     |<------------------- MP_KEY(CI-B + KeyB) ------------|
     |       DCCP-Response +  Confirm L (MP_CAPABLE, ...)  |
     |             |                                       |
     |   DCCP-Ack  |                                       |
     |---------------------------------------------------->|
     |<----------------------------------------------------|
     |   DCCP-Ack  |                                       |
     |             |                                       |
     |             |DCCP-Request + Change R(MP_CAPABLE,...)|
     |             |--- MP_JOIN(CI-B,RA) ----------------->|
     |             |<------MP_JOIN(CI-A,RB) + MP_HMAC(B)---|
     |             |DCCP-Response+Confirm L(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">
            <t indent="0" pn="section-3.3-4.1.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_KEY option with a Host-specific CI-A and a KeyA for
each of the supported key types as described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>. CI-A is a unique identifier during the
lifetime of an MP-DCCP connection.</t>
          </li>
          <li pn="section-3.3-4.2">
            <t indent="0" pn="section-3.3-4.2.1">Host B sends a DCCP-Response with Confirm feature for
MP-Capable and the MP_Key option with a unique Host-specific CI-B and a single Host-specific KeyB.
The type of the key is chosen from the list of supported types
from the previous request.</t>
          </li>
          <li pn="section-3.3-4.3">
            <t indent="0" pn="section-3.3-4.3.1">Host A sends a DCCP-Ack to confirm the proper key exchange.</t>
          </li>
          <li pn="section-3.3-4.4">
            <t indent="0" pn="section-3.3-4.4.1">Host B sends a DCCP-Ack to complete the handshake and set both connection ends to the OPEN state.</t>
          </li>
        </ul>
        <t indent="0" pn="section-3.3-5">It should be noted that DCCP is protected against corruption of DCCP header data (section 9 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>), so no additional mechanisms beyond the general confirmation are required to ensure that the header data has been properly received.</t>
        <t indent="0" pn="section-3.3-6">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-7">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-8">
          <li pn="section-3.3-8.1">
            <t indent="0" pn="section-3.3-8.1.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_JOIN option with Host B's CI-B,
obtained during the initial handshake. Additionally, an own random nonce
RA is transmitted with the MP_JOIN.</t>
          </li>
          <li pn="section-3.3-8.2">
            <t indent="0" pn="section-3.3-8.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 CI-A and a random nonce RB together with the computed MP_HMAC.
As specified in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>, 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-8.2.2">
MP_HMAC(B) = HMAC-SHA256(Key=d-keyB, Msg=RB+RA)</t>
          </li>
          <li pn="section-3.3-8.3">
            <t indent="0" pn="section-3.3-8.3.1">Host A sends a DCCP-Ack with the HMAC computed for the DCCP-Response.
As specified in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>, 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-8.3.2">
MP_HMAC(A) = HMAC-SHA256(Key=d-keyA, Msg=RA+RB)</t>
          </li>
          <li pn="section-3.3-8.4">
            <t indent="0" pn="section-3.3-8.4.1">Host B sends a DCCP-Ack to confirm the HMAC and to conclude the
handshaking.</t>
          </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:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.1-2">
            <li pn="section-3.4.1-2.1">
              <t indent="0" pn="section-3.4.1-2.1.1">an identifier (id 2) for the new IP address which is used as a reference in subsequent control exchanges.</t>
            </li>
            <li pn="section-3.4.1-2.2">
              <t indent="0" pn="section-3.4.1-2.2.1">a Nonce value to prevent replay attacks</t>
            </li>
            <li pn="section-3.4.1-2.3">
              <t indent="0" pn="section-3.4.1-2.3.1">the IP address of the new path (A2_IP)</t>
            </li>
            <li pn="section-3.4.1-2.4">
              <t indent="0" pn="section-3.4.1-2.4.1">A pair of bytes 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>
            </li>
          </ul>
          <t indent="0" pn="section-3.4.1-3">According to <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>, the following options are required in a packet carrying MP_ADDADDR:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.1-4">
            <li pn="section-3.4.1-4.1">
              <t indent="0" pn="section-3.4.1-4.1.1">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"/></t>
            </li>
            <li pn="section-3.4.1-4.2">
              <t indent="0" pn="section-3.4.1-4.2.1">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>
            </li>
          </ul>
          <t indent="0" pn="section-3.4.1-5">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:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.1-6">
            <li pn="section-3.4.1-6.1">
              <t indent="0" pn="section-3.4.1-6.1.1">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</t>
            </li>
            <li pn="section-3.4.1-6.2">
              <t indent="0" pn="section-3.4.1-6.2.1">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>
            </li>
          </ul>
          <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-7.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_ADDADDR(id 2, Nonce, 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:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.2-2">
            <li pn="section-3.4.2-2.1">
              <t indent="0" pn="section-3.4.2-2.1.1">an identifier (id 2) for the IP address to remove (A2_IP) and which was specified in a previous MP_ADDADDR message.</t>
            </li>
            <li pn="section-3.4.2-2.2">
              <t indent="0" pn="section-3.4.2-2.2.1">a Nonce value to prevent replay attacks</t>
            </li>
          </ul>
          <t indent="0" pn="section-3.4.2-3">According to <xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>, the following options are required in a packet carrying MP_REMOVEADDR:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.2-4">
            <li pn="section-3.4.2-4.1">
              <t indent="0" pn="section-3.4.2-4.1.1">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"/></t>
            </li>
            <li pn="section-3.4.2-4.2">
              <t indent="0" pn="section-3.4.2-4.2.1">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>
            </li>
          </ul>
          <t indent="0" pn="section-3.4.2-5">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:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.4.2-6">
            <li pn="section-3.4.2-6.1">
              <t indent="0" pn="section-3.4.2-6.1.1">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</t>
            </li>
            <li pn="section-3.4.2-6.2">
              <t indent="0" pn="section-3.4.2-6.2.1">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>
            </li>
          </ul>
          <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-7.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_REMOVEADDR(id 2, Nonce) +         |
     |------- 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-closing-an-mp-dccp-connecti">Closing an 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 MUST 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 fall back. 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 Multipath options, 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 fall back to regular DCCP. If this is not 
possible the connection MUST be closed.</t>
        <t indent="0" pn="section-3.6-3">If the endpoints fail to agree on the protocol version to use during the Multipath
Capable feature negotiation, the connection MUST either be closed or fall back
to regular DCCP. 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 fall back to regular DCCP.</t>
        <t indent="0" pn="section-3.6-4">The fall back 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
CI used in MP_JOIN (<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 KeyA/KeyB 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. The same procedure applies if the MP option is unknown.</t>
      </section>
      <section anchor="state-diagram" numbered="true" removeInRFC="false" toc="include" pn="section-3.7">
        <name slugifiedName="name-state-diagram">State Diagram</name>
        <t indent="0" pn="section-3.7-1">The MP-DCCP per subflow state transitions to a large extent follow the
state transitions defined for DCCP in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, with some modifications 
due to the MP-DCCP four-way handshake and fast close procedures. The state diagram below
illustrates the most common state transitions.  The diagram is illustrative.
For example, there are arcs (not shown) from several additional states 
to TIMEWAIT, contingent on the receipt of a valid DCCP-Reset.</t>
        <t indent="0" pn="section-3.7-2">The states transitioned
when moving from the CLOSED to OPEN state during the four-way handshake
remain the same as for DCCP, but it is no longer possible to transmit
application data while in the REQUEST state. The fast close procedure
can be triggered by either the client or the server and results in the transmission
of a Reset packet. The fast close procedure moves the state of the client and server
directly to TIMEWAIT and CLOSED, respectively.</t>
        <figure anchor="ref-mp-dccp-state-transition" align="left" suppress-title="false" pn="figure-24">
          <name slugifiedName="name-most-common-state-transitio">Most common state transitions of an MP-DCCP subflow</name>
          <artwork align="left" pn="section-3.7-3.1"><![CDATA[
   +----------------------------+    +------------------------------+
   |                            v    v                              |
   |                         +----------+                           |
   |           +-------------+  CLOSED  +-------------+             |
   |           | passive     +----------+   active    |             |
   |           |  open                       open     |             |
   |           |                          snd Request |             |
   |           v                                      v             |
   |     +-----------+                           +----------+       |
   |     |  LISTEN   |                           | REQUEST  |       |
   |     +-----+-----+                           +----+-----+       |
   |           | rcv Request             rcv Response |             |
   |           | snd Response              snd Ack    |             |
   |           v                                      v             |
   |     +-----------+                           +----------+       |
   |     |  RESPOND  |                           | PARTOPEN |       |
   |     +-----+-----+                           +----+-----+       |
   |           | rcv Ack             rcv Ack/DataAck  |             |
   |           | snd Ack                              |             |
   |           |             +-----------+            |             |
   |           +------------>|   OPEN    |<-----------+             |
   |                         +--+-+-+-+--+                          |
   |        server active close | | | |   active close              |
   |            snd CloseReq    | | | | or rcv CloseReq             |
   |                            | | | |    snd Close                |
   |                            | | | |                             |
   |     +-----------+          | | | |            +----------+     |
   |     | CLOSEREQ  |<---------+ | | +----------->| CLOSING  |     |
   |     +-----+-----+            | |              +----+-----+     |
   |           | rcv Close        | |         rcv Reset |           |
   |           | snd Reset        | |                   |           |
   |           |                  | | active FastClose  |           |
   |<----------+        rcv Close | | or rcv FastClose  v           |
   |   or server active FastClose | | snd Reset    +----+-----+     |
   |      or server rcv FastClose | +------------->| TIMEWAIT |     |
   |                    snd Reset |                +----+-----+     |
   +------------------------------+                     |           |
                                                        +-----------+
                                                    2MSL timer expires
]]></artwork>
        </figure>
      </section>
      <section anchor="congestion-control-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.8">
        <name slugifiedName="name-congestion-control-consider">Congestion Control Considerations</name>
        <t indent="0" pn="section-3.8-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="mps" numbered="true" removeInRFC="false" toc="include" pn="section-3.9">
        <name slugifiedName="name-maximum-packet-size-conside">Maximum Packet Size Considerations</name>
        <t indent="0" pn="section-3.9-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="maximum-number-of-subflows-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.10">
        <name slugifiedName="name-maximum-number-of-subflows-">Maximum number of Subflows Considerations</name>
        <t indent="0" pn="section-3.10-1">MP-DCCP does not support any explicit procedure to negotiate
the maximum number of subflows between endpoints. In practical
scenarios, however, there will be resource limitations on the host
or use cases that do not benefit from additional subflows.</t>
        <t indent="0" pn="section-3.10-2">It is RECOMMENDED to limit the number of subflows in implementations and to reject incoming subflow requests with a DCCP-Reset using the Reset Code "too busy" according to <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> if the resource limit is exceeded or it is known that the multipath connection will not benefit from further subflows. Likewise, the host that wants to create the subflows is RECOMMENDED to consider the aspect of available resources and the possible gains.</t>
        <t indent="0" pn="section-3.10-3">To avoid further inefficiencies with subflows due to short-lived connections, it MAY be useful to delay the start of additional subflows. The decision on the initial number of subflows can be based on the occupancy of the socket buffer and/or the timing.</t>
        <t indent="0" pn="section-3.10-4">While in the socket buffer based approach the number of initial subflows can be derived by opening new subflows until their initial windows cover the amount of buffered application data, the timing based approach delays the start of additional subflows based on a certain time period, load or knowledge of traffic and path properties. The delay based approach also provides resilience for low-bandwidth but long-lived applications. All this could also be supported by advanced APIs that signal application traffic requests to the MP-DCCP.</t>
      </section>
      <section anchor="path_usage_strategy" numbered="true" removeInRFC="false" toc="include" pn="section-3.11">
        <name slugifiedName="name-path-usage-strategies">Path usage strategies</name>
        <t indent="0" pn="section-3.11-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 an 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.11.1">
          <name slugifiedName="name-path-mobility">Path mobility</name>
          <t indent="0" pn="section-3.11.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 an 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 the MP_PRIO suboption or if not available pick the most divergent source-destination pair from the original used source-destination pair.</t>
          <ul empty="true" bare="false" indent="3" spacing="normal" pn="section-3.11.1-2">
            <li pn="section-3.11.1-2.1">
              <t indent="0" pn="section-3.11.1-2.1.1">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>
            </li>
          </ul>
        </section>
        <section anchor="concurrent_usage" numbered="true" removeInRFC="false" toc="include" pn="section-3.11.2">
          <name slugifiedName="name-concurrent-path-usage">Concurrent path usage</name>
          <t indent="0" pn="section-3.11.2-1">Different to a path mobility strategy, the selection between MP-DCCP
subflows is 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.<br/>
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.
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.11.2-2">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.11.2-3">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 the
general Internet, the framework specified in this document could be used to 
provide an IETF recommended method for MP-DCCP.
 </t>
          <t indent="0" pn="section-3.11.2-4"> </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">DCCP <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> 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. The security objectives for MP-DCCP are:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-4-3">
        <li pn="section-4-3.1">
          <t indent="0" pn="section-4-3.1.1">Provide assurance that the parties involved in an
MP-DCCP handshake procedure are identical to those in the original DCCP connection.</t>
        </li>
        <li pn="section-4-3.2">
          <t indent="0" pn="section-4-3.2.1">Before a path is used, verify that the new advertised path is valid for receiving traffic.</t>
        </li>
        <li pn="section-4-3.3">
          <t indent="0" pn="section-4-3.3.1">Provide replay protection, i.e., ensure that a request to add/remove a
subflow is 'fresh'.</t>
        </li>
        <li pn="section-4-3.4">
          <t indent="0" pn="section-4-3.4.1">Allow a party to limit the number of subflows that it allows.</t>
        </li>
      </ul>
      <t indent="0" pn="section-4-4">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"/>, <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/> 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. Depending on the security requirements, different Key Types can
be negotiated in the handshake procedure or must follow the fallback scenario
described in <xref target="security" format="default" sectionFormat="of" derivedContent="Section 4"/>. If there are security requirements that go beyond the
capabilities of Key Type 0, then it is RECOMMENDED that Key Type 0 is not enabled
to avoid downgrade attacks that result in the key being exchanged as plain text.
To ease demultiplexing while not revealing
cryptographic material, subsequent subflows use the initially exchanged
CI information. The keys exchanged once at the beginning 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 of subsequent subflows are the same as in the original
connection setup. This 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) for both
parties -- 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) is designed to 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"/>) is designed to ensure that this
does not set 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>
      <t indent="0" pn="section-4-6">As described in <xref target="mps" format="default" sectionFormat="of" derivedContent="Section 3.9"/>, a Maximum Packet Size (MPS) is maintained for an MP-DCCP connection.
If MP-DCCP exposes a minimum MPS across all paths,
any change to one path impacts the sender for all paths.
To mitigate attacks that seek to force a low MPS, MP-DCCP
could detect an attempt to reduce the MPS less than a minimum MPS, and then
stop using these paths.</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). When 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 middleboxes operating as NATs are provided in <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>
      <t indent="0" pn="section-5-3">The security impact of MP-DCCP aware middleboxes is discussed in <xref target="security" format="default" sectionFormat="of" derivedContent="Section 4"/>.</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="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/> defines 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, Olivier Bonaventure, Gorry Fairhurst 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 the RFC Required policy of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>, Section 4.7.  This document defines one new value which is requested to be allocated in the IANA DCCP Feature Numbers registry and three new registries to be allocated in the DCCP registry group.</t>
      <section anchor="new-multipath-capable-dccp-feature" numbered="true" removeInRFC="false" toc="include" pn="section-8.1">
        <name slugifiedName="name-new-multipath-capable-dccp-">New Multipath Capable DCCP feature</name>
        <t indent="0" pn="section-8.1-1">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">10 suggested</td>
              <td align="center" colspan="1" rowspan="1">Multipath Capable</td>
              <td align="center" colspan="1" rowspan="1">[ThisDocument]</td>
            </tr>
          </tbody>
        </table>
        <ul empty="true" bare="false" indent="3" spacing="normal" pn="section-8.1-3">
          <li pn="section-8.1-3.1">
            <t indent="0" pn="section-8.1-3.1.1">Note to RFC Editor: Please replace [ThisDocument] with a reference to the final RFC</t>
          </li>
        </ul>
      </section>
      <section anchor="new-mp-dccp-version-registry" numbered="true" removeInRFC="false" toc="include" pn="section-8.2">
        <name slugifiedName="name-new-mp-dccp-version-registr">New MP-DCCP version registry</name>
        <t indent="0" pn="section-8.2-1"><xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/> specifies 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">0</td>
              <td align="center" colspan="1" rowspan="1">0000 suggested</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>
        <ul empty="true" bare="false" indent="3" spacing="normal" pn="section-8.2-3">
          <li pn="section-8.2-3.1">
            <t indent="0" pn="section-8.2-3.1.1">Note to RFC Editor: Please replace [ThisDocument] with a reference to the final RFC</t>
          </li>
        </ul>
        <t indent="0" pn="section-8.2-4">Future MP-DCCP versions 1 to 15 are assigned from this registry using the RFC Required policy (Section 4.7 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      </section>
      <section anchor="new-multipath-option-and-registry" numbered="true" removeInRFC="false" toc="include" pn="section-8.3">
        <name slugifiedName="name-new-multipath-option-and-re">New Multipath option and registry</name>
        <t indent="0" pn="section-8.3-1">This document requests IANA to assign value 46 in the DCCP "Option Types" registry to "Multipath Options", as described in <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/>.</t>
        <t indent="0" pn="section-8.3-2">IANA is requested to create a new 'Multipath Options' 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 'Multipath Options' 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-multipath-options-registry">Multipath Options registry</name>
          <thead>
            <tr>
              <th align="center" colspan="1" rowspan="1">Multipath Option</th>
              <th align="center" colspan="1" rowspan="1">Name</th>
              <th align="center" colspan="1" rowspan="1">Description</th>
              <th align="center" colspan="1" rowspan="1">Reference</th>
            </tr>
          </thead>
          <tbody>
            <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 suboption 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 Multipath Options</td>
              <td align="center" colspan="1" rowspan="1"> </td>
            </tr>
          </tbody>
        </table>
        <t indent="0" pn="section-8.3-4">Future Multipath options with MP_OPT&gt;11 are assigned from this registry using the RFC Required policy (Section 4.7 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      </section>
      <section anchor="new-dccp-reset-code" numbered="true" removeInRFC="false" toc="include" pn="section-8.4">
        <name slugifiedName="name-new-dccp-reset-code">New DCCP Reset Code</name>
        <t indent="0" pn="section-8.4-1">IANA is requested to assign a new DCCP-Reset Code value 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>
      </section>
      <section anchor="new-multipath-key-type-registry" numbered="true" removeInRFC="false" toc="include" pn="section-8.5">
        <name slugifiedName="name-new-multipath-key-type-regi">New Multipath Key Type registry</name>
        <t indent="0" pn="section-8.5-1">IANA is requested to assign for this version of the MP-DCCP protocol a new 'Multipath Key Type' registry containing two different suboptions 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-254 (decimal) inclusive remain unassigned in this here specified version 0 of the protocol and are assigned via RFC 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-multipath-key-type-registry">Multipath Key Type registry with the MP_KEY Key Types for key data exchange on different paths</name>
          <thead>
            <tr>
              <th align="center" colspan="1" rowspan="1">Type</th>
              <th align="center" colspan="1" rowspan="1">Name</th>
              <th align="center" colspan="1" rowspan="1">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">3-254</td>
              <td align="center" colspan="1" rowspan="1">Unassigned</td>
              <td align="center" colspan="1" rowspan="1">Reserved for future use</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">255</td>
              <td align="center" colspan="1" rowspan="1">Experimental</td>
              <td align="center" colspan="1" rowspan="1">For private use only</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>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references" pn="section-9">
      <name slugifiedName="name-references">References</name>
      <references anchor="sec-normative-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="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="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>
        <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="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>
      </references>
      <references anchor="sec-informative-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-dccp-udp-header-conversion" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-amend-tsvwg-dccp-udp-header-conversion-01" derivedAnchor="I-D.amend-tsvwg-dccp-udp-header-conversion">
          <front>
            <title>Lossless and overhead free DCCP - UDP header conversion (U-DCCP)</title>
            <author fullname="Markus Amend" initials="M." surname="Amend">
              <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">   The Datagram Congestion Control Protocol (DCCP) is a transport-layer
   protocol that provides upper layers with the ability to use non-
   reliable congestion-controlled flows.  DCCP is not widely deployed in
   the Internet, and the reason for that can be defined as a typical
   example of a chicken-egg problem.  Even if an application developer
   decided to use DCCP, the middle-boxes like firewalls and NATs would
   prevent DCCP end-to-end since they lack support for DCCP.  Moreover,
   as long as the protocol penetration of DCCP does not increase, the
   middle-boxes will not handle DCCP properly.  To overcome this
   challenge, NAT/NATP traversal and UDP encapsulation for DCCP is
   already defined.  However, the former requires special middle-box
   support and the latter introduces overhead.  The recent proposal of a
   multipath extension for DCCP further underlines the challenge of
   efficient middle-box passing as its main goal is to be applied over
   the Internet, traversing numerous uncontrolled middle-boxes.  This
   document introduces a new solution which disguises DCCP during
   transmission as UDP without requiring middle-box modification or
   introducing any overhead.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-amend-tsvwg-dccp-udp-header-conversion-01"/>
          <refcontent>Work in Progress</refcontent>
        </reference>
        <reference anchor="IETF105.Slides" target="https://datatracker.ietf.org/meeting/105/materials/slides-105-tsvwg-sessa-62-dccp-extensions-for-multipath-operation-00" quoteTitle="true" derivedAnchor="IETF105.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="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="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="RFC5280" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5280" derivedAnchor="RFC5280">
          <front>
            <title>Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
            <author fullname="D. Cooper" initials="D." surname="Cooper"/>
            <author fullname="S. Santesson" initials="S." surname="Santesson"/>
            <author fullname="S. Farrell" initials="S." surname="Farrell"/>
            <author fullname="S. Boeyen" initials="S." surname="Boeyen"/>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <author fullname="W. Polk" initials="W." surname="Polk"/>
            <date month="May" year="2008"/>
            <abstract>
              <t indent="0">This memo profiles the X.509 v3 certificate and X.509 v2 certificate revocation list (CRL) for use in the Internet. An overview of this approach and model is provided as an introduction. The X.509 v3 certificate format is described in detail, with additional information regarding the format and semantics of Internet name forms. Standard certificate extensions are described and two Internet-specific extensions are defined. A set of required certificate extensions is specified. The X.509 v2 CRL format is described in detail along with standard and Internet-specific extensions. An algorithm for X.509 certification path validation is described. An ASN.1 module and examples are provided in the appendices. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5280"/>
          <seriesInfo name="DOI" value="10.17487/RFC5280"/>
        </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="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="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="RFC7323" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc7323" derivedAnchor="RFC7323">
          <front>
            <title>TCP Extensions for High Performance</title>
            <author fullname="D. Borman" initials="D." surname="Borman"/>
            <author fullname="B. Braden" initials="B." surname="Braden"/>
            <author fullname="V. Jacobson" initials="V." surname="Jacobson"/>
            <author fullname="R. Scheffenegger" initials="R." role="editor" surname="Scheffenegger"/>
            <date month="September" year="2014"/>
            <abstract>
              <t indent="0">This document specifies a set of TCP extensions to improve performance over paths with a large bandwidth * delay product and to provide reliable operation over very high-speed paths. It defines the TCP Window Scale (WS) option and the TCP Timestamps (TS) option and their semantics. The Window Scale option is used to support larger receive windows, while the Timestamps option can be used for at least two distinct mechanisms, Protection Against Wrapped Sequences (PAWS) and Round-Trip Time Measurement (RTTM), that are also described herein.</t>
              <t indent="0">This document obsoletes RFC 1323 and describes changes from it.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7323"/>
          <seriesInfo name="DOI" value="10.17487/RFC7323"/>
        </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="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="RFC9293" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc9293" derivedAnchor="RFC9293">
          <front>
            <title>Transmission Control Protocol (TCP)</title>
            <author fullname="W. Eddy" initials="W." role="editor" surname="Eddy"/>
            <date month="August" year="2022"/>
            <abstract>
              <t indent="0">This document specifies the Transmission Control Protocol (TCP). TCP is an important transport-layer protocol in the Internet protocol stack, and it has continuously evolved over decades of use and growth of the Internet. Over this time, a number of changes have been made to TCP as it was specified in RFC 793, though these have only been documented in a piecemeal fashion. This document collects and brings those changes together with the protocol specification from RFC 793. This document obsoletes RFC 793, as well as RFCs 879, 2873, 6093, 6429, 6528, and 6691 that updated parts of RFC 793. It updates RFCs 1011 and 1122, and it should be considered as a replacement for the portions of those documents dealing with TCP requirements. It also updates RFC 5961 by adding a small clarification in reset handling while in the SYN-RECEIVED state. The TCP header control bits from RFC 793 have also been updated based on RFC 3168.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="7"/>
          <seriesInfo name="RFC" value="9293"/>
          <seriesInfo name="DOI" value="10.17487/RFC9293"/>
        </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="RFC9293" format="default" sectionFormat="of" derivedContent="RFC9293"/>.
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
differently 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 delivery provided by 
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 process 
out-of-sequence data (e.g., through adaptive audio and video buffers), 
and so additional reordering support might not be necessary. The addition of optional 
reordering mechanisms are 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 could 
occur, because DCCP does not provide mechanisms to restore the original packet order.</t>
      <t indent="0" pn="section-appendix.a-9">In contrast to TCP, the receiver processing for MPTCP adopted a rigid
"just wait" approach, because TCP guarantees reliable in-order 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+y96XLbWJYw+B9PgXBGTEplkhYlr6rOnKZlu1JdXtSWsqor
6uvJgEhIQpokWABoWWX7i36NiZh5uX6SOfs9FwAlOdNVvUyrFkskcJdzzz37
MhwOk6Zo5vl++uzg4Ch9/qHJl3VRLuv0rKzSV+t5U6yy5iJ9s8qrrIEv0ssC
/uQv5nk6mc2qvK7zOslOT6v8/b57B0dMZuV0mS1g/FmVnTXDIm/Ohk39/vJ8
uNAHh7PpdDXc3UtmWQMP7u7sPhju3B+Od5Jp1uyndTNLkmJV7adNta6b3Z2d
Jzu7SZJVeYYfZct6VVZNcnm+n57oX+kEvk3/WFbviuV5+ruqXK+Sd/nVZVnN
9tPDZZNXy7wZPsMlJfX6dFHUuOnmagXzHz4/eZFMyxm8uZ+u62FWT4siqZts
Ofspm5fLnBaSJ8mq2E//3JTTQVrDlFV+VsNvVwv85V9hfevmoqz2k3SYpGmx
rAEyo3SyyJcz+JtB8iqr3q1r+7CsYMJn+bqppxd5epLP83flAj5XyD47gT9q
mChvwnNDeW44mc/zPH0Cj0yL5goeyKoFLHrW4CflDKZ7eH/3yQP6a71sKnjk
d3m1yJZX8FG+yIq5LmhEC/rHhgcezXJ4oCoRR/JZ0ZSV29JklD6t1ktYFK2U
tzVZLrPoY9rY77NqjutJf1wW7/OqhkW67diHeVOfZwDrdNd2om+GjTwYp48f
+50cX+azfBk2ksESRqe6hH98l61HdR6v+/dZXc/zyq0aMDmr3ef/EcumNYze
8Rq66/7DKH2bvSun+ftiaiv/Q17n82IZfUNrP4B1DNzC0/IsfVkuZ+XSbeE1
4O5Ftlg1cLeP/7KGa2U7sGdtwTBWk8/S38PdmNHRysLf8xJGlS5hNP5HHGOU
TUfrd24Dx6P0n8qLZU3D8vKPm3x1kS/d57T4px7bJ7MMfs3m6RFgqK0P0BVI
Vw2rT3/IgZAYpA+PHqR7b5/fZuU1zz66GP3M8//jaTOawhPJsoTb0QDs4A6n
b18c7I7HT+TX+zuPH+qve/d35NeHu3v35dfH492H9usj+hSp4QiWD3sG8oOf
pKmQ3sPJ6wnc1yY7h2/Tg3J5ntdEa+FXwF/YdVUCnYFftnCU7dSGqXmYrDpH
KF00zarev3fv8vJyVGRwAwCQ9wCVivMl3OimvkeEdmUvt/8efbhoFnMgtssz
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
zOJRJbX+5Jit9ZLaOnK1EbqFWd3ogrel4fMKizEA6p5WefZueEpxVMMFnqm1
UhVKp29SwXNssmIhF1bs0MJ9uYZWcocKJ90JElLwUPK50O5RzmrVEg3b0Nwf
jw7BJ+rcDqO+BJdfq4SF3JYvDcG8LtgTPzFS8UviO6+N5tztqEC+itQGRagP
uqgOUTFVMbhdZkvuA9C+U71ZD0Q02f4WMJ5uq0pR0bTarKn/nKMIPW/PLZda
KZ6vQ6Jdr1QLyRsRWHlB/AnlIIz3RlIBydrwUHpWLmy6VdirNRHI3hjXFsog
nmp9fHJgm5F5PlcS0DOo+tFNpsq06v9ti331wl5IMAgdHBBnuKY1Naw0X0+R
37h8L8WOSsShcIP+gmdJMiGrs8rbN0JwoEdIZ9tgix/aVHycKjOFgIxOTebF
Ip+hvIO6gNaoQ87240qCJlZRKRa1tLuVsfplevmcAp0KNv8kCrxBdKbCdrpY
Zln/bYSBs070InUwkdg+NdQNXaRNW8Iujbglef+pQIyi2PrB5hved9zVrr2W
slpU94nHopRyQz/Tcc9nfRZwJrHw+G4K9DQF4poCpU2ffMlnSbeB5hf/TYSY
JsD/4X92xHKoERb8vf4HnuDv4STfz/j79GstpBeiNxvb9OfT11sHojVF0aBJ
XP4mGuH+5u93W9/j33+LdezhPC1ueM27acQD5UdZofwIR9zrcERE+E2sEL/r
MwlGn3ujoCmgm4prk3EO72SUuqdiFasOW0SPJwOmy0+3peIV153yBVZOWFon
DUd6+qlfbhliv0irwe6Zvf0GpYp3rASRNakuQi0TJpXegpV1GLxYJlMKmVVN
giVO62zuCpizGNtpTHCNBKFKGRstyNr+eRtrmmPjxr/SqljPi2qY1qKrtwvj
1gXCI1vmGAneV2eULJhau3j3/9rbHSUTstO5+HBEWY3stC7bG/CHxVdBS0z5
doWNx4/oIB7tpViNS2oxa0tBQhUuUcpGCupUlTzelYdZbUeib5qUXqVaCkft
PnhAxg4RzyV/wy4c29usKhGDjAr1Kau0SgvvpJrpKNVqS/gMfsod6cjOEwc3
wZdD/NIX9sOppbpfRNXoC4HRFm1v+zapzZ+SjSEivV/cIqAEw9V20u+O5tg1
5gS76LpVdn4ew4fuUdpe3yrT8XD3wf2er3p31Zt3GM5WhsTD/S7Kgdww5MP7
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
O6VnLrL1P4EGM/+EqAEA

-->

</rfc>
