<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.39 (Ruby 3.4.9) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-tsvwg-sctp-dtls-chunk-03" category="std" consensus="true" submissionType="IETF" obsoletes="6083" updates="RFC5061" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.0 -->
  <front>
    <title abbrev="SCTP DTLS Chunk">Stream Control Transmission Protocol (SCTP) DTLS Chunk</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-sctp-dtls-chunk-03"/>
    <author initials="M." surname="Westerlund" fullname="Magnus Westerlund">
      <organization>Ericsson</organization>
      <address>
        <email>magnus.westerlund@ericsson.com</email>
      </address>
    </author>
    <author initials="J." surname="Preuß Mattsson" fullname="John Preuß Mattsson">
      <organization>Ericsson</organization>
      <address>
        <email>john.mattsson@ericsson.com</email>
      </address>
    </author>
    <author initials="C." surname="Porfiri" fullname="Claudio Porfiri">
      <organization>Ericsson</organization>
      <address>
        <email>claudio.porfiri@ericsson.com</email>
      </address>
    </author>
    <author initials="M." surname="Tüxen" fullname="Michael Tüxen">
      <organization abbrev="Münster Univ. of Appl. Sciences">Münster University of Applied Sciences</organization>
      <address>
        <postal>
          <street>Stegerwaldstrasse 39</street>
          <city>Steinfurt</city>
          <code>48565</code>
          <country>Germany</country>
        </postal>
        <email>tuexen@fh-muenster.de</email>
      </address>
    </author>
    <date year="2026" month="June" day="18"/>
    <area>Transport</area>
    <workgroup>TSVWG</workgroup>
    <abstract>
      <?line 92?>

<t>This document describes a method for adding Datagram Transport Layer
Security (DTLS) based authentication and cryptographic protection to the
Stream Control Transmission Protocol (SCTP).</t>
      <t>This SCTP extension is intended to enable communication privacy for
applications that use SCTP as their transport protocol and allows applications
to communicate in a way that is designed to prevent eavesdropping and detect
tampering or message forgery.
Once enabled, this also applies to the SCTP payload as well as the SCTP
control information.</t>
      <t>Applications using this SCTP extension can use most of the transport features
provided by SCTP and its other extensions.
The use of the SCTP Authentication extension defined in RFC 4895 is incompatible
with the extension defined in this document but would not provide any
additional service.
This implies that the Dynamic Address Reconfiguration as specified in RFC 5061
can only be used as described in this document.</t>
      <t>This document obsoletes RFC 6083 and updates RFC 5061.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-tsvwg-sctp-dtls-chunk/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Transport Area Working Group (tsvwg) Working Group mailing list (<eref target="mailto:tsvwg@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/tsvwg/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/tsvwg/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/gloinul/draft-westerlund-tsvwg-sctp-DTLS-chunk"/>.</t>
    </note>
  </front>
  <middle>
    <?line 115?>

<section anchor="introduction">
      <name>Introduction and Protocol Overview</name>
      <t>This document extends the Stream Control Transmission Protocol (SCTP), as
specified in <xref target="RFC9260"/>, by defining the DTLS chunk format and the procedures
for negotiating and managing its usage.
DTLS chunk support is integrated into the SCTP implementation, enabling the
secure transfer of SCTP packets (including both control and DATA chunks).</t>
      <t>The DTLS chunk protects a sequence of SCTP chunks by encapsulating their
DTLS-based ciphertext. This processing is based on DTLS 1.3, as specified in
<xref target="RFC9147"/>.</t>
      <t>Key management is performed outside of the SCTP implementation and is out of scope
of this document. This process is referred to as the DTLS Key Management Method.
While these methods can also be based on DTLS 1.3, it is not a requirement.</t>
      <t>The DTLS chunk in combination with the DTLS Key Management Method provides
mutual authentication, confidentiality, DTLS based data origin authentication,
integrity, and replay protection for SCTP packets.
The DTLS Key Management Method utilizes an API to provision the SCTP
association's DTLS chunk protection with key material to enable and rekey the
protection operations.</t>
      <t><xref target="sctp-DTLS-chunk-layering"/> is an example illustrating the DTLS chunk
processing in regard to SCTP and the Upper Layer Protocol (ULP) using
DTLS 1.3 as the DTLS Key Management Method.
Here the DTLS Key Management Method provides validation, i.e. using certificates,
handshaking, updating policies etc.</t>
      <figure anchor="sctp-DTLS-chunk-layering">
        <name>DTLS Chunk Layering in Regard to SCTP and ULP</name>
        <artset>
          <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="464" width="440" viewBox="0 0 440 464" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,32 L 8,272" fill="none" stroke="black"/>
              <path d="M 8,368 L 8,448" fill="none" stroke="black"/>
              <path d="M 72,280 L 72,320" fill="none" stroke="black"/>
              <path d="M 96,320 L 96,360" fill="none" stroke="black"/>
              <path d="M 136,32 L 136,272" fill="none" stroke="black"/>
              <path d="M 152,32 L 152,272" fill="none" stroke="black"/>
              <path d="M 168,80 L 168,224" fill="none" stroke="black"/>
              <path d="M 176,384 L 176,432" fill="none" stroke="black"/>
              <path d="M 192,64 L 192,96" fill="none" stroke="black"/>
              <path d="M 192,128 L 192,160" fill="none" stroke="black"/>
              <path d="M 192,208 L 192,256" fill="none" stroke="black"/>
              <path d="M 280,160 L 280,208" fill="none" stroke="black"/>
              <path d="M 280,280 L 280,320" fill="none" stroke="black"/>
              <path d="M 352,384 L 352,432" fill="none" stroke="black"/>
              <path d="M 368,64 L 368,96" fill="none" stroke="black"/>
              <path d="M 368,128 L 368,160" fill="none" stroke="black"/>
              <path d="M 368,208 L 368,256" fill="none" stroke="black"/>
              <path d="M 392,80 L 392,400" fill="none" stroke="black"/>
              <path d="M 408,32 L 408,272" fill="none" stroke="black"/>
              <path d="M 408,368 L 408,448" fill="none" stroke="black"/>
              <path d="M 8,32 L 136,32" fill="none" stroke="black"/>
              <path d="M 152,32 L 408,32" fill="none" stroke="black"/>
              <path d="M 192,64 L 368,64" fill="none" stroke="black"/>
              <path d="M 168,80 L 184,80" fill="none" stroke="black"/>
              <path d="M 368,80 L 392,80" fill="none" stroke="black"/>
              <path d="M 192,96 L 368,96" fill="none" stroke="black"/>
              <path d="M 192,128 L 368,128" fill="none" stroke="black"/>
              <path d="M 168,144 L 192,144" fill="none" stroke="black"/>
              <path d="M 192,160 L 368,160" fill="none" stroke="black"/>
              <path d="M 192,208 L 368,208" fill="none" stroke="black"/>
              <path d="M 168,224 L 184,224" fill="none" stroke="black"/>
              <path d="M 192,256 L 368,256" fill="none" stroke="black"/>
              <path d="M 8,272 L 136,272" fill="none" stroke="black"/>
              <path d="M 152,272 L 408,272" fill="none" stroke="black"/>
              <path d="M 72,320 L 280,320" fill="none" stroke="black"/>
              <path d="M 8,368 L 408,368" fill="none" stroke="black"/>
              <path d="M 176,384 L 352,384" fill="none" stroke="black"/>
              <path d="M 360,400 L 392,400" fill="none" stroke="black"/>
              <path d="M 176,432 L 352,432" fill="none" stroke="black"/>
              <path d="M 8,448 L 408,448" fill="none" stroke="black"/>
              <polygon class="arrowhead" points="400,360 388,354.4 388,365.6" fill="black" transform="rotate(90,392,360)"/>
              <polygon class="arrowhead" points="368,400 356,394.4 356,405.6" fill="black" transform="rotate(180,360,400)"/>
              <polygon class="arrowhead" points="288,280 276,274.4 276,285.6" fill="black" transform="rotate(270,280,280)"/>
              <polygon class="arrowhead" points="192,224 180,218.4 180,229.6" fill="black" transform="rotate(0,184,224)"/>
              <polygon class="arrowhead" points="192,80 180,74.4 180,85.6" fill="black" transform="rotate(0,184,80)"/>
              <polygon class="arrowhead" points="104,360 92,354.4 92,365.6" fill="black" transform="rotate(90,96,360)"/>
              <polygon class="arrowhead" points="80,280 68,274.4 68,285.6" fill="black" transform="rotate(270,72,280)"/>
              <g class="text">
                <text x="72" y="52">ULP</text>
                <text x="268" y="52">DTLS</text>
                <text x="304" y="52">1.3</text>
                <text x="240" y="84">Key</text>
                <text x="292" y="84">Exporter</text>
                <text x="240" y="148">Key</text>
                <text x="300" y="148">Management</text>
                <text x="224" y="196">ContentType</text>
                <text x="284" y="228">Record</text>
                <text x="244" y="244">Protection</text>
                <text x="324" y="244">Operator</text>
                <text x="420" y="324">keys</text>
                <text x="68" y="340">PPID</text>
                <text x="92" y="404">SCTP</text>
                <text x="272" y="404">Chunk</text>
                <text x="228" y="420">Protection</text>
                <text x="308" y="420">Operator</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art" align="center"><![CDATA[
+---------------+ +-------------------------------+
|      ULP      | |            DTLS 1.3           |
|               | |    +---------------------+    |
|               | | +->+    Key Exporter     +--+ |
|               | | |  +---------------------+  | |
|               | | |                           | |
|               | | |  +---------------------+  | |
|               | | +--+    Key Management   +  | |
|               | | |  +----------+----------+  | |
|               | | |             |             | |
|               | | | ContentType |             | |
|               | | |  +----------+----------+  | |
|               | | +->|        Record       |  | |
|               | |    | Protection Operator |  | |
|               | |    +----------+----------+  | |
+-------+-------+ +-----------------------------+-+
        ^                         ^             |
        |                         |             |
        +--+----------------------+             | keys
      PPID |                                    |
           V                                    V
+-----------------------------------------------+-+
|                    +---------------------+    | |
|        SCTP        |         Chunk       |<---+ |
|                    | Protection Operator |      |
|                    +---------------------+      |
+-------------------------------------------------+
]]></artwork>
        </artset>
      </figure>
      <t>After receiving an SCTP packet and identifying the association using the
SCTP common header, the DTLS chunk is processed by the Chunk Protection Operator.
The Chunk Protection Operator performs replay protection, decryption,
and authentication. If this processing is successful, the encapsulated SCTP chunks
are further processed.</t>
      <t>For outgoing traffic, after the SCTP stack has created the unprotected SCTP
packet containing control and/or DATA chunks, these SCTP chunks will be
processed by the Chunk Protection Operator for protection.
This results in a DTLS 1.3 record encapsulated in a DTLS chunk.</t>
      <t>The method of secure key-management, e.g. based on DTLS 1.3, providing
initial mutual authentication, key establishment, and periodic
re-authentication and rekeying with Diffie-Hellman of the DTLS chunk
protection is defined in separate documents (see
<xref target="key-management-considerations"/>).  To prevent downgrade attacks
affecting the DTLS Key Management negotiation the DTLS Key Management
Method should implement specific procedures when deriving keys.</t>
      <t>The Chunk Protection Operator performs protection operations on all
chunks of an SCTP packet.
No information is sent in plain text except for the following:</t>
      <ul spacing="normal">
        <li>
          <t>The initial SCTP handshake.</t>
        </li>
        <li>
          <t>The initial DTLS Key Management traffic.</t>
        </li>
        <li>
          <t>The SCTP common header and the SCTP DTLS chunk header of protected packets.</t>
        </li>
        <li>
          <t>The INIT and INIT ACK chunks during an SCTP restart procedure.</t>
        </li>
      </ul>
      <t>Support of the DTLS chunk and the selection of a DTLS Key Management Method
are negotiated during the SCTP handshake using a new parameter.
DTLS Key Management and application traffic are then multiplexed
using the Payload Protocol Identifier (PPID).
This document defines the dedicated PPID 4242 for use by all DTLS Key Management
Methods.</t>
      <t>Applications using the DTLS chunk can leverage most transport features provided by
SCTP and its extensions. However, the following limitations apply:</t>
      <ul spacing="normal">
        <li>
          <t>Performing an SCTP restart without knowing the restart key material is not supported.</t>
        </li>
        <li>
          <t>The use of the lookup address in the Dynamic Address Reconfiguration
extension as specified in <xref target="RFC5061"/> is not supported.</t>
        </li>
      </ul>
      <section anchor="relationship-to-rfc-6083-and-rfc-5061">
        <name>Relationship to RFC 6083 and RFC 5061</name>
        <t>This document obsoletes <xref target="RFC6083"/>, which defined the use of DTLS
over SCTP by encapsulating DTLS records as SCTP user data using the
SCTP-AUTH extension (<xref target="RFC4895"/>) for integrity protection of the SCTP
headers.  That approach suffered from several limitations: it could
not support SCTP user messages above 16384 bytes, it could not protect
SCTP control chunks, and it exposed significant SCTP metadata in clear
text.  The mechanism defined in this document replaces <xref target="RFC6083"/> by
integrating DTLS 1.3 record protection directly at the chunk level,
providing confidentiality and integrity for both user data and SCTP
control chunks without dependency on SCTP-AUTH.</t>
        <t>This document updates <xref target="RFC5061"/> by restricting the use of the Dynamic
Address Reconfiguration extension when the DTLS chunk is in use.
Specifically, the lookup address feature of <xref target="RFC5061"/> MUST NOT be used,
and the dynamic address reconfiguration extension MUST NOT be used unless
DTLS chunk handling is enabled in both directions. These restrictions
are necessary because SCTP-AUTH, which <xref target="RFC5061"/> relies on for
authenticating ASCONF chunks, is incompatible with this extension.</t>
      </section>
    </section>
    <section anchor="conventions">
      <name>Conventions</name>
      <t>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"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.
<?line -6?>
      </t>
      <section anchor="terminology">
        <name>Terminology</name>
        <dl>
          <dt>Chunk Protection Operator:</dt>
          <dd>
            <t>The component within the SCTP implementation that performs DTLS record
protection (encryption and authentication) on outgoing SCTP chunks and
the corresponding verification and decryption on incoming DTLS chunks.</t>
          </dd>
          <dt>DTLS Key Context:</dt>
          <dd>
            <t>DTLS key context includes key material (record payload key, sequence
number protection key, and initialization vector (IV)) for sending
and receiving, replay window for receiving, and last used sequence
number for sending.</t>
          </dd>
          <dt>Primary DTLS Key Context:</dt>
          <dd>
            <t>The DTLS key context used for normal SCTP association traffic, as
distinguished from the restart DTLS key context.</t>
          </dd>
          <dt>Restart DTLS Key Context:</dt>
          <dd>
            <t>A dedicated DTLS key context maintained for the sole purpose of
protecting the SCTP restart procedure.</t>
          </dd>
          <dt>DTLS Key Management Method:</dt>
          <dd>
            <t>A protocol or procedure, external to this specification, that performs
mutual authentication, key establishment, and periodic rekeying for
the DTLS chunk. Each method is identified by a DTLS Key Management
Identifier.</t>
          </dd>
          <dt>DTLS Key Management Identifier:</dt>
          <dd>
            <t>An 8-bit unsigned integer assigned by IANA that uniquely identifies a
DTLS Key Management Method, enabling negotiation during the SCTP
handshake via the DTLS Key Management Parameter.</t>
          </dd>
          <dt>Key Material:</dt>
          <dd>
            <t>Key material is all cryptographic information needed for protection
operation in one direction.</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="protocol-considerations">
      <name>Protocol Considerations</name>
      <section anchor="DTLS-engines">
        <name>DTLS Considerations</name>
        <t>Once the DTLS Key Management Method has established its context, it
derives primary and restart key material for sending and receiving and
configures the Chunk Protection Operator via an API. This establishes
the necessary DTLS key contexts for SCTP chunk encryption and
decryption.  A DTLS key context for primary operations MUST be
created, while a DTLS key context for SCTP association restart SHOULD
be created.</t>
        <t>DTLS key context includes key material such as record payload key,
