<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" category="exp" consensus="false" docName="draft-ietf-tsvwg-multipath-dccp-07" indexInclude="true" ipr="trust200902" prepTime="2023-02-15T03:04:02" scripts="Common,Latin" sortRefs="true" submissionType="IETF" symRefs="true" tocDepth="3" tocInclude="true">
  <!-- xml2rfc v2v3 conversion 3.16.0 -->
  <front>
    <title abbrev="Multipath DCCP">DCCP Extensions for Multipath Operation with Multiple Addresses</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-multipath-dccp-07" 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="02" year="2023" day="15"/>
    <area>transport</area>
    <workgroup>Transport Area Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">DCCP communications as defined in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> are restricted to a single path per
connection, yet multiple paths often exist between peers.  The
simultaneous use of available multiple paths for a DCCP session could
improve resource usage within the network and, thus, improve user
experience through higher throughput and improved resilience to
network failures.
Use cases for a Multipath DCCP (MP-DCCP) are mobile devices (e.g., handsets, vehicles) and residential home gateways simultaneously connected to distinct networks as, e.g., 
a cellular and a Wireless Local Area (WLAN) networks
or a cellular and a fixed access networks. Compared to existing multipath protocols, such as MPTCP, MP-DCCP provides specific support for non-TCP user
traffic (e.g., UDP or plain IP).  More details on potential use cases are provided in <xref target="website" format="default" sectionFormat="of" derivedContent="website"/>, <xref target="slide" format="default" sectionFormat="of" derivedContent="slide"/>, and <xref target="paper" format="default" sectionFormat="of" derivedContent="paper"/>.
All these use cases profit from an Open Source Linux reference implementation provided under <xref target="website" format="default" sectionFormat="of" derivedContent="website"/>.</t>
      <t indent="0" pn="section-abstract-2">This document specifies a set of extensions to
DCCP to support multipath operations.  Multipath DCCP provides 
the ability to simultaneously use multiple
paths between peers.  The protocol offers
the same type of service to applications as DCCP and it provides the
components necessary to establish and use multiple DCCP flows across
different paths simultaneously.</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
        This Internet-Draft is submitted in full conformance with the
        provisions of BCP 78 and BCP 79.
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
        Internet-Drafts are working documents of the Internet Engineering Task
        Force (IETF). Note that other groups may also distribute working
        documents as Internet-Drafts. The list of current Internet-Drafts is
        at <eref target="https://datatracker.ietf.org/drafts/current/" brackets="none"/>.
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
        Internet-Drafts are draft documents valid for a maximum of six months
        and may be updated, replaced, or obsoleted by other documents at any
        time. It is inappropriate to use Internet-Drafts as reference
        material or to cite them other than as "work in progress."
        </t>
        <t indent="0" pn="section-boilerplate.1-4">
        This Internet-Draft will expire on 19 August 2023.
        </t>
      </section>
      <section anchor="copyright" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.2">
        <name slugifiedName="name-copyright-notice">Copyright Notice</name>
        <t indent="0" pn="section-boilerplate.2-1">
            Copyright (c) 2023 IETF Trust and the persons identified as the
            document authors. All rights reserved.
        </t>
        <t indent="0" pn="section-boilerplate.2-2">
            This document is subject to BCP 78 and the IETF Trust's Legal
            Provisions Relating to IETF Documents
            (<eref target="https://trustee.ietf.org/license-info" brackets="none"/>) in effect on the date of
            publication of this document. Please review these documents
            carefully, as they describe your rights and restrictions with
            respect to this document. Code Components extracted from this
            document must include Revised BSD License text as described in
            Section 4.e of the Trust Legal Provisions and are provided without
            warranty as described in the Revised BSD License.
        </t>
      </section>
    </boilerplate>
    <toc>
      <section anchor="toc" numbered="false" removeInRFC="false" toc="exclude" pn="section-toc.1">
        <name slugifiedName="name-table-of-contents">Table of Contents</name>
        <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1">
          <li pn="section-toc.1-1.1">
            <t indent="0" pn="section-toc.1-1.1.1"><xref derivedContent="1" format="counter" sectionFormat="of" target="section-1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-introduction">Introduction</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.1.2">
              <li pn="section-toc.1-1.1.2.1">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.1.1"><xref derivedContent="1.1" format="counter" sectionFormat="of" target="section-1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-dccp-in-the-netwo">Multipath DCCP in the Networking Stack</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.2">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.2.1"><xref derivedContent="1.2" format="counter" sectionFormat="of" target="section-1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-terminology">Terminology</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.3">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.3.1"><xref derivedContent="1.3" format="counter" sectionFormat="of" target="section-1.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-concept">MP-DCCP Concept</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.4">
                <t indent="0" pn="section-toc.1-1.1.2.4.1"><xref derivedContent="1.4" format="counter" sectionFormat="of" target="section-1.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-requirements-language">Requirements Language</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.2">
            <t indent="0" pn="section-toc.1-1.2.1"><xref derivedContent="2" format="counter" sectionFormat="of" target="section-2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-operation-overview">Operation Overview</xref></t>
          </li>
          <li pn="section-toc.1-1.3">
            <t indent="0" pn="section-toc.1-1.3.1"><xref derivedContent="3" format="counter" sectionFormat="of" target="section-3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-protocol">MP-DCCP Protocol</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2">
              <li pn="section-toc.1-1.3.2.1">
                <t indent="0" pn="section-toc.1-1.3.2.1.1"><xref derivedContent="3.1" format="counter" sectionFormat="of" target="section-3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-capable-feature">Multipath Capable Feature</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.2">
                <t indent="0" pn="section-toc.1-1.3.2.2.1"><xref derivedContent="3.2" format="counter" sectionFormat="of" target="section-3.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multipath-option">Multipath Option</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2.2.2">
                  <li pn="section-toc.1-1.3.2.2.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.1.1"><xref derivedContent="3.2.1" format="counter" sectionFormat="of" target="section-3.2.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_confirm">MP_CONFIRM</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.2">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.2.1"><xref derivedContent="3.2.2" format="counter" sectionFormat="of" target="section-3.2.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_join">MP_JOIN</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.3">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.3.1"><xref derivedContent="3.2.3" format="counter" sectionFormat="of" target="section-3.2.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_fast_close">MP_FAST_CLOSE</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.4">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.4.1"><xref derivedContent="3.2.4" format="counter" sectionFormat="of" target="section-3.2.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_key">MP_KEY</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.5">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.5.1"><xref derivedContent="3.2.5" format="counter" sectionFormat="of" target="section-3.2.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_seq">MP_SEQ</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.6">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.6.1"><xref derivedContent="3.2.6" format="counter" sectionFormat="of" target="section-3.2.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_hmac">MP_HMAC</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.7">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.7.1"><xref derivedContent="3.2.7" format="counter" sectionFormat="of" target="section-3.2.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_rtt">MP_RTT</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.8">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.8.1"><xref derivedContent="3.2.8" format="counter" sectionFormat="of" target="section-3.2.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_addaddr">MP_ADDADDR</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.9">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.9.1"><xref derivedContent="3.2.9" format="counter" sectionFormat="of" target="section-3.2.9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_removeaddr">MP_REMOVEADDR</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.10">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.10.1"><xref derivedContent="3.2.10" format="counter" sectionFormat="of" target="section-3.2.10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_prio">MP_PRIO</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.11">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.11.1"><xref derivedContent="3.2.11" format="counter" sectionFormat="of" target="section-3.2.11"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-mp_close">MP_CLOSE</xref></t>
                  </li>
                  <li pn="section-toc.1-1.3.2.2.2.12">
                    <t indent="0" pn="section-toc.1-1.3.2.2.2.12.1"><xref derivedContent="3.2.12" format="counter" sectionFormat="of" target="section-3.2.12"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-experimental-mp-dccp-sub-op">Experimental MP-DCCP Sub-Option MP_EXP for private use</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.3.2.3">
                <t indent="0" pn="section-toc.1-1.3.2.3.1"><xref derivedContent="3.3" format="counter" sectionFormat="of" target="section-3.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-mp-dccp-handshaking-procedu">MP-DCCP Handshaking Procedure</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.4">
                <t indent="0" pn="section-toc.1-1.3.2.4.1"><xref derivedContent="3.4" format="counter" sectionFormat="of" target="section-3.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-address-knowledge-exchange">Address knowledge exchange</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2.4.2">
                  <li pn="section-toc.1-1.3.2.4.2.1">
                    <t indent="0" pn="section-toc.1-1.3.2.4.2.1.1"><xref derivedContent="3.4.1" format="counter" sectionFormat="of" target="section-3.4.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-removing-a-path">Removing a path (Section 3.2.9)</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.3.2.5">
                <t indent="0" pn="section-toc.1-1.3.2.5.1"><xref derivedContent="3.5" format="counter" sectionFormat="of" target="section-3.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-close-a-mp-dccp-connection">Close a MP-DCCP connection</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.6">
                <t indent="0" pn="section-toc.1-1.3.2.6.1"><xref derivedContent="3.6" format="counter" sectionFormat="of" target="section-3.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fallback">Fallback</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.7">
                <t indent="0" pn="section-toc.1-1.3.2.7.1"><xref derivedContent="3.7" format="counter" sectionFormat="of" target="section-3.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-congestion-control-consider">Congestion Control Considerations</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.8">
                <t indent="0" pn="section-toc.1-1.3.2.8.1"><xref derivedContent="3.8" format="counter" sectionFormat="of" target="section-3.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-maximum-packet-size-conside">Maximum Packet Size Considerations</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.4">
            <t indent="0" pn="section-toc.1-1.4.1"><xref derivedContent="4" format="counter" sectionFormat="of" target="section-4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-security-considerations">Security Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.5">
            <t indent="0" pn="section-toc.1-1.5.1"><xref derivedContent="5" format="counter" sectionFormat="of" target="section-5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-interactions-with-middlebox">Interactions with Middleboxes</xref></t>
          </li>
          <li pn="section-toc.1-1.6">
            <t indent="0" pn="section-toc.1-1.6.1"><xref derivedContent="6" format="counter" sectionFormat="of" target="section-6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-implementation">Implementation</xref></t>
          </li>
          <li pn="section-toc.1-1.7">
            <t indent="0" pn="section-toc.1-1.7.1"><xref derivedContent="7" format="counter" sectionFormat="of" target="section-7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-acknowledgments">Acknowledgments</xref></t>
          </li>
          <li pn="section-toc.1-1.8">
            <t indent="0" pn="section-toc.1-1.8.1"><xref derivedContent="8" format="counter" sectionFormat="of" target="section-8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-iana-considerations">IANA Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.9">
            <t indent="0" pn="section-toc.1-1.9.1"><xref derivedContent="9" format="counter" sectionFormat="of" target="section-9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
          </li>
          <li pn="section-toc.1-1.10">
            <t indent="0" pn="section-toc.1-1.10.1"><xref derivedContent="Appendix A" format="default" sectionFormat="of" target="section-appendix.a"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-differences-from-multipath-">Differences from Multipath TCP</xref></t>
          </li>
          <li pn="section-toc.1-1.11">
            <t indent="0" pn="section-toc.1-1.11.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.b"/><xref derivedContent="" format="title" sectionFormat="of" target="name-authors-addresses">Authors' Addresses</xref></t>
          </li>
        </ul>
      </section>
    </toc>
  </front>
  <middle>
    <section anchor="intro" numbered="true" removeInRFC="false" toc="include" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">Datagram Congestion Control Protocol (DCCP) <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> is a
transport protocol that provides bidirectional unicast connections of
congestion-controlled unreliable datagrams. DCCP communications are restricted to one single path. 
Multipath DCCP (MP-DCCP) is a set of extensions to DCCP  to 
enable DCCP flows to be established across multiple paths 
simultaneously. Such extensions are beneficial to applications that transfer<br/>
large amounts of data, due to the possibility to aggregate capacity of the 
multiple paths. In addition, the multipath extensions enable to tradeoff timeliness and reliability, 
which is important for low-latency applications that do not require 
guaranteed delivery services, such as Audio/Video streaming.</t>
      <t indent="0" pn="section-1-2">MP-DCCP has been first suggested
in the context of the 3GPP work on 5G multi-access solutions
<xref target="I-D.amend-tsvwg-multipath-framework-mpdccp" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-multipath-framework-mpdccp"/> and for hybrid access
networks <xref target="I-D.lhwxz-hybrid-access-network-architecture" format="default" sectionFormat="of" derivedContent="I-D.lhwxz-hybrid-access-network-architecture"/><xref target="I-D.muley-network-based-bonding-hybrid-access" format="default" sectionFormat="of" derivedContent="I-D.muley-network-based-bonding-hybrid-access"/>.
MP-DCCP can be applied for load-balancing, seamless session handover, and bandwidth
aggregation purposes (referred to as Access Traffic Steering, Switching, and Splitting (ATSSS)
in the 3GPP terminology <xref target="TS23.501" format="default" sectionFormat="of" derivedContent="TS23.501"/>).</t>
      <t indent="0" pn="section-1-3">This document presents the protocol changes required to add multipath
support to DCCP; specifically, those for signaling and setting up
multiple paths (a.k.a, "subflows"), managing these subflows, reordering of
data, and termination of sessions.</t>
      <t indent="0" pn="section-1-4">DCCP, as stated in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> does not provide reliable and ordered
delivery. Consequently, multiple application subflows may be multiplexed over a
single DCCP connection with no inherent performance penalty 
for application subflows that do not require in-ordered delivery. DCCP
does not provide built-in support for those multiple application subflows.</t>
      <t indent="0" pn="section-1-5">In the following, the term subflow refers to DCCP subflows transmitted
via different paths (4-tuple of source and destination address/port
pairs), not to be mixed up with the "application sub-flows" mentioned in
Section 17.2 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>.
Application subflows are differing content-wise
by source and destination port per application as, for example, enabled
by Service Codes introduced to DCCP in <xref target="RFC5595" format="default" sectionFormat="of" derivedContent="RFC5595"/>, and those application subflows
can be multiplexed over a single DCCP connection. For the sake of consistency
we assume that only a single application is served by a DCCP connection
here as shown in <xref target="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" format="default" sectionFormat="of" derivedContent="Figure 1"/>
while use of that feature should not impact DCCP operation on each single path
as noted in (Section 2.4 of <xref target="RFC5595" format="default" sectionFormat="of" derivedContent="RFC5595"/>).
Application subflows can co-exist with MP-DCCP operation as defined in this document.</t>
      <t indent="0" pn="section-1-6">As pointed out in <xref target="I-D.amend-tsvwg-multipath-framework-mpdccp" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-multipath-framework-mpdccp"/> the proposed encapsulation in terms of 
lightweight DCCP flow headers is more appropriate for unreliable 
IP traffic in terms of UDP and other non-TCP packets in comparison to MPTCP.
Such considerations are not detailed in the present specification.</t>
      <section anchor="mpdccp_network_stack" numbered="true" removeInRFC="false" toc="include" pn="section-1.1">
        <name slugifiedName="name-multipath-dccp-in-the-netwo">Multipath DCCP in the Networking Stack</name>
        <t indent="0" pn="section-1.1-1">MP-DCCP operates at the transport layer and aims to be transparent to
both higher and lower layers.  It is a set of additional features on
top of DCCP; <xref target="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" format="default" sectionFormat="of" derivedContent="Figure 1"/> illustrates this layering.  MP-DCCP is
designed to be used by applications in the same way as DCCP with no
changes to the application itself.</t>
        <figure anchor="ref-comparison-of-standard-dccp-and-mp-dccp-protocol-stacks" align="left" suppress-title="false" pn="figure-1">
          <name slugifiedName="name-comparison-of-standard-dccp">Comparison of Standard DCCP and MP-DCCP Protocol Stacks</name>
          <artwork align="left" pn="section-1.1-2.1"><![CDATA[
                             +-------------------------------+
                             |           Application         |
+---------------+            +-------------------------------+
|  Application  |            |            MP-DCCP            |
+---------------+            + - - - - - - - + - - - - - - - +
|      DCCP     |            |Subflow (DCCP) |Subflow (DCCP) |
+---------------+            +-------------------------------+
|      IP       |            |       IP      |      IP       |
+---------------+            +-------------------------------+
]]></artwork>
        </figure>
      </section>
      <section anchor="terminology" numbered="true" removeInRFC="false" toc="include" pn="section-1.2">
        <name slugifiedName="name-terminology">Terminology</name>
        <t indent="0" pn="section-1.2-1">Throughout this document we make use of terms that are either specific
for multipath transport or are defined in the context of MP-DCCP,
similar to <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, as follows:</t>
        <t indent="0" pn="section-1.2-2">Path: A sequence of links between a sender and a receiver, defined in
this context by a 4-tuple of source and destination address/ port pairs.</t>
        <t indent="0" pn="section-1.2-3">Subflow: A flow of DCCP segments operating over an individual path,
which forms part of a larger MP-DCCP connection. A subflow is started
and terminated similar to a regular (single-path) DCCP connection. The term subflow
can also be used to refer to an MP-DCCP connection with a single path.</t>
        <t indent="0" pn="section-1.2-4">(MP-DCCP) Connection: A set of one or more subflows, over which an
application can communicate between two hosts. The MP-DCCP connection is
exposed as single DCCP socket to the application.</t>
        <t indent="0" pn="section-1.2-5">Token: A locally unique identifier given to a multipath connection by a
host. May also be referred to as a "Connection ID".</t>
        <t indent="0" pn="section-1.2-6">Host: An end host operating an MP-DCCP implementation, and either
initiating or accepting an MP-DCCP connection.</t>
        <t indent="0" pn="section-1.2-7">In addition to these
terms, within framework of MP-DCCP the interpretation of, and effect on,
regular single-path DCCP semantics is discussed in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.</t>
      </section>
      <section anchor="concept" numbered="true" removeInRFC="false" toc="include" pn="section-1.3">
        <name slugifiedName="name-mp-dccp-concept">MP-DCCP Concept</name>
        <t indent="0" pn="section-1.3-1"><xref target="ref-example-mp-dccp-usage-scenario" format="default" sectionFormat="of" derivedContent="Figure 2"/> provides a general overview of the MP-DCCP working mode, whose main 
characteristics are summarized in this section.</t>
        <figure anchor="ref-example-mp-dccp-usage-scenario" align="left" suppress-title="false" pn="figure-2">
          <name slugifiedName="name-example-mp-dccp-usage-scena">Example MP-DCCP Usage Scenario</name>
          <artwork align="left" pn="section-1.3-2.1"><![CDATA[
           Host A                               Host B
------------------------             ------------------------
Address A1    Address A2             Address B1    Address B2
----------    ----------             ----------    ----------
  |             |                      |             |
  |         (DCCP subflow setup)       |             |
  |----------------------------------->|             |
  |<-----------------------------------|             |
  |             |                      |             |
  |             |  (DCCP subflow setup)|             |
  |             |--------------------->|             |
  |             |<---------------------|             |
  | merge individual DCCP subflows to one MP-DCCP connection
  |             |                      |             |
]]></artwork>
        </figure>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-1.3-3">
          <li pn="section-1.3-3.1">An MP-DCCP connection begins with a 4-way handshaking procedure, between 
two hosts as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. In <xref target="ref-example-mp-dccp-usage-scenario" format="default" sectionFormat="of" derivedContent="Figure 2"/>,
an MP-DCCP connection is established between addresses A1 and B1 on Hosts
A and B, respectively. It should be noted that MP-DCCP does not require the presence of 
more than one address in both peers.</li>
          <li pn="section-1.3-3.2">In case extra paths and corresponding addresses/ports are available, additional DCCP subflows are created on 
these paths and are attached to the existing MP-DCCP session, which
continues to appear as a single connection to the applications at both
ends. The creation of an additional DCCP subflow is illustrated between Address A2
on Host A and Address B1 on Host B.</li>
          <li pn="section-1.3-3.3">MP-DCCP identifies multiple paths by the presence of multiple
addresses/ports at hosts.  Combinations of these multiple addresses/ports
equate to the additional paths.  In the example, other potential
paths that could be set up are A1&lt;-&gt;B2 and A2&lt;-&gt;B2.  Although this
additional subflow is shown as being initiated from A2, it could
equally have been initiated from B1 or B2.</li>
          <li pn="section-1.3-3.4">The discovery and setup of additional subflows will be achieved
through a path management method including the logic and details of the procedures for adding/removing subflows;
this document describes supportive measures by which a host can initiate new subflows and signal available addresses 
between peers. The definition of a path management method is, however, out of scope of this document and subject to a 
corresponding policy and the specifics of the implementation. In the same context, if any of the MP-DCCP peer hosts has a limit on the maximum number of paths that can be maintained (e.g., similar to what is discussed in Section 3.4 of <xref target="RFC8041" format="default" sectionFormat="of" derivedContent="RFC8041"/>, the creation of new subflows from that peer host should be avoided and incoming subflow requests should be terminated.</li>
          <li pn="section-1.3-3.5">MP-DCCP adds connection-level sequence numbers and exchange of
Round-Trip Time (RTT) information to enable optional reordering features.</li>
          <li pn="section-1.3-3.6">Subflows are terminated as regular DCCP connections, as described
in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 8.3). The MP-DCCP connection is terminated by a
connection-level DCCP-CloseReq or DCCP-Close message.</li>
        </ul>
      </section>
      <section anchor="requirements-language" numbered="true" removeInRFC="false" toc="include" pn="section-1.4">
        <name slugifiedName="name-requirements-language">Requirements Language</name>
        <t indent="0" pn="section-1.4-1">The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
   "OPTIONAL" in this document are to be interpreted as described in
   BCP 14 <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/> <xref target="RFC8174" format="default" sectionFormat="of" derivedContent="RFC8174"/> when, and only when, they appear in all
   capitals, as shown here.</t>
      </section>
    </section>
    <section anchor="op_overview" numbered="true" removeInRFC="false" toc="include" pn="section-2">
      <name slugifiedName="name-operation-overview">Operation Overview</name>
      <t indent="0" pn="section-2-1">DCCP (Section 17.2 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>) allows multiple application 
subflows to be multiplexed over a single DCCP connection with 
potentially same performance. However, DCCP does not provide built-in 
support for multiple subflows and the Congestion Manager (CM) 
<xref target="RFC3124" format="default" sectionFormat="of" derivedContent="RFC3124"/>, as a generic multiplexing facility, can not fully support 
multiple congestion control mechanisms for multiple DCCP flows between 
same source and destination addresses. Various congestion control mechanisms 
have been specified to optimize DCCP performance for specific traffic types 
in terms of profiles denoted by a Congestion Control IDentifier (CCID).</t>
      <t indent="0" pn="section-2-2">The extension of DCCP towards Multipath-DCCP (MP-DCCP) is 
described in detail in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.</t>
      <t indent="0" pn="section-2-3">As a high level overview of the MP-DCCP operation, the data 
stream from a DCCP application is split 
by MP-DCCP operation into one or more subflows which can be 
transmitted via different also physically isolated paths.
The corresponding control information allows the receiver to optionally 
re-assemble and deliver the received data in the right order to the 
recipient application. The details of the transmission scheduling mechanism and 
optional reordering mechanism are up to the sender and receiver, respectively,
and are outside the scope of this document.</t>
      <t indent="0" pn="section-2-4">The following sections define MP-DCCP behavior in detail.</t>
      <t indent="0" pn="section-2-5">A Multipath DCCP connection provides a bidirectional connection of datagrams 
between two hosts exchanging data as in DCCP, thus, not requiring 
any change to the applications. However, Multipath DCCP enables the 
hosts to use different paths with different IP addresses to transport 
the packets of an MP-DCCP connection. MP-DCCP manages the request, 
set-up, authentication, prioritization, modification, and removal of
the DCCP subflows on different paths as well as the exchange of performance 
parameters.</t>
      <t indent="0" pn="section-2-6">The Multipath Capability for MP-DCCP can be negotiated with a new DCCP 
feature, as specified in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>. Once 
negotiated, all subsequent MP-DCCP operations for that connection are signalled with a 
variable length multipath-related option, as described in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>.
All MP-DCCP operations are signaled with MP-DCCP suboptions described in {#MP_OPT}.</t>
      <t indent="0" pn="section-2-7">The number of concurrent DCCP subflows can vary during the 
lifetime of a Multipath DCCP connection. The details of the path management decisions for
when to add or remove subflows are outside the scope of this document.</t>
    </section>
    <section anchor="protocol" numbered="true" removeInRFC="false" toc="include" pn="section-3">
      <name slugifiedName="name-mp-dccp-protocol">MP-DCCP Protocol</name>
      <t indent="0" pn="section-3-1">The DCCP protocol feature list (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 6.4) are
enriched with a new Multipath related feature with Feature number 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">Rule</th>
            <th align="center" colspan="1" rowspan="1">Rec'n Value</th>
            <th align="center" colspan="1" rowspan="1">Initial Req'd</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">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 means server-priority,
NN means non-negotiable.</t>
        </dd>
        <dt pn="section-3-3.3">Initial Value:</dt>
        <dd pn="section-3-3.4">
          <t indent="0" pn="section-3-3.4.1">The initial value for the feature. Every feature has a known initial value.</t>
        </dd>
        <dt pn="section-3-3.5">Req'd:</dt>
        <dd pn="section-3-3.6">
          <t indent="0" pn="section-3-3.6.1">This column is "Y" if and only if every DCCP implementation MUST
understand the feature. If it is "N", then the feature behaves like an extension, and it is safe to respond to Change options for the feature
with empty Confirm options.</t>
        </dd>
      </dl>
      <t indent="0" pn="section-3-4">The DCCP protocol options as defined in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 5.8) and (<xref target="RFC5634" format="default" sectionFormat="of" derivedContent="RFC5634"/>, Section 2.2.1) are enriched with 
