<?xml version='1.0' encoding='UTF-8'?>

<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>

<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-opsawg-ipfix-tcpo-v6eh-18" number="9740" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3" xml:lang="en" obsoletes="" updates="" >

  <front>
    <title abbrev="New TCP and IPv6 EH IPFIX IEs">New IPFIX Information Elements for TCP Options and IPv6 Extension Headers</title>
    <seriesInfo name="RFC" value="9740"/>
    <author fullname="Mohamed Boucadair" initials="M." surname="Boucadair">
      <organization>Orange</organization>
      <address>
        <email>mohamed.boucadair@orange.com</email>
      </address>
    </author>
    <author fullname="Benoit Claise" initials="B." surname="Claise">
      <organization>Huawei</organization>
      <address>
        <email>benoit.claise@huawei.com</email>
      </address>
    </author>
    <date year="2025" month="March"/>
    <area>OPS</area>
    <workgroup>opsawg</workgroup>
    <keyword>IPFIX</keyword>

    <abstract>

<t>This document specifies new IP Flow Information Export (IPFIX) Information Elements (IEs) to solve issues with existing ipv6ExtensionHeaders and tcpOptions IPFIX IEs, especially the ability to export any observed IPv6 extension headers or TCP options.</t>
    </abstract>
  </front>
  <middle>

<section anchor="introduction">
      <name>Introduction</name>
      <t>This document specifies new IP Flow Information Export (IPFIX) <xref target="RFC7011"/> Information Elements (IEs) to solve a set of issues encountered with the specifications of two IEs -- ipv6ExtensionHeaders (to export IPv6 extension headers) and tcpOptions (to export TCP options) <xref target="IANA-IPFIX"/>. More details about these issues are provided in the following subsections.</t>
      <t>This document deprecates the ipv6ExtensionHeaders and tcpOptions IPFIX IEs that were initially defined in <xref target="RFC5102"/>.</t>

          <t indent="3">Note that <xref target="RFC7012"/> obsoletes <xref target="RFC5102"/> and specifies that <xref target="IANA-IPFIX"/> is the normative reference for these IEs.</t>

      <section anchor="sec-eh-issues">
        <name>Issues with ipv6ExtensionHeaders Information Element</name>
        <t>The specification of the ipv6ExtensionHeaders IPFIX IE (64) does not:</t>
        <ul spacing="normal">
          <li>
            <t>Cover the full extension headers' range defined in the IPv6 specification (<xref section="4" sectionFormat="of" target="RFC8200"/>).</t>
          </li>
          <li>
            <t>Specify the procedure to follow when all bits are exhausted.</t>
          </li>
          <li>
            <t>Specify a means to export the order and the number of occurrences of a given extension header.</t>
          </li>
          <li>
            <t>Specify how to automatically update the IANA IPFIX registry <xref target="IANA-IPFIX"/> when a new value is assigned in the IPv6 Extension Header Types registry <xref target="IANA-EH"/>. Only a frozen set of extension headers can be exported using the ipv6ExtensionHeaders IE. For example, the ipv6ExtensionHeaders IE can't report some IPv6 EHs, specifically EHs for the Host Identity Protocol (139), Shim6 Protocol (140), or extension headers for experimentation and testing.</t>
          </li>
          <li>
            <t>Specify whether the exported values match the full enclosed values or only up to a limit imposed by hardware or software (e.g., <xref section="1.1" sectionFormat="of" target="RFC8883"/>). Note that some implementations may not be able to export all observed extension headers in a Flow because of a hardware or software limit (see, e.g., <xref target="I-D.ietf-6man-eh-limits"/>).</t>
	  </li>
	  <li>
	    <t>Discuss whether it covers all enclosed extension headers or only up to a limit.</t>
          </li>
          <li>
            <t>Specify how to report the length of IPv6 extension headers.</t>
          </li>
          <li>
            <t>Optimize the encoding.</t>
          </li>
          <li>
            <t>Explain the reasoning for reporting values that do not correspond to extension headers (e.g., "Unknown Layer 4 header" or "Payload compression header").</t>
          </li>
          <li>
            <t>Specify how to report extension header chains or aggregate lengths of extension headers.</t>
          </li>
        </ul>
        <t><xref target="sec-eh"/> addresses these issues.</t>
        <t>This specification deprecates the ipv6ExtensionHeaders IPFIX IE in favor of the new IEs defined in this document.</t>
      </section>
      <section anchor="sec-tcp-issues">
        <name>Issues with tcpOptions Information Element</name>
        <t>The specification of the tcpOptions IPFIX IE (209) does not:</t>
        <ul spacing="normal">
          <li>
            <t>Describe how some observed TCP options in a Flow can be exported using IPFIX. Only TCP options having a Kind &lt;= 63 can be exported in a tcpOptions IE.</t>
          </li>
          <li>
            <t>Allow reporting the observed Experiment Identifiers (ExIDs) that are carried in shared Experimental TCP options (Kind=253 or 254) <xref target="RFC6994"/>.</t>
          </li>
          <li>
            <t>Optimize the encoding.</t>
          </li>
        </ul>
        <t><xref target="sec-tcp"/> addresses these issues.</t>
        <t>This specification deprecates the tcpOptions IE in favor of the new IEs defined in this document.</t>
      </section>
    </section>
    <section anchor="conventions-and-definitions">
      <name>Conventions and Definitions</name>
        <t>
    The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>",
    "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL NOT</bcp14>",
    "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>",
    "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
    "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be
    interpreted as described in BCP&nbsp;14 <xref target="RFC2119"/> <xref
    target="RFC8174"/> when, and only when, they appear in all capitals, as
    shown here.
        </t>