sequence number protection key, and IV each for sending and receiving,
replay window for receiving, and last used sequence number for
sending. Each DTLS key context is associated with a three-value tuple
identifying the context, consisting of SCTP Association, the restart
indicator, and the DTLS epoch.</t>
        <t>The DTLS Chunk uses a single configuration of the DTLS record format.
The DTLS Connection ID in the DTLS Record layer MUST NOT be used in
the DTLS Chunk as the full DTLS connection state is not used in the
DTLS Chunk and the DTLS key context anyway can be identified. The
length field MUST NOT be used as the DTLS chunk provides record length
information. Finally 16-bit Sequence Numbers are used as they give
maximum support for reordering and there are no byte savings possible
to ensure the 32-bit alignment for the encrypted record.</t>
        <t>The first DTLS key context established for any SCTP association MUST
use epoch 3. Each subsequent DTLS key context will use the next
consecutive epoch value. Following the DTLS 1.3 specification <xref target="RFC9147"/> the
first DTLS record for each epoch will use sequence number 0.</t>
        <t>The replay window for the DTLS Sequence Number needs to account for the
concurrent transmission of packets on multiple paths in multihomed associations.
In particular, this applies to packets containing HEARTBEAT chunks.  The window
size must be sufficiently large to accommodate these latency differences.</t>
        <t>Endpoints implementing DTLS chunk MUST support DTLS records containing up to
2<sup>14</sup> (16384) bytes of plain text.</t>
      </section>
      <section anchor="sctp-considerations">
        <name>SCTP Considerations</name>
        <t>The SCTP authentication extension (SCTP-AUTH) defined in <xref target="RFC4895"/> is incompatible
with the extension defined in this document. Therefore, its support MUST NOT
be negotiated in combination with the support of the DTLS chunk.</t>
        <t>In particular, the dynamic address reconfiguration defined in <xref target="RFC5061"/> cannot
use SCTP-AUTH. Instead, the DTLS chunk is used for authentication.
This introduces the following limitations:</t>
        <ul spacing="normal">
          <li>
            <t>The lookup address MUST NOT be used.</t>
          </li>
          <li>
            <t>The dynamic address reconfiguration extension MUST NOT be used unless
DTLS chunk handling is enabled in both directions.</t>
          </li>
        </ul>
        <t>To mitigate potential information leakage from packet size variations,
implementations MAY pad SCTP packets to uniform sizes.
However, the padding MUST be applied within the encryption envelope to ensure
the padding itself is protected.</t>
        <t>Both SCTP and DTLS provide mechanisms for padding packets.
If padding of SCTP packets is desired to hide actual message sizes, it is
RECOMMENDED to use the SCTP Padding Chunk <xref target="RFC4820"/> to generate a consistent
SCTP payload size.
Support of this chunk is only required on the sender side; any SCTP receiver
will safely ignore the PAD Chunk. However, if the PAD chunk is not
supported DTLS padding MAY be used.</t>
        <t>It should be noted that regardless of whether SCTP padding or DTLS padding
is used, the additional bytes are not accounted for by the SCTP congestion control.
Extensive use of padding has potential to worsen congestion situations, as the
SCTP association will consume more bandwidth than its fair share as determined by
congestion control.</t>
        <t>The use of the SCTP PAD chunk is preferred, as it remains visible at the
SCTP layer. This enables future extensions or SCTP implementations to
correctly account for padding within congestion control mechanisms.
In contrast, DTLS padding conceals this packet expansion from the SCTP layer.</t>
      </section>
    </section>
    <section anchor="new-chunk-parameter-and-error-causes">
      <name>New Chunk, Parameter and Error Causes</name>
      <section anchor="protectedassoc-parameter">
        <name>DTLS Key Management Parameter</name>
        <t>The DTLS Key Management Parameter is used to negotiate the support of the
DTLS chunk and the Key Management Method used for the DTLS chunks.
The format of this chunk parameter is depicted in <xref target="key-management-parameter"/>.</t>
        <figure anchor="key-management-parameter">
          <name>DTLS Key Management Parameter</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="240" width="528" viewBox="0 0 528 240" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,64 L 8,160" fill="none" stroke="black"/>
                <path d="M 8,192 L 8,224" fill="none" stroke="black"/>
                <path d="M 88,128 L 88,160" fill="none" stroke="black"/>
                <path d="M 104,128 L 104,160" fill="none" stroke="black"/>
                <path d="M 120,128 L 120,160" fill="none" stroke="black"/>
                <path d="M 136,128 L 136,160" fill="none" stroke="black"/>
                <path d="M 136,192 L 136,224" fill="none" stroke="black"/>
                <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                <path d="M 264,128 L 264,160" fill="none" stroke="black"/>
                <path d="M 392,128 L 392,160" fill="none" stroke="black"/>
                <path d="M 520,64 L 520,160" fill="none" stroke="black"/>
                <path d="M 520,192 L 520,224" fill="none" stroke="black"/>
                <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                <path d="M 8,128 L 520,128" fill="none" stroke="black"/>
                <path d="M 8,160 L 520,160" fill="none" stroke="black"/>
                <path d="M 8,192 L 520,192" fill="none" stroke="black"/>
                <path d="M 8,224 L 520,224" fill="none" stroke="black"/>
                <g class="text">
                  <text x="16" y="36">0</text>
                  <text x="176" y="36">1</text>
                  <text x="336" y="36">2</text>
                  <text x="496" y="36">3</text>
                  <text x="16" y="52">0</text>
                  <text x="32" y="52">1</text>
                  <text x="48" y="52">2</text>
                  <text x="64" y="52">3</text>
                  <text x="80" y="52">4</text>
                  <text x="96" y="52">5</text>
                  <text x="112" y="52">6</text>
                  <text x="128" y="52">7</text>
                  <text x="144" y="52">8</text>
                  <text x="160" y="52">9</text>
                  <text x="176" y="52">0</text>
                  <text x="192" y="52">1</text>
                  <text x="208" y="52">2</text>
                  <text x="224" y="52">3</text>
                  <text x="240" y="52">4</text>
                  <text x="256" y="52">5</text>
                  <text x="272" y="52">6</text>
                  <text x="288" y="52">7</text>
                  <text x="304" y="52">8</text>
                  <text x="320" y="52">9</text>
                  <text x="336" y="52">0</text>
                  <text x="352" y="52">1</text>
                  <text x="368" y="52">2</text>
                  <text x="384" y="52">3</text>
                  <text x="400" y="52">4</text>
                  <text x="416" y="52">5</text>
                  <text x="432" y="52">6</text>
                  <text x="448" y="52">7</text>
                  <text x="464" y="52">8</text>
                  <text x="480" y="52">9</text>
                  <text x="496" y="52">0</text>
                  <text x="512" y="52">1</text>
                  <text x="80" y="84">Parameter</text>
                  <text x="140" y="84">Type</text>
                  <text x="168" y="84">=</text>
                  <text x="204" y="84">0x8006</text>
                  <text x="360" y="84">Parameter</text>
                  <text x="428" y="84">Length</text>
                  <text x="232" y="116">Tie</text>
                  <text x="280" y="116">Breaker</text>
                  <text x="44" y="148">Reserved</text>
                  <text x="96" y="148">R</text>
                  <text x="112" y="148">S</text>
                  <text x="128" y="148">C</text>
                  <text x="164" y="148">DTLS</text>
                  <text x="204" y="148">KMId</text>
                  <text x="236" y="148">#1</text>
                  <text x="292" y="148">DTLS</text>
                  <text x="332" y="148">KMId</text>
                  <text x="364" y="148">#2</text>
                  <text x="420" y="148">DTLS</text>
                  <text x="460" y="148">KMId</text>
                  <text x="492" y="148">#3</text>
                  <text x="8" y="180">:</text>
                  <text x="520" y="180">:</text>
                  <text x="36" y="212">DTLS</text>
                  <text x="76" y="212">KMId</text>
                  <text x="108" y="212">#N</text>
                  <text x="328" y="212">Padding</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|    Parameter Type = 0x8006    |       Parameter Length        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Tie Breaker                          |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|Reserved |R|S|C| DTLS KMId #1  | DTLS KMId #2  | DTLS KMId #3  |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
:                                                               :
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| DTLS KMId #N  |                    Padding                    |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </artset>
        </figure>
        <dl newline="true">
          <dt>Parameter Type: 16 bits (unsigned integer)</dt>
          <dd>
            <t>This value MUST be set to 0x8006.
Note that this parameter type requires the receiver to ignore the
parameter and continue processing if the parameter type is not supported.
This is accomplished (as described <xref section="3.2.1" sectionFormat="of" target="RFC9260"/>) by
the use of the upper bits of the parameter type.</t>
          </dd>
          <dt>Parameter Length: 16 bits (unsigned integer)</dt>
          <dd>
            <t>This value holds the length of the parameter in bytes, which is the
number of DTLS Key Management identifiers (N) plus 9.</t>
          </dd>
          <dt>Tie Breaker: 32 bits (unsigned integer)</dt>
          <dd>
            <t>This is a 32-bit random number to be used to determine the client and
server role for the Key Management Method.</t>
          </dd>
          <dt>Reserved: 5 bits (unsigned integer)</dt>
          <dd>
            <t>The reserved bits MUST be set to 0 by the sender and MUST be ignored by the
receiver.</t>
          </dd>
          <dt>R bit: 1 bit</dt>
          <dd>
            <t>The (R)estart supported bit.</t>
          </dd>
          <dt>S bit: 1 bit</dt>
          <dd>
            <t>The (S)erver role supported bit.</t>
          </dd>
          <dt>C bit: 1 bit</dt>
          <dd>
            <t>The (C)lient role supported bit.</t>
          </dd>
          <dt>DTLS Key Management Identifier: 8 bits (unsigned integer)</dt>
          <dd>
            <t>Each DTLS Key Management Identifier (<xref target="IANA-Protection-Solution-ID"/>)
is an 8-bit unsigned integer value indicating a DTLS Key Management Method.
The DTLS Key Management Methods are listed in descending order of preference,
i.e. the first listed in the parameter is the most preferred one and the last
listed one is the least preferred by the sender of the parameter.
The parameter MUST include at least one DTLS Key Management Identifier.</t>
          </dd>
          <dt>Padding: 0, 8, 16, or 24 bits (unsigned integer)</dt>
          <dd>
            <t>The padding MUST be set to 0 by the sender and MUST be ignored by the receiver.</t>
          </dd>
        </dl>
        <t>The DTLS Key Management Parameter MAY be included in the INIT and INIT ACK chunk
and MUST NOT be included in any other chunk.
Both peers include their respective preference list and the procedure
in <xref target="establishment-procedure"/> will determine the selected roles and chosen
method.</t>
      </section>
      <section anchor="DTLS-chunk">
        <name>DTLS Chunk (DTLS)</name>
        <t>The DTLS chunk is used to hold the DTLS 1.3 record with the protected
payload of a plain text SCTP packet without the SCTP common header.</t>
        <figure anchor="sctp-DTLS-chunk-newchunk-crypt-struct">
          <name>DTLS Chunk</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="240" width="528" viewBox="0 0 528 240" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,64 L 8,224" fill="none" stroke="black"/>
                <path d="M 136,64 L 136,128" fill="none" stroke="black"/>
                <path d="M 248,64 L 248,96" fill="none" stroke="black"/>
                <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                <path d="M 264,192 L 264,224" fill="none" stroke="black"/>
                <path d="M 520,64 L 520,224" fill="none" stroke="black"/>
                <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                <path d="M 8,128 L 136,128" fill="none" stroke="black"/>
                <path d="M 264,192 L 520,192" fill="none" stroke="black"/>
                <path d="M 8,224 L 520,224" fill="none" stroke="black"/>
                <g class="text">
                  <text x="16" y="36">0</text>
                  <text x="176" y="36">1</text>
                  <text x="336" y="36">2</text>
                  <text x="496" y="36">3</text>
                  <text x="16" y="52">0</text>
                  <text x="32" y="52">1</text>
                  <text x="48" y="52">2</text>
                  <text x="64" y="52">3</text>
                  <text x="80" y="52">4</text>
                  <text x="96" y="52">5</text>
                  <text x="112" y="52">6</text>
                  <text x="128" y="52">7</text>
                  <text x="144" y="52">8</text>
                  <text x="160" y="52">9</text>
                  <text x="176" y="52">0</text>
                  <text x="192" y="52">1</text>
                  <text x="208" y="52">2</text>
                  <text x="224" y="52">3</text>
                  <text x="240" y="52">4</text>
                  <text x="256" y="52">5</text>
                  <text x="272" y="52">6</text>
                  <text x="288" y="52">7</text>
                  <text x="304" y="52">8</text>
                  <text x="320" y="52">9</text>
                  <text x="336" y="52">0</text>
                  <text x="352" y="52">1</text>
                  <text x="368" y="52">2</text>
                  <text x="384" y="52">3</text>
                  <text x="400" y="52">4</text>
                  <text x="416" y="52">5</text>
                  <text x="432" y="52">6</text>
                  <text x="448" y="52">7</text>
                  <text x="464" y="52">8</text>
                  <text x="480" y="52">9</text>
                  <text x="496" y="52">0</text>
                  <text x="512" y="52">1</text>
                  <text x="36" y="84">Type</text>
                  <text x="64" y="84">=</text>
                  <text x="92" y="84">0x41</text>
                  <text x="180" y="84">reserved</text>
                  <text x="256" y="84">R</text>
                  <text x="360" y="84">Chunk</text>
                  <text x="412" y="84">Length</text>
                  <text x="64" y="116">Pre-Padding</text>
                  <text x="264" y="164">Payload</text>
                  <text x="372" y="212">Post-Padding</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Type = 0x41   | reserved    |R|         Chunk Length          |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Pre-Padding   |                                               |
+-+-+-+-+-+-+-+-+                                               |
|                                                               |
|                            Payload                            |
|                                                               |
|                               +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                               |       Post-Padding            |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </artset>
        </figure>
        <dl newline="true">
          <dt>Type: 8 bits (unsigned integer)</dt>
          <dd>
            <t>This value MUST be set to 0x41.
It should be noted that the chunk type requires the receiver
stop processing this SCTP packet, discard the unrecognized chunk and
all further chunks, and report the unrecognized chunk in an ERROR
chunk using the 'Unrecognized Chunk Type' error cause, if the receiver does
not support this chunk type.
This is accomplished (as described in <xref section="3.2" sectionFormat="of" target="RFC9260"/>) by the use
of the upper bits of the chunk type.</t>
          </dd>
          <dt>reserved: 7 bits</dt>
          <dd>
            <t>Reserved bits for future use. These bits MUST be set to 0 by
the sender and MUST be ignored by the receiver.</t>
          </dd>
          <dt>R: 1 bit (boolean)</dt>
          <dd>
            <t>Restart indicator. If this bit is set this DTLS chunk is protected
with a restart DTLS key context.</t>
          </dd>
          <dt>Chunk Length: 16 bits (unsigned integer)</dt>
          <dd>
            <t>This value holds the length of the Payload in bytes plus 4 plus the Payload
Pre-Padding length.</t>
          </dd>
          <dt>Pre-Padding: 8 bits</dt>
          <dd>
            <t>The sender MUST pad with one zero byte and the receiver MUST ignore the
padding bytes.</t>
          </dd>
          <dt>Payload: variable length</dt>
          <dd>
            <t>This MUST contain exactly one DTLSCiphertext as specified in DTLS 1.3 <xref target="RFC9147"/>.</t>
          </dd>
          <dt>Post-Padding: 0, 8, 16, or 24 bits</dt>
          <dd>
            <t>If the length of the Payload is not a multiple of 4 bytes, the sender
MUST pad the chunk with all zero bytes to make the chunk 32-bit
aligned.  The Padding MUST NOT be longer than 3 bytes and it MUST
be ignored by the receiver.</t>
          </dd>
        </dl>
        <t>From <xref section="4" sectionFormat="of" target="RFC9147"/>, the DTLS record header has variable length and