a new Multipath related variable-length option with option type 46, as
shown in <xref target="ref-option-list" format="default" sectionFormat="of" derivedContent="Table 2"/>.</t>
      <table anchor="ref-option-list" align="center" pn="table-2">
        <name slugifiedName="name-multipath-option-set">Multipath Option Set</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Type</th>
            <th align="center" colspan="1" rowspan="1">Option Length</th>
            <th align="center" colspan="1" rowspan="1">Meaning</th>
            <th align="center" colspan="1" rowspan="1">DCCP-Data?</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">46</td>
            <td align="center" colspan="1" rowspan="1">variable</td>
            <td align="center" colspan="1" rowspan="1">Multipath</td>
            <td align="center" colspan="1" rowspan="1">Y</td>
          </tr>
        </tbody>
      </table>
      <section anchor="mp_capable" numbered="true" removeInRFC="false" toc="include" pn="section-3.1">
        <name slugifiedName="name-multipath-capable-feature">Multipath Capable Feature</name>
        <t indent="0" pn="section-3.1-1">DCCP endpoints uses the Multipath Capable Feature to decide whether multipath extensions can be enabled for a DCCP connection.</t>
        <t indent="0" pn="section-3.1-2">Multipath Capable feature has feature number 10 and has length of one-byte.
The leftmost four bits are used to specify a compatible version of the
MP-DCCP implementation (0000 for this specification). The following four bits are unassigned in version 0. The unassigned bits MUST be set to zero by the sender and MUST be ignored by the receiver.</t>
        <artwork align="left" pn="section-3.1-3"><![CDATA[
    0  1  2  3   4  5  6  7
   +-----------+------------+
   |  Version  | Unassigned |
   +-----------+------------+
]]></artwork>
        <t indent="0" pn="section-3.1-4">The setting of Multipath Capable MUST follow the server-priority reconciliation rule described
in (<xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 6.3.1), which allows multiple versions to be
specified in order of priority.</t>
        <t indent="0" pn="section-3.1-5">The negotiation MUST be done as part of the initial handshake procedure
as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>, and no subsequent re-negotiation of
the Multipath Capable feature is allowed on the same MP-DCCP connection.</t>
        <t indent="0" pn="section-3.1-6">Clients MUST include a Change R option during the initial handshake request to
supply a list of supported MP-DCCP protocol versions, ordered by preference.</t>
        <t indent="0" pn="section-3.1-7">Servers MUST include a Confirm L option in the subsequent response to agree on
an MP-DCCP version to be used from the Client list, followed by its own
supported version(s) ordered by preference. Any subflow addition to an existing MP-DCCP connection MUST use the same
version negotiated for the first subflow.</t>
        <t indent="0" pn="section-3.1-8">If no agreement is found, the Server MUST reply with an empty Confirm L option
with feature number 10 and no values.</t>
        <t indent="0" pn="section-3.1-9">An example of successful version negotiation is shown hereafter:</t>
        <artwork align="left" pn="section-3.1-10"><![CDATA[
      Client                                             Server
      ------                                             ------
      DCCP-Req + Change R(CAPABLE, 1 0)
                     ----------------------------------->

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

                 * agreement on version = 1 *
]]></artwork>
        <ol spacing="normal" type="1" indent="adaptive" start="1" pn="section-3.1-11"><li pn="section-3.1-11.1" derivedCounter="1.">The Client indicates support for both MP-DCCP versions 1 and 0, with a preference