<t>This document uses the IPFIX-specific terminology (Information Element, Template Record,
   Flow, etc.) defined in
   <xref section="2" sectionFormat="of" target="RFC7011"/>. As in the base IPFIX specification <xref target="RFC7011"/>, these IPFIX-specific terms
   have the first letter of a word capitalized.</t>
      <t>Also, the document uses the terms defined in the IPv6 <xref target="RFC8200"/> and TCP <xref target="RFC9293"/> specifications.</t>
      <t>In addition, the document makes use of the following terms:</t>
      <dl spacing="normal" newline="false">
        <dt>Extension header chain:</dt>
        <dd>
          <t>Refers to the chain of extension headers that are present in an IPv6 packet.</t>
          <t>This term should not be confused with the IPv6 header chain,
          which includes the IPv6 header, zero or more IPv6 extension headers,
          and zero or a single Upper-Layer Header.</t>
        </dd>
        <dt>Flow with varying extension header chains:</dt>
        <dd>
          <t>Refers to a Flow where distinct extension header chains are
          observed. Concretely, different packets in such a Flow will have a
          different sequence of extension header type codes.</t>
        </dd>
      </dl>
    </section>
    <section anchor="sec-eh">
      <name>Information Elements for IPv6 Extension Headers</name>
      <section anchor="sec-v6ehtype">
        <name>ipv6ExtensionHeaderType Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeaderType</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>513</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Type of an IPv6 extension header observed in at least one packet of this Flow.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned8</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>identifier</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "IPv6 Extension Header Types" registry at <xref target="IANA-EH"/>.</t>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for
            the general definition of IPv6 extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6ehcount">
        <name>ipv6ExtensionHeaderCount Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeaderCount</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>514</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>The number of consecutive occurrences of the same extension header type in a Flow.</t>
            <t>This IE is reported, e.g., in the ipv6ExtensionHeaderTypeCountList IE.</t>
            <t>The type of the extension header is provided in the ipv6ExtensionHeaderType IE.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned8</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>totalCounter</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "IPv6 Extension Header Types" registry at <xref target="IANA-EH"/>.</t>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for
            the general definition of IPv6 extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6full">
        <name>ipv6ExtensionHeadersFull Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeadersFull</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>515</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>IPv6 extension headers observed in packets of this Flow. The
            information is encoded in a set of bit fields.  For each IPv6
            extension header, there is a bit in this set. The bit is set to 1
            if any observed packet of this Flow contains the corresponding
            IPv6 extension header.  Otherwise, if no observed packet of this
            Flow contains the respective IPv6 extension header, the value of
            the corresponding bit is 0.</t>
            <t>The IPv6 extension header associated with each bit is provided
            in <xref target="IANA-IPFIX-IPv6EH"/>. Bit 0 corresponds to the
            least significant bit (LSB) in the ipv6ExtensionHeadersFull IE, while bit
            255 corresponds to the most significant bit (MSB) of the IE.  In doing
            so, few octets will be needed to encode common IPv6 extension
            headers when observed in a Flow.</t>
            <t>The "No Next Header" (bit 2) value (<xref section="4.7"
            sectionFormat="of" target="RFC8200"/>) is used if there is no
            upper-layer header in an IPv6 packet.  Even if the value is not
            considered as an extension header as such, the corresponding bit
            is set in the ipv6ExtensionHeadersFull IE whenever that value is
            encountered in the Flow.</t>
            <t>Extension headers observed in a Flow with varying extension
            header chains <bcp14>MUST NOT</bcp14> be grouped in the
            ipv6ExtensionHeadersFull IE if the
            ipv6ExtensionHeaderChainLengthList IE is also present.</t>
            <t>If the ipv6ExtensionHeaderChainLengthList IE is not present,
            then extension headers observed in a Flow with varying extension
            header chains <bcp14>MAY</bcp14> be grouped in one single
            ipv6ExtensionHeadersFull IE or be exported in separate
            ipv6ExtensionHeadersFull IEs, one for each extension header
            chain.</t>
            <t>The ipv6ExtensionHeadersFull IE <bcp14>MUST NOT</bcp14> be
            exported if ipv6ExtensionHeaderTypeCountList IE is also present
            because of the overlapping scopes of these two IEs.</t>
            <t>The value of ipv6ExtensionHeadersFull IE may be encoded in
            fewer octets per the guidelines in <xref section="6.2"
            sectionFormat="of" target="RFC7011"/>.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned256</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>flags</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "IPFIX ipv6ExtensionHeaders Bits" registry at <xref target="IANA-IPFIX-IPv6EH"/>.</t>
            <t>See the "IPv6 Extension Header Types" registry at <xref target="IANA-EH"/>.</t>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for
            the general definition of IPv6 extension headers.</t>
            <t>The ipv6ExtensionHeadersFull IE deprecates the
            ipv6ExtensionHeaders IE (64) that was initially defined in <xref
            target="RFC5102"/>.</t>
            <t><xref target="RFC7012"/> obsoletes <xref target="RFC5102"/> and
            specifies that <xref target="IANA-IPFIX"/> is the normative
            reference for the ipv6ExtensionHeaders IE (64).</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6count">
        <name>ipv6ExtensionHeaderTypeCountList Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeaderTypeCountList</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>516</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>As per <xref section="4.1" sectionFormat="of"
            target="RFC8200"/>, IPv6 nodes must accept and attempt to process
            extension headers occurring any number of times in the same
            packet. This IE echoes the order of extension headers and number
            of consecutive occurrences of the same extension header type in a
            Flow.</t>
            <t>This IE is a subTemplateList of ipv6ExtensionHeaderType and
            ipv6ExtensionHeaderCount IEs.</t>
            <t>Each header chain in a Flow with varying extension header chains
            <bcp14>MUST</bcp14> be exported in a separate IE.</t>
            <t>The same extension header type may appear several times in an
            ipv6ExtensionHeaderTypeCountList IE.  For example, if an IPv6
            packet of a Flow includes a Hop-by-Hop Options header, a
            Destination Options header, a Fragment header, and a Destination
            Options header, the ipv6ExtensionHeaderTypeCountList IE will
            report:</t>
            <ul spacing="normal">
              <li>
                <t>the count of Hop-by-Hop Options headers,</t>
              </li>
              <li>
                <t>the occurrences of the Destination Options headers that are observed before a Fragment header,</t>
              </li>
              <li>
                <t>the occurrences of the Fragment headers, and</t>
              </li>
              <li>
                <t>the occurrences of the Destination Options headers that are observed right after a Fragment header.</t>
              </li>
            </ul>
            <t>If an implementation determines that an observed packet of a
            Flow includes an extension header (including an extension header
            that it does not support), then the exact observed code of that
            extension header <bcp14>MUST</bcp14> be echoed in the
            ipv6ExtensionHeaderTypeCountList IE. How an implementation
            disambiguates between unknown upper-layer protocols vs. extension
            headers is not IPFIX-specific. Refer, for example, to <xref
            section="2.2" sectionFormat="of" target="RFC8883"/> for a behavior
            of an intermediate node that encounters an unknown Next Header
            type.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>subTemplateList</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>list</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "IPv6 Extension Header Types" registry at <xref target="IANA-EH"/>.</t>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for the general definition of IPv6 extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6limit">
        <name>ipv6ExtensionHeadersLimit Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeadersLimit</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>517</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>When set to "false", this IE indicates that the exported
            extension header information (e.g., ipv6ExtensionHeadersFull or
            ipv6ExtensionHeaderTypeCountList) does not match the full enclosed
            extension headers, but only up to a limit that is typically set by
            hardware or software.</t>
            <t>When set to "true", this IE indicates that the exported
            extension header information matches the full enclosed extension
            headers.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>boolean</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>default</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for
            the general definition of IPv6 extension headers.</t>
            <t>See <xref target="RFC8883"/> for an example of IPv6 packet
            processing due to limits on extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6aggr">
        <name>ipv6ExtensionHeadersChainLength Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeadersChainLength</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>518</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>In theory, there are no limits on the number of IPv6 extension
            headers that may be present in a packet other than the path
            MTU. However, it was regularly reported that IPv6 packets with
            extension headers were often dropped in the Internet (e.g., <xref
            target="RFC7872"/>).</t>
            <t>As discussed in <xref section="1.2" sectionFormat="of"
            target="RFC8883"/>, some hardware devices implement a parsing
            buffer of a fixed size to process packets, including all the
            headers.  When the aggregate length of headers of an IPv6 packet
            exceeds that size, the packet will be discarded or deferred to a
            slow path.</t>
            <t>The ipv6ExtensionHeadersChainLength IE is used to report, in
            octets, the length of an extension header chain observed in a
            Flow.  The length is the sum of the lengths of all extension
            headers of the chain. Exporting such information might help
            identifying root causes of performance degradation, including
            packet drops.</t>
            <t>Each header chain length of a Flow with varying extension
            header chains <bcp14>MUST</bcp14> be exported in a separate
            ipv6ExtensionHeadersChainLength IE.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned32</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>identifier</t>
          </dd>
          <dt>Units:</dt>
          <dd>
            <t>octets</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for
            the general definition of IPv6 extension headers.</t>
            <t>See <xref target="RFC9098"/> for an overview of operational
            implications of IPv6 packets with extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-v6chain-list">
        <name>ipv6ExtensionHeaderChainLengthList Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>ipv6ExtensionHeaderChainLengthList</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>519</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>This IE is used to report the chains and their lengths as
            observed in a Flow with varying extension header chains.</t>
            <t>This IE is a subTemplateList of ipv6ExtensionHeadersFull and
            ipv6ExtensionHeadersChainLength IEs.</t>
            <t>If several extension header chains are observed in a Flow, each
            header chain <bcp14>MUST</bcp14> be exported in a separate
            ipv6ExtensionHeaderChainLengthList IE.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>subTemplateList</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>list</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "IPv6 Extension Header Types" registry at <xref target="IANA-EH"/>.</t>
            <t>See <xref section="4" sectionFormat="of" target="RFC8200"/> for the general definition of IPv6 extension headers.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="sec-tcp">
      <name>Information Elements for TCP Options</name>
      <section anchor="sec-tcpfull">
        <name>tcpOptionsFull Information Element</name>
        <t>This section specifies a new IE to cover the full TCP options range.</t>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>tcpOptionsFull</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>520</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>TCP options in packets of this Flow.  The information is
            encoded in a set of bit fields.  For each TCP option, there is a
            bit in this set.  The bit is set to 1 if any observed packet of
            this Flow contains the corresponding TCP option.  Otherwise, if no
            observed packet of this Flow contains the respective TCP option,
            the value of the corresponding bit is 0.</t>
            <t>Options are mapped to bits according to their option numbers.
            TCP option Kind 0 corresponds to the least significant bit in the
            tcpOptionsFull IE, while Kind 255 corresponds to the
            most significant bit of the IE. This approach allows an observer
            to export any observed TCP option even if it does not support that
            option and without requiring updating a mapping table.</t>
            <t>The value of tcpOptionsFull IE may be encoded in fewer octets
            per the guidelines in <xref section="6.2" sectionFormat="of"
            target="RFC7011"/>.</t>
            <t>The presence of tcpSharedOptionExID16List or
            tcpSharedOptionExID32List IEs is an indication that a shared TCP
            option (Kind=253 or 254) is observed in a Flow. The presence of
            tcpSharedOptionExID16List or tcpSharedOptionExID32List IEs takes
            precedence over setting the corresponding bits in the
            tcpOptionsFull IE for the same Flow. In order to optimize the use
            of the reduced-size encoding in the presence of
            tcpSharedOptionExID16List or tcpSharedOptionExID32List IEs, the
            Exporter <bcp14>MUST NOT</bcp14> set to 1 the shared TCP options
            (Kind=253 or 254) of the tcpOptionsFull IE that is reported
            for the same Flow.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned256</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>flags</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "TCP Option Kind Numbers" registry at <xref target="IANA-TCP"/>.</t>
            <t>See <xref target="RFC9293"/> for the general definition of TCP options.</t>
            <t>The tcpOptionsFull IE deprecates the tcpOptions IE (209) that was initially defined in <xref target="RFC5102"/>.</t>
            <t><xref target="RFC7012"/> obsoletes <xref target="RFC5102"/> and specifies that <xref target="IANA-IPFIX"/> is the normative reference for the tcpOptions IE (209).</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-tcpExID16">
        <name>tcpSharedOptionExID16  Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>tcpSharedOptionExID16</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>521</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Reports an observed 2-byte ExID in a shared TCP option
            (Kind=253 or 254) in a Flow.</t>
            <t>A basicList of tcpSharedOptionExID16 is used to report
            tcpSharedOptionExID16List values.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned16</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>identifier</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "TCP Experimental Option Experiment Identifiers (TCP ExIDs)" registry at <xref target="IANA-TCP-ExIDs"/>.</t>
            <t>See <xref target="RFC9293"/> for the general definition of TCP options.</t>
            <t>See <xref target="RFC6994"/> for the shared use of experimental TCP Options.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-tcpExID32">
        <name>tcpSharedOptionExID32 Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>tcpSharedOptionExID32</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>522</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Reports an observed 4-byte ExID in a shared TCP option
            (Kind=253 or 254) in a Flow.</t>
            <t>A basicList of tcpSharedOptionExID32 is used to report tcpSharedOptionExID32List values.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>unsigned32</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>identifier</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "TCP Experimental Option Experiment Identifiers (TCP ExIDs)" registry at <xref target="IANA-TCP-ExIDs"/>.</t>
            <t>See <xref target="RFC9293"/> for the general definition of TCP options.</t>
            <t>See <xref target="RFC6994"/> for the shared use of experimental TCP Options.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-ex">
        <name>tcpSharedOptionExID16List Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>tcpSharedOptionExID16List</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>523</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Reports observed 2-byte ExIDs in shared TCP options (Kind=253
            or 254) in a Flow.</t>
            <t>A basicList of tcpSharedOptionExID16 IEs in which each
            tcpSharedOptionExID16 IE carries an observed 2-byte ExID in a
            shared option.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>basicList</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>list</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "TCP Experimental Option Experiment Identifiers (TCP
            ExIDs)" registry at <xref target="IANA-TCP-ExIDs"/>.</t>
            <t>See <xref target="RFC9293"/> for the general definition of TCP options.</t>
            <t>See <xref target="RFC6994"/> for the shared use of experimental TCP Options.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
      <section anchor="sec-ex32">
        <name>tcpSharedOptionExID32List Information Element</name>
        <dl newline="false">
          <dt>Name:</dt>
          <dd>
            <t>tcpSharedOptionExID32List</t>
          </dd>
          <dt>ElementID:</dt>
          <dd>
            <t>524</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Reports observed 4-byte ExIDs in shared TCP options (Kind=253
            or 254) in a Flow.</t>
            <t>A basicList of tcpSharedOptionExID32 IEs in which each
            tcpSharedOptionExID32 IE carries an observed 4-byte ExID in a
            shared option.</t>
          </dd>
          <dt>Abstract Data Type:</dt>
          <dd>
            <t>basicList</t>
          </dd>
          <dt>Data Type Semantics:</dt>
          <dd>
            <t>list</t>
          </dd>
          <dt>Additional Information:</dt>
          <dd>
            <t>See the "TCP Experimental Option Experiment Identifiers (TCP ExIDs)" registry at <xref target="IANA-TCP-ExIDs"/>.</t>
            <t>See <xref target="RFC9293"/> for the general definition of TCP options.</t>
            <t>See <xref target="RFC6994"/> for the shared use of experimental TCP Options.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC 9740</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="implementation-and-operational-considerations">
      <name>Implementation and Operational Considerations</name>
      <t>Implementations of tcpSharedOptionExID16, tcpSharedOptionExID32, tcpSharedOptionExID16List, and tcpSharedOptionExID32List IEs are assumed to be provided with a list of valid ExIDs <xref target="IANA-TCP-ExIDs"/>. How that list is maintained is implementation-specific. Absent that list, an implementation can't autonomously determine whether an ExID is present and, if so, whether its length is 2 or 4 bytes.</t>
      <t>If a TCP Flow contains packets with a mix of 2-byte and 4-byte ExIDs, the same Template Record is used with both tcpSharedOptionExID16 and tcpSharedOptionExID32 IEs.</t>
    </section>
    <section anchor="sec-examples">
      <name>Examples</name>
      <t>This section provides a few examples to illustrate the use of some IEs defined in this document.</t>
      <section anchor="ipv6-extension-headers">
        <name>IPv6 Extension Headers</name>
        <t><xref target="ex-eh1"/> provides an example of EH/bit mappings in an ipv6ExtensionHeadersFull IE for an IPv6 Flow in which only