is depicted in <xref target="DTLSCiphertext-record-struct"/>.</t>
        <figure anchor="DTLSCiphertext-record-struct">
          <name>DTLS DTLSCiphertext</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="112" width="296" viewBox="0 0 296 112" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <g class="text">
                  <text x="28" y="36">struct</text>
                  <text x="64" y="36">{</text>
                  <text x="60" y="52">opaque</text>
                  <text x="180" y="52">unified_hdr[variable];</text>
                  <text x="60" y="68">opaque</text>
                  <text x="192" y="68">encrypted_record[length];</text>
                  <text x="8" y="84">}</text>
                  <text x="80" y="84">DTLSCiphertext;</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
    struct {
        opaque unified_hdr[variable];
        opaque encrypted_record[length];
    } DTLSCiphertext;
]]></artwork>
          </artset>
        </figure>
        <t>The DTLSCiphertext contains the unified_hdr followed by the
encrypted_record, where unified_hdr has variable format but a single
selected configuration is used in the DTLS Chunk. The use of one byte
of Pre-Padding ensures 32-bit alignment of the encrypted_record in
relation to the start of the DTLS chunk, which allows a receiver to
perform an in-place decryption and then process the sequence of
chunks.  SCTP as specified in <xref target="RFC9260"/> guarantees that chunks start
on a 32-bit boundary.</t>
        <t>The used DTLSCiphertext configuration contains the unified_hdr with
flags and the two least significant bits of the DTLS Epoch, a 16-bit
sequence number (S=1), no length field (L=0), and no Connection ID
(C=0). This results in a 3-byte unified_hdr (1 byte fixed header plus
2 bytes sequence number) and consequently 1 byte of Pre-Padding to
achieve 32-bit alignment of the encrypted_record. The used
DTLSCiphertext are shown in <xref target="DTLSCiphertext-recommended"/>.</t>
        <figure anchor="DTLSCiphertext-recommended">
          <name>DTLSCiphertext used structure</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="288" width="184" viewBox="0 0 184 288" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,48 L 8,160" fill="none" stroke="black"/>
                <path d="M 8,192 L 8,208" fill="none" stroke="black"/>
                <path d="M 24,48 L 24,80" fill="none" stroke="black"/>
                <path d="M 40,48 L 40,80" fill="none" stroke="black"/>
                <path d="M 56,48 L 56,80" fill="none" stroke="black"/>
                <path d="M 72,48 L 72,80" fill="none" stroke="black"/>
                <path d="M 88,48 L 88,80" fill="none" stroke="black"/>
                <path d="M 104,48 L 104,80" fill="none" stroke="black"/>
                <path d="M 136,48 L 136,160" fill="none" stroke="black"/>
                <path d="M 136,192 L 136,208" fill="none" stroke="black"/>
                <path d="M 8,48 L 136,48" fill="none" stroke="black"/>
                <path d="M 8,80 L 136,80" fill="none" stroke="black"/>
                <path d="M 8,128 L 136,128" fill="none" stroke="black"/>
                <path d="M 8,208 L 136,208" fill="none" stroke="black"/>
                <g class="text">
                  <text x="16" y="36">0</text>
                  <text x="32" y="36">1</text>
                  <text x="48" y="36">2</text>
                  <text x="64" y="36">3</text>
                  <text x="80" y="36">4</text>
                  <text x="96" y="36">5</text>
                  <text x="112" y="36">6</text>
                  <text x="128" y="36">7</text>
                  <text x="16" y="68">0</text>
                  <text x="32" y="68">0</text>
                  <text x="48" y="68">1</text>
                  <text x="64" y="68">0</text>
                  <text x="80" y="68">1</text>
                  <text x="96" y="68">0</text>
                  <text x="112" y="68">E</text>
                  <text x="128" y="68">E</text>
                  <text x="52" y="100">16</text>
                  <text x="80" y="100">bit</text>
                  <text x="44" y="116">Sequence</text>
                  <text x="108" y="116">Number</text>
                  <text x="64" y="164">Encrypted</text>
                  <text x="8" y="180">/</text>
                  <text x="52" y="180">Record</text>
                  <text x="136" y="180">/</text>
                  <text x="76" y="244">DTLSCiphertext</text>
                  <text x="72" y="260">Structure</text>
                  <text x="40" y="276">(Used</text>
                  <text x="124" y="276">Configuration)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+
|0|0|1|0|1|0|E E|
+-+-+-+-+-+-+-+-+
|    16 bit     |
|Sequence Number|
+-+-+-+-+-+-+-+-+
|               |
|  Encrypted    |
/  Record       /
|               |
+-+-+-+-+-+-+-+-+

  DTLSCiphertext
    Structure
  (Used Configuration)
]]></artwork>
          </artset>
        </figure>
      </section>
      <section anchor="new-error-causes">
        <name>New Error Causes</name>
        <t>This specification defines four new error causes.</t>
        <section anchor="enoprotected">
          <name>Missing DTLS Chunk Support</name>
          <t>The DTLS Chunk Support Required error cause can be sent by the receiver of the
packet containing the INIT chunk to indicate that the receiver requires the
support of the DTLS chunk, but no DTLS Key Management Parameter was included in
the INIT chunk.</t>
          <figure anchor="error-missing-dtls-chunk-support">
            <name>Error Missing DTLS Chunk Support</name>
            <artset>
              <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="112" width="528" viewBox="0 0 528 112" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                  <path d="M 8,64 L 8,96" fill="none" stroke="black"/>
                  <path d="M 184,64 L 184,72" fill="none" stroke="black"/>
                  <path d="M 184,88 L 184,96" fill="none" stroke="black"/>
                  <path d="M 216,64 L 216,72" fill="none" stroke="black"/>
                  <path d="M 216,88 L 216,96" fill="none" stroke="black"/>
                  <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                  <path d="M 520,64 L 520,96" fill="none" stroke="black"/>
                  <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                  <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                  <path class="jump" d="M 216,88 C 222,88 222,72 216,72" fill="none" stroke="black"/>
                  <path class="jump" d="M 184,88 C 178,88 178,72 184,72" fill="none" stroke="black"/>
                  <g class="text">
                    <text x="16" y="36">0</text>
                    <text x="176" y="36">1</text>
                    <text x="336" y="36">2</text>
                    <text x="496" y="36">3</text>
                    <text x="16" y="52">0</text>
                    <text x="32" y="52">1</text>
                    <text x="48" y="52">2</text>
                    <text x="64" y="52">3</text>
                    <text x="80" y="52">4</text>
                    <text x="96" y="52">5</text>
                    <text x="112" y="52">6</text>
                    <text x="128" y="52">7</text>
                    <text x="144" y="52">8</text>
                    <text x="160" y="52">9</text>
                    <text x="176" y="52">0</text>
                    <text x="192" y="52">1</text>
                    <text x="208" y="52">2</text>
                    <text x="224" y="52">3</text>
                    <text x="240" y="52">4</text>
                    <text x="256" y="52">5</text>
                    <text x="272" y="52">6</text>
                    <text x="288" y="52">7</text>
                    <text x="304" y="52">8</text>
                    <text x="320" y="52">9</text>
                    <text x="336" y="52">0</text>
                    <text x="352" y="52">1</text>
                    <text x="368" y="52">2</text>
                    <text x="384" y="52">3</text>
                    <text x="400" y="52">4</text>
                    <text x="416" y="52">5</text>
                    <text x="432" y="52">6</text>
                    <text x="448" y="52">7</text>
                    <text x="464" y="52">8</text>
                    <text x="480" y="52">9</text>
                    <text x="496" y="52">0</text>
                    <text x="512" y="52">1</text>
                    <text x="64" y="84">Cause</text>
                    <text x="108" y="84">Code</text>
                    <text x="136" y="84">=</text>
                    <text x="160" y="84">100</text>
                    <text x="200" y="84">TBC</text>
                    <text x="344" y="84">Cause</text>
                    <text x="396" y="84">Length</text>
                    <text x="432" y="84">=</text>
                    <text x="448" y="84">4</text>
                  </g>
                </svg>
              </artwork>
              <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|    Cause Code = 100 (TBC)     |       Cause Length = 4        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
            </artset>
          </figure>
          <dl newline="true">
            <dt>Cause Code: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 100 (TBC).</t>
            </dd>
            <dt>Cause Length: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 4.</t>
            </dd>
          </dl>
          <t>This error cause MAY be included in an ABORT chunk.
It MUST NOT be included in any other chunk.</t>
        </section>
        <section anchor="enocommonpsi">
          <name>No Common DTLS Key Management Method</name>
          <t>The No Common DTLS Key Management Method error cause can be used by the receiver
of the packet containing the INIT chunk to indicate that the receiver does not
support any of the DTLS Key Management Methods offered by the sender of the packet
containing the INIT chunk.</t>
          <t>The format of this error cause is depicted in <xref target="error-cause-no-common-method"/>.</t>
          <figure anchor="error-cause-no-common-method">
            <name>Error Cause No Common DTLS Key Management Method</name>
            <artset>
              <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="112" width="528" viewBox="0 0 528 112" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                  <path d="M 8,64 L 8,96" fill="none" stroke="black"/>
                  <path d="M 184,64 L 184,72" fill="none" stroke="black"/>
                  <path d="M 184,88 L 184,96" fill="none" stroke="black"/>
                  <path d="M 216,64 L 216,72" fill="none" stroke="black"/>
                  <path d="M 216,88 L 216,96" fill="none" stroke="black"/>
                  <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                  <path d="M 520,64 L 520,96" fill="none" stroke="black"/>
                  <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                  <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                  <path class="jump" d="M 216,88 C 222,88 222,72 216,72" fill="none" stroke="black"/>
                  <path class="jump" d="M 184,88 C 178,88 178,72 184,72" fill="none" stroke="black"/>
                  <g class="text">
                    <text x="16" y="36">0</text>
                    <text x="176" y="36">1</text>
                    <text x="336" y="36">2</text>
                    <text x="496" y="36">3</text>
                    <text x="16" y="52">0</text>
                    <text x="32" y="52">1</text>
                    <text x="48" y="52">2</text>
                    <text x="64" y="52">3</text>
                    <text x="80" y="52">4</text>
                    <text x="96" y="52">5</text>
                    <text x="112" y="52">6</text>
                    <text x="128" y="52">7</text>
                    <text x="144" y="52">8</text>
                    <text x="160" y="52">9</text>
                    <text x="176" y="52">0</text>
                    <text x="192" y="52">1</text>
                    <text x="208" y="52">2</text>
                    <text x="224" y="52">3</text>
                    <text x="240" y="52">4</text>
                    <text x="256" y="52">5</text>
                    <text x="272" y="52">6</text>
                    <text x="288" y="52">7</text>
                    <text x="304" y="52">8</text>
                    <text x="320" y="52">9</text>
                    <text x="336" y="52">0</text>
                    <text x="352" y="52">1</text>
                    <text x="368" y="52">2</text>
                    <text x="384" y="52">3</text>
                    <text x="400" y="52">4</text>
                    <text x="416" y="52">5</text>
                    <text x="432" y="52">6</text>
                    <text x="448" y="52">7</text>
                    <text x="464" y="52">8</text>
                    <text x="480" y="52">9</text>
                    <text x="496" y="52">0</text>
                    <text x="512" y="52">1</text>
                    <text x="64" y="84">Cause</text>
                    <text x="108" y="84">Code</text>
                    <text x="136" y="84">=</text>
                    <text x="160" y="84">101</text>
                    <text x="200" y="84">TBC</text>
                    <text x="344" y="84">Cause</text>
                    <text x="396" y="84">Length</text>
                    <text x="432" y="84">=</text>
                    <text x="448" y="84">4</text>
                  </g>
                </svg>
              </artwork>
              <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|    Cause Code = 101 (TBC)     |       Cause Length = 4        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
            </artset>
          </figure>
          <dl newline="true">
            <dt>Cause Code: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 101 (TBC).</t>
            </dd>
            <dt>Cause Length: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 4.</t>
            </dd>
          </dl>
          <t>This error cause MAY be included in an ABORT chunk.
It MUST NOT be included in any other chunk.</t>
        </section>
        <section anchor="tiebreakercol">
          <name>DTLS Key Management Tie Breaker Collision</name>
          <t>The DTLS Key Management Tie Breaker Collision error cause can be used to
indicate that both sides chose the same tie breaker.</t>
          <t>The format of this error cause is depicted in <xref target="error-cause-tie-breaker-collision"/>.</t>
          <figure anchor="error-cause-tie-breaker-collision">
            <name>Error Cause DTLS Key Management Tie Breaker Collision</name>
            <artset>
              <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="112" width="528" viewBox="0 0 528 112" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                  <path d="M 8,64 L 8,96" fill="none" stroke="black"/>
                  <path d="M 184,64 L 184,72" fill="none" stroke="black"/>
                  <path d="M 184,88 L 184,96" fill="none" stroke="black"/>
                  <path d="M 216,64 L 216,72" fill="none" stroke="black"/>
                  <path d="M 216,88 L 216,96" fill="none" stroke="black"/>
                  <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                  <path d="M 520,64 L 520,96" fill="none" stroke="black"/>
                  <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                  <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                  <path class="jump" d="M 216,88 C 222,88 222,72 216,72" fill="none" stroke="black"/>
                  <path class="jump" d="M 184,88 C 178,88 178,72 184,72" fill="none" stroke="black"/>
                  <g class="text">
                    <text x="16" y="36">0</text>
                    <text x="176" y="36">1</text>
                    <text x="336" y="36">2</text>
                    <text x="496" y="36">3</text>
                    <text x="16" y="52">0</text>
                    <text x="32" y="52">1</text>
                    <text x="48" y="52">2</text>
                    <text x="64" y="52">3</text>
                    <text x="80" y="52">4</text>
                    <text x="96" y="52">5</text>
                    <text x="112" y="52">6</text>
                    <text x="128" y="52">7</text>
                    <text x="144" y="52">8</text>
                    <text x="160" y="52">9</text>
                    <text x="176" y="52">0</text>
                    <text x="192" y="52">1</text>
                    <text x="208" y="52">2</text>
                    <text x="224" y="52">3</text>
                    <text x="240" y="52">4</text>
                    <text x="256" y="52">5</text>
                    <text x="272" y="52">6</text>
                    <text x="288" y="52">7</text>
                    <text x="304" y="52">8</text>
                    <text x="320" y="52">9</text>
                    <text x="336" y="52">0</text>
                    <text x="352" y="52">1</text>
                    <text x="368" y="52">2</text>
                    <text x="384" y="52">3</text>
                    <text x="400" y="52">4</text>
                    <text x="416" y="52">5</text>
                    <text x="432" y="52">6</text>
                    <text x="448" y="52">7</text>
                    <text x="464" y="52">8</text>
                    <text x="480" y="52">9</text>
                    <text x="496" y="52">0</text>
                    <text x="512" y="52">1</text>
                    <text x="64" y="84">Cause</text>
                    <text x="108" y="84">Code</text>
                    <text x="136" y="84">=</text>
                    <text x="160" y="84">102</text>
                    <text x="200" y="84">TBC</text>
                    <text x="344" y="84">Cause</text>
                    <text x="396" y="84">Length</text>
                    <text x="432" y="84">=</text>
                    <text x="448" y="84">4</text>
                  </g>
                </svg>
              </artwork>
              <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|    Cause Code = 102 (TBC)     |       Cause Length = 4        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
            </artset>
          </figure>
          <dl newline="true">
            <dt>Cause Code: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 102 (TBC).</t>
            </dd>
            <dt>Cause Length: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 4.</t>
            </dd>
          </dl>
          <t>This error cause MAY be included in an ABORT chunk.
It MUST NOT be included in any other chunk.</t>
        </section>
        <section anchor="incompatroles">
          <name>Incompatible DTLS Key Management Roles</name>
          <t>The Incompatible DTLS Key Management Roles error cause can be used to