for version 1.</li>
          <li pn="section-3.1-11.2" derivedCounter="2.">Server agrees on using MP-DCCP version 1, and supplies its own preference list.</li>
          <li pn="section-3.1-11.3" derivedCounter="3.">MP-DCCP is then enabled between the Client and Server with version 1.</li>
        </ol>
        <t indent="0" pn="section-3.1-12">If the version negotiation fails or the MP_CAPABLE feature is not present in the DCCP-Request or DCCP-Response packets of the initial handshake procedure, the MP-DCCP connection SHOULD fall back to regular DCCP or MUST be closed. Further details are specified in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/></t>
      </section>
      <section anchor="MP_OPT" numbered="true" removeInRFC="false" toc="include" pn="section-3.2">
        <name slugifiedName="name-multipath-option">Multipath Option</name>
        <t indent="0" pn="section-3.2-1">MP-DCCP uses one single option to signal various multipath-related operations. The format of this option is shown in <xref target="ref-mp-option-format" format="default" sectionFormat="of" derivedContent="Figure 3"/>.</t>
        <figure anchor="ref-mp-option-format" align="left" suppress-title="false" pn="figure-3">
          <name slugifiedName="name-multipath-option-format">Multipath Option Format</name>
          <artwork align="left" pn="section-3.2-2.1"><![CDATA[
            1          2          3         
 01234567 89012345 67890123 45678901 23456789
+--------+--------+--------+--------+--------+
|00101110| Length | MP_OPT | Value(s) ...
+--------+--------+--------+--------+--------+
 Type=46
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.2-3">The description of the fields of the multipath option is shown in <xref target="ref-mp-option-list" format="default" sectionFormat="of" derivedContent="Table 3"/>. MP_OPT refers to an MP-DCCP suboption.</t>
        <table anchor="ref-mp-option-list" align="center" pn="table-3">
          <name slugifiedName="name-mp_opt-option-types">MP_OPT Option Types</name>
          <thead>
            <tr>
              <th align="left" colspan="1" rowspan="1">Type</th>
              <th align="left" colspan="1" rowspan="1">Option Length</th>
              <th align="left" colspan="1" rowspan="1">MP_OPT</th>
              <th align="left" colspan="1" rowspan="1">Meaning</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">0 =MP_CONFIRM</td>
              <td align="left" colspan="1" rowspan="1">Confirm reception and processing of an MP_OPT option</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">12</td>
              <td align="left" colspan="1" rowspan="1">1 =MP_JOIN</td>
              <td align="left" colspan="1" rowspan="1">Join path to an existing MP-DCCP connection</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">2 =MP_FAST_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close an MP-DCCP connection unconditionally</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">3 =MP_KEY</td>
              <td align="left" colspan="1" rowspan="1">Exchange key material for MP_HMAC</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">9</td>
              <td align="left" colspan="1" rowspan="1">4 =MP_SEQ</td>
              <td align="left" colspan="1" rowspan="1">Multipath Sequence Number</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">23</td>
              <td align="left" colspan="1" rowspan="1">5 =MP_HMAC</td>
              <td align="left" colspan="1" rowspan="1">HMA Code for authentication</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">12</td>
              <td align="left" colspan="1" rowspan="1">6 =MP_RTT</td>
              <td align="left" colspan="1" rowspan="1">Transmit RTT values</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">7 =MP_ADDADDR</td>
              <td align="left" colspan="1" rowspan="1">Advertise additional Address</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">4</td>
              <td align="left" colspan="1" rowspan="1">8 =MP_REMOVEADDR</td>
              <td align="left" colspan="1" rowspan="1">Remove Address</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">4</td>
              <td align="left" colspan="1" rowspan="1">9 =MP_PRIO</td>
              <td align="left" colspan="1" rowspan="1">Change Subflow Priority</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">var</td>
              <td align="left" colspan="1" rowspan="1">10 =MP_CLOSE</td>
              <td align="left" colspan="1" rowspan="1">Close an MP-DCCP subflow</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">46</td>
              <td align="left" colspan="1" rowspan="1">TBD</td>
              <td align="left" colspan="1" rowspan="1">&gt;10</td>
              <td align="left" colspan="1" rowspan="1">Reserved for future MP suboptions defined in Version &gt; 0 or extension</td>
            </tr>
          </tbody>
        </table>
        <t indent="0" pn="section-3.2-5">These operations are largely inspired by the signals defined in <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>.</t>
        <section anchor="MP_CONFIRM" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.1">
          <name slugifiedName="name-mp_confirm">MP_CONFIRM</name>
          <artwork align="left" pn="section-3.2.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>
          <t indent="0" pn="section-3.2.1-2">Some multipath options require confirmation from the remote peer (see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>). Such options will be retransmitted by the sender 
until a MP_CONFIRM is received or confirmation of options is identified outdated. The further processing of the multipath options in the
receiving host is not the subject of MP_CONFIRM.</t>
          <t indent="0" pn="section-3.2.1-3">As the transmission of multipath suboptions is subject to out-of-order arrival, suboptions defined in <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>
SHALL be sent in a DCCP datagram with MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>. This allows to identify outdated suboptions which updates the same
dataset. In case of MP_ADDADDR, MP_REMOVEADDR the same dataset is identified based on AddressID, whereas the same dataset for MP_PRIO is identified by the subflow in use. An outdated
suboption is detected at the receiver if a previous suboption referring to the same dataset contained a higher sequence number
carried by MP_SEQ. Generating a MP_CONFIRM for suboptions identified outdated is optional.</t>
          <t indent="0" pn="section-3.2.1-4">Similarly MP_CONFIRM is subject to out-of-order arrival. To ensure that the most recent suboption is confirmed the associated
MP_SEQ received MUST be echoed. Otherwise inconsistency happens if between updates of a dataset with the same value, another value
is sent. If the MP_CONFIRM of the second update and the third update itself gets lost, the value of the second update is applied on
receiver side without being detected by the sender.</t>
          <t indent="0" pn="section-3.2.1-5">The length and sending path of the MP_CONFIRM are dependent on the confirmed suboptions and the received MP_SEQ, which will be both copied verbatim and
appended as list of confirmations. The list structures by first listing the received MP_SEQ followed by the confirmed suboption or suboptions. The same
rules apply when suboptions with different MP_SEQs are confirmed at once. This might happen if a datagram with MP_PRIO and a first MP_SEQ_1 and another datagram with MP_ADDADDR and a second MP_SEQ_2 are received in short succession. In this case, the structure described above is concatenated resulting in  MP_SEQ_1 + MP_PRIO + MP_SEQ_2 + MP_ADDADDR.</t>
          <table anchor="ref-mp-option-confirm" align="center" pn="table-4">
            <name slugifiedName="name-multipath-options-requiring">Multipath options requiring confirmation</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Type</th>
                <th align="left" colspan="1" rowspan="1">Option Length</th>
                <th align="left" colspan="1" rowspan="1">MP_OPT</th>
                <th align="left" colspan="1" rowspan="1">MP_CONFIRM Sending path</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">var</td>
                <td align="left" colspan="1" rowspan="1">7 =MP_ADDADDR</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">4</td>
                <td align="left" colspan="1" rowspan="1">8 =MP_REMOVEADDR</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">46</td>
                <td align="left" colspan="1" rowspan="1">4</td>
                <td align="left" colspan="1" rowspan="1">9 =MP_PRIO</td>
                <td align="left" colspan="1" rowspan="1">Any available</td>
              </tr>
            </tbody>
          </table>
          <t indent="0" pn="section-3.2.1-7">An example to illustrate the MP-DCCP confirm procedure for the MP_PRIO option is shown in <xref target="ref-mp-dccp-confirm-good" format="default" sectionFormat="of" derivedContent="Figure 4"/>. The host A sends a 
DCCP-Request on path A2-B2 with an MP_PRIO option with value 1 and associated sequence number of 1. Host B replies on the same path in 
this instance (but could be any path) with a DCCP-Response containing the MP_CONFIRM option and a list containing the original sequence number (1)
together with the associated option (MP_PRIO)</t>
          <figure anchor="ref-mp-dccp-confirm-good" align="left" suppress-title="false" pn="figure-4">
            <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 5"/>.
Here, a first DCCP-Data is sent from Host A to Host B with option MP_PRIO set to 4. Host A subsequently issues a second DCCP-Data with option MP_PRIO
set to 1. The delivery of the first MP_PRIO is delayed in the network between Host A and Host B and arrives after the second MP_PRIO. Host B
ignores this second MP_PRIO as the associated sequence number is earlier than the first. Host B sends a DCCP-Ack confirming receipt of the MP_PRIO(1) with sequence number 2.</t>
          <figure anchor="ref-mp-dccp-confirm-outdated" align="left" suppress-title="false" pn="figure-5">
            <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-6">
            <name slugifiedName="name-format-of-the-mp_join-subop">Format of the MP_JOIN Suboption</name>
            <artwork align="left" pn="section-3.2.2-1.1"><![CDATA[
              1          2          3
   01234567 89012345 67890123 45678901
  +--------+--------+--------+--------+
  |00101110|00001100|00000001| Addr ID|
  +--------+--------+--------+--------+
  | Path Token                        |
  +--------+--------+--------+--------+
  | Nonce                             |
  +--------+--------+--------+--------+
   Type=46  Length=12 MP_OPT=1
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.2-2">The MP_JOIN option is used by a host to add a new subflow to an existing MP-DCCP
connection. The Path Token is the SHA256 hash of the derived key (d-key),
which was previously exchanged with the MP_KEY option.
MP_HMAC MUST be set when using MP_JOIN to provide authentication (See
MP_HMAC for details). Also MP_KEY MUST be set to provide key material
for authentication purposes.</t>
          <t indent="0" pn="section-3.2.2-3">The MP_JOIN option includes an "Addr ID" (Address ID) generated by the sender of the option, used to identify the source
address of this packet, even if the IP header has been changed in
transit by a middlebox.  The numeric value of this field is generated
by the sender and must map uniquely to a source IP address for the
sending host.  The Address ID allows address removal (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>)
without needing to know what the source address at the receiver is,
thus allowing address removal through NATs.  The Address ID also
allows correlation between new subflow setup attempts and address
signaling (<xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>), to prevent setting up duplicate subflows
on the same path, if an MP_JOIN and MP_ADDADDR are sent at the same
time.</t>
          <t indent="0" pn="section-3.2.2-4">The Address IDs of the subflow used in the initial DCCP Request/Response exchange of
the first subflow in the connection are implicit, and have the value
zero.  A host MUST store the mappings between Address IDs and
addresses both for itself and the remote host.  An implementation
will also need to know which local and remote Address IDs are
associated with which established subflows, for when addresses are
removed from a local or remote host. An Address ID always has to be unique
over the lifetime of a subflow and can only be re-assigned if sender and
receiver no longer have them in use.</t>
          <t indent="0" pn="section-3.2.2-5">The Nonce is a 32-bit random value locally generated for every MP_JOIN option.
Together with the Token, the Nonce value builds the basis to calculate the
HMAC used in the handshaking process as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>.</t>
          <t indent="0" pn="section-3.2.2-6">If the path token can not be verified by the receiving host during a handshake negotiation, 
the new subflow MUST be closed, as specified in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/>.</t>
        </section>
        <section anchor="MP_FAST_CLOSE" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.3">
          <name slugifiedName="name-mp_fast_close">MP_FAST_CLOSE</name>
          <t indent="0" pn="section-3.2.3-1">Regular DCCP has the means of sending a Close or Reset signals to abruptly close a
connection.  With MP-DCCP, a regular Close or Reset only has the scope of the
subflow over which the signal was received. As such, it will only close the applicable subflow and will not
affect the remaining subflows concurrently in use on other paths.  A MP-DCCP connection will stay alive at
the data level in order to permit break-before-make handover between
subflows.  It is therefore necessary to provide an MP-DCCP-level
"Reset" to allow the abrupt closure of the whole MP-DCCP connection;
this is done via the MP_FAST_CLOSE suboption.</t>
          <figure anchor="ref-MP_FAST_CLOSE" align="left" suppress-title="false" pn="figure-7">
            <name slugifiedName="name-format-of-the-mp_fast_close">Format of the MP_FAST_CLOSE Suboption</name>
            <artwork align="left" pn="section-3.2.3-2.1"><![CDATA[
              1          2          3
   01234567 89012345 67890123 45678901 23456789
  +--------+--------+--------+--------+--------+
  |00101110|  var   |00000010| Key Data ...
  +--------+--------+--------+--------+--------+
   Type=46   Length  MP_OPT=2
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.3-3">For being effective, the MP_FAST_CLOSE suboption MUST be sent from an initiating host on all subflows as part of a DCCP-Reset packet with Reset Code 13. To protect unauthorized shutdown of a multipath DCCP connection, the selected Key Data of the peer host during the handshaking procedure is carried by the MP_FAST_CLOSE option.</t>
          <t indent="0" pn="section-3.2.3-4">With completion of this step, the initiating host can tear down the subflows and the multipath DCCP connection immediately terminates.</t>
          <t indent="0" pn="section-3.2.3-5">Upon reception of the MP_FAST_CLOSE and successful validation of the Key Data at the peer host, a DCCP Reset packet is replied on all subflows to the initiating host with Reset Code 13. The peer host can now close the whole MP-DCCP connection (i.e., it transitions the connection state directly to CLOSED).</t>
        </section>
        <section anchor="MP_KEY" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.4">
          <name slugifiedName="name-mp_key">MP_KEY</name>
          <figure anchor="ref-MP_KEY" align="left" suppress-title="false" pn="figure-8">
            <name slugifiedName="name-format-of-the-mp_key-subopt">Format of the MP_KEY Suboption</name>
            <artwork align="left" pn="section-3.2.4-1.1"><![CDATA[
                       1                   2                   3
   0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
  +---------------+---------------+---------------+---------------+
  |0 0 1 0 1 1 1 0|      var      |0 0 0 0 0 0 1 1| Key Type (1)  | 
  +---------------+---------------+---------------+---------------+
  |  Key Data (1) |  Key Type (2) |  Key Data (2) | ....
  +---------------+---------------+---------------+---------------+
      Type=46          Length         MP_OPT=3
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.4-2">The MP_KEY suboption is used to exchange key material between
hosts for a given connection. The Length varies between 12 and 68 Bytes for a single-key message, and up to
110 Bytes when all specified Key Types 0-2 are provided. The Key Type field is used to
specify the type of the following key data. Key types are shown in <xref target="ref-key-type-list" format="default" sectionFormat="of" derivedContent="Table 5"/>.</t>
          <table anchor="ref-key-type-list" align="center" pn="table-5">
            <name slugifiedName="name-mp_key-key-types">MP_KEY Key Types</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Key  Type</th>
                <th align="left" colspan="1" rowspan="1">Key Length (Bytes)</th>
                <th align="left" colspan="1" rowspan="1">Meaning</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">0 =Plain Text</td>
                <td align="left" colspan="1" rowspan="1">8</td>
                <td align="left" colspan="1" rowspan="1">Plain Text Key</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">1 =ECDHE-C25519-SHA256</td>
                <td align="left" colspan="1" rowspan="1">32</td>
                <td align="left" colspan="1" rowspan="1">ECDHE with SHA256 and Curve25519</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">2 =ECDHE-C25519-SHA512</td>
                <td align="left" colspan="1" rowspan="1">64</td>
                <td align="left" colspan="1" rowspan="1">ECDHE with SHA512 and Curve25519</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">3-255</td>
                <td align="left" colspan="1" rowspan="1"> </td>
                <td align="left" colspan="1" rowspan="1">Unassigned</td>
              </tr>
            </tbody>
          </table>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-4">
            <dt pn="section-3.2.4-4.1">Plain Text</dt>
            <dd pn="section-3.2.4-4.2">
              <t indent="0" pn="section-3.2.4-4.2.1">Key Material is exchanged in plain text between hosts, and the key
parts (key-a, key-b) are used by each host to generate the derived
key (d-key) by concatenating the two parts with the local key
in front (e.g. hostA d-key(A)=(key-a+key-b), hostB d-key(B)=(key-b+key-a)).</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-5">
            <dt pn="section-3.2.4-5.1">ECDHE-SHA256-C25519</dt>
            <dd pn="section-3.2.4-5.2">
              <t indent="0" pn="section-3.2.4-5.2.1">Public Key Material is exchanged via ECDHE key exchange with SHA256 and
Curve 25519 to generate the derived key (d-key) from the shared secret.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.4-6">
            <dt pn="section-3.2.4-6.1">ECDHE-SHA512-C25519</dt>
            <dd pn="section-3.2.4-6.2">
              <t indent="0" pn="section-3.2.4-6.2.1">Public Key Material is exchanged via ECDHE key exchange with SHA512 and
Curve 25519 to generate the derived key (d-key) from the shared secret.</t>
            </dd>
          </dl>
          <t indent="0" pn="section-3.2.4-7">Providing multiple keys is only permitted in the DCCP-Request message
of the handshake procedure for the first subflow, and allows the hosts to agree
on a single key type to be used as described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
          <t indent="0" pn="section-3.2.4-8">If the key type can not be agreed when the MP_KEY option is sent as part of the 
handshake procedure, the MP-DCCP connection should fallback to regular DCCP as 
indicated in <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/></t>
        </section>
        <section anchor="MP_SEQ" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.5">
          <name slugifiedName="name-mp_seq">MP_SEQ</name>
          <figure anchor="ref-MP_SEQ" align="left" suppress-title="false" pn="figure-9">
            <name slugifiedName="name-format-of-the-mp_seq-subopt">Format of the MP_SEQ Suboption</name>
            <artwork align="left" pn="section-3.2.5-1.1"><![CDATA[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|00001001|00000100| Multipath Sequence Number         
  +--------+--------+--------+--------+--------+--------+--------+
                    |
  +--------+--------+
   Type=46  Length=9 MP_OPT=4
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.5-2">The MP_SEQ suboption is used for end-to-end datagram-based sequence
numbers of an MP-DCCP connection. The initial data sequence
number (IDSN) SHOULD be set randomly <xref target="RFC4086" format="default" sectionFormat="of" derivedContent="RFC4086"/>.</t>
          <t indent="0" pn="section-3.2.5-3">The MP_SEQ number space is
different from the path individual sequence number space and MUST be
sent with any DCCP-Data and DCCP-DataACK packet.</t>
        </section>
        <section anchor="MP_HMAC" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.6">
          <name slugifiedName="name-mp_hmac">MP_HMAC</name>
          <figure anchor="ref-MP_HMAC" align="left" suppress-title="false" pn="figure-10">
            <name slugifiedName="name-format-of-the-mp_hmac-subop">Format of the MP_HMAC Suboption</name>
            <artwork align="left" pn="section-3.2.6-1.1"><![CDATA[
              1          2          3           4
   01234567 89012345 67890123 45678901 23456789 01234567
  +--------+--------+--------+--------+--------+--------+
  |00101110|00010111|00000101| HMAC-SHA256 (20 bytes) ...
  +--------+--------+--------+--------+--------+--------+
   Type=46  Length=23 MP_OPT=5
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.6-2">The MP_HMAC suboption is used to provide authentication for the MP_JOIN,
MP_ADDADDR, and MP_REMOVEADDR suboptions. The HMAC code is generated according
to <xref target="RFC2104" format="default" sectionFormat="of" derivedContent="RFC2104"/> in combination with the SHA256 hash algorithm described in
<xref target="RFC6234" format="default" sectionFormat="of" derivedContent="RFC6234"/>, with the output truncated to the leftmost 160 bits (20 bytes).</t>
          <t indent="0" pn="section-3.2.6-3">The "Key" used for the HMAC computation is the derived key (d-key)
described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>, while the HMAC "Message" is a concatenation of</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.6-4">
            <li pn="section-3.2.6-4.1">MP_JOIN: The token and nonce of the MP_JOIN for which authentication
   shall be performed.</li>
            <li pn="section-3.2.6-4.2">MP_ADDADDR: The Address ID with associated IP address
   and if defined port, otherwise two octets of value 0.</li>
            <li pn="section-3.2.6-4.3">MP_REMOVEADDR: Solely the Address ID.</li>
          </ul>
          <t indent="0" pn="section-3.2.6-5">MP_JOIN, MP_ADDADDR and MP_REMOVEADDR can co-exist or be used multiple times
within a single DCCP packet. As all this multipath options come along with an
individual MP_HASH option, this requires the MP_HASH to be correctly associated.
Otherwise, the receiver cannot validate multiple MP_JOIN, MP_ADDADDR or
MP_REMOVEADDR. Therefore, a MP_HASH MUST directly follow its associated multipath
option. In the likely case of sending a MP_JOIN together with a MP_ADDADDR, this
results in concatenating MP_JOIN + MP_HMAC_1 + MP_ADDADDR + MP_HMAC_2, whereas the
first MP_HMAC_1 is associated with the MP_JOIN and the second MP_HMAC_2 with the
MP_ADDADDR suboption.</t>
          <t indent="0" pn="section-3.2.6-6">If the HMAC can not be validated by a receiving host, the subsequent handling depends
on which suboption was being authenticated. If the suboption to be authenticated was either
MP_ADDADDR or MP_REMOVEADDR, the receiving host SHOULD 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, it MUST lead to a subflow closing (see <xref target="fallback" format="default" sectionFormat="of" derivedContent="Section 3.6"/>)</t>
        </section>
        <section anchor="MP_RTT" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.7">
          <name slugifiedName="name-mp_rtt">MP_RTT</name>
          <figure anchor="ref-MP_RTT" align="left" suppress-title="false" pn="figure-11">
            <name slugifiedName="name-format-of-the-mp_rtt-subopt">Format of the MP_RTT Suboption</name>
            <artwork align="left" pn="section-3.2.7-1.1"><![CDATA[
              1          2          3           4          5
   01234567 89012345 67890123 45678901 23456789 01234567 89012345
  +--------+--------+--------+--------+--------+--------+--------+
  |00101110|00001100|00000110|RTT Type| RTT
  +--------+--------+--------+--------+--------+--------+--------+
           | Age                               |
  +--------+--------+--------+--------+--------+
   Type=46  Length=12 MP_OPT=6
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.7-2">The MP_RTT suboption is used to transmit RTT values in milliseconds and
MUST belong to the path over which this information is transmitted.
Additionally, the age of the measurement is specified in milliseconds.
This information is in particular useful for the receiving host to
calculate the RTT difference between the subflows and to estimate whether
missing data has been lost.</t>
          <t indent="0" pn="section-3.2.7-3">The RTT and Age information is a 32-bit integer, which allows to cover a period of
approximately 1193 hours.</t>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-4">
            <dt pn="section-3.2.7-4.1">Raw RTT (=0)</dt>
            <dd pn="section-3.2.7-4.2">
              <t indent="0" pn="section-3.2.7-4.2.1">Raw RTT value of the last Datagram Round-Trip preferably provided by the CCID in use.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-5">
            <dt pn="section-3.2.7-5.1">Min RTT (=1)</dt>
            <dd pn="section-3.2.7-5.2">
              <t indent="0" pn="section-3.2.7-5.2.1">Min RTT value over a given period preferably provided by the CCID in use.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-6">
            <dt pn="section-3.2.7-6.1">Max RTT (=2)</dt>
            <dd pn="section-3.2.7-6.2">
              <t indent="0" pn="section-3.2.7-6.2.1">Max RTT value over a given period preferably provided by the CCID in use.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-7">
            <dt pn="section-3.2.7-7.1">Smooth RTT (=3)</dt>
            <dd pn="section-3.2.7-7.2">
              <t indent="0" pn="section-3.2.7-7.2.1">Averaged RTT value over a given period preferably provided by the CCID in use.</t>
            </dd>
          </dl>
          <dl newline="true" indent="3" spacing="normal" pn="section-3.2.7-8">
            <dt pn="section-3.2.7-8.1">Age</dt>
            <dd pn="section-3.2.7-8.2">
              <t indent="0" pn="section-3.2.7-8.2.1">The Age parameter defines the time difference between now - creation of the MP_RTT option -
 and the conducted RTT measurement in milliseconds. If no previous measurement
 exists, e.g., when initialized, the value is 0.</t>
            </dd>
          </dl>
          <t indent="0" pn="section-3.2.7-9">In <xref target="ref-MP_RTT_example" format="default" sectionFormat="of" derivedContent="Figure 12"/> an exemplary flow shows the exchange of path individual 
RTT information with RTT1 pointing to a first path and RTT2 to a second path. Those
RTT values might be extracted from the sender's Congestion Control procedure and
carried to the receiving host using MP_RTT suboption. With the reception of RTT1
and RTT2, the receiver is able to calculate the path_delta which corresponds to
the absolute difference of both values.
In case the path individual RTTs are symmetric in down- and uplink direction, packets
with missing sequence number MP_SEQ, e.g., in a reordering process, can be assumed
lost after path_delta/2.</t>
          <figure anchor="ref-MP_RTT_example" align="left" suppress-title="false" pn="figure-12">
            <name slugifiedName="name-exemplary-flow-of-mp_rtt-ex">Exemplary flow of MP_RTT exchange and usage</name>
            <artwork align="left" pn="section-3.2.7-10.1"><![CDATA[
   MP-DCCP                   MP-DCCP
   Sender                    Receiver
   +--------+  MP_RTT(RTT1)  +-------------+
   |   RTT1 |----------------|             |
   |        |                | path_delta= |
   |        |  MP_RTT(RTT2)  | |RTT1-RTT2| |
   |   RTT2 |----------------|             |
   +--------+                +-------------+
]]></artwork>
          </figure>
        </section>
        <section anchor="MP_ADDADDR" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.8">
          <name slugifiedName="name-mp_addaddr">MP_ADDADDR</name>
          <t indent="0" pn="section-3.2.8-1">The MP_ADDADDR suboption announces additional addresses (and, optionally,
port numbers) on which a host can be reached. This option can be used at any
time during an existing DCCP connection, when the sender wishes to
enable multiple paths and/or when additional paths become available.
Multiple instances of this suboption within a packet advertise simultaneously
new addresses.</t>
          <t indent="0" pn="section-3.2.8-2">Length is variable depending on the address family (IPv4 or IPv6) and whether a port number is
used. This field is in range between 8 and 22 bytes.</t>
          <t indent="0" pn="section-3.2.8-3">The presence of the final 2 octets, specifying the DCCP port number to
use, are optional and can be inferred from the length of the option.
Although it is expected that the majority of use cases will use the
same port pairs as used for the initial subflow (e.g., port 80
remains port 80 on all subflows, as does the ephemeral port at the
client), there may be cases (such as port-based load balancing) where
the explicit specification of a different port is required.  If no
port is specified, the receiving peer SHOULD assume that any attempt to
connect to the specified address has to be on the same port as is already
in use by the subflow on which the MP_ADDADDR signal was sent.</t>
          <t indent="0" pn="section-3.2.8-4">Along with the MP_ADDADDR option a MP_HMAC option MUST be sent for
authentication. The truncated HMAC parameter present in this MP_HMAC
option is the leftmost 20 bytes of an HMAC, negotiated and calculated
as described in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>. In the same way as for MP_JOIN,
the key for the HMAC algorithm, in the case of the message transmitted
by Host A, will be Key-A followed by Key-B, and in the case of Host B,
Key-B followed by Key-A.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID, IP address, and port that precede the HMAC in the
MP_ADDADDR option.  If the port is not present in the MP_ADDADDR option,
the HMAC message will nevertheless include 2 octets of value zero.
The rationale for the HMAC is to prevent unauthorized entities from
injecting MP_ADDADDR signals in an attempt to hijack a connection.
Note that, additionally, the presence of this HMAC prevents the
address from being changed in flight unless the key is known by an
intermediary.  If a host receives an MP_ADDADDR option for which it
cannot validate the HMAC, it SHOULD silently ignore the option.</t>
          <t indent="0" pn="section-3.2.8-5">The presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_ADDADDR is sent. Further details are given in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
          <figure anchor="refMP_ADDADDR" align="left" suppress-title="false" pn="figure-13">
            <name slugifiedName="name-format-of-the-mp_addaddr-su">Format of the MP_ADDADDR Suboption</name>
            <artwork align="left" pn="section-3.2.8-6.1"><![CDATA[
                      1                   2                   3
  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
  +---------------+---------------+-------+-------+---------------+
  |0 0 1 0 1 1 1 0|      var      |0 0 0 0 0 1 1 1|  Address ID   |
  +---------------+---------------+-------+-------+---------------+
  |          Address (IPv4 - 4 bytes / IPv6 - 16 bytes)           |
  +-------------------------------+-------------------------------+
  |   Port (2 bytes, optional)    | + MP_HMAC option
  +-------------------------------+
       Type=46         Length         MP_OPT=7
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.8-7">Every address has an Address ID that can be used for uniquely
identifying the address within a connection for address removal. The
Address ID is also used to identify MP_JOIN options (see <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>)
relating to the same address, even when address translators are in use.
The Address ID MUST uniquely identify the address for the sender of the
option (within the scope of the connection); the mechanism for
allocating such IDs is implementation specific.</t>
          <t indent="0" pn="section-3.2.8-8">All Address IDs learned via either MP_JOIN or MP_ADDADDR SHOULD be stored
by the receiver in a data structure that gathers all the
Address-ID-to-address mappings for a connection (identified by a token
pair). In this way, there is a stored mapping between the Address ID,
observed source address, and token pair for future processing of control
information for a connection. Note that an implementation
MAY discard incoming address advertisements at will, for example, for
avoiding the required mapping state, or because advertised addresses
are of no use to it (for example, IPv6 addresses when it has IPv4
only).  Therefore, a host MUST treat address advertisements as soft
state, and it MAY choose to refresh advertisements periodically.</t>
          <t indent="0" pn="section-3.2.8-9">Due to the proliferation of NATs, it is reasonably likely that one
host may attempt to advertise private addresses.  It is not
desirable to prohibit this, since there may be cases where both hosts
have additional interfaces on the same private network, and a host
MAY want to advertise such addresses. The MP_JOIN handshake to
create a new subflow (<xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>) provides mechanisms to minimize
security risks.  The MP_JOIN message contains a 32-bit token that
uniquely identifies the connection to the receiving host. If the
token is unknown, the host will return with a DCCP-Reset. In the unlikely
event that the token is known, subflow setup will continue, but the
HMAC exchange must occur for authentication.  This will fail, and
will provide sufficient protection against two unconnected hosts
accidentally setting up a new subflow upon the signal of a private
address.  Further security considerations around the issue of
MP_ADDADDR messages that accidentally misdirect, or maliciously direct,
new MP_JOIN attempts are discussed in <xref target="security" format="default" sectionFormat="of" derivedContent="Section 4"/>.
In case a sending host of a MP_ADDADDR knows about the inability
to establish incoming subflows on a particular address, a MP_ADDADDR
SHOULD NOT advertise this address unless sending host has new knowledge
about the ability. Such ability information can be obtained from local
firewall or routing settings, knowledge about availability of external
NAT or firewall, or from connectivity checks performed by the
host/application.</t>
          <t indent="0" pn="section-3.2.8-10">The reception of an MP_ADDADDR message is acknowledged using MP_CONFIRM
(<xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>). Using this mechanism reliable exchange of address
information is ensured.</t>
          <t indent="0" pn="section-3.2.8-11">A host can send an MP_ADDADDR message with an already assigned Address
ID, but the Address MUST be the same as previously assigned to this
Address ID, and the Port MUST be different from one already in use
for this Address ID.  If these conditions are not met, the receiver
SHOULD silently ignore the MP_ADDADDR.  A host wishing to replace an
existing Address ID MUST first remove the existing one (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>).</t>
          <t indent="0" pn="section-3.2.8-12">A host that receives an MP_ADDADDR but finds a connection set up to
that IP address and port number is unsuccessful SHOULD NOT perform
further connection attempts to this address/port combination for this
connection. However, a sender that wants to trigger a new incoming
connection attempt on a previously advertised address/port combination
can therefore refresh MP_ADDADDR information by sending the option again.</t>
        </section>
        <section anchor="MP_REMOVEADDR" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.9">
          <name slugifiedName="name-mp_removeaddr">MP_REMOVEADDR</name>
          <t indent="0" pn="section-3.2.9-1">If, during the lifetime of an MP-DCCP connection, a previously announced
address becomes invalid (e.g., if an interface disappears), the
affected host SHOULD announce this so that the peer can remove subflows
related to this address.</t>
          <t indent="0" pn="section-3.2.9-2">This is achieved through the Remove Address (MP_REMOVEADDR) suboption which
will remove a previously added address with an Address ID from a
connection and terminate any subflows currently using that address.</t>
          <t indent="0" pn="section-3.2.9-3">Along with the MP_REMOVEADDR suboption a MP_HMAC option MUST be sent for
authentication. The truncated HMAC parameter present in this MP_HMAC
option is the leftmost 20 bytes of an HMAC, negotiated and calculated
as described in <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>. In the same way as for MP_JOIN,
the key for the HMAC algorithm, in the case of the message transmitted
by Host A, will be Key-A followed by Key-B, and in the case of Host B,
Key-B followed by Key-A.  These are the keys that were exchanged and
selected in the original MP_KEY handshake. The message for the HMAC is
the Address ID.
The rationale for the HMAC is to prevent unauthorized entities from
injecting MP_REMOVEADDR signals in an attempt to hijack a connection.
Note that, additionally, the presence of this HMAC prevents the
address from being removed in flight unless the key is known by an
intermediary.  If a host receives an MP_REMOVEADDR option for which it
cannot validate the HMAC, it SHOULD silently ignore the option.</t>
          <t indent="0" pn="section-3.2.9-4">The presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_REMOVEADDR is sent. Further details are given in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
          <t indent="0" pn="section-3.2.9-5">The reception of an MP_REMOVEADDR message is acknowledged using MP_CONFIRM
(<xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>). Using this mechanism reliable exchange of address
information is ensured. To avoid inconsistent states, it is recommended to
release the sender address ID only after MP_REMOVEADDR has been confirmed.</t>
          <t indent="0" pn="section-3.2.9-6">The sending and receipt of this message SHOULD trigger the sending of
DCCP-Close and DCCP-Reset by client and server, respectively on the affected
subflow(s) (if possible), as a courtesy to cleaning up middlebox state, before
cleaning up any local state.</t>
          <t indent="0" pn="section-3.2.9-7">Address removal is undertaken by ID, so as to permit the use of NATs and
other middleboxes that rewrite source addresses.  If there is no address
at the requested ID, the receiver will silently ignore the request.</t>
          <figure anchor="refMP_REMOVEADDR" align="left" suppress-title="false" pn="figure-14">
            <name slugifiedName="name-format-of-themp_removeaddr-">Format of theMP_REMOVEADDR Suboption</name>
            <artwork align="left" pn="section-3.2.9-8.1"><![CDATA[
                     1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+---------------+---------------+---------------+---------------+
|0 0 1 0 1 1 1 0|0 0 0 0 0 1 0 0|0 0 0 0 1 0 0 0|   Address ID  |
+---------------+---------------+---------------+---------------+
     Type=46        Length=4         MP_OPT=8

-> followed by MP_HMAC option
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.9-9">A subflow that is still functioning MUST be closed with a DCCP-Close or
exchange as in regular DCCP, rather than using this option. For more
information, see Section <xref target="closing" format="default" sectionFormat="of" derivedContent="Section 3.5"/>.</t>
        </section>
        <section anchor="MP_PRIO" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.10">
          <name slugifiedName="name-mp_prio">MP_PRIO</name>
          <t indent="0" pn="section-3.2.10-1">In the event that a single specific path out of the set of available
paths shall be treated with higher priority compared to the others
when making scheduling decisions for user plane traffic, a host may 
wish to signal such change in priority  to the peer.
One reason for such behavior is due to the different costs involved in
using different paths (e.g., WiFi is free while cellular has limit on
volume, 5G has higher energy consumption). Also, the priority of a path
may be subject to dynamic changes, for example when the mobile runs out
of battery, the usage of only a single path may be the preferred choice
of the user. Therefore, the path priority should be considered as hints 
for the packet scheduler when making decisions which path to use for 
user plane traffic.</t>
          <t indent="0" pn="section-3.2.10-2">The MP_PRIO suboption, shown below, can be used to set a priority flag
for the path over which the suboption is received.</t>
          <figure anchor="ref-MP_PRIO" align="left" suppress-title="false" pn="figure-15">
            <name slugifiedName="name-format-of-the-mp_prio-subop">Format of the MP_PRIO Suboption</name>
            <artwork align="left" pn="section-3.2.10-3.1"><![CDATA[
                        1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +---------------+---------------+---------------+--------------+
   |0 0 1 0 1 1 1 0|0 0 0 0 0 1 0 0|0 0 0 0 1 0 0 1|(resvd)| prio |
   +---------------+---------------+---------------+--------------+
       Type=46         Length=4        MP_OPT=9
]]></artwork>
          </figure>
          <t indent="0" pn="section-3.2.10-4">The following values are available for Prio field:</t>
          <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.2.10-5">
            <li pn="section-3.2.10-5.1">0: Do not use. The path is not available.</li>
            <li pn="section-3.2.10-5.2">1: Standby: do not use this path for traffic scheduling, if another
   path (secondary or primary) is available. The path will only be used if 
   other secondary or primary paths are not established.</li>
            <li pn="section-3.2.10-5.3">2: Secondary: do not use this path for traffic scheduling, if the other
   paths are good enough. The path will be used occasionally for increasing 
   temporarily the available capacity, e.g. when primary paths are 
   congested or are not available. This is the recommended setting for
   paths that have costs or data caps as these paths will be used less
   frequently then primary paths.</li>
            <li pn="section-3.2.10-5.4">3 - 15: Primary: can use the path in any way deemed reasonable by peer. 
   The path will always be used for packet scheduling decisions. The 
   priority number indicates the relative priority of one path over the 
   other for primary paths. Higher numbers indicate higher priority. 
   The peer should consider sending more traffic over higher priority paths. 
   This is the recommended setting for paths that do not have a cost or 
   data caps associated with them as these paths will be frequently used.</li>
          </ul>
          <t indent="0" pn="section-3.2.10-6">Example use cases include:
1) Setting Wi-Fi path to Primary and Cellular paths to Secondary. In this case
   Wi-Fi will be used and Cellular only if the Wi-Fi path is congested or not
   available. Such setting results in using the Cellular path only temporally, 
   if more capacity is needed than the WiFi path can provide, indicating a 
   clear priority of the Wi-Fi path over the Cellular due to e.g. cost reasons.
2) Setting Wi-Fi path to Primary and Cellular to Standby. In this case Wi-Fi
   will be used and Cellular only, if the Wi-Fi path is not available. 
3) Setting Wi-Fi path to Primary and Cellular path to Primary. In this case,
   all packets can be scheduled  over all paths at all time.</t>
          <t indent="0" pn="section-3.2.10-7">If not specified, the default behavior is, that a path can always be used for 
packet scheduling decisions (MP_PRIO=3), if the path has been established and 
added to an existing MP-DCCP connection. At least one path should have a 
MP_PRIO value greater or equal to one for it to be allowed to send on the 
connection. MP_PRIO is assumed to be exchanged reliably using the MP_CONFIRM 
mechanisms (see <xref target="ref-mp-option-confirm" format="default" sectionFormat="of" derivedContent="Table 4"/>).</t>
          <t indent="0" pn="section-3.2.10-8">The presence of a MP_SEQ <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/> MUST be ensured in a DCCP datagram
in which MP_PRIO is sent. Further details are given in <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/>.</t>
        </section>
        <section anchor="MP_CLOSE" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.11">
          <name slugifiedName="name-mp_close">MP_CLOSE</name>
          <figure anchor="ref-MP_CLOSE" align="left" suppress-title="false" pn="figure-16">
            <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">For a graceful shutdown of a MP-DCCP connection, MP_CLOSE is used to communicate this to a peer host. On all subflows, the regular termination procedure as described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> MUST be initiated using MP_CLOSE in the initial packet (either a DCCP-CloseReq or a DCCP-Close). In the case where a DCCP-CloseReq is used, the following DCCP-Close MUST carry the MP_CLOSE as well. At the initiator of the DCCP-CloseReq all sockets, including the MP-DCCP connection socket, transition to CLOSEREQ state. To protect unauthorized shutdown of a multi-path connection, the selected Key Data of the peer host during the handshaking procedure MUST be carried by the MP_CLOSE option and validated by the peer host. Note, Key Data is different between MP_CLOSE option carried by DCCP-CloseReq or DCCP-Close.</t>
          <t indent="0" pn="section-3.2.11-3">On reception of a first DCCP-CloseReq carrying a MP_CLOSE with valid Key Data, or due to a local decision, all subflows transition to the CLOSING state before transmitting a DCCP-Close carrying MP_CLOSE. In this case, the MP-DCCP connection socket on the host sending the DCCP-Close reflects the state of the initial subflow used during handshake with MP_KEY option. If the initial subflow no longer exists, the state moves immediately to CLOSED.</t>
          <t indent="0" pn="section-3.2.11-4">Upon reception of the first DCCP-Close carrying a MP_CLOSE with valid Key Data at the peer host, all subflows, as well as the MP-DCCP connection socket, move to the CLOSED state. After this, a DCCP-Reset with Reset Code 1 MUST be sent on any subflow in response to a received DCCP-Close containing a valid MP_CLOSE option.</t>
          <t indent="0" pn="section-3.2.11-5">When the MP-DCCP connection socket is in CLOSEREQ or CLOSE state, new subflow requests using MP_JOIN MUST be ignored.</t>
          <t indent="0" pn="section-3.2.11-6">Contrary to a MP_FAST_CLOSE <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>, no single-sided abrupt termination is applied.</t>
        </section>
        <section anchor="MP_EXP" numbered="true" removeInRFC="false" toc="include" pn="section-3.2.12">
          <name slugifiedName="name-experimental-mp-dccp-sub-op">Experimental MP-DCCP Sub-Option MP_EXP for private use</name>
          <t indent="0" pn="section-3.2.12-1">This section reserves a MP-DCCP sub-option to define and specify any experimental additional feature for improving and optimization of MP-DCCP protocol. This
option may be applicable to specific environments or scenarios according to potential new requirements and meant for private use only at this stage. MP_OPT 
feature number 11 is foreseen with an exemplary description as below:</t>
          <figure anchor="ref-MP_EXP" align="left" suppress-title="false" pn="figure-17">
            <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">Details as length and type of data remain to be defined according to the foreseen use by the experimenters.</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 18"/>.</t>
        <figure anchor="ref-mp-dccp-handshaking" align="left" suppress-title="false" pn="figure-18">
          <name slugifiedName="name-example-mp-dccp-handshake">Example MP-DCCP Handshake</name>
          <artwork align="left" pn="section-3.3-2.1"><![CDATA[
          Host A                                         Host B 
------------------------                              ----------
Address A1    Address A2                              Address B1
----------    ----------                              ----------
     |             |                                       |
     |             DCCP-Request + MP_CAPABLE               |
     |------- MP_KEY(Key-A(1), Key-A(2),...) ------------->|
     |<---------------------- MP_KEY(Key-B) ---------------|
     |             DCCP-Response +  MP_CAPABLE             |
     |             |                                       |
     |   DCCP-Ack  |                                       |
     |--------- MP_KEY(Key-A) + MP_KEY(Key-B) ------------>|
     |<----------------------------------------------------|
     |   DCCP-Ack  |                                       |
     |             |                                       |
     |             |          DCCP-Request + MP_CAPABLE    |
     |             |--- MP_JOIN(TB,RA) ------------------->|
     |             |<------MP_JOIN(TB,RB) + MP_HMAC(B)-----|
     |             |DCCP-Response  + MP_CAPABLE            |
     |             |                                       |
     |             |DCCP-Ack                               |
     |             |-------- MP_HMAC(A) ------------------>|
     |             |<--------------------------------------|
     |             |DCCP-ACK                               |
]]></artwork>
        </figure>
        <t indent="0" pn="section-3.3-3">The basic initial handshake for the first subflow is as follows:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.3-4">
          <li pn="section-3.3-4.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_KEY option with an Host-specific Key-A for
each of supported types as described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/>.</li>
          <li pn="section-3.3-4.2">Host B sends a DCCP-Response with Confirm feature for
MP-Capable and the MP_Key option with a single Host-specific Key-B.
The type of the key is chosen from the list of supported types
from the previous request.</li>
          <li pn="section-3.3-4.3">Host A sends a DCCP-Ack with both Keys echoed to Host B.</li>
          <li pn="section-3.3-4.4">Host B sends a DCCP-Ack to confirm both keys and conclude the handshaking.</li>
        </ul>
        <t indent="0" pn="section-3.3-5">Host A waits for the final DCCP-Ack from host B before starting any
establishment of additional subflow connections.</t>
        <t indent="0" pn="section-3.3-6">The handshake for subsequent subflows based on a successful initial
handshake is as follows:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-3.3-7">
          <li pn="section-3.3-7.1">Host A sends a DCCP-Request with the MP-Capable feature Change
request and the MP_JOIN option with Host B's Token TB, generated from
the derived key by applying a SHA256 hash and truncating to the first
32 bits. Additionally, an own random nonce RA is transmitted with the
MP_JOIN.</li>
          <li pn="section-3.3-7.2">
            <t indent="0" pn="section-3.3-7.2.1">Host B computes the HMAC of the DCCP-Request and sends a DCCP-Response
with Confirm feature option for MP-Capable and the MP_JOIN option with
the Token TB and a random nonce RB together with the computed MP_HMAC.
The HMAC is calculated by taking the leftmost 20 bytes from the SHA256 hash
of a HMAC code created by using token and nonce received with MP_JOIN(A) as message
and the derived key described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> as key:  </t>
            <t indent="0" pn="section-3.3-7.2.2">
MP_HMAC(B) = HMAC-SHA256(Key=d-key(B), Msg=RB+RA)</t>
          </li>
          <li pn="section-3.3-7.3">
            <t indent="0" pn="section-3.3-7.3.1">Host A sends a DCCP-Ack with the HMAC computed for the DCCP-Response.
The HMAC is calculated by taking the leftmost 20 bytes from the SHA256 hash
of a HMAC code created by using token and nonce received with MP_JOIN(B) as message
and the derived key described in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> as key:  </t>
            <t indent="0" pn="section-3.3-7.3.2">
MP_HMAC(A) = HMAC-SHA256(Key=d-key(A), Msg=RA+RB)</t>
          </li>
          <li pn="section-3.3-7.4">Host B sends a DCCP-Ack to confirm the HMAC and to conclude the
handshaking.</li>
        </ul>
      </section>
      <section anchor="address-knowledge-exchange" numbered="true" removeInRFC="false" toc="include" pn="section-3.4">
        <name slugifiedName="name-address-knowledge-exchange">Address knowledge exchange</name>
        <t indent="0" pn="section-3.4-1">### Advertising a new path (<xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>)</t>
        <t indent="0" pn="section-3.4-2">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 19"/>. The MP_ADDADDR option passed in the DCCP-Data contains the following parameters:
* an identifier (id 2) for the new IP address which is used as a reference in subsequent control exchanges.
* the IP address of the new path (A2_IP)
* A pair of octets specifying the port number associated with this IP address. The value of 00 here, indicates that the port number is the same
  as that used for the initial subflow address A1_IP</t>
        <t indent="0" pn="section-3.4-3">The following options must be included in a packet carrying MP_ADDADDR:
* the leftmost 20 bytes of the HMAC(A) generated during the initial handshaking procedure described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/> and <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>
* the sequence number (seqno 12) for this message</t>
        <t indent="0" pn="section-3.4-4">Host B acknowledges receipt of the MP_ADDADDR message with a DCCP-Ack containing the MP_CONFIRM option. The parameters supplied in this
response are as follows:
* an MP_CONFIRM containing the MP_SEQ number (seqno 12) of the packet carrying the option that we are confirming together with the MP_ADDADDR option
* the leftmost 20 bytes of the HMAC(B) generated during the initial handshaking procedure <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
        <figure anchor="ref-mp-dccp-add-address" align="left" suppress-title="false" pn="figure-19">
          <name slugifiedName="name-example-mp-dccp-addaddr-pro">Example MP-DCCP ADDADDR procedure</name>
          <artwork align="left" pn="section-3.4-5.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_ADDADDR(id 2, A2_IP, 00) +        |
     |------- MP_HMAC(A) + MP_SEQ(seqno 12) -------------->|
     |             |                                       |      
     |   DCCP-Ack + MP_HMAC(B) +                           |
     |<----- MP_CONFIRM(seqno 12, MP_ADDADDR) -------------|
]]></artwork>
        </figure>
        <section anchor="removing-a-path-mpremoveaddr" numbered="true" removeInRFC="false" toc="include" pn="section-3.4.1">
          <name slugifiedName="name-removing-a-path">Removing a path (<xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/>)</name>
          <t indent="0" pn="section-3.4.1-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 20"/>. The MP_REMOVEADDR option passed in the DCCP-Data contains the following parameters:
* an identifier (id 2) for the IP address to remove (A2_IP) and which was specified in a previous MP_ADDADDR message.</t>
          <t indent="0" pn="section-3.4.1-2">The following options must be included in a packet carrying MP_REMOVEADDR
* the leftmost 20 bytes of the HMAC(A) generated during the initial handshaking procedure described in <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/> and <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/>
* the sequence number (seqno 33) for this message</t>
          <t indent="0" pn="section-3.4.1-3">Host B acknowledges receipt of the MP_REMOVEADDR message with a DCCP-Ack containing the MP_CONFIRM option. The parameters supplied in this
response are as follows:
* an MP_CONFIRM containing the MP_SEQ number (seqno 33) of the packet carrying the option that we are confirming, together with the MP_REMOVEADDR option
* the leftmost 20 bytes of the HMAC(B) generated during the initial handshaking procedure <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/></t>
          <figure anchor="ref-mp-dccp-remove-address" align="left" suppress-title="false" pn="figure-20">
            <name slugifiedName="name-example-mp-dccp-removeaddr-">Example MP-DCCP REMOVEADDR procedure</name>
            <artwork align="left" pn="section-3.4.1-4.1"><![CDATA[
          Host A                                         Host B 
------------------------                              -----------
Address A1    Address A2                               Address B1
----------    ----------                              -----------
     |             |                                       |
     |   DCCP-Data +  MP_REMOVEADDR(id 2) +                |
     |------- MP_HMAC(A) + MP_SEQ(seqno 33) -------------->|
     |             |                                       |      
     |   DCCP-Ack + MP_HMAC(B) +                           |
     |<----- MP_CONFIRM(seqno 33, MP_REMOVEADDR) ----------|
]]></artwork>
          </figure>
        </section>
      </section>
      <section anchor="closing" numbered="true" removeInRFC="false" toc="include" pn="section-3.5">
        <name slugifiedName="name-close-a-mp-dccp-connection">Close a MP-DCCP connection</name>
        <t indent="0" pn="section-3.5-1">When a host wants to close an existing subflow but not the whole MP-DCCP
connection, it initiates the regular DCCP connection termination procedure 
as described in <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 is RECOMMENDED to use an appropriate DCCP reset code as specified in
Table 2 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>. This could be, for example, sending reset code 5 (Option Error) when an MP-DCCP
option provides invalid data or reset code 9 (Too Busy) when the maximum number of maintainable paths
is reached. Note that receiving a reset code 9 for secondary subflows SHOULD NOT impact already existing active
subflows. If necessary, these subflows are terminated in a subsequent step using the procedures described in
this section.</t>
        <t indent="0" pn="section-3.5-2">When a host wants to terminate an  MP-DCCP connection, it is RECOMMENDED that the host
initiates the DCCP connection termination as per <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 MP-DCCP suboptions, faulty/non-supported MP-DCCP options or modification
of payload data.</t>
        <t indent="0" pn="section-3.6-2">At the start of an MP-DCCP connection, the handshake ensures exchange of MP-DCCP feature and
options and thus ensures that the path is fully MP-DCCP capable. If during the
handshake procedure it appears that DCCP-Request or DCCP-Response
messages don't carry the MP_CAPABLE feature, the MP-DCCP connection will not be 
established and the handshake SHOULD fall back to regular DCCP or MUST be closed.</t>
        <t indent="0" pn="section-3.6-3">The same fallback SHOULD take place if the endpoints fail to agree on a protocol
version to use during the Multipath Capable feature negotiation, which is described
in <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/>. The protocol version negotiation distinguishes between negotiation
for the initial connection establishment, and addition of subsequent subflows. If
protocol version negotiation is not successful during the initial connection establishment,
MP-DCCP connection will fall back to regular DCCP.</t>
        <t indent="0" pn="section-3.6-4">Similar procedure MUST be applied if the MP_KEY <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> Key Type cannot be negotiated,
a final ACK carrying MP_KEY with wrong Key-A/Key-B is received or MP_KEY option is malformed.</t>
        <t indent="0" pn="section-3.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. Also non-verifiable MP_HMAC <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/> or MP_JOIN Path Token <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/> as
part of the subsequent flow establishment MUST lead to a subflow closing.</t>
        <t indent="0" pn="section-3.6-6">Another relevant case is when payload data is modified by middleboxes. DCCP uses 
checksum to protect the data, as described in section 9 of <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>. A checksum will 
fail if the data has been changed in any way. All data from the start of the segment that
failed the checksum onwards cannot be considered trustworthy. DCCP defines that if 
the checksum fails, the receiving endpoint MUST drop the application data and report 
that data as dropped due to corruption using a Data Dropped option (Drop Code 3, 
Corrupt). If this happens in an MP-DCCP connection, the affected subflow can either be closed
or other action can be taken.</t>
      </section>
      <section anchor="congestion-control-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.7">
        <name slugifiedName="name-congestion-control-consider">Congestion Control Considerations</name>
        <t indent="0" pn="section-3.7-1">Senders MUST manage per-path congestion status, and SHOULD avoid to send
more data on a given path than congestion control on that path
allows.</t>
        <t indent="0" pn="section-3.7-2">When a Multipath DCCP connection uses two or more paths, there is no
guarantee that these paths are fully disjoint.  When two (or more
paths) share the same bottleneck, using a standard congestion control
scheme could result in an unfair distribution of the bandwidth with
the multipath connection getting more bandwidth than competing single
path connections.  Multipath TCP uses the coupled congestion control
Linked Increases Algorithm (LIA) specified in <xref target="RFC6356" format="default" sectionFormat="of" derivedContent="RFC6356"/> to
solve this problem.  This scheme can be adapted also for Multipath DCCP.
The same applies to other coupled congestion control schemes, which
have been proposed for Multipath TCP such as Opportunistic Linked
Increases Algorithm <xref target="OLIA" format="default" sectionFormat="of" derivedContent="OLIA"/>. The details of the congestion control
algorithms are outside the scope of this document.</t>
      </section>
      <section anchor="maximum-packet-size-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-3.8">
        <name slugifiedName="name-maximum-packet-size-conside">Maximum Packet Size Considerations</name>
        <t indent="0" pn="section-3.8-1">A DCCP implementation maintains the maximum packet size (MPS) during operation of a DCCP session. This procedure is specified for single-path DCCP in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 14. Without any restrictions, this is adopted for MP-DCCP operations, in particular the PMTU measurement and the Sender Behaviour. As per this definition a DCCP application interface SHOULD let the application discover the current MPS, this is subject to ambiguity with potential different path MPS in a multipath system.</t>
        <t indent="0" pn="section-3.8-2">For compatibility reasons, an MP-DCCP implementation SHOULD always announce the minimum MPS across all paths.</t>
      </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 or some other kind of
end-to-end security is recommended;
Secure Real-time Transport Protocol (SRTP) <xref target="RFC3711" format="default" sectionFormat="of" derivedContent="RFC3711"/> is one candidate
protocol for authentication. Together with Encryption of Header
Extensions in SRTP, as provided by <xref target="RFC6904" format="default" sectionFormat="of" derivedContent="RFC6904"/>, also integrity would
be provided.</t>
      <t indent="0" pn="section-4-2">As described in <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, DCCP provides protection against hijacking
and limits the potential impact of some denial-of-service attacks, but
DCCP provides no inherent protection against attackers' snooping on data
packets. Regarding the security of MP-DCCP no additional risks should be
introduced compared to regular DCCP. Thereof derived are the
following key security requirements to be fulfilled by MP-DCCP:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-4-3">
        <li pn="section-4-3.1">Provide a mechanism to confirm that parties involved in a subflow
handshake are identical to those in the original connection setup.</li>
        <li pn="section-4-3.2">Provide verification that the new address to be included in a MP
connection is valid for a peer to receive traffic at before using it.</li>
        <li pn="section-4-3.3">Provide replay protection, i.e., ensure that a request to add/remove a
subflow is 'fresh'.</li>
      </ul>
      <t indent="0" pn="section-4-4">In order to achieve these goals, MP-DCCP includes a hash-based handshake
algorithm documented in Sections <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> and <xref target="handshaking" format="default" sectionFormat="of" derivedContent="Section 3.3"/>. The
security of the MP-DCCP connection depends on the use of keys that are
shared once at the start of the first subflow and are never sent again
over the network. To ease demultiplexing while not giving away any
cryptographic material, future subflows use a truncated cryptographic
hash of this key as the connection identification "token". The keys are
concatenated and used as keys for creating Hash-based Message
Authentication Codes (HMACs) used on subflow setup, in order to verify
that the parties in the handshake are the same as in the original
connection setup. It also provides verification that the peer can
receive traffic at this new address. Replay attacks would still be
possible when only keys are used;
therefore, the handshakes use single-use random numbers (nonces) at both
ends -- this ensures that the HMAC will never be the same on two handshakes.
Guidance on generating random numbers suitable for use as keys is given
in <xref target="RFC4086" format="default" sectionFormat="of" derivedContent="RFC4086"/>. During normal operation, regular DCCP protection
mechanisms (such as header checksum to protect DCCP headers against
corruption) will provide the same level of protection against attacks on
individual DCCP subflows as exists for regular DCCP.</t>
      <t indent="0" pn="section-4-5">As discussed in <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/>, a host may advertise its private
addresses, but these might point to different hosts in the receiver's
network.  The MP_JOIN handshake (<xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/>) will ensure that this
does not succeed in setting up a subflow to the incorrect host.
However, it could still create unwanted DCCP handshake traffic.  This
feature of MP-DCCP could be a target for denial-of-service exploits,
with malicious participants in MP-DCCP connections encouraging the
recipient to target other hosts in the network.  Therefore,
implementations should consider heuristics at both the
sender and receiver to reduce the impact of this.</t>
    </section>
    <section anchor="middlebox" numbered="true" removeInRFC="false" toc="include" pn="section-5">
      <name slugifiedName="name-interactions-with-middlebox">Interactions with Middleboxes</name>
      <t indent="0" pn="section-5-1">Issues from interaction with on-path middleboxes such as NATs, firewalls, proxies,
intrusion detection systems (IDSs), and others have to be considered for all
extensions to standard protocols since otherwise unexpected reactions of
middleboxes may hinder its deployment. DCCP already provides means to
mitigate the potential impact of middleboxes, also in comparison to TCP (see
<xref target="RFC4043" format="default" sectionFormat="of" derivedContent="RFC4043"/>, Section 16). In case, however, both hosts are located behind a NAT or
firewall entity, specific measures have to be applied such as the <xref target="RFC5596" format="default" sectionFormat="of" derivedContent="RFC5596"/>-specified
simultaneous-open technique that update the (traditionally asymmetric)
connection-establishment procedures for DCCP.  Further standardized technologies
addressing NAT type middleboxes are covered by <xref target="RFC5597" format="default" sectionFormat="of" derivedContent="RFC5597"/>.</t>
      <t indent="0" pn="section-5-2"><xref target="RFC6773" format="default" sectionFormat="of" derivedContent="RFC6773"/> specifies UDP Encapsulation for NAT Traversal of DCCP sessions,
similar to other UDP encapsulations such as for SCTP <xref target="RFC6951" format="default" sectionFormat="of" derivedContent="RFC6951"/>. The alternative
U-DCCP approach proposed in <xref target="I-D.amend-tsvwg-dccp-udp-header-conversion" format="default" sectionFormat="of" derivedContent="I-D.amend-tsvwg-dccp-udp-header-conversion"/> would
reduce tunneling overhead. The handshaking procedure for DCCP-UDP
header conversion or use of a DCCP-UDP negotiation procedure to signal support
for DCCP-UDP header conversion would require encapsulation during the handshakes
and use of two additional port numbers out of the UDP port number space, but
would require zero overhead afterwards.</t>
    </section>
    <section anchor="implementation" numbered="true" 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="website" format="default" sectionFormat="of" derivedContent="website"/>.</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">Due to the great spearheading work of the Multipath TCP authors in <xref target="RFC6824" format="default" sectionFormat="of" derivedContent="RFC6824"/>/<xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, some text
passages were copied almost unmodified from these documents.</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, and Behcet Sarikaya.</t>
    </section>
    <section anchor="iana-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-8">
      <name slugifiedName="name-iana-considerations">IANA Considerations</name>
      <t indent="0" pn="section-8-1">This section provides guidance to the Internet Assigned Numbers Authority (IANA) regarding registration of values related to the MP extension of the DCCP protocol 
in accordance with <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>.  This document defines one new value to be added to the DCCP Feature Numbers registry and three new registries to be added to the DCCP registry group.</t>
      <t indent="0" pn="section-8-2">This document requests IANA to assign a new DCCP feature parameter for negotiating
the support of multipath capability for DCCP sessions between hosts
as described in <xref target="protocol" format="default" sectionFormat="of" derivedContent="Section 3"/>. The following entry in <xref target="ref-add-feature-list" format="default" sectionFormat="of" derivedContent="Table 6"/> should be
added to the Feature Numbers registry in the DCCP registry group according to <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/>, Section 19.4. under the "DCCP Protocol" heading.</t>
      <table anchor="ref-add-feature-list" align="center" pn="table-6">
        <name slugifiedName="name-addition-to-dccp-feature-nu">Addition to DCCP Feature Numbers registry</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Feature Name</th>
            <th align="center" colspan="1" rowspan="1">Specification</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">10 (suggested)</td>
            <td align="center" colspan="1" rowspan="1">MP-DCCP capability feature</td>
            <td align="center" colspan="1" rowspan="1">[ThisDocument]</td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-4">As outlined in sect. <xref target="mp_capable" format="default" sectionFormat="of" derivedContent="Section 3.1"/> the new 1-Byte entry above includes a 4-bit part to specify the version of the used MP-DCCP implementation. This document requests IANA to create a new 'MP-DCCP Versions' registry within the DCCP registry group to track the MP-DCCP version. The initial content of this registry is as follows:</t>
      <table anchor="ref-add-version-list" align="center" pn="table-7">
        <name slugifiedName="name-mp-dccp-versions-registry">MP-DCCP Versions Registry</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Version</th>
            <th align="center" colspan="1" rowspan="1">Description</th>
            <th align="center" colspan="1" rowspan="1">Specification</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">0000</td>
            <td align="center" colspan="1" rowspan="1">Version 0</td>
            <td align="center" colspan="1" rowspan="1">[ThisDocument]</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">0001 - 1111</td>
            <td align="center" colspan="1" rowspan="1">Unassigned</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-6">Future MP-DCCP versions 1 to 15 are assigned from this registry using the Specification Required policy (Section 4.6 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      <t indent="0" pn="section-8-7">This document requests IANA to assign a new DCCP protocol option of type=46 as described in Section 3.2.</t>
      <t indent="0" pn="section-8-8">IANA is requested to create a new 'MP-DCCP Suboptions' registry within the DCCP registry group. The following entries in <xref target="ref-add-proto-opt-list" format="default" sectionFormat="of" derivedContent="Table 8"/> should be added to the new 'MP-DCCP Suboptions' registry. The registry in <xref target="ref-add-proto-opt-list" format="default" sectionFormat="of" derivedContent="Table 8"/> has an upper boundary of 255 in the numeric value field.</t>
      <table anchor="ref-add-proto-opt-list" align="center" pn="table-8">
        <name slugifiedName="name-mp-dccp-suboptions-registry">MP-DCCP Suboptions registry</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Symbol</th>
            <th align="center" colspan="1" rowspan="1">Name</th>
            <th align="center" colspan="1" rowspan="1">Reference</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">Type=46</td>
            <td align="center" colspan="1" rowspan="1">MP_OPT</td>
            <td align="center" colspan="1" rowspan="1">DCCP Multipath option</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=0</td>
            <td align="center" colspan="1" rowspan="1">MP_CONFIRM</td>
            <td align="center" colspan="1" rowspan="1">Confirm reception/processing of an MP_OPT option</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_CONFIRM" format="default" sectionFormat="of" derivedContent="Section 3.2.1"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=1</td>
            <td align="center" colspan="1" rowspan="1">MP_JOIN</td>
            <td align="center" colspan="1" rowspan="1">Join subflow to existing MP-DCCP connection</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_JOIN" format="default" sectionFormat="of" derivedContent="Section 3.2.2"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=2</td>
            <td align="center" colspan="1" rowspan="1">MP_FAST_CLOSE</td>
            <td align="center" colspan="1" rowspan="1">Close MP-DCCP connection</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=3</td>
            <td align="center" colspan="1" rowspan="1">MP_KEY</td>
            <td align="center" colspan="1" rowspan="1">Exchange key material for MP_HMAC</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=4</td>
            <td align="center" colspan="1" rowspan="1">MP_SEQ</td>
            <td align="center" colspan="1" rowspan="1">Multipath Sequence Number</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=5</td>
            <td align="center" colspan="1" rowspan="1">MP_HMAC</td>
            <td align="center" colspan="1" rowspan="1">Hash-based Message Auth. Code for MP-DCCP</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_HMAC" format="default" sectionFormat="of" derivedContent="Section 3.2.6"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=6</td>
            <td align="center" colspan="1" rowspan="1">MP_RTT</td>
            <td align="center" colspan="1" rowspan="1">Transmit RTT values and calculation parameters</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_RTT" format="default" sectionFormat="of" derivedContent="Section 3.2.7"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=7</td>
            <td align="center" colspan="1" rowspan="1">MP_ADDADDR</td>
            <td align="center" colspan="1" rowspan="1">Advertise additional Address(es)/Port(s)</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_ADDADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.8"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=8</td>
            <td align="center" colspan="1" rowspan="1">MP_REMOVEADDR</td>
            <td align="center" colspan="1" rowspan="1">Remove Address(es)/ Port(s)</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_REMOVEADDR" format="default" sectionFormat="of" derivedContent="Section 3.2.9"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=9</td>
            <td align="center" colspan="1" rowspan="1">MP_PRIO</td>
            <td align="center" colspan="1" rowspan="1">Change Subflow Priority</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_PRIO" format="default" sectionFormat="of" derivedContent="Section 3.2.10"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=10</td>
            <td align="center" colspan="1" rowspan="1">MP_CLOSE</td>
            <td align="center" colspan="1" rowspan="1">Close MP-DCCP subflow</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_OPT" format="default" sectionFormat="of" derivedContent="Section 3.2"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT=11</td>
            <td align="center" colspan="1" rowspan="1">MP_EXP</td>
            <td align="center" colspan="1" rowspan="1">Experimental Sub-Option for private use</td>
            <td align="center" colspan="1" rowspan="1">
              <xref target="MP_EXP" format="default" sectionFormat="of" derivedContent="Section 3.2.12"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">MP_OPT&gt;11</td>
            <td align="center" colspan="1" rowspan="1">Unassigned</td>
            <td align="center" colspan="1" rowspan="1">Reserved for future MP-DCCP suboptions</td>
            <td align="center" colspan="1" rowspan="1"> </td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-8-10">Future MP-DCCP sub-options with MP_OPT&gt;11 can be assigned from this registry using the Specification Required policy (Section 4.6 of <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>).</t>
      <t indent="0" pn="section-8-11">In addition IANA is requested to assign a new DCCP Reset Code value 13 (or TBD) in the DCCP Reset Codes Registry, with the short description "Abrupt MP termination".  Use of this reset code is defined in section <xref target="MP_FAST_CLOSE" format="default" sectionFormat="of" derivedContent="Section 3.2.3"/>.</t>
      <t indent="0" pn="section-8-12">In addition IANA is requested to assign for this version of the MP-DCCP protocol a new 'MP_KEY' registry containing three different sub options to the MP-KEY option to identify the MP_KEY Key types in terms of 8-bit values as specified in <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/> according to the entries in <xref target="ref-mp_key-sub-opt-list" format="default" sectionFormat="of" derivedContent="Table 9"/> below. Values in range 3-255 (decimal) inclusive remain unassigned in this version 0 of the protocol and are assigned via Specification Required <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>
in potential future versions of the MP-DCCP protocol.</t>
      <table anchor="ref-mp_key-sub-opt-list" align="center" pn="table-9">
        <name slugifiedName="name-mp-dccp-mp_key-registry-wit">MP-DCCP MP_KEY registry with type sub-options for key data exchange on different paths</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Value</th>
            <th align="center" colspan="1" rowspan="1">Key Type</th>
            <th align="center" colspan="1" rowspan="1">Name or Meaning</th>
            <th align="left" colspan="1" rowspan="1">Reference</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">0</td>
            <td align="center" colspan="1" rowspan="1">Plain Text</td>
            <td align="center" colspan="1" rowspan="1">Plain Text Key</td>
            <td align="left" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">1</td>
            <td align="center" colspan="1" rowspan="1">ECDHE-C25519-SHA256</td>
            <td align="center" colspan="1" rowspan="1">ECDHE with SHA256 and Curve25519</td>
            <td align="left" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">2</td>
            <td align="center" colspan="1" rowspan="1">ECDHE-C25519-SHA512</td>
            <td align="center" colspan="1" rowspan="1">ECDHE with SHA512 and Curve25519</td>
            <td align="left" colspan="1" rowspan="1">
              <xref target="MP_KEY" format="default" sectionFormat="of" derivedContent="Section 3.2.4"/></td>
          </tr>
        </tbody>
      </table>
    </section>
  </middle>
  <back>
    <references pn="section-9">
      <name slugifiedName="name-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="I-D.amend-tsvwg-multipath-framework-mpdccp" quoteTitle="true" target="https://datatracker.ietf.org/doc/html/draft-amend-tsvwg-multipath-framework-mpdccp-01" derivedAnchor="I-D.amend-tsvwg-multipath-framework-mpdccp">
        <front>
          <title>A multipath framework for UDP traffic over heterogeneous access networks</title>
          <author fullname="Markus Amend" initials="M." surname="Amend">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Eckard Bogenfeld" initials="E." surname="Bogenfeld">
            <organization showOnFrontPage="true">Deutsche Telekom</organization>
          </author>
          <author fullname="Anna Brunstrom" initials="A." surname="Brunstrom">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Andreas Kassler" initials="A." surname="Kassler">
            <organization showOnFrontPage="true">Karlstad University</organization>
          </author>
          <author fullname="Veselin Rakocevic" initials="V." surname="Rakocevic">
            <organization showOnFrontPage="true">City University of London</organization>
          </author>
          <date day="8" month="July" year="2019"/>
          <abstract>
            <t indent="0">   More and more of today's devices are multi-homing capable, in
   particular 3GPP user equipment like smartphones.  In the current
   standardization of the next upcoming mobile network generation 5G
   Rel.16, this is especially targeted in the study group Access Traffic
   Steering Switching Splitting [TR23.793].  ATSSS describes the
   flexible selection or combination of 3GPP untrusted access like Wi-Fi
   and cellular access, overcoming the single-access limitation of
   today's devices and services.  Another multi-connectivity scenario is
   the Hybrid Access [I-D.lhwxz-hybrid-access-network-architecture][I-D.
   muley-network-based-bonding-hybrid-access], providing multiple access
   for CPEs, which extends the traditional way of single access
   connectivity at home to dual-connectivity over 3GPP and fixed access.
   A missing piece in the ATSSS and Hybrid Access is the access and path
   measurement, which is required for efficient and beneficial traffic
   steering decisions.  This becomes particularly important in
   heterogeneous access networks with a multitude of volatile access
   paths.  While MP-TCP has been proposed to be used within ATSSS, there
   are drawbacks when being used to encapsulate unreliable traffic as it
   blindly retransmits each lost frame leading to excessive delay and
   potential head-of-line blocking.  A decision for MP-TCP though leaves
   the increasing share of UDP in today's traffic mix
   (&lt;https://arxiv.org/abs/1801.05168&gt;) unconsidered.  In this document,
   a multi-access framework is proposed leveraging the MP-DCCP network
   protocol, which enables flexible traffic steering, switching and
   splitting also for unreliable traffic.  A benefit is the support for
   pluggable congestion control which enables our framework to be used
   either independent or complementary to MP-TCP.

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


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


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-muley-network-based-bonding-hybrid-access-03"/>
        <refcontent>Work in Progress</refcontent>
      </reference>
      <reference anchor="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="paper" quoteTitle="true" target="https://doi.org/10.1109/LCN44214.2019.8990746" derivedAnchor="paper">
        <front>
          <title>A Framework for Multiaccess Support for Unreliable Internet Traffic using Multipath DCCP</title>
          <author initials="M." surname="Amend" fullname="Markus Amend">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="E." surname="Bogenfeld" fullname="Eckard Bogenfeld">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="M." surname="Cvjetkovic" fullname="Milan Cvjetkovic">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="V." surname="Rakocevic" fullname="Veselin Rakocevic">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="M." surname="Pieska" fullname="Marcus Pieska">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="A." surname="Kassler" fullname="Andreas Kassler">
            <organization showOnFrontPage="true"/>
          </author>
          <author initials="A." surname="Brunstrom" fullname="Anna Brunstrom">
            <organization showOnFrontPage="true"/>
          </author>
          <date year="2019" month="October"/>
        </front>
        <seriesInfo name="DOI" value="10.1109/LCN44214.2019.8990746"/>
      </reference>
      <reference anchor="RFC0793" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc793" derivedAnchor="RFC0793">
        <front>
          <title>Transmission Control Protocol</title>
          <author fullname="J. Postel" initials="J." surname="Postel">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="1981"/>
        </front>
        <seriesInfo name="RFC" value="793"/>
        <seriesInfo name="DOI" value="10.17487/RFC0793"/>
      </reference>
      <reference anchor="RFC2104" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc2104" derivedAnchor="RFC2104">
        <front>
          <title>HMAC: Keyed-Hashing for Message Authentication</title>
          <author fullname="H. Krawczyk" initials="H." surname="Krawczyk">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Bellare" initials="M." surname="Bellare">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="R. Canetti" initials="R." surname="Canetti">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="February" year="1997"/>
          <abstract>
            <t indent="0">This document describes HMAC, a mechanism for message authentication using cryptographic hash functions. HMAC can be used with any iterative cryptographic hash function, e.g., MD5, SHA-1, in combination with a secret shared key.  The cryptographic strength of HMAC depends on the properties of the underlying hash function.  This memo provides information for the Internet community.  This memo does not specify an Internet standard of any kind</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="2104"/>
        <seriesInfo name="DOI" value="10.17487/RFC2104"/>
      </reference>
      <reference anchor="RFC2119" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="1997"/>
          <abstract>
            <t indent="0">In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="2119"/>
        <seriesInfo name="DOI" value="10.17487/RFC2119"/>
      </reference>
      <reference anchor="RFC3124" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc3124" derivedAnchor="RFC3124">
        <front>
          <title>The Congestion Manager</title>
          <author fullname="H. Balakrishnan" initials="H." surname="Balakrishnan">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Seshan" initials="S." surname="Seshan">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2001"/>
          <abstract>
            <t indent="0">This document describes the Congestion Manager (CM), an end-system module that enables an ensemble of multiple concurrent streams from a sender destined to the same receiver and sharing the same congestion properties to perform proper congestion avoidance and control, and allows applications to easily adapt to network congestion.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="3124"/>
        <seriesInfo name="DOI" value="10.17487/RFC3124"/>
      </reference>
      <reference anchor="RFC3711" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="D. McGrew" initials="D." surname="McGrew">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Naslund" initials="M." surname="Naslund">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="E. Carrara" initials="E." surname="Carrara">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="K. Norrman" initials="K." surname="Norrman">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2004"/>
          <abstract>
            <t indent="0">This document describes the Secure Real-time Transport Protocol (SRTP), a profile of the Real-time Transport Protocol (RTP), which can provide confidentiality, message authentication, and replay protection to the RTP traffic and to the control traffic for RTP, the Real-time Transport Control Protocol (RTCP).   [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="3711"/>
        <seriesInfo name="DOI" value="10.17487/RFC3711"/>
      </reference>
      <reference anchor="RFC4043" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Gindin" initials="T." surname="Gindin">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2005"/>
          <abstract>
            <t indent="0">This document defines a new form of name, called permanent identifier, that may be included in the subjectAltName extension of a public key certificate issued to an entity.</t>
            <t indent="0">The permanent identifier is an optional feature that may be used by a CA to indicate that two or more certificates relate to the same entity, even if they contain different subject name (DNs) or different names in the subjectAltName extension, or if the name or the affiliation of that entity stored in the subject or another name form in the subjectAltName extension has changed.</t>
            <t indent="0">The subject name, carried in the subject field, is only unique for each subject entity certified by the one CA as defined by the issuer name field.  However, the new name form can carry a name that is unique for each subject entity certified by a CA.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4043"/>
        <seriesInfo name="DOI" value="10.17487/RFC4043"/>
      </reference>
      <reference anchor="RFC4086" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="J. Schiller" initials="J." surname="Schiller">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Crocker" initials="S." surname="Crocker">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2005"/>
          <abstract>
            <t indent="0">Security systems are built on strong cryptographic algorithms that foil pattern analysis attempts.  However, the security of these systems is dependent on generating secret quantities for passwords, cryptographic keys, and similar quantities.  The use of pseudo-random processes to generate secret quantities can result in pseudo-security. A sophisticated attacker may find it easier to reproduce the environment that produced the secret quantities and to search the resulting small set of possibilities than to locate the quantities in the whole of the potential number space.</t>
            <t indent="0">Choosing random quantities to foil a resourceful and motivated adversary is surprisingly difficult.  This document points out many pitfalls in using poor entropy sources or traditional pseudo-random number generation techniques for generating such quantities.  It recommends the use of truly random hardware techniques and shows that the existing hardware on many systems can be used for this purpose. It provides suggestions to ameliorate the problem when a hardware solution is not available, and it gives examples of how large such quantities need to be for some applications.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="106"/>
        <seriesInfo name="RFC" value="4086"/>
        <seriesInfo name="DOI" value="10.17487/RFC4086"/>
      </reference>
      <reference anchor="RFC4340" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="S. Floyd" initials="S." surname="Floyd">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2006"/>
          <abstract>
            <t indent="0">The Datagram Congestion Control Protocol (DCCP) is a transport protocol that provides bidirectional unicast connections of congestion-controlled unreliable datagrams.  DCCP is suitable for applications that transfer fairly large amounts of data and that can benefit from control over the tradeoff between timeliness and reliability.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="4340"/>
        <seriesInfo name="DOI" value="10.17487/RFC4340"/>
      </reference>
      <reference anchor="RFC5595" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5595" derivedAnchor="RFC5595">
        <front>
          <title>The Datagram Congestion Control Protocol (DCCP) Service Codes</title>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document describes the usage of Service Codes by the Datagram Congestion Control Protocol, RFC 4340.  It motivates the setting of a Service Code by applications.  Service Codes provide a method to identify the intended service/application to process a DCCP connection request.  This provides improved flexibility in the use and assignment of port numbers for connection multiplexing.  The use of a DCCP Service Code can also enable more explicit coordination of services with middleboxes (e.g., network address translators and firewalls).  This document updates the specification provided in RFC 4340.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5595"/>
        <seriesInfo name="DOI" value="10.17487/RFC5595"/>
      </reference>
      <reference anchor="RFC5596" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document specifies an update to the Datagram Congestion Control Protocol (DCCP), a connection-oriented and datagram-based transport protocol.  The update adds support for the DCCP-Listen packet.  This assists DCCP applications to communicate through middleboxes (e.g., a Network Address Port Translator or a DCCP server behind a firewall), where peering endpoints need to initiate communication in a near- simultaneous manner to establish necessary middlebox state.   [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5596"/>
        <seriesInfo name="DOI" value="10.17487/RFC5596"/>
      </reference>
      <reference anchor="RFC5597" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="September" year="2009"/>
          <abstract>
            <t indent="0">This document defines a set of requirements for NATs handling the Datagram Congestion Control Protocol (DCCP).  These requirements allow DCCP applications, such as streaming applications, to operate consistently, and they are very similar to the TCP requirements for NATs, which have already been published by the IETF.  Ensuring that NATs meet this set of requirements will greatly increase the likelihood that applications using DCCP will function properly.  This  document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="150"/>
        <seriesInfo name="RFC" value="5597"/>
        <seriesInfo name="DOI" value="10.17487/RFC5597"/>
      </reference>
      <reference anchor="RFC5634" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc5634" derivedAnchor="RFC5634">
        <front>
          <title>Quick-Start for the Datagram Congestion Control Protocol (DCCP)</title>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="A. Sathiaseelan" initials="A." surname="Sathiaseelan">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="August" year="2009"/>
          <abstract>
            <t indent="0">This document specifies the use of the Quick-Start mechanism by the Datagram Congestion Control Protocol (DCCP).  DCCP is a transport protocol that allows the transmission of congestion-controlled, unreliable datagrams.  DCCP is intended for applications such as streaming media, Internet telephony, and online games.  In DCCP, an application has a choice of congestion control mechanisms, each specified by a Congestion Control Identifier (CCID).  This document specifies general procedures applicable to all DCCP CCIDs and specific procedures for the use of Quick-Start with DCCP CCID 2, CCID 3, and CCID 4.  Quick-Start enables a DCCP sender to cooperate with Quick-Start routers along the end-to-end path to determine an allowed sending rate at the start of a connection and, at times, in the middle of a DCCP connection (e.g., after an idle or application- limited period).  The present specification is provided for use in controlled environments, and not as a mechanism that would be intended or appropriate for ubiquitous deployment in the global Internet.  This memo defines an Experimental Protocol for the  Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5634"/>
        <seriesInfo name="DOI" value="10.17487/RFC5634"/>
      </reference>
      <reference anchor="RFC6234" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Hansen" initials="T." surname="Hansen">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2011"/>
          <abstract>
            <t indent="0">Federal Information Processing Standard, FIPS</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6234"/>
        <seriesInfo name="DOI" value="10.17487/RFC6234"/>
      </reference>
      <reference anchor="RFC6356" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="D. Wischik" initials="D." surname="Wischik">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="October" year="2011"/>
          <abstract>
            <t indent="0">Often endpoints are connected by multiple paths, but communications are usually restricted to a single path per connection.  Resource usage within the network would be more efficient were it possible for these multiple paths to be used concurrently.  Multipath TCP is a proposal to achieve multipath transport in TCP.</t>
            <t indent="0">New congestion control algorithms are needed for multipath transport protocols such as Multipath TCP, as single path algorithms have a series of issues in the multipath context.  One of the prominent problems is that running existing algorithms such as standard TCP independently on each path would give the multipath flow more than its fair share at a bottleneck link traversed by more than one of its subflows.  Further, it is desirable that a source with multiple paths available will transfer more traffic using the least congested of the paths, achieving a property called "resource pooling" where a bundle of links effectively behaves like one shared link with bigger capacity.  This would increase the overall efficiency of the network and also its robustness to failure.</t>
            <t indent="0">This document presents a congestion control algorithm that couples the congestion control algorithms running on different subflows by linking their increase functions, and dynamically controls the overall aggressiveness of the multipath flow.  The result is a practical algorithm that is fair to TCP at bottlenecks while moving traffic away from congested links.  This document defines an Experimental  Protocol for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6356"/>
        <seriesInfo name="DOI" value="10.17487/RFC6356"/>
      </reference>
      <reference anchor="RFC6773" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Perkins" initials="C." surname="Perkins">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="November" year="2012"/>
          <abstract>
            <t indent="0">This document specifies an alternative encapsulation of the Datagram Congestion Control Protocol (DCCP), referred to as DCCP-UDP.  This encapsulation allows DCCP to be carried through the current generation of Network Address Translation (NAT) middleboxes without modification of those middleboxes.  This document also updates the Session Description Protocol (SDP) information for DCCP defined in RFC 5762.  [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6773"/>
        <seriesInfo name="DOI" value="10.17487/RFC6773"/>
      </reference>
      <reference anchor="RFC6824" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc6824" derivedAnchor="RFC6824">
        <front>
          <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
          <author fullname="A. Ford" initials="A." surname="Ford">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Raiciu" initials="C." surname="Raiciu">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="O. Bonaventure" initials="O." surname="Bonaventure">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="January" year="2013"/>
          <abstract>
            <t indent="0">TCP/IP communication is currently restricted to a single path per connection, yet multiple paths often exist between peers.  The simultaneous use of these multiple paths for a TCP/IP session would improve resource usage within the network and, thus, improve user experience through higher throughput and improved resilience to network failure.</t>
            <t indent="0">Multipath TCP provides the ability to simultaneously use multiple paths between peers.  This document presents a set of extensions to traditional TCP to support multipath operation.  The protocol offers the same type of service to applications as TCP (i.e., reliable bytestream), and it provides the components necessary to establish and use multiple TCP flows across potentially disjoint paths.  This  document defines an Experimental Protocol for the Internet community.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6824"/>
        <seriesInfo name="DOI" value="10.17487/RFC6824"/>
      </reference>
      <reference anchor="RFC6904" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="April" year="2013"/>
          <abstract>
            <t indent="0">The Secure Real-time Transport Protocol (SRTP) provides authentication, but not encryption, of the headers of Real-time Transport Protocol (RTP) packets.  However, RTP header extensions may carry sensitive information for which participants in multimedia sessions want confidentiality.  This document provides a mechanism, extending the mechanisms of SRTP, to selectively encrypt RTP header extensions in SRTP.</t>
            <t indent="0">This document updates RFC 3711, the Secure Real-time Transport Protocol specification, to require that all future SRTP encryption transforms specify how RTP header extensions are to be encrypted.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6904"/>
        <seriesInfo name="DOI" value="10.17487/RFC6904"/>
      </reference>
      <reference anchor="RFC6951" 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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="R. Stewart" initials="R." surname="Stewart">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2013"/>
          <abstract>
            <t indent="0">This document describes a simple method of encapsulating Stream Control Transmission Protocol (SCTP) packets into UDP packets and its limitations.  This allows the usage of SCTP in networks with legacy NATs that do not support SCTP.  It can also be used to implement SCTP on hosts without directly accessing the IP layer, for example, implementing it as part of the application without requiring special privileges.</t>
            <t indent="0">Please note that this document only describes the functionality required within an SCTP stack to add on UDP encapsulation, providing only those mechanisms for two end-hosts to communicate with each other over UDP ports.  In particular, it does not provide mechanisms to determine whether UDP encapsulation is being used by the peer, nor the mechanisms for determining which remote UDP port number can be used.  These functions are out of scope for this document.</t>
            <t indent="0">This document covers only end-hosts and not tunneling (egress or ingress) endpoints.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="6951"/>
        <seriesInfo name="DOI" value="10.17487/RFC6951"/>
      </reference>
      <reference anchor="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">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Paasch" initials="C." surname="Paasch">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="G. Detal" initials="G." surname="Detal">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="January" year="2017"/>
          <abstract>
            <t indent="0">This document discusses both use cases and operational experience with Multipath TCP (MPTCP) in real networks.  It lists several prominent use cases where Multipath TCP has been considered and is being used.  It also gives insight to some heuristics and decisions that have helped to realize these use cases and suggests possible improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8041"/>
        <seriesInfo name="DOI" value="10.17487/RFC8041"/>
      </reference>
      <reference anchor="RFC8126" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8126" derivedAnchor="RFC8126">
        <front>
          <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
          <author fullname="M. Cotton" initials="M." surname="Cotton">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="B. Leiba" initials="B." surname="Leiba">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="T. Narten" initials="T." surname="Narten">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="June" year="2017"/>
          <abstract>
            <t indent="0">Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
            <t indent="0">To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
            <t indent="0">This is the third edition of this document; it obsoletes RFC 5226.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="26"/>
        <seriesInfo name="RFC" value="8126"/>
        <seriesInfo name="DOI" value="10.17487/RFC8126"/>
      </reference>
      <reference anchor="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">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="May" year="2017"/>
          <abstract>
            <t indent="0">RFC 2119 specifies common key words that may be used in protocol  specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the  defined special meanings.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="8174"/>
        <seriesInfo name="DOI" value="10.17487/RFC8174"/>
      </reference>
      <reference anchor="RFC8684" quoteTitle="true" target="https://www.rfc-editor.org/rfc/rfc8684" derivedAnchor="RFC8684">
        <front>
          <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
          <author fullname="A. Ford" initials="A." surname="Ford">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Raiciu" initials="C." surname="Raiciu">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="M. Handley" initials="M." surname="Handley">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="O. Bonaventure" initials="O." surname="Bonaventure">
            <organization showOnFrontPage="true"/>
          </author>
          <author fullname="C. Paasch" initials="C." surname="Paasch">
            <organization showOnFrontPage="true"/>
          </author>
          <date month="March" year="2020"/>
          <abstract>
            <t indent="0">TCP/IP communication is currently restricted to a single path per connection, yet multiple paths often exist between peers. The simultaneous use of these multiple paths for a TCP/IP session would improve resource usage within the network and thus improve user experience through higher throughput and improved resilience to network failure.</t>
            <t indent="0">Multipath TCP provides the ability to simultaneously use multiple paths between peers. This document presents a set of extensions to traditional TCP to support multipath operation. The protocol offers the same type of service to applications as TCP (i.e., a reliable bytestream), and it provides the components necessary to establish and use multiple TCP flows across potentially disjoint paths.</t>
            <t indent="0">This document specifies v1 of Multipath TCP, obsoleting v0 as specified in RFC 6824, through clarifications and modifications primarily driven by deployment experience.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8684"/>
        <seriesInfo name="DOI" value="10.17487/RFC8684"/>
      </reference>
      <reference anchor="slide" target="https://datatracker.ietf.org/meeting/105/materials/slides-105-tsvwg-sessa-62-dccp-extensions-for-multipath-operation-00" quoteTitle="true" derivedAnchor="slide">
        <front>
          <title>MP-DCCP for enabling transfer of UDP/IP traffic over multiple data paths in multi-connectivity networks</title>
          <author initials="M." surname="Amend" fullname="Markus Amend">
            <organization showOnFrontPage="true"/>
          </author>
          <date>n.d.</date>
        </front>
        <seriesInfo name="IETF105" value=""/>
      </reference>
      <reference anchor="TS23.501" target="https://www.3gpp.org/ftp//Specs/archive/23_series/23.501/23501-g70.zip" quoteTitle="true" derivedAnchor="TS23.501">
        <front>
          <title>System architecture for the 5G System; Stage 2; Release 16</title>
          <author>
            <organization showOnFrontPage="true">3GPP</organization>
          </author>
          <date year="2020" month="December"/>
        </front>
      </reference>
      <reference anchor="website" target="https://multipath-dccp.org/" quoteTitle="true" derivedAnchor="website">
        <front>
          <title>Multipath extension for DCCP</title>
          <author>
            <organization showOnFrontPage="true"/>
          </author>
          <date>n.d.</date>
        </front>
      </reference>
    </references>
    <section anchor="diff_mptcp" numbered="true" 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">Multipath DCCP is similar to Multipath TCP <xref target="RFC8684" format="default" sectionFormat="of" derivedContent="RFC8684"/>, in that it
extends the related basic DCCP transport protocol <xref target="RFC4340" format="default" sectionFormat="of" derivedContent="RFC4340"/> with
multipath capabilities in the same way as Multipath TCP extends TCP
<xref target="RFC0793" format="default" sectionFormat="of" derivedContent="RFC0793"/>.
However, because of the differences between the underlying TCP and DCCP
protocols, the transport characteristics of MPTCP and MP-DCCP are
different.</t>
      <t indent="0" pn="section-appendix.a-2"><xref target="table_tcp_dccp_comp" format="default" sectionFormat="of" derivedContent="Table 10"/> compares the protocol characteristics of TCP
and DCCP, which are by nature inherited by their respective multipath
extensions.  A major difference lies in the delivery of payload, which
is for TCP an exact copy of the generated byte-stream. DCCP behaves
in a different way and does not guarantee to deliver any payload nor the
order of delivery.
Since this is mainly affecting the receiving endpoint of a TCP or
DCCP communication, many similarities on the sender side can be identified.
Both transport protocols share the 3-way initiation of a
communication and both employ congestion control to adapt the sending
rate to the path characteristics.</t>
      <table anchor="table_tcp_dccp_comp" align="center" pn="table-10">
        <name slugifiedName="name-tcp-and-dccp-protocol-compa">TCP and DCCP protocol comparison</name>
        <thead>
          <tr>
            <th align="center" colspan="1" rowspan="1">Feature</th>
            <th align="center" colspan="1" rowspan="1">TCP</th>
            <th align="center" colspan="1" rowspan="1">DCCP</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="center" colspan="1" rowspan="1">Full-Duplex</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Connection-Oriented</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Header option space</td>
            <td align="center" colspan="1" rowspan="1">40 bytes</td>
            <td align="center" colspan="1" rowspan="1">&lt; 1008 bytes or PMTU</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Data transfer</td>
            <td align="center" colspan="1" rowspan="1">reliable</td>
            <td align="center" colspan="1" rowspan="1">unreliable</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Packet-loss handling</td>
            <td align="center" colspan="1" rowspan="1">re-transmission</td>
            <td align="center" colspan="1" rowspan="1">report only</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Ordered data delivery</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Sequence numbers</td>
            <td align="center" colspan="1" rowspan="1">one per byte</td>
            <td align="center" colspan="1" rowspan="1">one per PDU</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Flow control</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Congestion control</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">ECN support</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Selective ACK</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">depends on congestion control</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Fix message boundaries</td>
            <td align="center" colspan="1" rowspan="1">no</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Path MTU discovery</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Fragmentation</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">SYN flood protection</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
          <tr>
            <td align="center" colspan="1" rowspan="1">Half-open connections</td>
            <td align="center" colspan="1" rowspan="1">yes</td>
            <td align="center" colspan="1" rowspan="1">no</td>
          </tr>
        </tbody>
      </table>
      <t indent="0" pn="section-appendix.a-4">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-6">Therefore, the sender logic is not much different between MP-DCCP and
MPTCP.</t>
      <t indent="0" pn="section-appendix.a-7">The receiver side for MP-DCCP has to deal with the unreliable transport 
character of DCCP. The multipath sequence numbers included in MP-DCCP (see <xref target="MP_SEQ" format="default" sectionFormat="of" derivedContent="Section 3.2.5"/>) facilitates
adding optional mechanisms for data stream packet reordering 
at the receiver.  Information from the MP_RTT multipath option (<xref target="MP_RTT" format="default" sectionFormat="of" derivedContent="Section 3.2.7"/>), 
DCCP path sequencing and the DCCP Timestamp Option provide further means 
for advanced reordering approaches, e.g., as described in <xref target="I-D.amend-iccrg-multipath-reordering" format="default" sectionFormat="of" derivedContent="I-D.amend-iccrg-multipath-reordering"/>.
Such mechanisms do, however, not affect interoperability
and are not part of the MP-DCCP protocol.  Many 
applications that use unreliable transport protocols can also inherently deal 
with out-of-sequence data (e.g., through adaptive audio and video buffers), 
and so additional reordering support may not be necessary. The addition of optional 
reordering mechanisms are most likely to be needed when the 
different DCCP subflows are routed across paths with different latencies. 
In theory, applications using DCCP are aware that packet reordering might 
happen, since DCCP has no mechanisms to prevent it.</t>
      <t indent="0" pn="section-appendix.a-8">The receiving process for MPTCP is on the other hand a rigid
"just wait" approach, since TCP guarantees reliable delivery.</t>
    </section>
    <section anchor="authors-addresses" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.b">
      <name slugifiedName="name-authors-addresses">Authors' Addresses</name>
      <author initials="M." surname="Amend" fullname="Markus Amend" role="editor">
        <organization abbrev="DT" showOnFrontPage="true">Deutsche Telekom</organization>
        <address>
          <postal>
            <street>Deutsche-Telekom-Allee 9</street>
            <city>Darmstadt</city>
            <code>64295</code>
            <country>Germany</country>
          </postal>
          <email>Markus.Amend@telekom.de</email>
        </address>
      </author>
      <author initials="A." surname="Brunstrom" fullname="Anna Brunstrom">
        <organization showOnFrontPage="true">Karlstad University</organization>
        <address>
          <postal>
            <street>Universitetsgatan 2</street>
            <city>Karlstad</city>
            <code>651 88</code>
            <country>Sweden</country>
          </postal>
          <email>anna.brunstrom@kau.se</email>
        </address>
      </author>
      <author initials="A." surname="Kassler" fullname="Andreas Kassler">
        <organization showOnFrontPage="true">Karlstad University</organization>
        <address>
          <postal>
            <street>Universitetsgatan 2</street>
            <city>Karlstad</city>
            <code>651 88</code>
            <country>Sweden</country>
          </postal>
          <email>andreas.kassler@kau.se</email>
        </address>
      </author>
      <author initials="V." surname="Rakocevic" fullname="Veselin Rakocevic">
        <organization showOnFrontPage="true">City University of London</organization>
        <address>
          <postal>
            <street>Northampton Square</street>
            <city>London</city>
            <country>United Kingdom</country>
          </postal>
          <email>veselin.rakocevic.1@city.ac.uk</email>
        </address>
      </author>
      <author initials="S." surname="Johnson" fullname="Stephen Johnson">
        <organization showOnFrontPage="true">BT</organization>
        <address>
          <postal>
            <street>Adastral Park</street>
            <city>Martlesham Heath</city>
            <code>IP5 3RE</code>
            <country>United Kingdom</country>
          </postal>
          <email>stephen.h.johnson@bt.com</email>
        </address>
      </author>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA+296Xbb2JUo/P88BZbrR0kpkhYleUwqt2nJlVLiQddSJTcr
neUFkZCEmAQYAJSsWP5Wv0a/Xj/Jt8dz9gFADS5Xd7pXq+9N0SRwhn322fMw
HA5dkzfz7Hmyv7d3mLz82GRFnZdFnZyWVfJ6NW/yZdqcJ2+XWZU28ENymcM/
+Yd5lkxmsyqr66x26clJlV08N+/giG5WTot0AePPqvS0GeZZczps6ovLs+FC
HxzOptPlcOuJm6UNPLi9tb0z3Noejh+5ado8T7KPS+fyZfU8aapV3WxvbT3b
2nYurbIUv0qLellWjbs8e54c67+SCfya/KmsPuTFWfK7qlwt3Yfs6rKsZs+T
g6LJqiJrhvu4JFevThZ5jZturpYw/8HL4x+cm5YzePV5sqqHaT3Nc1c3aTF7
n87LIqOVZM4t8+fJX5pyOkhqmLPKTmv4dLXAD3+FBa6a87J67pKhS5K8qAE0
o2SyyIoZ/Jth8jqtPqxq/2VZwYT72aqpp+dZcpzNsw/lAr5X0O4fwz9qmChr
wnNDeW44mc+zLHkGj0zz5goeSKsFLHrW4DflDKZ7vLv97BH9a1U0FTzyu6xa
pMUVfJUt0nyuCxrRgv6l4YFHswweqEpEkmyWN2VltjQZJS+qVQGLopXytiZF
kUZf08b+kFZzXE/yU5FfZFUNizTb8V9mTX2WAqyTbb8TfTNs5NE4efrU7uTo
MptlRdhICksYnegS/uVDuhrVWbzuP6R1Pc8qs2pA5bQ23/9XLJvWMPrAa+iu
+4+j5F36oZxmF/nUr/yPWZ3N8yL6hda+B+sw607K0+RVWczKwuzgDaDuebpY
NnC3j/6+gmvlN+Cf9euFsZpslvwBrsaMTlbWfcErGFW6gtH4X3CMUTodrT6Y
9R+Nkt+X50VNw/Lqj5pseZ4V5nta+wuL7JNZCh/TeXIICOrXB9gKpKuG1Sc/
ZkBIPKAPDh8lO+9e3mXlNc8+Oh/9jef/l5NmNKUnXF4AEVwA2bvI4BonB8P9
UYo3o0PATiv4HojLh+FiicRMn56fX378x/D86qTKZ8N0OgVKOQTCQ0+m1fQc
ljRtVpUfHUbMrvwTJ2mdzYYncAiw6HiUvuUQFV3NlsPzLJ1l1XBaFnTuZRE/
nU+nlV18lQFVzCqkdvDcux/2tp4825GP2+OtXf9x/Ew+7oy39dudJ+OxfNzd
2t3xH58+1o87u1vy8dGjZ4/Cx8fh4xP9+HhHx328HT7uPNJnHz95olM8furX
8PjZVvj4SJfzdGvXfxxvP/Yfn+izTx8/pY/HR9s7o0db9HCSCDc8ugLEWCT2
kIgjNkCYH/1Ofv414G56liXbv07eAa2E40rGj2kUT/vpj/B553eHh/Rv5nLf
ApvbGo6BzT35lidOqzNE9fOmWdbPHz68vLwc7ZwtlyN4++Fps3z48GiZTeuH
tKSL7OH2zvsaTi2rH/Ly4T/wv8OzJ1ujf+RLGPIyO0G69Dyx+wrcOVNWT/si
Xt23jJhL02LguWUK8kAEsEnyg16CIDowsiZHqyUxZfz+p6ICSpGegOygfBjZ
9ulpPgVei9y6JUB0wTmU/yZdtip/vdy179WXwL7Ks6w4zead119OP6TVrPN7
z+x7F3/Lmg8lE954CfkcWELn9/YYLaoeDdFH3Nes4xCw4UPaA4YpgCH6sf1y
xA6jt7tccc37lt+3RmhJA+YKjJ8Nx3ALdvkKMD4j1dWj3n978DwZb43G461n
D1/tvdnd3R7vjvC90dNnz7ae7OJ1q+f5LIuQ8fXhkMRZRLisAGRDvCJR8TSr
kAv+tH/48OAQvyLEK4FQJguVaWF1aYIIWMPm+GskpgWQgfwC2agQ6Ppr4qbZ
O0mg461HvfcRFwfLnn7IqhEK03QjF8AkYYsP4aWHwK9gqHRePyS41ADgR8Ih
QEyv0+HjbWYVngDUQ4CTYQilyvrDrS0Hi3j76mASgffB68NjgG5eJ0XZAKSq
rCnhrSZfpMBR4W1im8U0g0fqVVajWOMApCVI2Xjx63K+wvEfGGR4AIe6/aAD
igeHFWB9hhywxoND+vsUSENOtINWCVIBnA4cbIYzggDxcpFVZ3jick74EZQI
GBWg3dBqEqDp50U5L89gpkEy2Xv9oHOYepR0ju/ggpyn83yed397M0p+B+JJ
9we8kuXS3/vot59GyU/LdHZ+lV51f/z9aPjnUfIqA+KzmmX8thsOh6AJoBg0
bZxzhOAgqCxWRT4lQMDO6mSWneYFCDqAuZ8+Cf/9/BkYWZaAotZU+RTFoKZM
0gSpLZwGkVqAjlMcL4tBcgVk2V8IvgvlKeALADKvm+QEIJvBv5YZSBgj4KHn
matzfCEtshIQewW8EI4rvQAhi4h9azC8mSnrnIiVyIZAVAMimy+WFVxHXGy5
quBAVzWyWNQ6YUt4/HKqeIwD+GIF56cvwayV46MmZGjOQfM7O0/O87PzrNJ/
LlcN4YC8NcO54GD5jdLp+KewdGD79cj9BJuZAnfXZcccKtkQcrNJUF6UJzkS
ESTV8MZGNjobDZJzmLAGHWEAovJ5PgWpdZPWgFODBgCscp6cl4ssASUiu0yv
6sSCc36VyOHw2c3gDPJi2nhKBCc/SHgmuGjTbD5fzdOKZgA1OAeWi3z4VTmF
aUg13vjTq8mbzUDJaF+t907zjzCd8HB9ErhducArTwshbMD75alHAjAFlbic
oy68mp4jThK5GHiqjFBHypTUINDkSH9rIyAUQHeQutBZKoEWKALZBmEqWc5T
wIWDw03AvNdlhcBu4LAARQEjy0bAufKnhscik8rFENno8+cB/IPoJH7EbX/6
RLLN588jBwo1IlydmaFgmNMcFgqcDB5HswhoTYyor/Ji9REOVCkRoNc8Q4rD
dhO/gFUB0rZdw8i543MgprNyusLnFS64crgdDV6kQKwRRQmMAH6FW4C+p914
K1t46uHu8BqlgKbIzHCYGNVwt3pdHV/XnvvuDxqWB1uuadAamFuCZhRcMxwg
3gEiNsvl3FIpWg/dwSYsCwYAGrRYlgWRaUB35FcVLRFIF7Lx+pzesivksU7n
5SWMPK2Ax7hZfkqH0AixifcH4EZSushnM9if+wbl0KqcrYjyJZ++yfGfn4HA
Aqc9A5kWEL44g/nxV/gIP4Iaqnvf4ItvSS2cZOq8XSqACbRss9mTfAbXcioM
jGg40NVAgpHeIkWWmVEAwZnnhEBehJ7JGuFMevlBh+oDbC3dHyVuLTHL16Ef
P4gfHAlX0RHAtydZOC4iIHgobQbgWocCSsL03M6Daz/JCmBnU7zNbSQiaHqR
LnFzlJOSdIH6PkkKCJpBMlsR/iFusvjhkT49O6sypLZws5fpVMwj+KCLlzoC
BEnS2SxnzohPLLpaVJ0ILHC2ChRwuBUgLy1Qdkf6ycQej41WAHT6EvjAOUIZ
CAUgSlow/QMoDuewrGJ61bPjWUkyV5X9fQXok7izVQowaEBCAiI4R0PPld47
Q4Anq1lePvwjIF5JJpV0ASgA90Ap8nmKVxzu92leARbWqzNEuwy4MbNcRD7Y
qQIIVdmEeCRcCdCGWUQWRqHCXe0+fbq7xQRFFIAQAoANHcJ3nOdwPNpdLSqf
P/Pzd7aoIBlWcEyBsgMSE/SzmZxKCi+moM1N4VWALMCQeKpKL8jgUY1gLnIC
/3OZz5pzp2hGLGBVARKiUEBcQngong+DTvXgIzjPiqY5ArkHNoUfcdgjWFBD
/HZjcnx0dLSpB0QnAhIxnCsKtVcALTVrfP682WEwSyAKRGMbS8ensAc4d0Uu
XtxsFrDdKb8RGvBrz8HT+fwKrwbsjsBV52dA1nChuGwgIrTo1bJ1tZKNdPRh
BNf0Qb06IfrxYHOQgOqQkvzOzFd/GiTBUoXEkS84C/O4cYYx8R06EhDciFEO
EMJAj5quVDwrM9FhmCwnnrDisDQZXAK9WCj6FDUAB0CH2/V7MdfUrxZ2cYVI
pA+hKEVqZuqE/grBVoLPjpWihDWeC/MyihTIGekcSJQjCbRvvj7ykBdD2UQS
NiFumdbOT1b5vBnmRSSL8YHeuE8A8gHj4Clwp/KScBX/iYeiT7FUFHhHWDQS
8AXgNID5Ik+TNufe2B02K5waj5XFLDyZGTJFOfCUPVAPyQm0TIGAAQrhzpgT
LUiIXS0ZvLiwB61tDBnxErwZ8BVhiTuSQxk/GW3j5AZrQDDsgz/yK14+4idR
zKIZXuZ15k6u1i2eJYQsPlKU5cly8TFFEXIgnGWG4xyJTLVXohCRi+TCd5VA
qxiOxlaVafkY+07PCanrYmnSj6Wj5AexgtbpBzoW+K0GJQD5lbuEWUDjRxkQ
sbEsQJr0I9n585q4FMx2cqV6YJjE4QWgW3teXha8JcCg4ZQ0j7wGcag8HZJD
Lq1mbM2Az8BK+LNSNHxk+gFIO/LaeaZKKa3tNEvJqAtTgNpJCAN8GFRrXoyX
o5HFZSmwUSM1uZTuDtOTDUWV7dGuxxSG/uYaVEGgT8shq9LsTxXOE6aNVfnG
km+4chPQREq0gcBxgTZLELoXsxXCj+xoBvgFIlANmh+fTUF3l4QoNwfNGUR/
/N8g5SXsYajxGBeof8HRwlhVjtIUYq6RUJ0xs9mRUZUjItugZq5K3xINWw3Z
3cJhI26TCjlyJCQSxs1Uz6GLh8fHSqDCK1MmF3gU4y9I/N+0NSN5402wFx0h
5oAywAB7LwLEe0Koz0Fw4vNCRa1houfF/nl6lYkinS9ULOafUyJwoMadwObV
NoFPAmjhE72JStZBE8ngKoKCMCzIiwqva8ol/sr8+GfekySfz1doYWpIHYPZ
aTEoLCYeR3NQsDJk8Ex1Tuhe8UW24qrAlDTCS+CFqvUJm3MqbYh0HlGHps7m
p4Dm7v+Dv2A67fv7bnjz33c3v35tPtu76n937Qm+u9/s161x7YTxPxS+9vdb
Zk+G0f91/u1kAj9uPPuRcGdRYjv//gp7x78D3VPv3vXXzsM/d3bCnU/Pk29+
xpVgi/f33+4FYgR37UheD2YMPTtvFyD6UX8LpALJzbGVzL8xcvpnlMzJKIlk
PKLyCTDTBfJY5VpEOYl3IcXLciKcStxILgxqaaBDKC6Shczwkkihk6UPUCHP
0fgHF5J4GPpHSYKoRbRDr7M7hOHR28dy8JSWBoL+h2AjQoJFJi62IlbZNMtJ
MQprcLRTXQSJAHcX9ERoQkkPSITgLC6JcFdIIazhjK39wlJRZyDBBhncLAeZ
dwWEFIE1EE0cZe0avRlMbROyKFT+aK0MNPGCbU6qRYXyq9VEYJcGnAiEMzKs
brAUMcR5N7uy1XFLbibxLJ3XgcrCaCRL07BFz+KYvkbGfYBSsOrs+Sf5FGmz
aBVC/EFeHtQtghfDJi2cJdAswKipKfNHD0wyAVmzqXkrPasD5pF9ZKkD5Tsj
Y9Ylsv4edoDaa/kho/XOS1I10V4G6Jew6fw0h3WeAY4VDOxwDczEiGQO1zZK
XiM3EqC2FPE0eRAAlBzsP4DJf4SX0IsJYtKMdmdQyhxBbO5lwZsvKSjpwLgF
BysybCzbb1ssII1Kub0ABLQIIgAD9YR4mc7cYYIcecZA9mlUH5algGYyRZF8
4BQZDS7qnQFls8mnJNjN8nq6qmtVmpUwkrmaRCiZE+CF+wG6NuVPQNNYDBH9
xdNW8uQM6ymoM1VegrThjaFpcpYVGcb3IM5d5Nmlmpp0FpXLFqD3AAxYL0Uv
AMoR6BEDKaWmpaeEw4sFzPEPIzzXAt0eoQIPGHDr5j966IVbx26iZ9c95CRa
MpmM8TH/r+3obf36RfTQi20Xz3br3PG/XIv9tv615uvr6LUNq7wj7VgtN9e/
dguDxr/f9rz2mzu8d9Miv3Bv8nvfFm997c57i7/p32nfa+jQzizfallR2K7f
pSVfCphIdLr5GquE9JKf8ov4idy2R/IUCEIJhhIkv0qQkvYwhpPsLAetQbjX
7hBVBnKanqd08ZcYBzADpWfguY3cYc90WGeup1V+olTLjACECw35dyNNAxm7
n8UCObEODi/4aCw03m+kuXCD4WmkHLWMN+Hv0ZSJkhtGFqLvAzQ9sUOcZGJZ
IEFP5/bWOjXsBf2WJTAZnhg4vFkQPsh6EBKkabLzTo/hoCCXJnowKg13wcVN
ywoXxzbysCeyrzF19U79gdVJY5TE56ZVRpJQGY6KDLphLhqtAVH5nDkwbsu7
lHXzYs4dsCgiI6HsmBcr1h9BWMjQa10HucecVleiIHUdQSKDAWMXiYWWLGbk
tFi3PXLaeE05IEAg6Br4Vyhzwd0awq4/vPDH4cUIFWk6HjOQYNrH7r20gq3t
w2pUGkOn/YkI0hpHE1l24zcVLn9foXSnAAzAEL9YIpZfb6hkY453wcswvHxC
6KkiOQqeqyUhwGT8m+FvX2wziLbpMww9mTfnFLuB3DvsT1dg5W8yEpIHC9FG
hC3026CTfrI9QCczB5eEbaEQeZ5eZOz2ar2DB1QBx/WHg6iB8lBJ/jVxaayW
LauMR/5LQA5yIE3P8+wim3ns52gUvm3s5iCJEeg7bBZJ1nS+monnI8HgpKlo
QRLecKp2OyaFEo8yw1ceVtkCpCl4V5fxaz+t1SqVQNZq6AcSBPOnNY0HOCYC
P0u60zQAJylALAsXHIFAXh4T5BMooMzdihsgOKIWmPtLthYWIOrCwWakOaJy
jIrhtFyKBdduiZayOvkbyrekAHgaYSnZsoTrfyX28Mwrzh6qsfw+Utwm+5Vo
qoBJSBau2sIp7k5Y0DkRoTnofihrs7M4/ZgvVoukWC1OOPrQXgixv4MoC2eM
2rGEuhj18RIfbEvkanXeMVZnDHlGjb1pUbLo4AjDORZBl22YT3pRUpAKxWYU
oOMZjCLuk+Euw/NB4e1QMkCG2tDh4RzOch7sBgwORqTsI1sD0a3HZ/euXBWz
4XGVL5PjHE5g493x8WbiA/KZrIvHHSMP6QIa/6BaSP2qjixnMmp6WnvlvMXm
60EkUPj4vGTDOIMG/iCejnY2b1B77Zyki3o+FsMH3xzuzUG/eZf9PZHIbP4C
rkaNcoooYO9YFmArxysA3wp+o+3iIj5kV6g0wRE8eP3T0fGDAf83efOWPr97
+X9/Onj3ch8/H/04efXKf+AncBj499ufXskj+Cm8vPf29euXb/b5ffg2aX31
evLnB6R30jhvD48P3r6ZvHrQcWXwaZAm7vVWPhQryOEgLwCg413Gc0xFAPWR
cX78ZBc+X55nonOT04n/CffgSoWDHA0pxJGm6TJv0jkfLzMP9DchVN03JtHt
raqin74pl+9VMf0skZcbN3gIN3Eq8gH3eU6dldvv43tj4dh59gr7JOpk/MQj
ECuEZsaCY8fN66yf168zIu9IRkzs02ui0VWysfd6M3G0XUwEEROhqPDAsfx+
6B6mU4l3QUqHKzld0cJl9hAQEGKdEol1AnxHspDXizpepQk38roAQeJmyyFQ
g+SPKN+v6ltmc0E00Fg8jp7CGOf8H7IC65+noAcNZ1R/FwbC1Ymzbi+KH5xn
iN8s55PxsyfC7GDfm7Y29vYO9jmIIzNpG2rpbMrLFO+592kNu4FcLtKLWJ7o
setM8BzRIZUwMVpnjfFuSuY1FDDvOLBIQiPFNN5y+WL4SoJu7K6/E65/2WuH
FIFEGKUzEQNJHDFAJr3l+VXN4SgwYTkncsvSKkEvFgn05C1bkZuL21LLtZ48
8hgY11XZMAVsWmiciIRW2HdmDBOxtlfkPiXepMI0DDLNlzmt25g6RUKKxD3Z
MYcZYcbnbEWRNR5faRGujwuaRwCiILDK7MZAH8zzViUdOFXPQPRCZyu/1it/
CWL68A81takD2x/2SQbXKi+rgIKIcm1frKF3xj4Yh0uaZyTSj4IgAbXahmgV
LXBddCQp6cMcF8TB40GvxoccyncijfRojobAttbNwghjjuO54X103rSDWoiM
hy8PDo3czNGD4ruhkFp1ibNG2mcv1u9YiFbcJVFtANcya4ar5YBSG5CkTOXi
LoEQViCH/0P+vShn3ks+ENQAjQJtsqe0kFjBB9C39wWgvcxA80lr0Qq9UBeR
SrdM0XbdkEbAuBNAuZcuNTCZssjiiLwiOytFURNDEYq29IQTiY+5uifaROMW
y/cY4wnHg0agt7SIMNQA7zxuTEK7usSplmCo1AbosqGZNKB5WI+7AAZDUuk8
K85QszF5lkyO+KIOeqxVlhZj8HnPQsKkOqc3k6xOeOT2sN+8PnwPEthnuadB
DUF7/aqiA4zPFqF9gYHXoGSqNurm+WmG8aysta29tL0krK3jzeB4fJUBh8Ka
xhoCnAntstiUdCcq5L7p+mE/feOBytvXSHj+WaOA5hiJ0y/XPx7tUmKHywqQ
bs5j1Atg0NPVEemhH+QfAvPxFp66a0U1yRtDXANx4es3/Ph18joD6g0HsMZo
+24FeAb/yabfFiDZzFf4rwNS1+eoHnw7S67d9XMyKz+X/641qT/vPtV+5/k1
ufTHWzh5687CSqK1JUeH3q685b+kvzf6kDcxWxCoQTmML1BEZzpvFff93D0n
TAOmAGgMFIPZd7Wai6dUs3Vl7BEuaAHwlMizaigE8Ap1nTdv5DcMRBLSAFui
4EYGJ4FXJ83lywuCeWeml2QmUkxgk8CHgg/dvDjC/cAh8ajkEJ+vFiQpPfjz
A7Y1iD4DnzMatMfVmKBe5yirhOIa4rUcnKL5C4d884CktcL+zjwZeMY8/4DC
TBAvB5qegXJbepqx55lEJ/y4J6R9aemjH9YR9meLJZBxEGhP82qhj476rqEO
Ewe99d/HR6OnnDrFP2POuP15e7Q9GnMmVnxh3bobqxR7KBSbF8MvyWfKaNl9
3Hd7+QlzeZNjfBiQ/S2/+4pHXXeZr1nBx2ST/7P+tq67vdH3fD13H+tV86wo
vq6tewp/f27fR7Op7nWUfR1ljYa3dEmBEj4MoPO8VzRnkD0pdpGSBFlUWD8A
JrsBswDSD1yCrMu9uRciH0igrM0uNJzJue489pKetqk1oRn+ophBkRLDk6sm
Y3Vinp02CzSgnYLiCTKqOEg0UoPFEFTwKPyooeRXqckgrNH1hw8kG1vwJ9cq
r+MYRjEzBYG7NXsB2gmH5wGW6nRb/JL5kV4gm5DY42HF/8iqUh0NRknQp+DF
smKl1SpII+NTB1o/TpLtJNmBf+wmyaMkAYR8gr/ZkK0ofIti9AAV/yhrhc8/
hXVe3/IuTU3HoXkGGBHROWnaA8NMthdxgV5GEox/a8nR49EO0JuBms1bdh+B
vph6XCSXsj5INgFeggpoIpkqaUfAz8ifF6KTGsOE1MdpHAPuFk8oE/eitFIv
sF87swj9628MhqbibtnB503lPQqKc3uYXavYxl6ODM0ezETeKZk14mZ3c6LR
YNwsGo8ospwIFDoG2JqUhUA8z1r0BAaazoHIu/RZmhhBRojQXZzwrVe6Og1o
tSBDflhzhuNZlVH2uVHS9O6ZKFmxvmcJg4R2MBC05LXhrQQO48KeZJiNenPN
HpJJceWN9DZwKC267lSjwdCOUUPV03O6YqNoedYuqWE0CwpGp4hAtG2S6XOU
Alack50lDFSeocrwtFhqLlpSgUKXJYZ+CgzTkLyEsoPDOCwJNaCDp8yp05U/
6Oj65NbAm56Cyvk8ieJ/5BTu88c703IP9Hev9/kVrW+BvB8N/d/5y7CxNzmc
vHj1cgB0dGuzP3q5VxaI/37r1gQ+y5T1EufUUzCTDoB4d2a+S1BOz4S/MvhR
Bl70PUzwK6HbY+ZLchAY4jKl6HNrnqbohdalqhOOsdgaqD4WLgQFw+pkY8Ca
7ZEiJK2HrBdSbKZ1VccDcSdS7l+tt9EMTlcWxtwJhpe8ZsFaxQ9vhQobo+w9
XgIt167ugOl5HwKfshZdifX1vRyTJcJs3edUByFRilVEL9WF9E6JlTEo3cJG
BpHR1xAOcQedouHkBBMlSDkwXrSy8qxriq6r2Sj5YVWR/KamAbJkxHYaHA+H
+9yRK0Xm9LaMkIFBMqTJalaJvVTv9IVY/PsMMSFXngUqNAJ7y4KS/U4a0mKp
AjK/gUalpCdXYRw+mgi/Hf/JJVvj7Z3dR4+fJE+f8cfk8RP+mODX+DHhJ54+
C+Hwd/rgrre2xlvj8Xjr2qggBD34QNosMpTRaHTfgUnB+X73cRwl1gbKWr3h
B/r5WzHHsJSyVFMuM5psPvPoaUsb3HoeooXpPkPWoWHK3k6Gyhrpaj2qGr8f
/m4xxaz7U32urb31aHO3mGfW/aHKhxqf2lYA22XBIIl/jxTj7ZsfDt69pq+U
3KPczjtGskTXva5FcCZI0e4F3u0ZxtsKEkBwnOH3bw/e6Fe/B8WOrX23Sx8W
Suv2sE0z/DA5On6/9+rt0UvYA3nC++PyVsUUPTveU3OXGXZohj+8/LM/6Zdq
t0YXulZTEmv0+x9fT/bWnHQ0wzM/HChBOMPRy//rvwp34kijIcTkdzMuRTNs
7/gZHtEMYWnXCXymFFHWhCPL/91nMCf9mGZ4d6x34ppLrWKUC37J4tlNq++f
wZzDE5phsr8P/+8dfTWZAUds8jqKPNMYurvOsOsXnDzlPbx8/faPL3ESNJyS
pfm2Me88wzOa4fDdwVv9SoQ6Taw6VGXzC6E0ljuNV0FnaN8H1QPuM8Pxi30Z
7rfjrdajACVJ1UVcOl2R3PG65W/wNjtV4X8L5IdSmMVEc93DKCLzEtMcIcRI
lmthEZj9FPs/KDEHjaJFvcyNOYIZfrcEFicyoa8JhIpvEkMUSZ6Qf3zuTze8
jYkHBIA/Ktl2H6befdgZW8cXfsCo78D8BX2ut+QPxAHRmqfMDgSyKAl8lblV
PoBPwlCFo3y/JTL/ERa6ajN2X3ciWldQmNEt1GQctLZRg67dZv7yGqZdczEZ
HVfDMavMBg/EVi63AgI5R8dWwI68Du58wOVoWWgKlOExGFiDdikde0bhcCxS
itAb89g+uUYTZh1PiU9SaJ5I+GJ5oBhHSvjRVXLURidOwAcH4wzmqqL0FEIl
YbGYDsmWqLSqciDkgzU3ey24HYeNkRGRdRAxvapfXv2UxAM/feIPeCHJ6aEB
F6VC8crD0K6E7Wur5Uxyk8VggXPUWTPy4ewMHOEjWHPMUPxgpZLXWmdH5WFQ
NxSOcLCPdr2M6l92XhWBgKh9a5grPS4OUUZdk4w0fmPOb4ziOrOGK7tJErmP
O8lPWa29IAUmvMNJa2QqK7sLw6gWDiVNNbm8FXTppnjWvFI+jVHyO0rA4rQ0
ewkosMngTxfTE68rpRjQccSBq/Or1lW6Be0AGzCgs15VUjyCLgneAARH0SQR
yAT5MnZ2pXVdTsla5QTL/L1VLTSbnpd4Kd/idcSiHBTd6itXgPa7XGa4v1Ov
vSuukb9bgeuriBDISe5BiwEHvtM/HSWbFQ253lRtFzDI3a/R1DyTCXyoHSid
lf+SU+CTM1TUgcM3rIqzv7F3FLxJUq+oLJxHIfKa46IxhJoD5D26RRRQjM/i
6eAQdwmcTtn10doLZxUv8eXCxzqHczE4oxsMh0KHpDZzJc9k5ZmWy5xNnieA
jAuuHLqkWSgsdN7Hu5jW0k91U62mjcays81yLjpIzxoiy+uaDSTRDeC5iPag
i4ChzgGnEbmKY3x4NkmL8VNQiRS03xIhXFCUGCMiX/0OASVio8UZcWs87ns2
hSkadl5TqZrfFLyRV7elSJyABQsAnaPdTSyruQ+Fx1sHV4AR0YPZuBnSExSm
+XKiDY9jneEkkA9RYkYS1vud3853YSXfmcWirfc+6nlAzCOLt3f7++X19PD+
WuG+rQGhClRcmeyK+/6t11TaqtAvOFVbJ/oKU3U1CblSXZtTLFpKzKcnHOS/
th4FFEJ8Xlfb+EkzeNuo94vo7m4yT1GOoQwxPCvLGUs/GYt4EyK1GCTiYsut
mFIm28MX295/0pqPrcnEF4QKeGbYZvtIN8cjSTwjr0zOpnDPz2g6DA6n6w76
VUMRexsnK5O6hQGSXL9ADO+xeVnEDyW4lvsFm5O47lrPgm58llMmVWvhG+NN
15RnHADgWbDZqQy9IcDZ7Khyd8rxNo++SO6W6q1/6x6+W8q3/v281O/uWuJ/
MTjulBDc+8x1/wAWZ0Ex+3tRJuPNQODh7G4e4O6087drVvC1tiAY/F3S/bt5
AHKPGVRXMAwUCJv+GL7CFtp29w51WZeTrRfREzFMy4Y/N1GhYD0hbDv3W9QQ
KcQll20rNF2P5NJAFik+X2LlWWvwhHKjn1KqhoGBVT9mFNsrco+PmUpE2mY7
gdxyWL1cYhvEpYRTQl12R/p48OhT1gBXrFeIhJl6xnIy1lijXqUCq/dkiIym
SiI8kF6FKjxaaVw1DpMrLOvnKHxQkHBJ6L+2kr8MrBTdcXRO7etdmGc0JvsG
5oBJ7aC25TRHWoQNeI6hXIpAMpl+UDRA8k0C5LIxeoLcfQZbe7Lt0f9S6P9k
Co04bMmzP6PdzdsGuBW2t67A/P3rV9nCdrSF8b22MBz+6zpkGN6VyfTt4u4w
wL+fu4K+v7sAES9uH4e7wwBr2Nz2fwGb88anu7I6Id8dy6LEsJJbgDyZ5BPA
T/dzCNzR8n9XE3tkw0ezPfx3S23442uiPMnB/vV9xkuwdltCtbTWQv9e471B
68XNp3mP8YLfgBX978fb6jgYx8igRyVn/4OJ28j8OR7ZEz42PwSJxNetZD1M
UlBSmy+/xo9teqUw6zeg5Wig5OjHyfajxxg+7K1nmJWHRhZ0LG/MhvCfTS0+
d4nBnWLpBSlEc6dmQdsRL7XGLqjD1wbwkhFK45oERKVP/W25gTeOssyPgsqs
BOZsjpIJSmoyXytAWAezvnHX42TWUuejfthzlCWaBpMHgsoPkg1lpwf7m1IQ
rOuoEVBqEpWGWnvfAT1KacBO699oQA8HPg0wk4IMbPjowaEUsw018BXyWKYQ
XSq5VCjkhhEn5UfpfwGiDOU7G6MsxkBi9ArigN+A68ZTL0CyBvAtpY7d/Eoa
8nD6ckgIVCODU1ssF7Cj6QOw1IWiL2ne3gb5WoKV5/PnTaem4IJ7KuG8mJnC
NSYC7PxYHZdEPXCYNslzmgpBflatcvJmclz3LbUunayXknGl6LCKwPbqcY2V
tGkwZFQKBvFILtSX502K1Qx2OGAsxTNuTOH5ZLbiJM6QWObalg8p7+GRlQt7
ButpJR4uhRTagDEjTnA87NIHL+lOVnUQ+jXejtiUqM0Pve5pK2F0om5N9U6b
hIipA/k0bwaSr3CRBWeBw4h+LKfDJI5uc92UUkIKUHBJnbXaFYxwD2R694mp
ZJ1HdBTPRDDqk1tWEHNStBIZHFn3SfVDlDP4hlSPyjn6XNMmhmFKcexeXyFC
yK/Z4luhXCUujihgWDQOwemEM81L5yklzdAvfFLESEodmJAiSOg2XVNXapZ3
nAvpI6+xehbV3ppfsb95GDIxTs39D+4ZkJ7mmPtf+WNbqL+QkYpZLJWB3tke
ngAtqrDRxEKojtbDDNSSCseTEhrT3JE77hjQiF+xQZ/n4UGxRsSMmdhJWucE
BJhmigXCaY2OeIZF6k6ltvr2amw+8FXixZB3apGIEwqHjdypLb+45AqkJm7V
BM4OOHfaUpM4HrUvTTiEn468SBhCz1gwDP+mbEQT8nouKjbnEZan3n+WSowO
HAyG0jQ+TgVp/km1WqLZYcphPJFckfzJ5PcOTBXZ1niEbzq9yY7NtNKIreQa
AmVI5lDHD1yBmtrFULUsurQ0LK+LTAecBX8SqoQQwtOjcGQu5QKjQhPEqhtS
in2uMQXucFHjQguGSTmxSX89W8zObqhmK9aqShs6Wkrm5yoVPpcGKT9W2QH8
qbL0w/Akg9uQDamKsvZnUVLnq7D4Quu4FHoh7jzlxScfYsWVetwDgv4DOkaf
VcQHSmBDpUP4wOV5Oe8LpP61GNprTvDBehYi6hm8swGrX10fCeHF9439uSnK
CL/5A0iIZDf7ksCiG8OItjvagIHWOp3APBJpBtjOgv3iXCEXUGxw0yEYgbgI
feBMhV+uEFxoUQHJYbeFpdXanDUikjJF5m8oanO8Q+EQmMSEd2pVcF9KKmhb
n4MOi3ZTGmuxLg9f/LTZnH39/jQ0I9/X/jJJV731NsmjG+JFuqAR5EycI3qF
qY7zLAR0U4XsbDkwwk+AE9L7Bssz0Y6MyBSiBtbuECSNBQixwJNQftbqWqhx
/LSkIBkNcu5FAs7yCNlDQFxmqX3cQ0zEPQ+xgcY3RUdIwWIafxEfvgTptPfe
e+jR0TA3vDREeB0hSTbyUTYi2i06C2cdxsIiNUFKuJAK6xwEC6otpAwPdT7i
dPBhjQWkj/T00aAWMYLHtxOgPAmQoQRoUvLsPt+5bsn/e/+bSBZNgP8f/29L
zE3qheff9f/gCaZjFIcgVsavtZAkYBiOLP/mmbY349/p36MWIf0ZkycReZU/
pbLyJ8R2p0NsEUPWUVn8rc/wgt9HAVyqt2e9wfbKo7mMDmdzc4H3tt1FFo1J
PllQY8ZcTfTx0+TFVePbtkq9c5qJK+mxxkR1kRywMXmalQi8wV4+1KOpk63h
dtRPlJfhj86r/7JBpzngFOF15UUzk72N60FpZkSjcM2wlDsT2TACeGyIP9pS
A/iC1BuIrG70g4Bmgza1eZcUlmu31hnb+8MdXLcYGLKVfH9IHVuPsduDWWXn
7ykaKcOjtL2+VWLmycu9/R9fDve2Hz0aPxuKsa075M42ZnTgo0xv5UE89r1V
dZHR6zTkdnfIR+PtniEf73aGfCQI1xpyZwifezbQC3ub8r7uePQWRrhgQujx
mnlUJct2gKZ7Tj+91juW18bKiFk79CQ35JBrRNdv4DkxzOoSkmPqZAOXkA7w
u+HJZqh6ABICdctSg6oqptb+CYMYCyi+EiLGVBTBAl48k9dWWXPnRVADhBIE
MKqWSrNNEhpvY7L5PS/uO17bgH59Ib++kF9P6Nd0E1gfAPWiBi4OINwimDEa
MKYINgDwDlcnoP/cAEOU3hktcHeesLXQDhZPWJIwmqwBUQQgHwIPsllFnttp
lTU3LRzw8estXJD7F1z4IdHS0EZ6TrhGehEpoazUNcHcEIVJCS13Qlh78lj7
c9gZsU29P1+0jZKE0TzoK3F+EMpsU/lvsW9484Z/1xg3aIYZc5qOcd/HNLQK
Prj7pOhKiV61aXQydFMqTMnZ1j3ptyINUsT+NxKx/z8zQYb11a3xtWiuW3fJ
z/tKmTI9JL534D7v2DOV0HY7Ehqe2joJDX/rk9Dw+66ERtZE7ChYDrH7jUYW
cyNdH9XhtJbz+hqFx8byTaab1rvJxsH+0ZtNzSwXhxPbOudXUlx36+ljzuMy
a5bXiZxQazofc+2pj0Q1+uYZ7WAUftfUuXF0+yTg8sqEAKU2IGiy9wdR/oz6
RJZRujH46cuvzBffky/HzPatoE96K8aUU7qngtbG9lZywnLlz8ob60Ns2J5g
9qMOZhN416E2/diH2/RDr/qxxjdqYnvRhD5wNqVI3EImerqdHUDzTVGnt35A
bPxUVsjmnLZY2x5vYfFq7nap/RmCxGNdyOn8DFNHzxdxZWwa5vE210DzL5ar
Zon95KpVwfRdTBC+XtX48RbXfwoHKQ6HByAnPIgr6Ml2FjCkL6uyhuW7FkcU
O8JnyvWYZ2G4B6+Zaz9g34YRALn2EFdtF/hz0T32EHBBGOl/Yf397P6hIkzR
YeJIwDQ5x0TqkIZq9eFgn7ddlXz/gwMquGXxVaqOd+oT5LBWifS/oOwilF/L
aSN1NtivsoUXJfHzBgR6nhyVc7JiRSugBu2MgO0sjhj/on6yZM/kA/TSFPqq
aiedw+Ly4kLB0PyPMCJ7XTc3cYoZmym6qpQsOkNQ8YpNjn70TnkaRLI5a387
8QkWn8jxSyaoAN6R86lZg9jlDLtDqUksdKZpSR9wyspFsKELyWb9ASe20TqI
0HtDmFQFowJq4bxD23O1cEpLCKyViK4RSTcMfp4QdGE9bWmUkEjtTDgpRtrc
WtVHR/hOyZamyuj+wg/bUW6i87Gm8lYe7cVGkXjfdhxKyoP6Jw3JizwQItQy
TTDeOjkdiaeJnXUDtexq4SwUZOeci4apXeSK57sbqPSl7+hi7jPaWw68bz3U
ejnJ4qfobem+F2FHfHMspnm7rIggNdAr9lZRWC2aViXt2MYbECC7cRYgpNx5
mR6Nc/HPz7N0JgEh4mhDAzAFO/ACgqC+6QUPLMNAcgd8+J8sqfswOPwGN43i
wzVWofjKMvl1Mjm7LTvpzuFtNwo8Ic7tcUfgwR2uk3fwtz5xB7/vlXaanpod
QIIW+XyeMyHgqA8Rg4nci+TA3MC6kSlBKNTNR5kgZNePMKraF2Lha5aeeZ4t
/Ya0blzkh7erwSqb3XmoxEwFV4i0WdgcOnBUWGld5qZ0UegCbV11hKnpXNpx
PZUYZpKjSVpLjzpKrtdC8j5eDNNzRXjCwamNFXXrixbt4zewz8kZ1o+PKkZi
iIU0/wAZJS9nKARRW/WPtAagQ+Pxsx3Y1Ip6uL1LL2m2je+3Nt3zRP8ZJQjP
U8yU0GRQ01GHi5mlJ2haETO2uvaw1YSPQOkYmF7DLzzrGGfVf8qsvHy208sm
vnym9KPMtE0zyT9/gZmOFiWGNvFkOzjZBIZP0TD2y8wIyCFlpBFNfDF8ESWl
lgMGF/WgKXoDh1FvJ0ML5MIPVTwV799sRR5gfCK6d62rlnBBR19uwDyLA5Jw
WQ8S7k5FhivR59ErbdPTAdm3urv2rRd5se8l04g4KAyewT8w4IID/87VJBf1
EGip8Q53ZG8ZO1SPj8cJ1ReW8EZNGaLXESzwxLawVxZ+qEcyHEhZZ85QRs7H
PpEOiVPfHa7xsZzf1n2dW4LZEWmpus6FjrbIkw/WjWj2iCN/9Hnvxca9Od1C
S0pGEnPCmVsxwcPdvZ9lc8xg4k4qvgcKkh3HUSt1OV81EcrBfBTzp6U3tcBG
n0UF1iM+q6sFIDNGxWKPj/KyGIqHDVuEJ76Fx0CLEHLZT6WrbcOM1glgnCPV
xTQ3kTizgRZ/BnF3BZqdQ3osyVJh7w9txpEaqLp/Gt6dJJRG3l+R653APKpL
zNkoAAjsVIae4tjvqiWOGT87jrNu09fgJeq4i67Nvr7vPhyWsU0Oa5SSxkP8
53V4mC7BXZZhNxj/tTfYI7q89/mEmqUR3XOu1YKo7+85YQsaBr4NRmiV3km8
VcnbSzsdJSVBfXEFaFTbwmEhKHQjxSK1oaHPwFGhUbFhbiZeFzE9ECmak9qU
SrEGmUp+Y38AVvm8cky6JTrRZA504nO88V8CQy8xoJWupPS1a/X/hGU/NCGu
US9OWASr6JpWP5Ja5/PMp3GHQHijZKlJQKJYUl9zrc5x+rTIKCHBYSRlaKPl
nDiXYTBfZZ51OSpxxPvyQewpMJqrZOPg8GIXVTD472Mu4a813dPEHAFacVe1
h7T3qMM6K8IRZYZPaYztbTZgiQhm26OyyweBtC3GmIHWZFc/I9tAzOQA/hWa
IKjriLZU0shealMnDeM9LwjF4cn0Joqy71/KLRSyj0sOxAq1bdK/cS04eBGj
IZG4Sq0qKcnMPc1occs0ryiKLDLMqUFd1URpHUlvPN1yHIZZ67/bcUncgaYU
iSNbngOvxxbs9Dgv0k2peu3mgIMjYc0U2MxL3cBwUfJRwQviEZiXKZZRmgO+
AYQ32ULhmJNzkHpcyl6K64RGQjh3MB7NMDgTxRKnP3hVoa26U9SUqO7MCRjU
aMCXFAJSBvgC+sJJXvNQZA1B31F6AMGk5jRmoASzKydBrK1iT554NC3qFEJu
a+5WMwnWtNazSsa86bo38rCsXGzoZNtzsPnSq0G8jGoE57UO7oKaGFmI1S4s
Ph18dGDLgvOVEEFj1lNwXl0gn+NWqtjXO621ehZb19VLGhmcvcF74NMexODG
GiSZj63OiXk2nEQ88DWF/pBdDSdRkR/85oU0N4mH5azigaMnOu9MOJcFg7Ql
eYJc1IRjl3g3gj8dxT4feCmT+NIW4un1rlw+Nd1OBAGgg7FBeGBs0LwFwktu
5opXYWYs7FJOroNXfKVIipM71VNBuvMWHxINrGvlyG/MNYCf5txonIvnb3dM
35SFQvSZCzmm885ebd5OFPCKGN5gdBdSXLh2WEVMpOb4dhGLwK7d/ron5/nf
0PmdRu0I3pQNEwfbv1ytFDH/gGXxNeKFsanV8zXkAGyiNHE0p3PSG1YFgURR
GwbiDkBoHkXjOQasYvRqdcUHIsKGyPO15CG1SELwceSNa9vFFZZkSFxjxLQc
qsMuU+/x9zX6Qv00qsw266nuh4SQ12TW62ug9VX9Zi1aiYSW3/zcH96uf/eJ
Nf3PCzVt/9eK+/cINR1zqKn1PrWMiz9nHQE4Oj6LYkPYONP4hySTwRfjx+rW
jdWA9rjtv1t/l3UcIsnZEIktCOGbrLp81+J4d5lY0aUdztofzfok0lIMwq6z
serv1s6aOG7wZUWGNEogs629vcSmuZ5Oc1VVBtVxvDBuwnikwbvNsCSO4cxs
WlulkwsbZ4DVxn9B+e2fNx3nX7YKSXoOQ4myNqWO2S28UlZ8ldXG1XKdcmMR
zW2NcnNbma1xWq8KIxsCCnrAJDQZyGz+WuQA7XBKAtEcgwQbzjwCioRphKg5
xL2VVAIlIWwe5RzOs7QqJCSO3UcBiFWEDyFOBbMpfZJvsMcUUsDP1MojtDhL
cVj1tvqDHB7sY5SNgsdnZnLochTpH1UaTdkv7lBD2Ayl+kDMUqGdjM+8Sh02
Mnsb+cKVJ1LrOU4DlhhQcsDjRLYUdFzaVlrqOmuXa29hlHgOTLkzccLo68mf
qdN9WpkO9D4dWfVT7nqecqoa536KrWHAmIB97EPRR9Ym/PYpEWLArvJpuqIS
4zLwLKi5LuUMroLbuOLNAuIVTUVkM5gW2CzaEEVAEuswfHGTJcfghA6ZuNgx
uVm7OeCh5WnjZLHSjg/BMz0vy1o68p3Cq+ftV9lCzX2QAcv3V76XLZwWJq9W
XvvCNO2BKKnoTC4LsmiLj5vOqCwyisQn9c8IV8FYsMQSrk1mLASaVIeZgaAY
5JUaJ2EB5zn6QRBNBxiKMM36tEsuJkUWSIrL5Jbcxu5BItRpOm2XsJOlSG0l
CfKkMQi1LtOitXhWY8PKj42bPERcou6Ip5W16kNsWHoaOhabZuIwGeAw9Q0H
tWC64m5jef1B0+N1MhWspSqe8RnxzcPDcG2qmmedNJ9eU7P6zV2jRSpWBUmk
Ax/7yhJ9lcG1Ltq1/aTEMj4Kki0hh2NZ3Rs0/MAybJzGT2PjzvICS+ZivbBG
M4m99Y/qIpRTgFFP4wKCVi4mEmyMQ2fLCeYax1WvsPE6ddyR5DnSpM8QnA0F
5VCPiIJ1M0asdDolWFIitakYEJ/zaqlYxpp8ybWZCdlUI4AVqrzrD5qKDM9M
/Xp0w7H1BiuNoZvPsBVBAdEro5Ut8prt50S3FilaU7hYiHxNNjof3+GrJmCN
ViCnq7pWzVzXhiK3WvXTxJaY8NqArguPFB0MJR8bjCNdmh37STkdP9Br2yY6
td7awFDM8E646Zu3x+ZeEh9T2ijqVLRIpLK4Z1zcPJudwTn4BcrypBK8tpS2
XEnEs/JEimWTNkc5BhhLk10if8YyATAi+yYIMWDlfjqBh9hceQYAHPY8qABF
HJBWHEFHo3OjWfSuXhCCnGfTD3WITBOLElHch7Y3PCtskUMoVhKVfiDYpn6V
s+BkElXLbcSKFzCon2rmlbmhXNgglS271gunIXAt97boh9TQ3VvN8bTWrFGr
mYo1LfGpLyKNOLR2CJHwEooqo0FSjYrm+DGIAOa1kZFDEgtpIL6tYhwsTE0W
ZUEs2TrfgdOE5akBhYudznK92RlZUhZZE7vm3A26eIBMqNGBfgARyTGjlGOT
nfcjtMVs9m5K02y2tMqTuJ2eGjDhjIjIrLE4IOxPcy74Z9MKskby5ehlU6rG
m6NCPcFVYTJszR0XXHfaHcHWM1G6JWeowz+koW2UrJ5MVDLhx/ISDVIDoWeZ
dG1Hps9DVvnZGTkckHAouXLdBQjhMsjVERA7S3JTLpsoVQRUNrNmEXNpTq48
NQtWGWZVJp7cRHlydFc4SYzFG9j07agqSV8Y/qC1JfGT+TIv4kVCOxpZldSh
wGVxvMCF/ASrlKdVzZ4Bqf0gHNVb4WV48TmVQVIgWz0Cq9Xq3WlnttbhE+nj
Ognp9DzPLsiPwmWGKKYn7uOzEcFp07q70E7lRMyhd1pnPDOeACVR5sJxun+E
LkhWNPecnA2h5IWvd7ES6hpk/V77f19E+f96Af7XC9DyAvwCdnSLef/VpnSt
1/S1Telmj/9drOlmyV9oUF8jMZqB/xmERqx1QgYb25SlYSuNMU4Ab1pwIxAQ
P2CeTMORtLJWINSUNsoxQPF2Q5U/7cKh+WQ+jJ+qkZlqxrQ9BpLggUoRjXkN
9DjSlbUf28yWecEU59AHljuPD6h9NFecgcVqzIRwUi1PhD06N4D/LksQbgGs
m+S1x0sIeJDVVMRjOpfEfhDMfJFCtXFxDSRnn0EuxcnU9AzyolYNP5LdAKRN
iio9rB4laODg7BuXGktkC2CiiUYkInhcz8kvQhVZUICAiLeLC7KZ6DSYKYvS
Y4qvO0g5vph9s98KeOO6UD03Ut650Z10D2/Sz3Um/fx6HR1HknUcbZl/j/m/
10nsSbr+Cmvo87FI+HpIGhAny1Pnhr+NWGfLrdPywdgGXT1umPiJ2BEzCXVa
Ec+o1hCZh0D8wYeIhkWF3yLDlhZScyH+jOOMTKb0AFntuVZFXwWap+50rCC1
wDtmqBvclgyboLOQ+OmTJHAQTVbRnuqyk1CPnzhElvS3YFbzqVrqspA4/JV3
UVH9t9MQ9+U4HMwnvJGFWXct3cCW2oUSc/ooMV8shnR7a0dW7AWXgaox5m0l
uTrTnDtvkzerxpHmaUHSF1rdvGkb7bgOtVjThZmMrAJjjN/3jTDVLp1hC6q3
RSZGaOk7Bi+dZOcpCOikUM6CITuo7lNK2weVpZyz3OD4kExUEcFElJk/5T/k
1Ky+yjLJSpxm8zmd9zl1mELiBlgK460WQEEf/Y6+F+BhNucZm/VWC8IAKZir
Mk/uo7pSmtiJWdv0P5tdFekCDpPhUUfuixAWuChPcHEgydd44ljf4ATlsUrE
KwqTpEaExOwUVQhDZE6RwiRibXpe5lNfJwEPMMqOazSw1+9BaghQxh5bMbns
wXmO8ptTwVNiBwVVMglRFAQKWMNijTYHRs6BA7guIuEdEbs4N2zQKz+QmjiY
mnI5iBysiGkYvxgWfzpPz8wS2+krWZwi4+sg3lzx6n4lr75CIMLPLffEccf3
YyDj6w3gHRezzWuCZisO+Geso4eHdJiI8JBnnXBiQoV1bnr6sZMLFWosSUg/
Csuh8xQiB3bk5RDT5879Co/sebJfkiGPmjYe+2h3jpMyAbb49Ph5ctSA4HNy
9TyZ+dcSKTctFXMFrQ0tFZMK0VsFDD2+wSkJGCFdEqFewMdNEs79xGFNoUyn
XgMYVscr1Q/RGU/jicVgaarpgiyMu9p+jqyL37v/vjwnsTsTRQWb02QFGm7a
29AdlFPQxEWN5HrDBfrdiKLrgKiTllVa5ZIyHY50mgIxgtvPOQNMiLq71nGm
nLyRUXtXBUcEaDY6idzp1Q91EqH1JdojMW1yVDJTKrkZHy6rlhYstYZzR7ue
S1Y5/p1WvhlN01k/o90Ohuo8eo7Yu6AzmqaFRg37Jl4o5qOdZZZl6Fbwzl2K
WSV+6wERH4WUP7axKzGJj+g6H6SHg5JftQJLiRkFIoabXMRsEs3UgT43ZjBG
4dM25o6SH5kXa9kRnaQt4LQ2iFZHYWnKz7z6tiDtQRCaFtIWlmTqMOKtuGGR
Qi4RO7EJOxA5dDCLJJ2c7cU6zDGIQvHyzmkXjBBPLiGZz914E+40L+1P+RBE
IGXEgkNcv0wFIVl5GehA3AUSF87DRGgcjUGESeiBmZIbRIZ7hxECMJq5duSy
UziaVHmVvbN4nTyR0AQyPuF4MDGdqVIEIuBZNuMQ/EJWpYvC+yM+5IGiE+f0
41ioPFcRzrb25DHXL0wkVaJCU7ZG4fWD+7t9r4PAI2AGEx8Av4uLu/kABv0n
0CJ0bufe2GF+bDUIpdNEnzyneKmYpuLhLJFsyrnmrqCig8FQWEo/oQoDuLxW
pP8sO00BEaw6MFAlyR9hD+VyN5Au3y/w+51NDygazJuJbKl5hIFjH0F/V5Ao
xmnSYDQZ1QKWQYX2CA1wKrZwhPQZKWoV3gi41dhHoaQ3ueS+Fg8QlZqk3WKm
RqPIBfY6tBuTjDh5OZimxUZ3ZW5UMO0lzsSu3NZo/Rcxe+ryv8TgKbq1qdiu
xdq/rCLCvasgfMU62uNfuI72eKsjZN9cQ3tN+ewUkDedUhZ+XJy6zwPphzF1
CZB7rgpm4URHKDvX10EeJW/bmUvMddlIo+431ORM7m3HFYUVxHZ2tww+SkXm
yNrNa4tbdQgJ2ZCIUGs8epf9nYRH89Wmd3URoZauiK13ZPe8k6CnGKsULRKz
h69i8MPGLoEQE4EJi2xK3xonnojgVhIlHog0EO58t2pgyS1yQhFpXyX6HRaI
I3vxfUqTD5k2/wJlyb1Zr1Ob3JYlJ6IdFaeJpuFQ1EFYBxqZvN1Io2TbY5op
O5gQvgBq9LZVhjxqX+nfokP2FYR4Jm3rmwcYUfyQyBXax0RZ2aBVcTw6PhJM
YNSDN7+TEuDsFAhuU57cIJ9fki6orwn4WvxRvkQHaYMczAxAcBAHpGkFrUpw
oJ3VSFRC0CHEY2pvc9MTS/Oa2gOEJitaxCDMib7GOq4kr1XR1xaSb5/hXQ+w
r5J8Ox8Tr7Y267zhfnKwTzjal/t6NyfSJTSvtU69+KA65ebjSIKysNELbASX
nkSEb75DvN13aN+cyl5bVwVg+KdQ43QdunByr6cygObSdIFdWDYMU5w7davN
mafo5AZCVYiqMUgLj7RV+5+kBtPJ5fMAcUTKg9dUyEP6eFjeggLVkir8qxH/
5UcMtKbQ9bnfHrDH4VvfJfbl/ztUBZbCklEzI7EEfvgsYS21QAOlqIoc1n4w
2PYwlI/iCiHsQ5Sy4nhmmV2GiZA+BYlSq9/mC1JvxL+JQy7yf/ggcJ0OqXo5
Leds+tCgEDEmmwYwKH+qRyIrLvKqLDjwHI3206xIQVWqQ71DchqW6NPFa4nH
KRH5EuiOHdGylMNZIkixZbuRCCIQFbORCC+J092JoWFMJc+QrNVIsjV4J1QW
YWlAmELNNuTn/3N9hLy2brLZWPsaJEyTjl/s0+9fYw0wDgipvcC8y19nCff9
63dTrkkFG3ebSuJlXSf74m+x73FfFZJaSwBQMJjU+CeTDmfgi/6lpSKja8Hi
nyCtyScPdzqjek+k1vAl/dGIQ4deHPr0ja0+7dykuKGZtw7VVyvb9uWO23K3
23d9eQNn//h9mzj7v/Dc/fo3+7/QyPl+rZv7VkD/vn+rW3qu7+WovDklRe5N
DicvXr1c87Kul8WhDQpU2xhvDjhkbWN7cwDXcjPuOOybDP9mDfjNYC82292K
b1q2SA1cEKdv4V/cG7j1sm9nfO+Xe3c52WRYr9n1bQC7+e+rLDv+8iu9fCOy
rW2mrZLXxvGLwbtJBz8igMUvC/js+y82Q+rvxovN9Rh2HaPY2rvxCwAsnNoX
vGzRjTbZC7GbAXYPDOsse+8Pty67t9u21bzXNNpWbpSp0xVbRk69DhY4TG8P
BrZSigGkJhessBFUG+ugwTB6mmjp4V66ZC+uyIF7ZNwEIIiK4DM+IiXRC4Y4
zdALsRohjP486l+CdX1XS4zwz2bak6cvuJmqW4/8ul+01y2YSrPusd3UyuUu
sVuxKwadMVqxhnd01/0CzYIU9G3aC0mg7BSL2hWmVlHOyV2tvbnEVMvXAoAh
jq7/UPAy0NooSfMPGAedwXxs0mNorAXMhDtSiCWZR6BIagooL6WOSMv4A6PJ
Oi7TvKkNRhXST5fGpZ2c86Ri6ADVoWIjR3HlvEmfyiBydKqqTL7grtdRta5U
jMimlrE3unAFJO4aEtJe5CKY3h3/OShv223TGHwM//Fv/15Ln3KgvLZvLAaF
J+JqCXXdMcYa9D6xbkQF6XEuTjOwsizebkd9l7C+/CiJ68Bid9zLQnvYch33
d5NW8dhQgzrRnVhE4kr04lHmsEJj+HxnQNF7F13SfxtNUHj/lWxDVKClwJRE
43hrL1q1wMkqzOv3Rbf1+mr8fsinIGVAqG9vVoa/tOZgYDSyNIYmBFOJATzx
Dp9WJX1v21GjGnFm4FGpD312oaSoRY81BBFfhJ+fOz5B4evJ97aHBMpY32tT
pkHyuj77/t2L70CWuJXe+HP3kFRKEB30PytcX3xduE7Ww3WicJ18BzLWHWmx
h65UQbbUGKaN6TGopapIhbRYdTSSjWwieXNMQND2w4FOrbbtYieUCNINPv/N
kLhn04KzTsptGJiyBcTRqgEx3TpK7dkBrs4rvax+s5TT0YGBV2iNDsxpOu4d
fplqsrVHSrK1+MT+2Onjs7OAG/yKMu00tb/Cah/J9qZHcNymybmU7JXaN6RC
k4MWcIXpDZuSwhz+cCiSCIc0wwkdDYc02X5/cLgJD0647AdG63Blr1YZRZv4
2Q1hyWszCwPNF6re2krQQTaIIoXUUB6nk5LVHiCFd0aeurEcYuoNA7CLdkSg
1sShkgPkCyQsF+e0ePysG0TbhAjYelPk9O7gpQys1biy2mJx7NK6qZ1YaDTA
+XSyjHbJ3A34oiiTsceZkL0i0tMLm+dTx6kuETLHqdqBVhirfytyQP0wHE6m
SE3C5jzXC8HtL1gsTtlR62WhX0l+kg7Yncq0fDJbVe9h69QoElGs55yhRzMK
pWOK3ebOndt8p/N+8UXn3ekY989hUftSk9rXtKl9LaNaIL5sj5KzJbI6SIi+
DYAGoQGi9XKPyv6dYKDBvDtp8HddNv+nx1JkrSNJpxBzz85/49cuV8kv2XbL
aS1/jRHAsLx1RgC9MR61tXozZWYz6zdsPypHcAvj97GdNtaLc8XEqevj2Nbw
/m7iZ88q7i4BcH5qjxDQneeXkwMM06YyEeQPFnYtlZVRMqBys7a5Rkh376H0
o5/NIwMI/ltwyZ2dL+eSPSm0/+SMEnf7pYxy0M8pOyj/v8zyfxKzDMcr5KfD
eu7OLBH7/psxy52dQQwFu4M1zDLmDuv4pbk3EctEfVoSyPvCZT59o3mksbrs
meVUks9DZLLqQljOB6Oq8Z5dnpdhLc7G5lF7Io6J1MwG0zLYlpjrjbnsqf/h
gy5h8FE2YhZtrQ+03YcmTknLrPHCJRJFQlCkyLUUvoyi6HzQJafPcqmDvOoL
EiWDgTaBdpwVKmRIwRXZiLUCwbuXe29fv375Zv/lvmYwYsw5NmlaVggzBlNF
2yALUYv9umOyKW7jCgxoJNFoKsmWrWqWGj9nhn2UbEiE0cuqKqtNqdHqS/5o
4I6vRqj1fCgoAYuahbGeJRvHZZm8WNVXmyb3NP2YL1YL5SCwXgxkQBZDO6C4
fccVI7kpRqjoGcoOpvE8ZDf36WjebG7qQuULYEyNL8HlkTilIglaEkFaFWVo
YU8lGba23bswslFL8oisYu31TbY0ge8ee2PUdY2JzMKshN77Ziv/JD03thdz
1LpBJSnj63bTNUupRlwUxwzfkrNKsdazZu14pMGYLnqsE9xpCgNLQNwm90dN
7sFWmaHKW3fhX+bBtem2rb/fyJBvtTFHHEjb31P7hj8PgL9MviXL6l+T+w7x
l1ZXjb/KACZM8rswj/kb/lae/MsLnXvdWLf+KVwCGf3523Adz00PR9KSrVxa
gYMmo7ySBz9gCgzB4YFbK8N3wjGjoHnmC5IQIl1MXIiaJdyORNk42tNHovJO
/zMR2iz/u9aq5Ol/ciS45wAov/wgzUlBWvF9Sj35VBJ0SpFzmOK0JD3AKJ2K
ZVjXiTIqNeNLianzpF/qCU+zUNbjlOpewJzCVAVBJXMDf6Xy17g+R5qzkW8i
0lqxVi22i6oEtoelPaZWMMmIK2pqH6eb2R3iy5qAiQaL14fqeMegVhMGjg9T
gfAyFFfzwbjuAnRDYiZwi2obrhv6juMQq3lz9bAoi2Fw7uuDqshTpZKZ777j
qKveFTXtQdEA+ZxklZDH/IZCgtY1r4lddVTzSd9S/yqVB5J1sMtrVfsXg8lf
zDunK8z/9jOzN5YYf1AYXW/4YpNIbUIeNHIKa36G9wX7eruzsviPf/v3ppVw
I5FFsoW1WQ/cCYUbIbt2xmAMKZF2PJombSRE93NUsMbXp8K6eXqjfCUq2jzV
CJX0Rbgz1P2wJqQi19kZVjqRepYxSqkYa5Tw1773dzvaQDEz5+Zl4nnylNwR
JV8s38thqWVM50x0TjMOVpJECW/Frc98l8vwhGs7dwzYW0I6+d+FZ3GMSydG
AxHI3bggyY01ARw9Boq1a3DrkGPteePpHuWLnNJqO7lNqdqDvNkJI5mMPxjD
hDDcWZukn2SmOuPApRIbgwFgVurDUYhgXlZYhJKinx5yxUNTC0VaHpjgKSKo
c65TzL3AA0m3lVv/VnL5wBsSZLm6bw+BCvfOh/hraQYtXinVGpjkqXm1hxhI
grCusHWvfE1RKsOWU8EJis/ArL087ktmiIG/OppFrkUd4fUAe3/DxDnLNYIw
LmAIvwAFpquldbGMxTIJJTGTQ7yGHF9iqsyjqXop1Fk0ZcXzru56S0dxrP3G
ZUgwKTi7wCQM3r80M7DsgY6f2Adr4KbM24iJ1wpLDjiuaA3aYxPyBCnAgZLY
2jYCzX551tGKJ4kfiS6RI4omdyHuwWz6L0nZCwT4nJ8KXVsbC7bsbKGFtmjk
TDrm6pxlcZlWs9pcLVMFqalWNTYYaM6vZO+hfS8WIjtNXDQYCTztnnVKq/mQ
ZlW55OiGUPSbN8AlCUlu4LLL/G1NryzJiMqNX8sKBXB8byUBF2TN25fH1P2B
/+YksJ1B4vb4rU3Jn8uxoQ08XmgN0HXs3xf9DXploYKWv2UO81Lpq3Rqy65T
ZUEkfmjx6vbQ3Yuq5gOJpAqPUgF8kRZobgfJ0WeX6vuYMbaSdiVahpgKS0rG
vKOaEGwGKUJDZ6pngPfZDKUBE2oTp1pe3K175OXZwC3bZJ+uAjYckOpwbDMx
PVmK0p2t0gpuXJZ5+cfX+CD6RjIQsEgkp80oSTiVDsbc0JJz9PAmlnurTFn0
k7Jp5hms5MPAIwL2AJ1hT5XuFh3WRlhkYoDighty9qviFOM+kE3DhV3ZLMgT
GO8yn1HRGIAMWY08NAwgzqSuBAEhvCTgXiwztlNSdKtrvYwFIgOIj5XCcBTd
aolXtmc7r/LiA1aM5MJB8PxEiwgnG68OJpuxS4xIzuOdR4+Bsjalq7GKHF8D
kfq174RCSboNz9IlVUBGsk5BgxEqjILMxkyctZ2Gy52vW7rMUYt8xT1PiMCh
jbHUYJcYJNqG8y1J/asCWe40YSC4PiD85S1A4a8snWlVhdBfqQ1NX4GZkbJc
NXgzGdlCayaUBMvpasG9LTFbSSyIh2yEOsr/kXVu9YRvTas9k1oa68gSqWU8
cJyN14dHmyqYsQbp7bqsGGFDInaw8Tma3CZ/9mSP5JzPcIPbRmst4Tje5abc
1PABOAzcEmxzLcpXo9XJZ+VS4xGDaKMbphLWphcGbu/w9fFPUVt2VRmk/fQL
Vn5XFfAzNgAyrJHZ5FIgnKaxTCNUahcaOM+aLmfJ4fi0bo3UKodFH4XdmIqF
6eIkBykdpC0SG0MyZ1xkEd9ng2sgBfVV3eAl4loRVHKyySV0TzTnyLrUwgal
4lzZxdSUz7irDqAGTppOK1SOfVEZStHF0+MuLDHmJZ++8T1QgvgN2+R6n7oS
6o3Lcid3l5lWV8umPKvS5TkaAmSIQMaRY55nXPQdcQ85EQqSAepcg2jdQBt4
cGcV1S+Lq7oP2Bc7Y6jzA6Sh6DXlXjiwinxITSOuTP+bTYKWlOo9OITpKE8X
+0UzQfqQY07wqQOUwx5kGYVOC+Tiysu/dgRSLLmfzofUbOAYA7dJNjlUxWrj
6N3x4SZfpJ0n4zFQVqyXWhDxnFEphqCF9TX6OY6czS8Lgpdc8R9Bls0q9/Ij
oCBX8QGEwwkH3A6EjorkU6bsz7Z28SITnfbwTS6R1zlyKfELKAnf5L3S/Gh2
qPQ0F+L66NhNAq8wVRGtJYpRL4v4N1A3ReDDacK3w/J0iHnfORZGbhoYoybd
yMUzFqVHrr7Z+U0Qkf7j3/49qYuypD5nIkBKDSTgpu+ys7Ty5Rj8IRtzDddg
1nwIalMV6oBisfWqnK2mxL1C8dhYoz3GZWIKrAQ0i2zigo0PQ5xDKyybC86p
siD5nILEr8WDaWWUKXEoNzE1Fcej2GUS1Coqc28qwgbFx0Qws17Jd2rKBZca
TJfpFOuP25+sliOzEFbmhKR6K5bpli47ikNnXh+6xA5LbdTRQcet8sgySGAl
RdzXpUsbTWhhqS5v7FI6915drmxk0wAqzRWhoOrZQ+2DAQsyOVnfUuuSb6kc
F9y6asYLku4bIqmelSnqNMFgS1tEzy7Gy0tHcA/tIEh4SYHBISy2juLcKYwn
TjimtpcWZddY47gPve8KJ3Qv9GmAU3ckMGOyDl26rnIYJ6mRZYksYBdcMrDh
e+c8/5Ruc1Qah8rSzzLmgPPsI54U1xlGXnImvlHqgFFcuZgVLLAGGBCFgXZX
9F5N8jabvh7Re44yclQQw9uVdrrCaTCZ4OoDSlZ4wFIgp15hmfiShi98cw8N
LKcnEDsp6QF38GM449cSOjWJyDhpmHWygXYN0FFWkh0VtYUjkcijF12mK2eM
wXqTWxaeSNtJ6/aNdZ0bi90IiQN4etp/cbUzjeu5egRbc7ORmtKNE6rNPEUK
kAOt1JL9bEihUhYKZwLGr10TF1/2++PTFtkUP2pSkdS73KD0EoApEgRg4Y7w
fTjkJXZs6mRiCt26ow5aJSuUYeqR+90KODRVcys0ToviD+I11CAN+iq6hJyC
JLAC0qqd56BbTx/j9d1neb3AygrzIBYPYvt3IF9xHTpRcs6J+yd9JiauaEC/
18oXXTCJbCZRp0APgTnAhNr5reWqSEocxqHCiytxOptwg1rKChEk2rZdlCni
7ns28SQqmR5SXFByaLUWzGrfDq1GyRf7orDtCOvCeCH8XGqhG0NTVn1bO0+f
1nS3jLtYEqAs16BgRC8Ok3FcjXemXaIvxV+KtRyBjydDlbac782VN2Jq4Ksi
bTVXBYZVSIEh23hTioKzFu5twkZk0cAZpI9pBZIjnURXuso+LuclwHbgSKz0
LRRFJwN1pWDgdZkK3ipsuZGeqe8JNpYvqaUHbpenZWk6OoMI8HLZXazi1J2i
tOcZXBXU4mu94TSltjnRBiUXKiWgQMYg9wImnhgq4skB6oKpbILz0Ex3jk/f
eCMuNiDAjpSS/ZaH9/i1smA12Tb30FvJTWS10SF8hLv0ESj3gATGVc1sWW8X
a4TYhXz/CDuIUUWihpoik8GDJSZjbCWpaD53WZD50Z6nFi1VJWrpJktjXeJF
WhVYR4WMlBipJD6GU2f3gFfvPCfI4r0D6WFeXpEdQxRriUYyrV1TWgCM0uRn
WlKlT8o303gFROTmvGbvGxpwMPrGCanc3YmsDo+5mCDXXDvXCxS64hIzoZ7X
7CjPKQeVG0+GNpbU+QlURp82LgaHCN7qa9IzxU3Roh49egb0e+gNJ67OUbZJ
iwzuzhDoOMYpTc+pLy2Ti9XSt1DagOsbwkhg3CvQJNFysmmY9DB2WZiQrNNS
SWnorCrHThUHaeJyXp7l2K6ZSSXeUIQApcPbk+aQ5gtCKVUPYXNPKIGflcUn
TwD+3kZUJz/tH6L6mS5rzBzV/GAcHdRedPFwJ1hrdAKkr4NFgUkCDpPZYcLV
wfGO9o4PVVt9NFbHaTqnPqIU+vbTUI08VYnhLt4cSCzlYLg/ShekvdcXl2cc
ibqaLYfMDbFgq7ijYHOs+SrRWMEZUJwCwgUf57n7Q7D1NIawH6ec2I+diCDg
zXD4WORcDSPZxiBktnR27KQ79qXYpklVjGHZVyoSsYGlVyKGl5FSa9IKa9tL
BWe2KYc13GNuVezi6f+RVaUHGLeZIlcRG50O4n7mZAj2BxcMDOkJ6l3eg+V5
Ah8qXSttl8S2rcDlG7gvMEQtKedUHy+UNw56VqhizISTGk01VHlb/JEO9BTA
xkYNY3R2c1hahRVFr6R3czBDZx9B/1LdwFinVz7ioQF8vMxO6rzJpNtNMvGZ
FKTjR/3IqewxXriUgEm6EvBLr95Flm4uNVoHq/3T7d3Pnx/S56ePn5Kdhywr
DWzYYfYNxXZQY75puczJXE95CavCOzLVO4hKm+ilWvNB5zvDECX2xpisEMJg
0iGon+Jyhf+rnSt1KB5+P4ctXQCq/rg6KwfJG9gQCB9Z8q5clMlrkAkK+Pbt
AkjGG0wZOgWlujxPsXTzi3I1TWdpXjGbfJGdT9GaDgzkQ3qVCsJN3kw6tvWo
sqDnXWcq2wv4SToAGSWZaO/cN3IvJlzWFTTtDRx/EyVbMR3Bp1xRBg9KmmtE
zTtRyEw8v7YVGkJACGoIXAyNlkRSBp/leJs0Bjbfe1CqhxUNiYjznEMs3EvL
cvtpfhBBUTckq74SCzvGxHAlQvpaHDS9I/k3z6oSdUkBrl+Xr0lJB4FmEgKm
3MwoCCo04kR652ljcebYk8/BYSg6BFcahtOwuVxppGc1PmJGOpl3DJgKa+Up
wQQHC6+uQnYbJvnJIodYJAa5oLf6RSBZC1eT5tYCWVzyrt+/8my0O+Kmcxw3
SsOoRflBIsQBgX+d/JEO3vxdh1WhShf/XSdHIvcwxmLix/Xzdr7P8+5XN/34
/BrLHY63UDM942YGmzhVFLEmpyZLu07+gnizL2jzV1zHp+ff9EFf80Y0BFd9
E2uBj8kjE2Jmc6oxKHEVo1ZEljdOjocvrppMkIA5kTHf7Q5PcrajhkqfHBvj
Wb3vITVb47gZJbdcElH7+JJ8q4P8kSeovw0ohHThBtyirs4UWWXMgbJORnoT
ttVIbgjR6IC5UUUeQDFqmpToYvDzvqke2kEoSiQyKBKhSwd3nl/L8AkWeU/k
s8611UETfhzrwWPXF/jDx38qfLdzHaGF9Ra3BBwRbrUhjr4Bj0s/sPWxBc46
GSO4x48kH1EWIBzUQjQEgMegescSFHYKB+UbeIve/93RYx//w+R/c/QFdNbz
ljJUbJZqoG3iqDPvjLYxlA2HzH3RK6lL34uivgro3ZG0j/iKYTOQX1o7Vvvt
EOCYJ926GJ7N0uUbJkEZEQM9luhbPilX0izqNNl+9MgbMQD+oLIJw6VuWS1C
DFfianECcDdUt4cU3/x3DeihxUsCGofr00eFbyDadyXlQsx91dhrLTFsFkaw
DsKoYNeNeyGLGgwDMA570eKzWzyLpu/KK1qSylccf0gaE6u0vnkvLq1UShQ3
wGjNMuZZyNYXFvb7Mi+sre6GIM1oLxJ92NnLNs8S5TZcSxrjuiHXQ8zmgdhZ
dngWDEY1r7zUgHP0eajzRNuKk927fxb2MnX3ssuzYPK0eSUc/JEmkjMDvmUv
3P2kO8sjniVa33WPQ4WE8BFH6tmQkngWiRvtzPKYZ3l3HGHysdRZS/B7bYtn
uriTuhBS0v0s8HjvXp7wLFpKQGaZeFu20bsl43kjqzcfHoKci72NW3vxlvHW
LE9lLyFvlskF+S7tuEl74L5zsZUf7CzPeBbqPxNe4Sp7SGnpxhz61qW3nD51
de05F2zq0k4Ia98XvZ43/N1CYVBMkLLV5pWoYr2pVN8uvN6eBavV98zyW5yl
JYrQuVAhezbcnsaiRMhZifbSsz8rwMRsqy3CBCZoBeKkLcWEYvq1r8jGm/BB
fb+8SHNQhCSFXqGjK9SYpg3Mgcc7FAF6/GJ/M9K6woNBmhuErFCQJ6omqoP/
YMJtDkBXN6mmD0Dz/qnOjJzss3g19CwO3e4Q7nvs09ffaKkW7ZYEQQpD4m0k
r6j0BWr1wU4GB+4zC7xVYmjyGbC+DLvFfc4P/opZFVzzNeccXDKMPSWtSElm
3Y4iDbEL7fruHWkPVDLgV0PBR5XEqCPBiGUq7kJNdGdniJLYBnZ6WaTzTdbT
0Jan1eVX4f5J3RAPyy1f8MNDUUIZ/CsXeboOoQ3moqkmeDjkSnutYM2RjVoi
ok9WickYyYnI3aRDfQ+lM3LhzQLhXaXC+BHS5fkPBbPDOYL1OPvYRIswX+NO
1lJkxgIzJophL/f2f3w53IOjHD+TQo2Jfs03VL6kRnsroJ706Noxt3vGfDTe
7o6JX948ppDZHqRs01m5HpHSw24WS1rxRlMNS4yyDxmBRbshN+qZAHxKi0Iz
5r78PFUXZGz8/fQNvv9+sWymS3izFXmPxs7gdWm9ae3DuUR75A27E2emMyn6
hah6NQ3Z+MBGf3tshihFvfeY6UzACsUXUKBP3VqSTg2f2fO09eTZDtJN7yQ/
yaapui/OA1GbmjQ5ssCgxYzL85KFvGD/uQ+vlJyTsBc4DnTrZupgJj+6vqoH
jaFA/rTIOUaxHu8B9O/RufQenZgAA4kBrGMa0zMF7lPXpsmDSIZOrpKCLVoU
3JiHHl05ValA5y2SOg9n4wMGLjUBmf9v6Ov30EnmBv6zbI5OclJnJZFJI+u5
V4zADIttTJHDLX1cWShQhPWLhoDuWboQjzAlJGc1ma8NUnNE1yyEDZv0jlLX
QsHjmlRVcG6j4wAoipjkBY/cUc5RzhyJjXQenQ+UcaNiSE8eEblvjimL1Ine
pZ31KNJmQS2e+J4wpmq1FQ4toMh+kYV88bHZyL2gEITOfahN4snOEPcv5Sw0
Gt9F8xN0yHeNPXnKq74ECIpKTJeNXxXaxrlvSSkxYXjZYgwjRqOm0Q5RPt47
bH9ltag+yXMdA+nhLLcxG7It/LCaz4f7mPXxMV7IVVa35u5+1V4bmgnUcf62
ytll+OWjcTy1SkTk8+RXd7V2VxjtX3+TjLe2nmpNr4rTF+xolG9GmHJq1eNr
7TlqLDtAuzpfttbGySNDyntH1+6c5QMcbSgFw2u10EqCHMXZ9Y/2tuJwEmJM
njb0w60obwAbjXYU15Sr/avU7xWNaWhhj7863P9pzWg/SNV5ugR2IV+0tr3u
xVo72u0Y8nLvjXdN3ba220c7ot6PSNSjthS9o5lQ3h5aQXDLP/r6e2K9RLLW
A6S7rI0SbhGlNTnm6ufs9IcqPQuJLDfv9A749uc3mN9bzmyg4heP9mM6P+XY
HRvk9mWjYQ20HvlApUcrlxghwYdBoRyI3mttZs4SS5CsxDEGkowW6PTyCAmD
8L9GJhlEwcEDRVwkHBcl2rd8+SpMrMJvU06L943CKX0Dg6CnGDLFnlaiPty2
Gn7lVNCzM3SJS1JrEP448ZjFiAXu9xS0Rt/VCxiWdEp2XYy+iY/pYbCw1vf9
sM3V1vOxm1lX7/fEx/4YQbCzhv4r0fs9U4IWbH/WaHR37aH8rNH2uX0bSWYd
pXT9aKUWpopHe/lxiUFr4hDuvEXJQiz5HvsYZvj+FLMHYvZob1sH+4O+1hbo
11y74zgAXaRADKebaiWMBcap9bXEFU2hmDmaTkJmfGAqiZLWaI2OJpKDATre
JGVEgCBeOi/eaWydFNsJOYVt3mvTa3TCUNSM7PCbySncbzgArLaGIQ2hwi2s
yMSaU/AwHj8L/Zp5apDBSWC9bhY0kYPilDoGkjFV6w2I9X3R9httBIv65iCR
RC+zL23T6Q17x/kCQyThhN9Glf2SUwmK5JhUCqJLZxcYTjOzC9bwMySiXO+w
GyoSggjz6bQ6G/pVD8NAqKEeIUIYcM1KE5mKGMNaCgcQU5Q/o73zWTSlxBas
MxslyWvUU1yUN6nl/vtRJmgkqL1IqK2mYjLOcdB3uWo4JFwQiA56g2HSnFfl
6uycFRAUUNLVLC+5gzQAu0xOVngNMGSZNlPHqXIB3CosYWixr8oiNaskttPU
qfE46MwQBsAIMwpam+cfpEExDUiFMH3FxqCvt/MT4HXYFwXtcSAhE28CR3iJ
OR7xL8eVNEs0HkdnwCZwtRBgDpMmCHTvCKcoOC4lMZDIbE8IQKQwO6QkDq7b
iSlthpD4+NO6FmJyzMYe0Vsl4l5a7+Rn+cw9+NuKSjTmzQOP9zo/vmyydT0i
Bb3bGZvU/w8wd7zpHVkBAA==

-->

</rfc>