the     IPv6 Destination Options (0) header is observed. The bits are set following the table provided in <xref target="sec-initial"/>.</t>

        <figure anchor="ex-eh1">
          <name>Example of EH/Bit Mappings in the ipv6ExtensionHeadersFull IE</name>
          <artwork align="center"><![CDATA[
MSB                                                      LSB
                     1                          25
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 ... 8 9 0 1 2 3 4 5
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...+-+-+-+-+-+-+-+-+
|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|   |0|0|0|0|0|0|0|1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...+-+-+-+-+-+-+-+-+]]></artwork>
        </figure>
        <t>The leading zeros are dropped per the reduced-size encoding guidance. One octet is thus sufficient to send these observed options on the wire. Concretely, the ipv6ExtensionHeadersFull IE will be set to 0x01 (<xref target="ex-eh1-wire"/>).</t>
        <figure anchor="ex-eh1-wire">
          <name>Example A of ipv6ExtensionHeadersFull IE with Reduced-Size Encoding</name>
          <artwork align="center"><![CDATA[
MSB           LSB
 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+
|0|0|0|0|0|0|0|1|
+-+-+-+-+-+-+-+-+]]></artwork>
        </figure>
        <t><xref target="ex-eh2"/> provides another example of reported values in an ipv6ExtensionHeadersFull IE for an IPv6 Flow in which