indicate that the roles chosen are incompatible.</t>
          <t>The format of this error cause is depicted in <xref target="error-cause-incompat-roles"/>.</t>
          <figure anchor="error-cause-incompat-roles">
            <name>Error Cause Incompatible DTLS Key Management Roles</name>
            <artset>
              <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="112" width="528" viewBox="0 0 528 112" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                  <path d="M 8,64 L 8,96" fill="none" stroke="black"/>
                  <path d="M 184,64 L 184,72" fill="none" stroke="black"/>
                  <path d="M 184,88 L 184,96" fill="none" stroke="black"/>
                  <path d="M 216,64 L 216,72" fill="none" stroke="black"/>
                  <path d="M 216,88 L 216,96" fill="none" stroke="black"/>
                  <path d="M 264,64 L 264,96" fill="none" stroke="black"/>
                  <path d="M 520,64 L 520,96" fill="none" stroke="black"/>
                  <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                  <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                  <path class="jump" d="M 216,88 C 222,88 222,72 216,72" fill="none" stroke="black"/>
                  <path class="jump" d="M 184,88 C 178,88 178,72 184,72" fill="none" stroke="black"/>
                  <g class="text">
                    <text x="16" y="36">0</text>
                    <text x="176" y="36">1</text>
                    <text x="336" y="36">2</text>
                    <text x="496" y="36">3</text>
                    <text x="16" y="52">0</text>
                    <text x="32" y="52">1</text>
                    <text x="48" y="52">2</text>
                    <text x="64" y="52">3</text>
                    <text x="80" y="52">4</text>
                    <text x="96" y="52">5</text>
                    <text x="112" y="52">6</text>
                    <text x="128" y="52">7</text>
                    <text x="144" y="52">8</text>
                    <text x="160" y="52">9</text>
                    <text x="176" y="52">0</text>
                    <text x="192" y="52">1</text>
                    <text x="208" y="52">2</text>
                    <text x="224" y="52">3</text>
                    <text x="240" y="52">4</text>
                    <text x="256" y="52">5</text>
                    <text x="272" y="52">6</text>
                    <text x="288" y="52">7</text>
                    <text x="304" y="52">8</text>
                    <text x="320" y="52">9</text>
                    <text x="336" y="52">0</text>
                    <text x="352" y="52">1</text>
                    <text x="368" y="52">2</text>
                    <text x="384" y="52">3</text>
                    <text x="400" y="52">4</text>
                    <text x="416" y="52">5</text>
                    <text x="432" y="52">6</text>
                    <text x="448" y="52">7</text>
                    <text x="464" y="52">8</text>
                    <text x="480" y="52">9</text>
                    <text x="496" y="52">0</text>
                    <text x="512" y="52">1</text>
                    <text x="64" y="84">Cause</text>
                    <text x="108" y="84">Code</text>
                    <text x="136" y="84">=</text>
                    <text x="160" y="84">103</text>
                    <text x="200" y="84">TBC</text>
                    <text x="344" y="84">Cause</text>
                    <text x="396" y="84">Length</text>
                    <text x="432" y="84">=</text>
                    <text x="448" y="84">4</text>
                  </g>
                </svg>
              </artwork>
              <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|    Cause Code = 103 (TBC)     |       Cause Length = 4        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
            </artset>
          </figure>
          <dl newline="true">
            <dt>Cause Code: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 103 (TBC).</t>
            </dd>
            <dt>Cause Length: 16 bits (unsigned integer)</dt>
            <dd>
              <t>This value MUST be set to 4.</t>
            </dd>
          </dl>
          <t>This error cause MAY be included in an ABORT chunk.
It MUST NOT be included in any other chunk.</t>
        </section>
      </section>
    </section>
    <section anchor="procedures">
      <name>Procedures</name>
      <section anchor="establishment-procedure">
        <name>Establishment of a Protected Association</name>
        <t>An SCTP endpoint wanting to use the DTLS chunk can operate in one of two modes:</t>
        <dl>
          <dt>Strict DTLS mode:</dt>
          <dd>
            <t>The SCTP endpoint wants to use the DTLS chunk and is not willing to operate
without DTLS chunk protection.</t>
          </dd>
          <dt>Loose DTLS mode:</dt>
          <dd>
            <t>The SCTP endpoint want to use the DTLS chunk but is willing to operate without
DTLS chunk protection.</t>
          </dd>
        </dl>
        <t>A received DTLS Key Management Parameter is compatible, if the following two
conditions are satisfied:</t>
        <ol spacing="normal" type="1"><li>
            <t>At least one of the DTLS Key Management Identifiers listed in the parameter
matches a locally supported one.</t>
          </li>
          <li>
            <t>At least one of the roles (client or server) indicated in the parameter
complements a local role.</t>
          </li>
        </ol>
        <t>To initiate an SCTP association, an SCTP endpoint wanting to use the DTLS chunk
MUST send an SCTP packet with an INIT chunk containing the DTLS Key Management
Parameter (see <xref target="protectedassoc-parameter"/>).
This parameter lists the supported DTLS Key Management Identifiers
(see <xref target="key-management-parameter"/>) in descending order of preference.</t>
        <t>If an SCTP endpoint operating in strict DTLS mode receives an SCTP packet
containing an INIT chunk with a compatible DTLS Key Management Parameter,
it MUST reply with a packet containing an INIT ACK containing its own DTLS Key
Management Parameters.</t>
        <t>If an SCTP endpoint operates in strict DTLS mode and receives an SCTP packet
with an INIT or INIT ACK chunk does not contain any DTLS Key Management Parameter
or only an incompatible one, the endpoint MUST send an SCTP packet with an
ABORT chunk.
It MAY include the appropriate error cause
"Missing DTLS Chunk Support" (see <xref target="enoprotected"/>),
"No Common DTLS Key Management Method" (see <xref target="enocommonpsi"/>),
or "No Common DTLS Key Management Method" (see <xref target="incompatroles"/>).</t>
        <t>If an SCTP endpoint operates in loose DTLS mode, it MAY continue with the
handshake in any case.</t>
        <t>To ensure that each endpoint's Key Management Method knows which role it has and
both endpoints agree on which method that was chosen the below procedure MUST be
executed by both endpoints before entering the ESTABLISHED state.</t>
        <t>First the Key Management role of each endpoint is determined. This is
done by evaluating the S and C bits in the two endpoints'
parameters. This falls into the following cases:</t>
        <ol spacing="normal" type="1"><li>
            <t>At least one endpoint indicates a single role (client or server) and the peer
supports the other role. In this case the endpoint indicating a single role
takes that role, and the other endpoint takes the reverse role.</t>
          </li>
          <li>
            <t>Both endpoints indicate both roles, this is to be expected for endpoints
supporting simultaneous open. In this case the role needs to be determined
using the parameter's Tie breaker. The endpoint with the larger value SHALL be
the server, and the other endpoint takes the client role. In case both
endpoints have the same tie breaker value, the selection has failed and the
association MUST be aborted.
The ABORT chunk MAY include the SCTP error cause
"DTLS Key Management Tie Breaker Collision" (see <xref target="tiebreakercol"/>).
Endpoints are RECOMMENDED to attempt establishing a new SCTP association.</t>
          </li>
        </ol>
        <t>Once the key management roles have been established, the endpoints
determine the method to be used. The prioritized list of DTLS Key
Management Identifiers provided by the endpoint acting as the server
is evaluated, and the first identifier also supported by the peer
endpoint is selected.</t>
        <t>When the SCTP association has been established, the process defined by the
selected DTLS Key Management Method MUST be followed for establishing
DTLS key contexts and installing them.</t>
      </section>
      <section anchor="dtls-chunk-handling">
        <name>DTLS Chunk Handling</name>
        <t>The DTLS chunk MUST NOT be bundled with any other chunk. Specifically,
it MUST appear as the first and only chunk in the packet.</t>
        <figure anchor="sctp-DTLS-encrypt-chunk-states-1">
          <name>Unprotected SCTP Packet</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="208" width="528" viewBox="0 0 528 208" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,64 L 8,192" fill="none" stroke="black"/>
                <path d="M 520,64 L 520,192" fill="none" stroke="black"/>
                <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                <path d="M 8,128 L 520,128" fill="none" stroke="black"/>
                <path d="M 8,160 L 520,160" fill="none" stroke="black"/>
                <path d="M 8,192 L 520,192" fill="none" stroke="black"/>
                <g class="text">
                  <text x="16" y="36">0</text>
                  <text x="176" y="36">1</text>
                  <text x="336" y="36">2</text>
                  <text x="496" y="36">3</text>
                  <text x="16" y="52">0</text>
                  <text x="32" y="52">1</text>
                  <text x="48" y="52">2</text>
                  <text x="64" y="52">3</text>
                  <text x="80" y="52">4</text>
                  <text x="96" y="52">5</text>
                  <text x="112" y="52">6</text>
                  <text x="128" y="52">7</text>
                  <text x="144" y="52">8</text>
                  <text x="160" y="52">9</text>
                  <text x="176" y="52">0</text>
                  <text x="192" y="52">1</text>
                  <text x="208" y="52">2</text>
                  <text x="224" y="52">3</text>
                  <text x="240" y="52">4</text>
                  <text x="256" y="52">5</text>
                  <text x="272" y="52">6</text>
                  <text x="288" y="52">7</text>
                  <text x="304" y="52">8</text>
                  <text x="320" y="52">9</text>
                  <text x="336" y="52">0</text>
                  <text x="352" y="52">1</text>
                  <text x="368" y="52">2</text>
                  <text x="384" y="52">3</text>
                  <text x="400" y="52">4</text>
                  <text x="416" y="52">5</text>
                  <text x="432" y="52">6</text>
                  <text x="448" y="52">7</text>
                  <text x="464" y="52">8</text>
                  <text x="480" y="52">9</text>
                  <text x="496" y="52">0</text>
                  <text x="512" y="52">1</text>
                  <text x="236" y="84">Common</text>
                  <text x="292" y="84">Header</text>
                  <text x="248" y="116">Chunk</text>
                  <text x="284" y="116">#1</text>
                  <text x="240" y="148">.</text>
                  <text x="256" y="148">.</text>
                  <text x="272" y="148">.</text>
                  <text x="248" y="180">Chunk</text>
                  <text x="284" y="180">#n</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                         Common Header                         |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           Chunk #1                            |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                            . . .                              |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           Chunk #n                            |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </artset>
        </figure>
        <t>The diagram shown in <xref target="sctp-DTLS-encrypt-chunk-states-1"/> describes
the structure of an unprotected SCTP packet as described in <xref target="RFC9260"/>.</t>
        <figure anchor="sctp-DTLS-encrypt-chunk-states-2">
          <name>Protected SCTP Packets</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="144" width="528" viewBox="0 0 528 144" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,64 L 8,128" fill="none" stroke="black"/>
                <path d="M 520,64 L 520,128" fill="none" stroke="black"/>
                <path d="M 8,64 L 520,64" fill="none" stroke="black"/>
                <path d="M 8,96 L 520,96" fill="none" stroke="black"/>
                <path d="M 8,128 L 520,128" fill="none" stroke="black"/>
                <g class="text">
                  <text x="16" y="36">0</text>
                  <text x="176" y="36">1</text>
                  <text x="336" y="36">2</text>
                  <text x="496" y="36">3</text>
                  <text x="16" y="52">0</text>
                  <text x="32" y="52">1</text>
                  <text x="48" y="52">2</text>
                  <text x="64" y="52">3</text>
                  <text x="80" y="52">4</text>
                  <text x="96" y="52">5</text>
                  <text x="112" y="52">6</text>
                  <text x="128" y="52">7</text>
                  <text x="144" y="52">8</text>
                  <text x="160" y="52">9</text>
                  <text x="176" y="52">0</text>
                  <text x="192" y="52">1</text>
                  <text x="208" y="52">2</text>
                  <text x="224" y="52">3</text>
                  <text x="240" y="52">4</text>
                  <text x="256" y="52">5</text>
                  <text x="272" y="52">6</text>
                  <text x="288" y="52">7</text>
                  <text x="304" y="52">8</text>
                  <text x="320" y="52">9</text>
                  <text x="336" y="52">0</text>
                  <text x="352" y="52">1</text>
                  <text x="368" y="52">2</text>
                  <text x="384" y="52">3</text>
                  <text x="400" y="52">4</text>
                  <text x="416" y="52">5</text>
                  <text x="432" y="52">6</text>
                  <text x="448" y="52">7</text>
                  <text x="464" y="52">8</text>
                  <text x="480" y="52">9</text>
                  <text x="496" y="52">0</text>
                  <text x="512" y="52">1</text>
                  <text x="236" y="84">Common</text>
                  <text x="292" y="84">Header</text>
                  <text x="236" y="116">DTLS</text>
                  <text x="280" y="116">Chunk</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
 0                   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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                         Common Header                         |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          DTLS Chunk                           |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </artset>
        </figure>
        <t>The diagram shown in <xref target="sctp-DTLS-encrypt-chunk-states-2"/> describes the
structure of a protected SCTP packet being sent.  Such packets contain only the
SCTP common header and one DTLS chunk.</t>
        <t>Once the part of the DTLS key context responsible for sending DTLS chunks
has been configured by the application, all SCTP packets SHALL be sent using a DTLS chunk.</t>
        <t>When an SCTP packet needs to be sent, the sequence of chunks is used
as <tt>DTLSInnerPlaintext.content</tt> and <tt>DTLSInnerPlaintext.type</tt> is set
to <tt>application_data</tt> <xref target="RFC9147"/>. Then the <tt>DTLSCiphertext</tt> is
computed per the DTLS 1.3 specification <xref target="RFC9147"/> and the configured
cipher suite, and the result is used as the payload. Finally the SCTP
common header is prepended.</t>
        <t>When the DTLS chunk is used, the endpoint MUST consider the DTLS chunk header
and the overhead of DTLS to ensure that the final SCTP packet does not exceed
the PMTU.</t>
        <t>Upon receipt of an SCTP packet in which a DTLS chunk is bundled with any
other chunk, the entire packet MUST be silently discarded.</t>
        <t>After the application has restricted the SCTP packet handling to protected
SCTP packets only, an SCTP packet not containing a DTLS chunk MUST be
silently discarded.</t>
        <t>When processing the payload of the DTLS chunk (i.e. the <tt>DTLSCiphertext</tt>),
the Restart flag in addition to the <tt>unified_hdr</tt> is used to find the keys for
processing the <tt>encrypted_record</tt> following DTLS 1.3 <xref target="RFC9147"/>.</t>
        <t>After the <tt>encrypted_record</tt> has been verified and decrypted, the
corresponding chunks (the <tt>DTLSInnerPlaintext.content</tt>) are processed as
defined in the corresponding specifications.</t>
        <t>If the Chunk Protection Operator experiences a non-critical error,
it MUST NOT abort the association.</t>
      </section>
      <section anchor="termination-procedure">
        <name>Termination of a Protected Association</name>
        <t>Note that the closure of any DTLS Key Management Method doesn't
compromise the capability of terminating the SCTP association gracefully as
that capability only relies on the Key Context and not on the DTLS Key
Management Method from where it has been derived.</t>
      </section>
      <section anchor="sec-restart">
        <name>SCTP Restart Considerations</name>
        <t>This section deals with the handling of an unexpected INIT chunk
during an association lifetime as described in <xref section="5.2" sectionFormat="of" target="RFC9260"/>
with the purpose of defining a protected restart procedure.</t>
        <t>When the upper layer protocols require support of SCTP restart for associations
using the DTLS chunk, as in case of 3GPP NG-C protocol <xref target="ETSI-TS-38.413"/>, the
endpoint needs to support also the protected SCTP restart procedure described
below. Implementation of the protected restart procedure is RECOMMENDED; however,
it is not required, as it relies on the availability of persistent secure storage
for the restart DTLS key context. An endpoint will know that its peer supports
this protected SCTP restart procedure from the DTLS Key Management Parameter's R bit
<xref target="key-management-parameter"/>.</t>
        <t>The protected SCTP restart procedure keeps the security characteristics of
an SCTP association using DTLS chunks.</t>
        <t>In protected SCTP restart, INIT and INIT ACK chunks are sent
according to <xref target="RFC9260"/>, but COOKIE ECHO and COOKIE ACK chunks
are encrypted using DTLS chunks and the restart DTLS key contexts. The
endpoints MUST include the DTLS Key Management Parameter in the INIT
and INIT ACK, using the same method list, but with a new random Tie Breaker.</t>
        <t>In order to support protected SCTP restart, the SCTP endpoints need
to allocate and maintain dedicated restart DTLS key contexts. SCTP
packets protected by these contexts will be identified in the DTLS
chunk with the R (Restart) bit set (see <xref target="DTLS-chunk"/>).  Both SCTP
endpoints need to ensure that restart DTLS key contexts are preserved
for supporting the protected SCTP restart use case.</t>
        <t>For a protected SCTP endpoint to be available for protected SCTP restart,