the     Destination Options (0), IPv6 Hop-by-Hop Options (1), and Routing (5) headers are observed. One octet is sufficient to report these observed options. Concretely, the ipv6ExtensionHeadersFull IE will be set to 0x23.</t>
        <figure anchor="ex-eh2">
          <name>Example B of ipv6ExtensionHeadersFull IE with Reduced-Size Encoding</name>
          <artwork align="center"><![CDATA[
MSB           LSB
 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+
|0|0|1|0|0|0|1|1|
+-+-+-+-+-+-+-+-+]]></artwork>
        </figure>
        <t>Let us now consider an IPv6 Flow in which the following EH chain is observed: Routing (5), Mobility (7), and Authentication (9) header. <xref target="ex-eh3"/>
shows the ipv6ExtensionHeadersFull IE (0x02A0) to report this individual chain.</t>
        <figure anchor="ex-eh3">
          <name>Example of ipv6ExtensionHeadersFull IE Reported for an Extension Header Chain</name>
          <artwork align="center"><![CDATA[
MSB                          LSB
                     1
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|0|0|0|0|0|0|1|0|1|0|1|0|0|0|0|0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+]]></artwork>
        </figure>
      </section>
      <section anchor="tcp-options">
        <name>TCP Options</name>
        <section anchor="reduced-size-encoding">
          <name>Reduced-Size Encoding</name>
          <t>Given TCP Kind allocation practices and the option mapping defined in <xref target="sec-tcpfull"/>, fewer octets are likely to be used for Flows with common TCP options.</t>
          <t><xref target="ex-tcp1"/> shows an example of Kind/bit mappings in a tcpOptionsFull IE for a TCP Flow in which End of Option List (0), Maximum Segment Size (2), and Window Scale (3) options are observed.</t>
          <figure anchor="ex-tcp1">
            <name>Example of TCP Options / Bit Mappings in a tcpOptionsFull IE</name>
            <artwork align="center"><![CDATA[
MSB                                                      LSB
                     1                          25
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 ... 8 9 0 1 2 3 4 5
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...+-+-+-+-+-+-+-+-+
|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|0|   |0|0|0|0|1|1|0|1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...+-+-+-+-+-+-+-+-+]]></artwork>
          </figure>
          <t>One octet is sufficient to report these observed options. Concretely, the tcpOptionsFull IE will be set to 0x0D (<xref target="ex-tcp1-wire"/>).</t>
          <figure anchor="ex-tcp1-wire">
            <name>Example of tcpOptionsFull IE with Reduced-Size Encoding</name>
            <artwork align="center"><![CDATA[
MSB           LSB
 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+
|0|0|0|0|1|1|0|1|
+-+-+-+-+-+-+-+-+]]></artwork>
          </figure>
        </section>
        <section anchor="shared-options">
          <name>Shared Options</name>
          <t>Let us consider a TCP Flow in which shared options with ExIDs 0x0348 (HOST_ID) <xref target="RFC7974"/>, 0x454E     (TCP-ENO) <xref target="RFC8547"/>, and 0xE2D4C3D9  (Shared Memory Communications over RDMA protocol) <xref target="RFC7609"/> are observed. <xref target="ex-tcp2"/> shows an excerpt of the Data Set encoding with a focus on the tcpSharedOptionExID16 and tcpSharedOptionExID32 IEs. The meaning of the fields is defined in <xref target="RFC6313"/>.</t>
          <figure anchor="ex-tcp2">
            <name>Example of TCP Shared IEs</name>
            <artwork align="center"><![CDATA[
 MSB                                                          LSB
 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
:                           ...                                 :
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      255      |        List Length = 9        |semantic=allof |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|tcpSharedOptionExID16 = 521    |         Field Length = 2      |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|              0x0348           |             0x454E            |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      255      |        List Length = 9        |semantic=allof |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|tcpSharedOptionExID32 = 522    |         Field Length = 4      |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           0xE2D4C3D9                          |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
:                           ...                                 :]]></artwork>
          </figure>
        </section>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>IPFIX security considerations are discussed in <xref section="11" sectionFormat="of" target="RFC7011"/>.</t>
      <t>ipv6ExtensionHeadersChainLength and ipv6ExtensionHeadersLimit IEs can be exploited by an unauthorized observer as a means to deduce the processing capabilities of nodes. <xref section="8" sectionFormat="of" target="RFC7012"/> discusses the required measures to guarantee the integrity and confidentiality of the exported information.</t>
      <t>This document does not add new security considerations for exporting IEs other than those already discussed in <xref section="8" sectionFormat="of" target="RFC7012"/>.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <section anchor="deprecate-ipv6extensionheaders-and-tcpoptions-information-elements">
        <name>Deprecate ipv6ExtensionHeaders and tcpOptions Information Elements</name>
        <t>IANA has updated the "IPFIX Information Elements" registry under the "IP Flow Information Export (IPFIX) Entities" registry group <xref target="IANA-IPFIX"/> as follows:</t>
        <ul spacing="normal">
          <li>
            <t>The ipv6ExtensionHeaders IE (64) entry has been marked as deprecated in favor of the ipv6ExtensionHeadersFull IE defined in this document. This note is echoed in the "Additional Information" of the ipv6ExtensionHeaders IE.</t>
          </li>
          <li>
            <t>The tcpOptions IE (209) entry has been marked as deprecated in favor of the tcpOptionsFull IE defined in this document. This note is echoed in the "Additional Information" of the tcpOptions IE.</t>
          </li>
          <li>
            <t>The following has been added to the "Additional Information" of both the ipv6ExtensionHeaders and tcpOptions IEs:  </t>
            <ul spacing="normal">
              <li>
                <t>This Information Element was initially specified in <xref target="RFC5102"/>.</t>
              </li>
              <li>
                <t><xref target="RFC7012"/> has obsoleted <xref target="RFC5102"/> and specifies that <xref target="IANA-IPFIX"/> is the normative reference for this Information Element.</t>
              </li>
            </ul>
          </li>
        </ul>
        <t>Also, IANA has updated the reference of ipv6ExtensionHeaders IE (64) and tcpOptions IE (209) to point to this document.</t>
      </section>
      <section anchor="ipfix-information-elements">
        <name>IPFIX Information Elements</name>
        <t>IANA has added the following new IPFIX IEs to the "IPFIX Information Elements" registry under the "IP Flow Information Export (IPFIX) Entities" registry group <xref target="IANA-IPFIX"/>:</t>
        <table anchor="iana-new-ies">
          <name>New IPFIX Information Elements</name>
          <thead>
            <tr>
              <th align="left">ElementID</th>
              <th align="left">Name</th>
              <th align="left">Specification</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">513</td>
              <td align="left">ipv6ExtensionHeaderType</td>
              <td align="left"><xref target="sec-v6ehtype"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">514</td>
              <td align="left">ipv6ExtensionHeaderCount</td>
              <td align="left">
                <xref target="sec-v6ehcount"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">515</td>
              <td align="left">ipv6ExtensionHeadersFull</td>
              <td align="left">
                <xref target="sec-v6full"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">516</td>
              <td align="left">ipv6ExtensionHeaderTypeCountList</td>
              <td align="left">
                <xref target="sec-v6count"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">517</td>
              <td align="left">ipv6ExtensionHeadersLimit</td>
              <td align="left">
                <xref target="sec-v6limit"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">518</td>
              <td align="left">ipv6ExtensionHeadersChainLength</td>
              <td align="left">
                <xref target="sec-v6aggr"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">519</td>
              <td align="left">ipv6ExtensionHeaderChainLengthList</td>
              <td align="left">
                <xref target="sec-v6chain-list"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">520</td>
              <td align="left">tcpOptionsFull</td>
              <td align="left">
                <xref target="sec-tcpfull"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">521</td>
              <td align="left">tcpSharedOptionExID16</td>
              <td align="left">
                <xref target="sec-tcpExID16"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">522</td>
              <td align="left">tcpSharedOptionExID32</td>
              <td align="left">
                <xref target="sec-tcpExID32"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">523</td>
              <td align="left">tcpSharedOptionExID16List</td>
              <td align="left">
                <xref target="sec-ex"/> of RFC 9740</td>
            </tr>
            <tr>
              <td align="left">524</td>
              <td align="left">tcpSharedOptionExID32List</td>
              <td align="left">
                <xref target="sec-ex32"/> of RFC 9740</td>
            </tr>
          </tbody>
        </table>

      </section>
      <section anchor="ipfix-information-element-data-type">
        <name>IPFIX Information Element Data Type</name>
        <t>IANA has added the following new abstract data type to the "IPFIX Information Element Data Types" registry under the "IP Flow Information Export (IPFIX) Entities" registry group <xref target="IANA-IPFIX"/>:</t>
        <table anchor="iana-new-dt">
          <name>New IPFIX Information Element Data Type</name>
          <thead>
            <tr>
              <th align="left">Value</th>
              <th align="left">Description</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">23</td>
              <td align="left">unsigned256</td>
              <td align="left">RFC 9740</td>
            </tr>
          </tbody>
        </table>
        <section anchor="unsigned256">
          <name>unsigned256</name>
          <t>The type "unsigned256" represents a non-negative integer value in the
range of '0' to '2<sup>256</sup> - 1'. Similar to <xref section="6.1.1" sectionFormat="of" target="RFC7011"/>, this type <bcp14>MUST</bcp14> be encoded using the default canonical format in network byte order.</t>
          <t>Reduced-size encoding (<xref section="6.2" sectionFormat="of" target="RFC7011"/>) applies to this data type. The reduction in size can be to any number of octets smaller than the unsigned256 type if the data value still fits, i.e., so that only leading zeros are dropped.</t>
        </section>
      </section>
      <section anchor="sec-iana-eh">
        <name>IPFIX Registry for IPv6 Extension Headers</name>
        <t>IANA has created a new registry entitled "IPFIX ipv6ExtensionHeaders Bits" in the IANA IPFIX registry group <xref target="IANA-IPFIX"/>.</t>
        <t>When a new code is assigned to an IPv6 EH in <xref target="IANA-EH"/>, the next available free bit is selected by IANA for this EH from the "IPFIX ipv6ExtensionHeaders Bits" registry, and the registry is updated with the details that mirror the assigned EH. The "Label" mirrors the "keyword" of an EH as indicated in <xref target="IANA-Protocols"/>, while the "Protocol Number" mirrors the "Protocol Number" in <xref target="IANA-EH"/>. IANA has added the following note to <xref target="IANA-EH"/>:</t>