the DTLS chunk requires access to a DTLS key context associated with the
SCTP association. This key context MUST be maintained in a well-defined
state such that both endpoints have a consistent view of the DTLS sequence
numbers and replay window (i.e., initialized but never used). The SCTP restart
DTLS key MUST NOT be used for any purpose other than SCTP association restart.</t>
        <t>An SCTP endpoint wanting to be able to initiate a protected SCTP restart needs
to store securely and persistently the restart keys, and related DTLS epoch,
indexed so that when performing a restart with a peer endpoint, the restarting
endpoint can identify the right restart key and DTLS epoch and
initialize the restart DTLS key context for when restarting the SCTP
association.</t>
        <t>The keys and epoch need to be stored securely and persistently so that they
survive the events that are causing the protected SCTP restart procedure to be
used, for instance a crash of the SCTP stack. The security considerations for
persistent secure storage of key material are further discussed in
<xref target="sec-consideration-storage"/>.</t>
        <t>A DTLS chunk using the restart DTLS key context is identified by
having the R bit (Restart Indicator) set in the DTLS chunk (see
<xref target="sctp-DTLS-chunk-newchunk-crypt-struct"/>).  There's exactly one
active restart DTLS key context at a time, the newest. However, a crash at
the time having completed the DTLS Key Management exchange but failing to
commit the DTLS key context to persistent secure storage could result
in loss of the latest DTLS key context. Therefore, the endpoints
SHOULD retain the old restart DTLS key context until the
DTLS Key Management confirms the new ones are committed to secure storage.
For example, this can ensure that signals to terminate the old DTLS
key contexts (including the restart context) are never sent until the
new restart DTLS key context has been committed to
storage.</t>
        <t>Implementations will also need to consider the risk of two-time pads,
i.e. the usage of the same nonce twice. An SCTP endpoint restarted and
sent a number of packets using the restart key context thus using
sequence number 1 to 8. If this endpoint restarts again, it is crucial
that the restarted endpoint does not reuse sequence number 1 to 8 a second
time. Ensuring that a sequence number is never reused in the context
of a crash may be hard, thus the simpler solution is to remove a restart
key context that is being used from the persistent storage to prevent
reuse.</t>
        <figure anchor="DTLS-chunk-restart">
          <name>Handshake of SCTP Restart for DTLS in SCTP</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="240" width="528" viewBox="0 0 528 240" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 40,48 L 40,208" fill="none" stroke="black"/>
                <path d="M 408,48 L 408,208" fill="none" stroke="black"/>
                <path d="M 440,64 L 440,96" fill="none" stroke="black"/>
                <path d="M 440,144 L 440,176" fill="none" stroke="black"/>
                <path d="M 440,64 L 496,64" fill="none" stroke="black"/>
                <path d="M 40,80 L 208,80" fill="none" stroke="black"/>
                <path d="M 248,80 L 400,80" fill="none" stroke="black"/>
                <path d="M 48,96 L 192,96" fill="none" stroke="black"/>
                <path d="M 264,96 L 408,96" fill="none" stroke="black"/>
                <path d="M 440,96 L 496,96" fill="none" stroke="black"/>
                <path d="M 440,144 L 496,144" fill="none" stroke="black"/>
                <path d="M 40,160 L 112,160" fill="none" stroke="black"/>
                <path d="M 320,160 L 400,160" fill="none" stroke="black"/>
                <path d="M 48,176 L 112,176" fill="none" stroke="black"/>
                <path d="M 312,176 L 408,176" fill="none" stroke="black"/>
                <path d="M 440,176 L 496,176" fill="none" stroke="black"/>
                <path d="M 424,48 C 432.83064,48 440,55.16936 440,64" fill="none" stroke="black"/>
                <path d="M 424,112 C 432.83064,112 440,104.83064 440,96" fill="none" stroke="black"/>
                <path d="M 424,128 C 432.83064,128 440,135.16936 440,144" fill="none" stroke="black"/>
                <path d="M 424,192 C 432.83064,192 440,184.83064 440,176" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="408,160 396,154.4 396,165.6" fill="black" transform="rotate(0,400,160)"/>
                <polygon class="arrowhead" points="408,80 396,74.4 396,85.6" fill="black" transform="rotate(0,400,80)"/>
                <polygon class="arrowhead" points="56,176 44,170.4 44,181.6" fill="black" transform="rotate(180,48,176)"/>
                <polygon class="arrowhead" points="56,96 44,90.4 44,101.6" fill="black" transform="rotate(180,48,96)"/>
                <g class="text">
                  <text x="40" y="36">Initiator</text>
                  <text x="408" y="36">Responder</text>
                  <text x="228" y="84">INIT</text>
                  <text x="472" y="84">Plain</text>
                  <text x="212" y="100">INIT</text>
                  <text x="248" y="100">ACK</text>
                  <text x="136" y="164">[DTLS</text>
                  <text x="212" y="164">CHUNK(COOKIE</text>
                  <text x="292" y="164">ECHO)]</text>
                  <text x="488" y="164">Protected</text>
                  <text x="136" y="180">[DTLS</text>
                  <text x="212" y="180">CHUNK(COOKIE</text>
                  <text x="288" y="180">ACK)]</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
Initiator                                     Responder
    |                                             | -.
    |                                             |   +-------
    +--------------------(INIT)------------------>|   | Plain
    |<-----------------(INIT ACK)-----------------+   +-------
    |                                             | -'
    |                                             | -.
    |                                             |   +-------
    +---------[DTLS CHUNK(COOKIE ECHO)]---------->|   | Protected
    |<--------[DTLS CHUNK(COOKIE ACK)]------------+   +-------
    |                                             | -'
    |                                             |

]]></artwork>
          </artset>
        </figure>
        <t>The <xref target="DTLS-chunk-restart"/> shows how the control chunks being
used for SCTP association restart are transported within DTLS in SCTP.</t>
        <t>A restarted SCTP association MUST continue to use the restart DTLS key context,
for user traffic until a new primary DTLS key context will be available. The
implementors SHOULD initiate a rekeying as soon as possible,
and derive the primary and restart keys so that the time when no
restart DTLS key context is available is kept to a minimum. Note that another
restart attempt prior to having created new restart DTLS key context
for the new SCTP association will result in the endpoints being unable
to restart the SCTP association.</t>
        <t>After restart, the next primary DTLS key context MUST use epoch 3,
i.e. the epoch value is reset. After having derived a new
primary DTLS key context, the endpoint installs it
and starts using it. The new restart DTLS key context is only installed
after all old in-flight restart packets have been received.</t>
        <t>An SCTP endpoint supporting only normal SCTP restart and involved in
an SCTP association using DTLS chunks SHOULD NOT attempt to restart
the association. The effect will be that the restart initiator will
receive INIT ACK but then all sent packets with COOKIE ECHO will be
dropped until the peer endpoint times out the SCTP association from lack
of any response from the restarting node.</t>
        <t>An SCTP endpoint supporting only legacy SCTP restart and involved
in an SCTP association using DTLS chunks, when receiving a COOKIE ECHO
chunk protected by DTLS chunk as described above, thus having the
R bit (Restart Indicator) set in the DTLS chunk (see
<xref target="sctp-DTLS-chunk-newchunk-crypt-struct"/>), MUST silently discard it.</t>
      </section>
    </section>
    <section anchor="key-management-considerations">
      <name>DTLS Key Management Method Considerations</name>
      <t>This document specifies the mechanisms for protecting SCTP associations using
DTLS chunks, including an API for managing the corresponding key material.
While this document defines the interface, the upper layer is responsible
for the actual key management.</t>
      <t>DTLS Key Management Methods define the procedures for initial key generation,
key updates and peer authentication. These procedures are out of scope for
this document.
Currently two DTLS Key Management Methods with different properties (such as
mutual authentication and rekeying) are defined:</t>
      <ul spacing="normal">
        <li>
          <t><xref target="I-D.ietf-tsvwg-dtls-chunk-key-management"/></t>
        </li>
        <li>
          <t><xref target="I-D.westerlund-tsvwg-sctp-DTLS-handshake"/></t>
        </li>
      </ul>
      <t>An SCTP endpoint MAY support multiple DTLS Key Management Methods subject to
implementation requirements and local security policies.</t>
      <t>Every DTLS Key Management Method</t>
      <ul spacing="normal">
        <li>
          <t>MUST be registered in the IANA Registry <xref target="IANA-Protection-Solution-ID"/>
to receive a unique identifier, enabling negotiation during the SCTP handshake.</t>
        </li>
        <li>
          <t>SHOULD use the PPID from <xref target="sec-iana-ppid"/> to ensure that the DTLS Key
Management Method related user messages are processed by the relevant entity.</t>
        </li>
        <li>
          <t>SHOULD ensure that the local receive keys are installed before the peer
installs the corresponding send keys.</t>
        </li>
        <li>
          <t>MUST include in its key derivation the DTLS Key Management Parameter
(including the parameter header and excluding the optional padding) as the
sequence of bytes sent and received over the network during the SCTP handshake,
to mitigate downgrade attacks.</t>
        </li>
      </ul>
    </section>
    <section anchor="abstract-api">
      <name>Abstract API</name>
      <t>This section describes an abstract API that is needed between a
DTLS Key Management Method and the DTLS chunk. This is an
example API and there are alternative implementations.</t>
      <t>This API enables the cryptographic protection operations by setting
record payload key, sequence number keys, and initialization vector
(IV) for primary and restart DTLS contexts in both send and receive
direction. The record payload key is used by the cipher suite for DTLS
record protection (<xref section="5.2" sectionFormat="of" target="RFC8446"/>). The initialization
vector (IV) is random material used to XOR with the sequence number to
create the nonce per <xref section="5.3" sectionFormat="of" target="RFC8446"/>.  The sequence number
key is used to encrypt the sequence number (<xref section="4.2.3" sectionFormat="of" target="RFC9147"/>).</t>
      <t>As this API references the key material as for send or receive, it will
be the responsibility of the Key Management Method used to define how
it maps the endpoint's role to which keys are for send and receive
direction respectively.</t>
      <section anchor="set-supported-dtls-key-management-parameters">
        <name>Set Supported DTLS Key Management Parameters</name>
        <t>Prior to attempting to establish an SCTP association an SCTP endpoint
needs to configure which DTLS Key Management Methods it supports, as
well as the roles and if restart is supported. This information is
included in the DTLS Key Management Parameter, which, when these
parameters are set, will be included in either INIT or INIT ACK chunks.</t>
        <t>An endpoint can either support: client only, server only, or client
and server. The latter is for situations where both endpoints may attempt
to establish an SCTP association towards each other, potentially
causing a simultaneous sending of INIT chunks. Depending on port
configuration SCTP supports this happening during the association
establishment, and the result will be a single SCTP association. However,
to select the same Key Management Method on both sides, the SCTP stack
will resolve the key management role for this association.</t>
        <t>Request: Set Supported DTLS Key Management Methods</t>
        <dl>
          <dt>Parameters:</dt>
          <dd>
            <t/>
          </dd>
          <dt>* SCTP Association Handle:</dt>
          <dd>
            <t>The handle to what may become an SCTP Association or a server port
accepting association establishment.</t>
          </dd>
        </dl>
        <ul spacing="normal">
          <li>
            <dl>
              <dt>Key Management Roles Supported:</dt>
              <dd>
                <t>The endpoint indicates if it can act as client only, server only,
or client and server.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Support SCTP Restart (boolean):</dt>
              <dd>
                <t>Indicate if the endpoint is capable of supporting SCTP restart when DTLS chunk
has been negotiated. If both endpoints indicate flag then a restart has the
potential to succeed.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Requires DTLS Chunk security (boolean):</dt>
              <dd>
                <t>SCTP association is only established if both endpoints support DTLS
Chunk and have included the DTLS Key Management Parameter.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>List of Identifiers:</dt>
              <dd>
                <t>A prioritized list of DTLS Key Management identifiers
<xref target="IANA-Protection-Solution-ID"/> that are supported, from the most
preferred to the least preferred.</t>
              </dd>
            </dl>
          </li>
        </ul>
        <t>Reply: Success or Error</t>
        <t>Parameters: None</t>
      </section>
      <section anchor="get-agreed-dtls-key-management-method-and-role">
        <name>Get Agreed DTLS Key Management Method and Role</name>
        <t>After an SCTP association has been established the key management
function needs to know which method was agreed on and which role this
endpoint will have. The function provides both endpoints' actual
values from the DTLS Key Management Parameter, used in key derivation
to prevent downgrade attacks.</t>
        <t>Request: Get Agreed DTLS Key Management Method and Role</t>
        <dl>
          <dt>Parameters:</dt>
          <dd>
            <t/>
          </dd>
          <dt>* SCTP Association Handle:</dt>
          <dd>
            <t>The handle to an established SCTP Association.</t>
          </dd>
        </dl>
        <t>Reply: Success or Error</t>
        <t>Parameters:</t>
        <ul spacing="normal">
          <li>
            <dl>
              <dt>Key Management Role:</dt>
              <dd>
                <t>The role that was selected for this endpoint, one of client or server.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Key Management Method:</dt>
              <dd>
                <t>The selected Key Management Method as a DTLS Key Management Identifier.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Down Grade Prevention Data:</dt>
              <dd>
                <t>In network byte order the whole of the DTLS Key Management Parameter
including header and excluding padding that the endpoint with the
client role offered, followed by the corresponding parameter content
of the endpoint with the server role in seperable records.</t>
              </dd>
            </dl>
          </li>
        </ul>
      </section>
      <section anchor="cipher-suite-capabilities">
        <name>Cipher Suite Capabilities</name>
        <t>The DTLS Key Management Method needs to know which cipher suites defined
for use with DTLS 1.3 that are supported by the DTLS chunk and its
protection operations block. All TLS cipher suites that are defined are
listed in the TLS cipher suite registry <xref target="TLS-CIPHER-SUITES"/> at IANA
and are identified by a 2-byte value. Thus this needs to return a list
of all supported cipher suites to the higher layer.</t>
        <t>Request : Get Cipher Suites</t>
        <t>Parameters : none</t>
        <t>Reply   : Cipher Suites</t>
        <t>Parameters : list of cipher suites</t>
      </section>
      <section anchor="establish-send-key-material">
        <name>Establish Send Key Material</name>
        <t>The DTLS chunk can use one out of multiple sets of cipher suite and
corresponding key materials. Some limitations do exists when establishing
Key Material to avoid issues:</t>
        <ul spacing="normal">
          <li>
            <t>Primary Keys  MUST be installed prior to Restart Keys for each epoch to avoid
them being used unless this endpoint is attempting a restart.</t>
          </li>
          <li>
            <t>With the exception of restart keys when this endpoint attempts
restart of the SCTP association, the first DTLS epoch set in an
association MUST be 3. Any subsequent epoch must be the next
consecutive number compared to the previously used.</t>
          </li>
        </ul>
        <t>The following information needs to be provided when setting send key material:</t>
        <t>Request : Establish Send Key Material</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <dl>
              <dt>SCTP Association:</dt>
              <dd>
                <t>Reference to the SCTP association to set the key material for.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Restart indication:</dt>
              <dd>
                <t>A bit indicating whether the key material is for restart purposes</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>DTLS Epoch:</dt>
              <dd>
                <t>The DTLS epoch this key material is valid for. Note that Epoch lower than
3 are not expected as they are used during DTLS handshake.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Cipher Suite:</dt>
              <dd>
                <t>2 bytes cipher suite identification for the DTLS 1.3 cipher suite used
to identify the DTLS AEAD algorithm to perform the DTLS record protection.
The cipher suite is fixed for a (SCTP Association, Key) pair.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Key Material:</dt>
              <dd>
                <t>The cipher suite specific binary object containing all necessary
information for protection operations such as Record Payload Key,
Sequence Number Key and IV. The secret will be used by the DTLS 1.3
client to encrypt the record. Binary arbitrary long object depending
on the cipher suite used.</t>
              </dd>
            </dl>
          </li>
        </ul>
        <t>Reply: Established or Failed</t>
      </section>
      <section anchor="establish-receive-key-material">
        <name>Establish Receive Key Material</name>
        <t>The DTLS chunk can use one out of multiple sets of cipher suite and
corresponding key materials.</t>
        <t>The following information needs to be provided when setting receive key material:</t>
        <t>Request : Establish Receive Key Material</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <dl>
              <dt>SCTP Association:</dt>
              <dd>
                <t>Reference to the SCTP association to set the key material for.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Restart indication:</dt>
              <dd>
                <t>A bit indicating whether the key material is for restart purposes</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>DTLS Epoch:</dt>
              <dd>
                <t>The DTLS epoch these keys are valid for. Note that Epoch lower than
3 are not expected as they are used during DTLS handshake. The DTLS
epoch must be the next in turn.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Cipher Suite:</dt>
              <dd>
                <t>2 bytes cipher suite identification for the DTLS 1.3 cipher suite used
to identify the DTLS AEAD algorithm to perform the DTLS record protection.
The cipher suite is fixed for a (SCTP Association, Key) pair.</t>
              </dd>
            </dl>
          </li>
          <li>
            <dl>
              <dt>Key Material:</dt>
              <dd>
                <t>The cipher suite specific binary object containing all necessary
information for protection operations such as Record Payload Key,
Sequence Number Key and IV. The secret will be used by the DTLS 1.3
client to encrypt the record. Binary arbitrary long object depending
on the cipher suite used.</t>
              </dd>
            </dl>
          </li>
        </ul>
        <t>Reply : Established or Failed</t>
      </section>
      <section anchor="destroy-send-key-material">
        <name>Destroy Send Key Material</name>
        <t>A function to destroy the send key material for a given epoch for the
Primary or Restart DTLS Key Context for a given SCTP Association.</t>
        <t>Request : Destroy Send Key Material</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: Destroyed</t>
        <t>Parameters : Success or Error</t>
      </section>
      <section anchor="destroy-receive-key-material">
        <name>Destroy Receive Key Material</name>
        <t>A function to destroy the receive key material for a given epoch for
the Primary or Restart DTLS Key Context for a given SCTP Association.</t>
        <t>Request: Destroy Receive Key Material</t>
        <t>Parameters:</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: Destroyed</t>
        <t>Parameters: Success or Error</t>
      </section>
      <section anchor="set-key-to-use">
        <name>Set Key to Use</name>
        <t>Set which key to use to protect the future SCTP packets sent by the
SCTP Association. This function can be replace by Establish Send Key
Material which immediately enables the primary key for the next epoch
when installed.</t>
        <t>Setting the restart keys to be used instead of primary keys SHALL only
be done when attempting to perform a restart of the SCTP association.</t>
        <t>Request: Set Key used</t>
        <t>Parameters:</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: Key set</t>
        <t>Parameters: true or false</t>
      </section>
      <section anchor="require-protected-sctp-packets">
        <name>Require Protected SCTP Packets</name>
        <t>A function to configure an SCTP association to require that all SCTP
packets, excepts those with INIT or INIT ACK chunks, being received on
this endpoint are required to be protected in a DTLS chunk going
forward. Any unprotected SCTP packets to this SCTP association will be
discarded.</t>
        <t>Parameters:</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
        </ul>
        <t>Reply: Acknowledgement</t>
      </section>
      <section anchor="get-aead-encryption-invocations">
        <name>Get AEAD Encryption Invocations</name>
        <t>Get the number of AEAD encryption invocations (protected SCTP packets)
for a given epoch.</t>
        <t>Request : Get AEAD Encryption Invocations</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: AEAD Encryption Invocations</t>
        <t>Parameters : non-negative integer</t>
      </section>
      <section anchor="get-aead-decryption-invocations">
        <name>Get AEAD Decryption Invocations</name>
        <t>Get the number of AEAD decryption invocations for a given epoch.</t>
        <t>Request : Get AEAD Decryption Invocations</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: AEAD Decryption Invocations</t>
        <t>Parameters : non-negative integer</t>
      </section>
      <section anchor="get-failed-aead-decryption-invocations">
        <name>Get Failed AEAD Decryption Invocations</name>
        <t>Get the number of failed AEAD decryption invocations for a given epoch.</t>
        <t>Request : Get Failed AEAD Decryption Invocations</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>DTLS Epoch</t>
          </li>
        </ul>
        <t>Reply: Failed AEAD Decryption Invocations</t>
        <t>Parameters : non-negative integer</t>
      </section>
      <section anchor="configure-replay-protection">
        <name>Configure Replay Protection</name>
        <t>The DTLS replay protection in this usage is expected to be fairly
robust. Its depth of handling is related to maximum network path
reordering that the receiver expects to see during the SCTP
association. However as the actual reordering in number of packets is
a combination of how delayed one packet may be compared to another,
times the actual packet rate. This value may become larger for some
applications and may need to be tuned. Thus, having the potential for
setting this a more suitable value depending on the use case should be
supported.</t>
        <t>Note this sets the configuration across any DTLS key context for a
given SCTP Association and both primary and restart usages.</t>
        <t>Request : Configure Replay Protection</t>
        <t>Parameters :</t>
        <ul spacing="normal">
          <li>
            <t>SCTP Association</t>
          </li>
          <li>
            <t>Restart indication</t>
          </li>
          <li>
            <t>Configuration parameters</t>
          </li>
        </ul>
        <t>Reply: Replay Protection Configured</t>
        <t>Parameters : true or false</t>
      </section>
    </section>
    <section anchor="socket-api">
      <name>Socket API Considerations</name>
      <t>This section describes how the socket API defined in <xref target="RFC6458"/> needs to be
extended to provide a way for the application to control the usage of the
DTLS chunk.</t>
      <t>A 'Socket API Considerations' section is contained in all SCTP-related
specifications published after <xref target="RFC6458"/> describing an extension for which
implementations using the socket API as specified in <xref target="RFC6458"/> would require
some extension of the socket API.
Please note that this section is informational only.</t>
      <t>Please also note, that the API described in this section can change in a
non-backwards compatible way during the evolution of this document due to
changed functionality or gained experience during the implementation.</t>
      <t>A socket API implementation based on <xref target="RFC6458"/> is extended by supporting
several new <tt>IPPROTO_SCTP</tt>-level socket options and a new flag for
<tt>recvmsg()</tt>.</t>
      <section anchor="sctpassocchange-notification">
        <name><tt>SCTP_ASSOC_CHANGE</tt> Notification</name>
        <t>When an <tt>SCTP_ASSOC_CHANGE</tt> notification (specified in <xref section="6.1.1" sectionFormat="of" target="RFC6458"/>) is delivered indicating a <tt>sac_state</tt> of <tt>SCTP_COMM_UP</tt> or
<tt>SCTP_RESTART</tt> for an SCTP association where both peers support the
DTLS chunk, <tt>SCTP_ASSOC_SUPPORTS_DTLS</tt> should be listed in the
<tt>sac_info</tt> field.</t>
      </section>
      <section anchor="a-new-flag-for-recvmsg-msgprotected">
        <name>A New Flag for <tt>recvmsg()</tt> (<tt>MSG_PROTECTED</tt>)</name>
        <t>This flag is returned by <tt>recvmsg()</tt> in <tt>msg_flags</tt> for all user messages
for which all DATA chunks were received in protected SCTP packets.
This also means that if <tt>sctp_recvv()</tt> is used, <tt>MSG_PROTECTED</tt> is returned
in the <tt>*flags</tt> argument.</t>
      </section>
      <section anchor="functions">
        <name>Functions</name>
        <section anchor="sctpdtlsnrciphersuites">
          <name><tt>sctp_dtls_nr_cipher_suites()</tt></name>
          <t><tt>sctp_dtls_nr_cipher_suites()</tt> returns the number of cipher suites supported
by the SCTP implementation.</t>
          <t>The function prototype is:</t>
          <sourcecode type="c"><![CDATA[
unsigned int
sctp_dtls_nr_cipher_suites(void);
]]></sourcecode>
          <t>This function can be used in combination with <tt>sctp_dtls_cipher_suites()</tt>.</t>
        </section>
        <section anchor="sctpdtlsciphersuites">
          <name><tt>sctp_dtls_cipher_suites()</tt></name>
          <t><tt>sctp_dtls_cipher_suites()</tt> returns the cipher suites supported by the
SCTP implementation.</t>
          <t>The function prototype is:</t>
          <sourcecode type="c"><![CDATA[
int
sctp_dtls_cipher_suites(uint8_t cipher_suites[][2], unsigned int n);
]]></sourcecode>
          <dl>
            <dt>and the arguments are</dt>
            <dd>
              <t/>
            </dd>
            <dt><tt>cipher_suites</tt>:</dt>
            <dd>
              <t>An array where the supported cipher suites are stored. A cipher suite is
represented by two <tt>uint8_t</tt> using the IANA assigned values in the
TLS cipher suite registry <xref target="TLS-CIPHER-SUITES"/>.</t>
            </dd>
            <dt><tt>n</tt>:</dt>
            <dd>
              <t>The number of cipher suites which can be stored in <tt>cipher_suites</tt>.</t>
            </dd>
          </dl>
          <t><tt>sctp_dtls_cipher_suites</tt> returns <tt>-1</tt>, if <tt>n</tt> is smaller than the number
of cipher suites supported by the stack. If <tt>n</tt> is equal to or larger than
the number of cipher suites supported by the SCTP implementation, the
cipher suites are stored in <tt>cipher_suites</tt> and the number of supported
cipher suites is returned.</t>
        </section>
      </section>
      <section anchor="socket-options">
        <name>Socket Options</name>
        <t>The following table provides an overview of the <tt>IPPROTO_SCTP</tt>-level socket
options defined by this section.</t>
        <table anchor="socket-options-table">
          <name>Socket Options</name>
          <thead>
            <tr>
              <th align="left">Option Name</th>
              <th align="left">Data Type</th>
              <th align="left">Set</th>
              <th align="left">Get</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_LOCAL_CONFIG</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_config</tt></td>
              <td align="left">X</td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_GET_CONFIG</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_config</tt></td>
              <td align="left"> </td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_GET_LOCAL_KM_PARAM</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_kmp</tt></td>
              <td align="left"> </td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_GET_PEER_KM_PARAM</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_kmp</tt></td>
              <td align="left"> </td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_SET_SEND_KEYS</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_keys</tt></td>
              <td align="left">X</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_ADD_RECV_KEYS</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_keys</tt></td>
              <td align="left">X</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_DEL_RECV_KEYS</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_keys_id</tt></td>
              <td align="left">X</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_ENFORCE_PROTECTION</tt></td>
              <td align="left">
                <tt>struct sctp_assoc_value</tt></td>
              <td align="left">X</td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_REPLAY_WINDOW</tt></td>
              <td align="left">
                <tt>struct sctp_assoc_value</tt></td>
              <td align="left">X</td>
              <td align="left">X</td>
            </tr>
            <tr>
              <td align="left">
                <tt>SCTP_DTLS_GET_STATS</tt></td>
              <td align="left">
                <tt>struct sctp_dtls_stats</tt></td>
              <td align="left"> </td>
              <td align="left">X</td>
            </tr>
          </tbody>
        </table>
        <t><tt>sctp_opt_info()</tt> needs to be extended to support:</t>
        <ul spacing="normal">
          <li>
            <t><tt>SCTP_DTLS_LOCAL_CONFIG</tt>,</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_GET_CONFIG</tt>,</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_GET_LOCAL_KM_PARAM</tt>,</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_GET_PEER_KM_PARAM</tt>,</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_ENFORCE_PROTECTION</tt>,</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_REPLAY_WINDOW</tt>, and</t>
          </li>
          <li>
            <t><tt>SCTP_DTLS_GET_STATS</tt>.</t>
          </li>
        </ul>
        <section anchor="get-or-set-the-local-dtls-key-management-configuration-sctpdtlslocalconfig">
          <name>Get or Set the Local DTLS Key Management Configuration (<tt>SCTP_DTLS_LOCAL_CONFIG</tt>)</name>
          <t>This socket option allows to get and set the DTLS Key Management identifiers being