<!-- Note exactly matches https://www.iana.org/assignments/ipv6-parameters -->
        <t indent="3">Note: When a new code is assigned to an IPv6 Extension Header, the next available free bit in <xref target="IANA-IPFIX-IPv6EH"/> is selected for this new Extension Header. <xref target="IANA-IPFIX-IPv6EH"/> is updated accordingly. Modifications to existing registrations must be mirrored in <xref target="IANA-IPFIX-IPv6EH"/>.</t>
<!-- end -->

        <t>Otherwise, the registration policy for the registry is Expert Review (<xref section="4.5" sectionFormat="of" target="RFC8126"/>). See more details in <xref target="sec-de"/>.</t>
        <section anchor="sec-initial">
          <name>Initial Values</name>
          <t>The initial values of this registry are provided in <xref target="iana-new-eh"/>.</t>
          <table anchor="iana-new-eh">
            <name>Initial Values of the "IPFIX ipv6ExtensionHeaders Bits" Registry</name>
            <thead>
              <tr>
                <th align="left">Bit</th>
                <th align="left">Label</th>
                <th align="left">Protocol Number</th>
                <th align="left">Description</th>
                <th align="left">Reference</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left">0</td>
                <td align="left">DST</td>
                <td align="left">60</td>
                <td align="left">Destination Options for IPv6</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">1</td>
                <td align="left">HOP</td>
                <td align="left">0</td>
                <td align="left">IPv6 Hop-by-Hop Options</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">2</td>
                <td align="left">NoNxt</td>
                <td align="left">59</td>
                <td align="left">No Next Header for IPv6</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">3</td>
                <td align="left">UNK</td>
                <td align="left"></td>
                <td align="left">Unknown extension or transport header</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">4</td>
                <td align="left">FRA0</td>
                <td align="left">44</td>
                <td align="left">Fragment header - first fragment</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">5</td>
                <td align="left">RH</td>
                <td align="left">43</td>
                <td align="left">Routing header</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">6</td>
                <td align="left">FRA1</td>
                <td align="left">44</td>
                <td align="left">Fragmentation header - not first fragment</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">7</td>
                <td align="left">MOB</td>
                <td align="left">135</td>
                <td align="left">Mobility Header</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">8</td>
                <td align="left">ESP</td>
                <td align="left">50</td>
                <td align="left">Encapsulating Security Payload</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">9</td>
                <td align="left">AH</td>
                <td align="left">51</td>
                <td align="left">Authentication Header</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">10</td>
                <td align="left">HIP</td>
                <td align="left">139</td>
                <td align="left">Host Identity Protocol</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">11</td>
                <td align="left">SHIM6</td>
                <td align="left">140</td>
                <td align="left">Shim6 Protocol</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">12</td>
                <td align="left"></td>
                <td align="left">253</td>
                <td align="left">Use for experimentation and testing</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">13</td>
                <td align="left"></td>
                <td align="left">254</td>
                <td align="left">Use for experimentation and testing</td>
                <td align="left">RFC 9740</td>
              </tr>
              <tr>
                <td align="left">14 to 255</td>
                <td align="left"></td>
                <td align="left"></td>
                <td align="left">Unassigned</td>
                <td align="left"></td>
              </tr>
            </tbody>
          </table>
        </section>
        <section anchor="sec-de">
          <name>Guidelines for the Designated Experts</name>
          <t>It is suggested that multiple designated experts be appointed for registry change requests.</t>
          <t>Designated experts are solicited only for changes that are not covered by the automatic mirroring described above. For example, a registration may request two bits for a new EH to cover specific behaviors or uses of that EH.</t>
          <t>Criteria that should be applied by the designated experts include determining whether the proposed registration duplicates existing entries, whether the exception to the automatic mirroring procedure is justified, and whether the registration description is clear and fits the purpose of this registry.</t>
          <t>Within the review period, the designated experts will either approve or deny the registration request, communicating this decision to the IANA. Denials should include an explanation and, if applicable, suggestions as to how to make the request successful.</t>
        </section>
      </section>
    </section>
  </middle>
  <back>
    <displayreference target="I-D.ietf-6man-eh-limits" to="EH-LIMITS"/>

    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>

        <reference anchor="IANA-IPFIX" target="https://www.iana.org/assignments/ipfix">
          <front>
            <title>IP Flow Information Export (IPFIX) Entities</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>

        <reference anchor="IANA-IPFIX-IPv6EH" target="https://www.iana.org/assignments/ipfix">
          <front>
            <title>IPFIX ipv6ExtensionHeaders Bits</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>

        <reference anchor="IANA-EH" target="https://www.iana.org/assignments/ipv6-parameters">
          <front>
            <title>IPv6 Extension Header Types</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>

        <reference anchor="IANA-TCP" target="https://www.iana.org/assignments/tcp-parameters">
          <front>
            <title>TCP Option Kind Numbers</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
           </front>
        </reference>

        <reference anchor="IANA-TCP-ExIDs" target="https://www.iana.org/assignments/tcp-parameters">
          <front>
            <title>TCP Experimental Option Experiment Identifiers (TCP ExIDs)</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>

        <reference anchor="IANA-Protocols" target="https://www.iana.org/assignments/protocol-numbers">
          <front>
            <title>Protocol Numbers</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>

	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7011.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7012.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8200.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6994.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9293.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6313.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8126.xml"/>

      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>

	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.5102.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8883.xml"/>