sent to the peer during the handshake, the supported DTLS roles, and determines
whether the restart operation is supported and the use of the DTLS chunk is
required.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_config {
        sctp_assoc_t sdc_assoc_id;
        uint16_t sdc_flags;
        uint16_t sdc_nr_kmids;
        uint8_t sdc_kmids[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdc_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
For <tt>setsockopt()</tt>, only <tt>SCTP_FUTURE_ASSOC</tt> can be used.</t>
            </dd>
            <dt><tt>sdc_flags</tt>:</dt>
            <dd>
              <dl>
                <dt>This field may contain any of the following flags and is composed of a</dt>
                <dd>
                  <t/>
                </dd>
                <dt>bitwise OR of these values.</dt>
                <dd>
                  <t/>
                </dd>
                <dt><tt>SCTP_DTLS_CLIENT</tt>:</dt>
                <dd>
                  <t>All Key Management Methods in <tt>sdc_kmids</tt> can operate as a DTLS client.</t>
                </dd>
                <dt><tt>SCTP_DTLS_SERVER</tt>:</dt>
                <dd>
                  <t>All Key Management Methods in <tt>sdc_kmids</tt> can operate as a DTLS server.</t>
                </dd>
                <dt><tt>SCTP_DTLS_RESTART</tt>:</dt>
                <dd>
                  <t>All Key Management Methods in <tt>sdc_kmids</tt> support the restart operation.</t>
                </dd>
                <dt><tt>SCTP_DTLS_REQUIRED</tt>:</dt>
                <dd>
                  <t>If this flag is set, the SCTP endpoint operates in strict DTLS mode.
Otherwise, it operates in loose DTLS mode.</t>
                </dd>
              </dl>
            </dd>
            <dt><tt>sdc_nr_kmids</tt>:</dt>
            <dd>
              <t>The number of entries in <tt>sdc_kmids</tt>.</t>
            </dd>
            <dt><tt>sdc_kmids</tt>:</dt>
            <dd>
              <t>The DTLS Key Management identifiers which will be sent to the peer
in the DTLS Key Management Parameter in the sequence provided.</t>
            </dd>
          </dl>
          <t>This socket option can be used with <tt>setsockopt()</tt> only for SCTP endpoints in
the <tt>SCTP_CLOSED</tt> state for configuration.
It can be used with <tt>getsockopt()</tt> in any state.</t>
        </section>
        <section anchor="get-the-dtls-key-management-configuration-sctpdtlsgetconfig">
          <name>Get the DTLS Key Management Configuration (<tt>SCTP_DTLS_GET_CONFIG</tt>)</name>
          <t>This socket option reports the DTLS Key Management Parameters negotiated during
the handshake.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_config {
        sctp_assoc_t sdc_assoc_id;
        uint16_t sdc_flags;
        uint16_t sdc_nr_kmids;
        uint8_t sdc_kmids[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdc_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdc_flags</tt>:</dt>
            <dd>
              <dl>
                <dt>This field contains any of the following flags and is composed of a bitwise</dt>
                <dd>
                  <t/>
                </dd>
                <dt>OR of these values.</dt>
                <dd>
                  <t/>
                </dd>
                <dt><tt>SCTP_DTLS_CLIENT</tt>:</dt>
                <dd>
                  <t>Indicates that the Key Management Method provided in <tt>sdc_kmids</tt> acts as
a client.</t>
                </dd>
                <dt><tt>SCTP_DTLS_SERVER</tt>:</dt>
                <dd>
                  <t>Indicates that the Key Management Method provided in <tt>sdc_kmids</tt> acts as
a server.</t>
                </dd>
                <dt><tt>SCTP_DTLS_RESTART</tt>:</dt>
                <dd>
                  <t>Indicates that the Key Management Method provided in <tt>sdc_kmids</tt> supports
the restart operation.</t>
                </dd>
              </dl>
            </dd>
            <dt><tt>sdc_nr_kmids</tt>:</dt>
            <dd>
              <t>The number of entries in <tt>sdc_kmids</tt>.
A value of 1 indicates that DTLS chunk support was successfully negotiated,
while a value of 0 indicates negotiation failed.</t>
            </dd>
            <dt><tt>sdc_kmids</tt>:</dt>
            <dd>
              <t>The DTLS Key Management identifier which was negotiated.</t>
            </dd>
          </dl>
          <t>This socket option will fail on any SCTP endpoint in state <tt>SCTP_CLOSED</tt>,
<tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="get-the-local-dtls-key-management-parameter-sctpdtlsgetlocalkmparam">
          <name>Get the Local DTLS Key Management Parameter (<tt>SCTP_DTLS_GET_LOCAL_KM_PARAM</tt>)</name>
          <t>This socket option provides the DTLS Key Management Parameter sent by the
endpoint during the handshake.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_kmp {
        sctp_assoc_t sdk_assoc_id;
        uint32_t sdk_nr_bytes;
        uint8_t sdk_bytes[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdk_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdk_nr_bytes</tt>:</dt>
            <dd>
              <t>The number of entries in <tt>sdk_bytes</tt>.</t>
            </dd>
            <dt><tt>sdk_bytes</tt>:</dt>
            <dd>
              <t>The DTLS Key Management Parameter sent by the endpoint as the sequence
of bytes sent over the network. This includes the parameter header and
excludes the optional parameter padding.</t>
            </dd>
          </dl>
          <t>This socket option will fail on any SCTP endpoint in state <tt>SCTP_CLOSED</tt>,
<tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="get-the-peer-dtls-key-management-parameter-sctpdtlsgetpeerkmparam">
          <name>Get the Peer DTLS Key Management Parameter (<tt>SCTP_DTLS_GET_PEER_KM_PARAM</tt>)</name>
          <t>This socket option provides the DTLS Key Management Parameter received by the
endpoint during the handshake.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_kmp {
        sctp_assoc_t sdk_assoc_id;
        uint32_t sdk_nr_bytes;
        uint8_t sdk_bytes[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdk_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdk_nr_bytes</tt>:</dt>
            <dd>
              <t>The number of entries in <tt>sdk_bytes</tt>.</t>
            </dd>
            <dt><tt>sdk_bytes</tt>:</dt>
            <dd>
              <t>The DTLS Key Management Parameter received by the endpoint as the sequence
of bytes received over the network. This includes the parameter header and
excludes the optional parameter padding.</t>
            </dd>
          </dl>
          <t>This socket option will fail on any SCTP endpoint in state <tt>SCTP_CLOSED</tt>,
<tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="set-send-keys-sctpdtlssetsendkeys">
          <name>Set Send Keys (<tt>SCTP_DTLS_SET_SEND_KEYS</tt>)</name>
          <t>Using this socket option allows to add a particular set of keys used for
sending DTLS chunks.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_keys {
        sctp_assoc_t sdk_assoc_id;
        uint8_t sdk_cipher_suite[2];
        uint16_t sdk_restart;
        uint64_t sdk_epoch;
        uint16_t sdk_key_len;
        uint16_t sdk_iv_len;
        uint16_t sdk_sn_key_len;
        uint16_t sdk_unused;
        uint8_t sdk_keys[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdk_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdk_cipher_suite</tt>:</dt>
            <dd>
              <t>The cipher suite for which the keys are used.</t>
            </dd>
            <dt><tt>sdk_restart</tt>:</dt>
            <dd>
              <t>If the value is <tt>0</tt>, the regular keys are added, if a value different
from <tt>0</tt> is used, the restart keys are added.</t>
            </dd>
            <dt><tt>sdk_unused</tt>:</dt>
            <dd>
              <t>This field is ignored.</t>
            </dd>
            <dt><tt>sdk_epoch</tt>:</dt>
            <dd>
              <t>The epoch for which the keys are added.</t>
            </dd>
            <dt><tt>sdk_key_len</tt>:</dt>
            <dd>
              <t>The length of the key specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_iv_len</tt>:</dt>
            <dd>
              <t>The length of the initialization vector specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_sn_key_len</tt>:</dt>
            <dd>
              <t>The length of the sequence number key specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_keys</tt>:</dt>
            <dd>
              <t>The key of length <tt>sdk_key_len</tt> directly followed by the initialization
vector of length <tt>sdk_iv_len</tt> directly followed by the sequence number key
of length <tt>sdk_sn_key_len</tt>.</t>
            </dd>
          </dl>
          <t>This socket option can only be used on SCTP endpoints in states other than
<tt>SCTP_LISTEN</tt>, <tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.
If the socket option is successful, all affected DTLS chunks sent will use the
specified keys until the keys are changed again by another call of this
socket option.</t>
        </section>
        <section anchor="add-receive-keys-sctpdtlsaddrecvkeys">
          <name>Add Receive Keys (<tt>SCTP_DTLS_ADD_RECV_KEYS</tt>)</name>
          <t>Using this socket option allows to add a particular set of keys used for
receiving DTLS chunks.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_keys {
        sctp_assoc_t sdk_assoc_id;
        uint8_t sdk_cipher_suite[2];
        uint16_t sdk_restart;
        uint64_t sdk_epoch;
        uint16_t sdk_key_len;
        uint16_t sdk_iv_len;
        uint16_t sdk_sn_key_len;
        uint16_t sdk_unused;
        uint8_t sdk_keys[];
};
]]></sourcecode>
          <dl>
            <dt><tt>sdk_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdk_cipher_suite</tt>:</dt>
            <dd>
              <t>The cipher suite for which the keys are used.</t>
            </dd>
            <dt><tt>sdk_restart</tt>:</dt>
            <dd>
              <t>If the value is <tt>0</tt>, the regular keys are added, if a value different
from <tt>0</tt> is used, the restart keys are added.</t>
            </dd>
            <dt><tt>sdk_unused</tt>:</dt>
            <dd>
              <t>This field is ignored.</t>
            </dd>
            <dt><tt>sdk_epoch</tt>:</dt>
            <dd>
              <t>The epoch for which the keys are added.</t>
            </dd>
            <dt><tt>sdk_key_len</tt>:</dt>
            <dd>
              <t>The length of the key specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_iv_len</tt>:</dt>
            <dd>
              <t>The length of the initialization vector specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_sn_key_len</tt>:</dt>
            <dd>
              <t>The length of the sequence number key specified in <tt>sdk_keys</tt>.</t>
            </dd>
            <dt><tt>sdk_keys</tt>:</dt>
            <dd>
              <t>The key of length <tt>sdk_key_len</tt> directly followed by the initialization
vector of length <tt>sdk_iv_len</tt> directly followed by the sequence number key
of length <tt>sdk_sn_key_len</tt>.</t>
            </dd>
          </dl>
          <t>This socket option can only be used on SCTP endpoints in states other than
<tt>SCTP_LISTEN</tt>, <tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="delete-receive-keys-sctpdtlsdelrecvkeys">
          <name>Delete Receive Keys (<tt>SCTP_DTLS_DEL_RECV_KEYS</tt>)</name>
          <t>Using this socket option allows to remove a particular set of keys used for
receiving DTLS chunks.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_keys_id {
   sctp_assoc_t sdki_assoc_id;
   uint32_t sdki_restart;
   uint64_t sdki_epoch;
}
]]></sourcecode>
          <dl>
            <dt><tt>sdki_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sdki_restart</tt>:</dt>
            <dd>
              <t>If the value is <tt>0</tt>, the regular keys are removed, if a value different
from <tt>0</tt> is used, the restart keys are removed.</t>
            </dd>
            <dt><tt>sdki_epoch</tt>:</dt>
            <dd>
              <t>The epoch for which the keys are removed.</t>
            </dd>
          </dl>
          <t>This socket option can only be used on SCTP endpoints in states other than
<tt>SCTP_CLOSED</tt>, <tt>SCTP_LISTEN</tt>, <tt>SCTP_COOKIE_WAIT</tt> and
<tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="get-or-set-protection-enforcement-sctpdtlsenforceprotection">
          <name>Get or Set Protection Enforcement (<tt>SCTP_DTLS_ENFORCE_PROTECTION</tt>)</name>
          <t>Enabling this socket option on an SCTP endpoint enforces that received
SCTP packets are only processed, if they are protected.
All received packets with the first chunk not being an INIT chunk, INIT ACK
chunk, or DTLS chunk will be silently discarded.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_assoc_value {
   sctp_assoc_t assoc_id;
   uint32_t assoc_value;
};
]]></sourcecode>
          <dl>
            <dt><tt>assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
          </dl>
          <t><tt>assoc_value</tt>:
  The value <tt>0</tt> represents that the option is off, any other value represents
  that the option is on.</t>
          <t>This socket option is off by default on any SCTP endpoint.
Once protection has been enforced by enabling this socket option on an
SCTP endpoint, it cannot be disabled again.
Whether protection has been enforced on an SCTP endpoint can be queried
in any state other than <tt>SCTP_CLOSED</tt>.
Protection can be enforced in any state other than <tt>SCTP_CLOSED</tt>,
<tt>SCTP_COOKIE_WAIT</tt> and <tt>SCTP_COOKIE_ECHOED</tt>.</t>
        </section>
        <section anchor="get-statistic-counters-sctpdtlsgetstats">
          <name>Get Statistic Counters (<tt>SCTP_DTLS_GET_STATS</tt>)</name>
          <t>This socket options allows to get various statistic counters for a
specific SCTP endpoint.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_dtls_stats {
   sctp_assoc_t sds_assoc_id;
   uint64_t sds_dropped_unprotected;
   uint64_t sds_aead_failures;
   uint64_t sds_recv_protected;
   uint64_t sds_sent_protected;
   /* There will be added more fields before the WGLC. */
   /* There might be additional platform specific counters. */
};
]]></sourcecode>
          <dl>
            <dt><tt>sds_assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{FUTURE|CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
            <dt><tt>sds_dropped_unprotected</tt>:</dt>
            <dd>
              <t>The number of unprotected packets received for this SCTP endpoint after
protection was enforced.</t>
            </dd>
            <dt><tt>sds_aead_failures</tt>:</dt>
            <dd>
              <t>The number of AEAD failures when processing received DTLS chunks.</t>
            </dd>
            <dt><tt>sds_recv_protected</tt>:</dt>
            <dd>
              <t>The number of DTLS chunks successfully processed.</t>
            </dd>
            <dt><tt>sds_sent_protected</tt>:</dt>
            <dd>
              <t>The number of DTLS chunks sent.</t>
            </dd>
          </dl>
        </section>
        <section anchor="get-or-set-the-replay-protection-window-size-sctpdtlsreplaywindow">
          <name>Get or Set the Replay Protection Window Size (<tt>SCTP_DTLS_REPLAY_WINDOW</tt>)</name>
          <t>This socket option can be used to configure the replay protection for SCTP
endpoints.</t>
          <t>The following structure is used as the <tt>option_value</tt>:</t>
          <sourcecode type="c"><![CDATA[
struct sctp_assoc_value {
   sctp_assoc_t assoc_id;
   uint32_t assoc_value;
};
]]></sourcecode>
          <dl>
            <dt><tt>assoc_id</tt>:</dt>
            <dd>
              <t>This parameter is ignored for one-to-one style sockets.
For one-to-many style sockets, this parameter indicates upon which
SCTP association the caller is performing the action.
It is an error to use <tt>SCTP_{CURRENT|ALL}_ASSOC</tt>.</t>
            </dd>
          </dl>
          <t><tt>assoc_value</tt>:
  The maximum number of DTLS chunks in the replay protection window.</t>
        </section>
      </section>
    </section>
    <section anchor="IANA-Consideration">
      <name>IANA Considerations</name>
      <t>This document adds registry entries or registries in the Stream Control
Transmission Protocol (SCTP) Parameters group handled by IANA:</t>
      <ul spacing="normal">
        <li>
          <t>One new registry for the Key Management IDs</t>
        </li>
        <li>
          <t>One new SCTP Chunk Types and its corresponding Chunk Type Flags registry</t>
        </li>
        <li>
          <t>One new SCTP Chunk Parameter Type</t>
        </li>
        <li>
          <t>Two new SCTP Error Cause Codes</t>
        </li>
        <li>
          <t>A new Payload Protocol Identifier</t>
        </li>
      </ul>
      <section anchor="IANA-Protection-Solution-ID">
        <name>DTLS Key Management Method Identifiers</name>
        <t>Note: The RFC Editor is requested to replace RFC-To-Be with a reference to this document.</t>
        <t>IANA is requested to create a new registry called "DTLS Key Management Method".
This registry is part of the Stream Control Transmission Protocol (SCTP)
Parameters grouping.</t>
        <t>The purpose of this registry is to assign DTLS Key Management Method
Identifier for any DTLS Key Management Method used for the extension described
in this document.
Each entry will be assigned an 8-bit unsigned integer value from the suitable range.</t>
        <table anchor="iana-psi">
          <name>DTLS Key Management Method Identifiers</name>
          <thead>
            <tr>
              <th align="right">Identifier</th>
              <th align="left">Key Management Method Name</th>
              <th align="left">Reference</th>
              <th align="left">Contact</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">0</td>
              <td align="left">DTLS Chunk with Pre-shared cryptographic parameters</td>
              <td align="left">RFC-To-Be</td>
              <td align="left">Draft Authors</td>
            </tr>
            <tr>
              <td align="right">1-191</td>
              <td align="left">Available for Assignment using Specification Required policy</td>
              <td align="left"> </td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">192-254</td>
              <td align="left">Available for Assignment using First Come, First Served policy</td>
              <td align="left"> </td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">255</td>
              <td align="left">Reserved for extension of the identifier space</td>
              <td align="left"> </td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>New entries in the range 1-191 are registered following the Specification Required policy
as defined by <xref target="RFC8126"/>.  New entries in the range 192-254 are first come, first served with
expert review. The expert reviewers' primary purpose is to ensure that the registration is
relevant and not performed to consume the number space.</t>
      </section>
      <section anchor="sctp-chunk-type">
        <name>SCTP Chunk Type</name>
        <t>In the Stream Control Transmission Protocol (SCTP) Parameters group's
"Chunk Types" registry, IANA is requested to update the reference for the
DTLS chunk as depicted in <xref target="iana-chunk-types"/> with a reference to this
document.</t>
        <table anchor="iana-chunk-types">
          <name>DTLS Chunk Type</name>
          <thead>
            <tr>
              <th align="right">ID Value</th>
              <th align="left">Chunk Type</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">0x41</td>
              <td align="left">DTLS Chunk (DTLS)</td>
              <td align="left">RFC-To-Be</td>
            </tr>
          </tbody>
        </table>
        <t>IANA is requested to add the corresponding registration table for the chunk
flags of the DTLS chunk with the initial contents shown in <xref target="iana-chunk-flags"/>:</t>
        <table anchor="iana-chunk-flags">
          <name>DTLS Chunk Flags</name>
          <thead>
            <tr>
              <th align="right">Chunk Flag Value</th>
              <th align="left">Chunk Flag Name</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">0x01</td>
              <td align="left">R bit</td>
              <td align="left">RFC-To-Be</td>
            </tr>
            <tr>
              <td align="right">0x02</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x04</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x08</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x10</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x20</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x40</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="right">0x80</td>
              <td align="left">Unassigned</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
      </section>
      <section anchor="sctp-chunk-parameter-types">
        <name>SCTP Chunk Parameter Types</name>
        <t>In the Stream Control Transmission Protocol (SCTP) Parameters group's
"Chunk Parameter Types" registry, IANA is requested to update the reference for
the DTLS Key Management as depicted in <xref target="iana-chunk-parameter-types"/> with a
reference to this document.</t>
        <table anchor="iana-chunk-parameter-types">
          <name>DTLS Key Management Chunk Parameter</name>
          <thead>
            <tr>
              <th align="right">ID Value</th>
              <th align="left">Chunk Parameter Type</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">0x8006</td>
              <td align="left">DTLS Key Management</td>
              <td align="left">RFC-To-Be</td>
            </tr>
          </tbody>
        </table>
      </section>
      <section anchor="IANA-Extra-Cause">
        <name>SCTP Error Cause Codes</name>
        <t>In the Stream Control Transmission Protocol (SCTP) Parameters group's
"Error Cause Codes" registry, IANA is requested to add the new
entries depicted below in <xref target="iana-error-cause-codes"/> with a
reference to this document.</t>
        <table anchor="iana-error-cause-codes">
          <name>Error Cause Codes</name>
          <thead>
            <tr>
              <th align="right">ID Value</th>
              <th align="left">Error Cause Codes</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">100 (TBC)</td>
              <td align="left">Missing DTLS Chunk Support</td>
              <td align="left">RFC-To-Be</td>
            </tr>
            <tr>
              <td align="right">101 (TBC)</td>
              <td align="left">No Common DTLS Key Management Method</td>
              <td align="left">RFC-To-Be</td>
            </tr>
            <tr>
              <td align="right">102 (TBC)</td>
              <td align="left">DTLS Key Management Tie Breaker Collision</td>
              <td align="left">RFC-To-Be</td>
            </tr>
            <tr>
              <td align="right">103 (TBC)</td>
              <td align="left">Incompatible DTLS Key Management Roles</td>
              <td align="left">RFC-To-Be</td>
            </tr>
          </tbody>
        </table>
        <t>The suggested cause code will need to be confirmed by IANA.</t>
      </section>
      <section anchor="sec-iana-ppid">
        <name>SCTP Payload Protocol Identifier</name>
        <t>In the Stream Control Transmission Protocol (SCTP) Parameters group's
"Payload Protocol Identifiers" registry, IANA is requested to update the
reference for the PPID 4242 as depicted in <xref target="iana-payload-protection-id"/> with a
reference to this document.</t>
        <table anchor="iana-payload-protection-id">
          <name>Protection Operator Protocol Identifier Registered</name>
          <thead>
            <tr>
              <th align="right">ID Value</th>
              <th align="left">SCTP Payload Protocol Identifier</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="right">4242</td>
              <td align="left">DTLS Key Management Messages</td>
              <td align="left">RFC-To-Be</td>
            </tr>
          </tbody>
        </table>
      </section>
    </section>
    <section anchor="Security-Considerations">
      <name>Security Considerations</name>
      <t>All the security and privacy considerations of the security protocol
used as the Chunk Protection Operator apply.</t>
      <t>DTLS replay protection MUST NOT be turned off.</t>
      <section anchor="privacy-considerations">
        <name>Privacy Considerations</name>
        <t>Use of the SCTP DTLS chunk provides privacy to SCTP by protecting user
data and much of the SCTP control signaling. The SCTP association is
identifiable based on the 5-tuple where the destination IP and
port and VTag are fixed for each direction. Advanced privacy features such
as sequence number encryption might
therefore have limited effect.</t>
      </section>
      <section anchor="aead-limit-considerations">
        <name>AEAD Limit Considerations</name>
        <t><xref section="4.5.3" sectionFormat="of" target="RFC9147"/> defines limits on the number of records
q that can be protected using the same key as well as limits on the
number of received packets v that fail authentication with each key.
To adhere to these limits the DTLS Key Management Method can
periodically poll the DTLS protection operation function to see
when a limit has been reached or is close to being reached.
Instead of periodic polling, a callback can be used.</t>
      </section>
      <section anchor="Downgrade-Attacks">
        <name>Downgrade Attacks</name>
        <t>Downgrade attacks may attempt to force the DTLS Key Management Method
by altering the content of INIT chunk, for instance by removing
all offered DTLS Key Management Methods but the one desired. This is possible
if the attacker is an on-path attacker that can modify packets
because INIT and INIT ACK chunks are plain text.</t>
        <t>Preventing the downgrade attacks is implemented by using the content
of the DTLS Key Management Parameter sent in the INIT chunk plus the
content of the DTLS Key Management Parameter received in the INIT ACK
chunk from the responder for deriving the keys from the handshake
secrets obtained during the DTLS initial handshake. Using the whole
content of the parameters ensures that the role selection and thus the
method selection isn't possible to manipulate.</t>
        <t>If the attacker succeeds in changing the DTLS Key Management Parameter
in either INIT, INIT ACK or both chunks, the peers will not be able to
derive the same keys and the association will fail to complete.  Any
modification will result in association failure, thus preventing
down-grade.</t>
        <t>In case any DTLS Key Management Method does not include the parameter
content in its key-derivation down-grade would be possible if that
DTLS Key Management Method is selected. It is up to endpoint policies
to determine what level of protection it deems necessary against
down-grade attacks.</t>
      </section>
      <section anchor="sec-consideration-storage">
        <name>Persistent Secure Storage of Restart Key Context</name>
        <t>The restart DTLS key context needs to be stored securely and persistently. Securely
as access to this security context may enable an attacker to perform a restart,
resulting in a denial of service on the existing SCTP association. It can also
give the attacker access to the ULP. Thus the storage needs to provide at least
as strong resistance against exfiltration as the main DTLS key context store.</t>
        <t>How to realize persistent storage is highly dependent on the ULP and
how it utilizes restarted SCTP associations.  One way can be to have
an actual secure persistent storage solution accessible to the
endpoint. In other use cases the persistence part might be
accomplished by keeping the current restart DTLS key context with the
ULP State if that is sufficiently secure.</t>
      </section>
    </section>
    <section anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors thank Hannes Tschofenig and Tirumaleswar Reddy for their
participation in the design team and their contributions to this document.
We also like to thank Xin Long for his contributions to this document and
Amanda Baber with IANA for feedback on our IANA registry.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC4820" target="https://www.rfc-editor.org/info/rfc4820" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.4820.xml">
          <front>
            <title>Padding Chunk and Parameter for the Stream Control Transmission Protocol (SCTP)</title>
            <author fullname="M. Tuexen" initials="M." surname="Tuexen"/>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="P. Lei" initials="P." surname="Lei"/>
            <date month="March" year="2007"/>
            <abstract>
              <t>This document defines a padding chunk and a padding parameter and describes the required receiver side procedures. The padding chunk is used to pad a Stream Control Transmission Protocol (SCTP) packet to an arbitrary size. The padding parameter is used to pad an SCTP INIT chunk to an arbitrary size. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4820"/>
          <seriesInfo name="DOI" value="10.17487/RFC4820"/>
        </reference>
        <reference anchor="RFC4895" target="https://www.rfc-editor.org/info/rfc4895" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.4895.xml">
          <front>
            <title>Authenticated Chunks for the Stream Control Transmission Protocol (SCTP)</title>
            <author fullname="M. Tuexen" initials="M." surname="Tuexen"/>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="P. Lei" initials="P." surname="Lei"/>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2007"/>
            <abstract>
              <t>This document describes a new chunk type, several parameters, and procedures for the Stream Control Transmission Protocol (SCTP). This new chunk type can be used to authenticate SCTP chunks by using shared keys between the sender and receiver. The new parameters are used to establish the shared keys. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4895"/>
          <seriesInfo name="DOI" value="10.17487/RFC4895"/>
        </reference>
        <reference anchor="RFC5061" target="https://www.rfc-editor.org/info/rfc5061" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.5061.xml">
          <front>
            <title>Stream Control Transmission Protocol (SCTP) Dynamic Address Reconfiguration</title>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="Q. Xie" initials="Q." surname="Xie"/>
            <author fullname="M. Tuexen" initials="M." surname="Tuexen"/>
            <author fullname="S. Maruyama" initials="S." surname="Maruyama"/>
            <author fullname="M. Kozuka" initials="M." surname="Kozuka"/>
            <date month="September" year="2007"/>
            <abstract>
              <t>A local host may have multiple points of attachment to the Internet, giving it a degree of fault tolerance from hardware failures. Stream Control Transmission Protocol (SCTP) (RFC 4960) was developed to take full advantage of such a multi-homed host to provide a fast failover and association survivability in the face of such hardware failures. This document describes an extension to SCTP that will allow an SCTP stack to dynamically add an IP address to an SCTP association, dynamically delete an IP address from an SCTP association, and to request to set the primary address the peer will use when sending to an endpoint. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5061"/>
          <seriesInfo name="DOI" value="10.17487/RFC5061"/>
        </reference>
        <reference anchor="RFC8126" target="https://www.rfc-editor.org/info/rfc8126" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8126.xml">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton"/>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <author fullname="T. Narten" initials="T." surname="Narten"/>
            <date month="June" year="2017"/>
            <abstract>
              <t>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>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>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="RFC9147" target="https://www.rfc-editor.org/info/rfc9147" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9147.xml">
          <front>
            <title>The Datagram Transport Layer Security (DTLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <author fullname="N. Modadugu" initials="N." surname="Modadugu"/>
            <date month="April" year="2022"/>
            <abstract>
              <t>This document specifies version 1.3 of the Datagram Transport Layer Security (DTLS) protocol. DTLS 1.3 allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>The DTLS 1.3 protocol is based on the Transport Layer Security (TLS) 1.3 protocol and provides equivalent security guarantees with the exception of order protection / non-replayability. Datagram semantics of the underlying transport are preserved by the DTLS protocol.</t>
              <t>This document obsoletes RFC 6347.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9147"/>
          <seriesInfo name="DOI" value="10.17487/RFC9147"/>
        </reference>
        <reference anchor="RFC9260" target="https://www.rfc-editor.org/info/rfc9260" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9260.xml">
          <front>
            <title>Stream Control Transmission Protocol</title>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="M. Tüxen" initials="M." surname="Tüxen"/>
            <author fullname="K. Nielsen" initials="K." surname="Nielsen"/>
            <date month="June" year="2022"/>
            <abstract>
              <t>This document describes the Stream Control Transmission Protocol (SCTP) and obsoletes RFC 4960. It incorporates the specification of the chunk flags registry from RFC 6096 and the specification of the I bit of DATA chunks from RFC 7053. Therefore, RFCs 6096 and 7053 are also obsoleted by this document. In addition, RFCs 4460 and 8540, which describe errata for SCTP, are obsoleted by this document.</t>
              <t>SCTP was originally designed to transport Public Switched Telephone Network (PSTN) signaling messages over IP networks. It is also suited to be used for other applications, for example, WebRTC.</t>
              <t>SCTP is a reliable transport protocol operating on top of a connectionless packet network, such as IP. It offers the following services to its users:</t>
              <t>The design of SCTP includes appropriate congestion avoidance behavior and resistance to flooding and masquerade attacks.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9260"/>
          <seriesInfo name="DOI" value="10.17487/RFC9260"/>
        </reference>
        <reference anchor="TLS-CIPHER-SUITES" target="https://www.iana.org/assignments/tls-parameters/tls-parameters.xhtml#tls-parameters-4">
          <front>
            <title>TLS Cipher Suites</title>
            <author>
              <organization/>
            </author>
            <date year="2023" month="November"/>
          </front>
        </reference>
        <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>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="RFC8174" target="https://www.rfc-editor.org/info/rfc8174" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC6083" target="https://www.rfc-editor.org/info/rfc6083" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6083.xml">
          <front>
            <title>Datagram Transport Layer Security (DTLS) for Stream Control Transmission Protocol (SCTP)</title>
            <author fullname="M. Tuexen" initials="M." surname="Tuexen"/>
            <author fullname="R. Seggelmann" initials="R." surname="Seggelmann"/>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="January" year="2011"/>
            <abstract>
              <t>This document describes the usage of the Datagram Transport Layer Security (DTLS) protocol over the Stream Control Transmission Protocol (SCTP).</t>
              <t>DTLS over SCTP provides communications privacy for applications that use SCTP as their transport protocol and allows client/server applications to communicate in a way that is designed to prevent eavesdropping and detect tampering or message forgery.</t>
              <t>Applications using DTLS over SCTP can use almost all transport features provided by SCTP and its extensions. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6083"/>
          <seriesInfo name="DOI" value="10.17487/RFC6083"/>
        </reference>
        <reference anchor="RFC6458" target="https://www.rfc-editor.org/info/rfc6458" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6458.xml">
          <front>
            <title>Sockets API Extensions for the Stream Control Transmission Protocol (SCTP)</title>
            <author fullname="R. Stewart" initials="R." surname="Stewart"/>
            <author fullname="M. Tuexen" initials="M." surname="Tuexen"/>
            <author fullname="K. Poon" initials="K." surname="Poon"/>
            <author fullname="P. Lei" initials="P." surname="Lei"/>
            <author fullname="V. Yasevich" initials="V." surname="Yasevich"/>
            <date month="December" year="2011"/>
            <abstract>
              <t>This document describes a mapping of the Stream Control Transmission Protocol (SCTP) into a sockets API. The benefits of this mapping include compatibility for TCP applications, access to new SCTP features, and a consolidated error and event notification scheme. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6458"/>
          <seriesInfo name="DOI" value="10.17487/RFC6458"/>
        </reference>
        <reference anchor="RFC8446" target="https://www.rfc-editor.org/info/rfc8446" xml:base="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8446.xml">
          <front>
            <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2018"/>
            <abstract>
              <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8446"/>
          <seriesInfo name="DOI" value="10.17487/RFC8446"/>
        </reference>
        <reference anchor="I-D.ietf-tsvwg-rfc4895-bis" target="https://datatracker.ietf.org/doc/html/draft-ietf-tsvwg-rfc4895-bis-05" xml:base="https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-tsvwg-rfc4895-bis.xml">
          <front>
            <title>Authenticated Chunks for the Stream Control Transmission Protocol (SCTP)</title>
            <author fullname="Michael Tüxen" initials="M." surname="Tüxen">
              <organization>Münster Univ. of Applied Sciences</organization>
            </author>
            <author fullname="Randall R. Stewart" initials="R. R." surname="Stewart"/>
            <author fullname="Peter Lei" initials="P." surname="Lei">
              <organization>Netflix, Inc.</organization>
            </author>
            <author fullname="Hannes Tschofenig" initials="H." surname="Tschofenig"/>
            <date day="21" month="April" year="2025"/>
            <abstract>
              <t>This document describes a new chunk type, several parameters, and procedures for the Stream Control Transmission Protocol (SCTP). This new chunk type can be used to authenticate SCTP chunks by using shared keys between the sender and receiver. The new parameters are used to establish the shared keys. This document obsoletes RFC 4895.</t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-rfc4895-bis-05"/>
        </reference>
        <reference anchor="I-D.ietf-tsvwg-dtls-chunk-key-management" target="https://datatracker.ietf.org/doc/html/draft-ietf-tsvwg-dtls-chunk-key-management-01" xml:base="https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-tsvwg-dtls-chunk-key-management.xml">
          <front>
            <title>Using Datagram Transport Layer Security (DTLS) for Key Management for the Stream Control Transmission Protocol (SCTP) DTLS Chunk</title>
            <author fullname="Michael Tüxen" initials="M." surname="Tüxen">
              <organization>Münster University of Applied Sciences</organization>
            </author>
            <author fullname="Hannes Tschofenig" initials="H." surname="Tschofenig">
              <organization>University of Applied Sciences Bonn-Rhein-Sieg</organization>
            </author>
            <author fullname="Tirumaleswar Reddy.K" initials="T." surname="Reddy.K">
              <organization>Nokia</organization>
            </author>
            <date day="2" month="March" year="2026"/>
            <abstract>
              <t>This document defines how Datagram Transport Layer Security (DTLS) 1.3 is used to establish keys for securing SCTP using the DTLS Chunk mechanism. It specifies how a DTLS handshake is used to establish the initial security context for an SCTP association and describes procedures for key updates and post-handshake authentication. The goal is to enable authenticated, and confidential communication over SCTP using the DTLS Chunk, leveraging standardized DTLS features for key management and rekeying.</t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-dtls-chunk-key-management-01"/>
        </reference>
        <reference anchor="I-D.westerlund-tsvwg-sctp-DTLS-handshake" target="https://datatracker.ietf.org/doc/draft-westerlund-tsvwg-sctp-dtls-handshake/">
          <front>
            <title>Datagram Transport Layer Security (DTLS) in the Stream Control Transmission Protocol (SCTP) DTLS Chunk</title>
            <author initials="M." surname="Westerlund" fullname="Magnus Westerlund">
              <organization>Ericsson</organization>
            </author>
            <author initials="J." surname="Preuß Mattsson" fullname="John Preuß Mattsson">
              <organization>Ericsson</organization>
            </author>
            <author initials="C." surname="Porfiri" fullname="Claudio Porfiri">
              <organization>Ericsson</organization>
            </author>
            <date year="2025" month="July"/>
          </front>
        </reference>
        <reference anchor="ETSI-TS-38.413" target="https://www.etsi.org/deliver/etsi_ts/138400_138499/138413/18.05.00_60/ts_138413v180500p.pdf">
          <front>
            <title>NG Application Protocol (NGAP) version 18.5.0 Release 18</title>
            <author>
              <organization/>
            </author>
            <date year="2025" month="March"/>
          </front>
        </reference>
      </references>
    </references>
  </back>
  <!-- ##markdown-source:
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
I8wAy0n0Q9lzWfIXVjUfmf8PZGk/GuY0AQA=

-->

</rfc>