<!-- [I-D.ietf-6man-eh-limits] IESG State: IESG Evaluation 2025-02-17 -->
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-6man-eh-limits.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7872.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9098.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7974.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8547.xml"/>
	<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7609.xml"/>

      </references>
    </references>

<section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>Thanks to <contact fullname="Paul Aitken"/>, <contact fullname="Éric
      Vyncke"/>, and <contact fullname="Joe Touch"/> for the reviews and
      comments. Special thanks to <contact fullname="Andrew Feren"/> for
      sharing data about scans of IPFIX data he collected.</t>
      <t>Thanks to <contact fullname="Wesley Eddy"/> for the tsvart review,
      <contact fullname="Yingzhen Qu"/> for the opsdir review, <contact
      fullname="Dirk Von Hugo"/> for intdir review, <contact fullname="Joel
      Halpern"/> for the genart review, and <contact fullname="Tero Kivinen"/>
      for the secdir review.</t>
      <t>Thanks to <contact fullname="Thomas Graf"/> for the Shepherd review.</t>
      <t>Thanks to <contact fullname="Mahesh Jethanandani"/> for the AD review.</t>
      <t>Thanks to <contact fullname="Éric Vyncke"/>, <contact fullname="Erik
      Kline"/>, <contact fullname="Roman Danyliw"/>, and <contact
      fullname="Zaheduzzaman Sarker"/> for the IESG review.</t>
    </section>
  </back>
</rfc>
