<?xml version="1.0" encoding="us-ascii"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.5 (Ruby 3.1.2) -->


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

<!ENTITY RFC8200 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8200.xml">
<!ENTITY RFC8402 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8402.xml">
<!ENTITY RFC8754 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8754.xml">
<!ENTITY RFC8986 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8986.xml">
<!ENTITY RFC2119 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml">
<!ENTITY RFC8174 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml">
<!ENTITY RFC7942 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7942.xml">
<!ENTITY RFC9252 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9252.xml">
<!ENTITY RFC9259 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9259.xml">
<!ENTITY RFC9350 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9350.xml">
<!ENTITY RFC9352 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9352.xml">
<!ENTITY RFC9513 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9513.xml">
<!ENTITY RFC9514 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9514.xml">
<!ENTITY I-D.ietf-6man-sids SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-6man-sids.xml">
<!ENTITY I-D.ietf-idr-bgp-ls-sr-policy SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-idr-bgp-ls-sr-policy.xml">
<!ENTITY I-D.ietf-idr-sr-policy-safi SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-idr-sr-policy-safi.xml">
<!ENTITY I-D.ietf-pce-segment-routing-ipv6 SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-pce-segment-routing-ipv6.xml">
]>


<rfc ipr="trust200902" docName="draft-ietf-spring-srv6-srh-compression-17" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title>Compressed SRv6 Segment List Encoding</title>

    <author initials="W." surname="Cheng" fullname="Weiqiang Cheng" role="editor">
      <organization>China Mobile</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>chengweiqiang@chinamobile.com</email>
      </address>
    </author>
    <author initials="C." surname="Filsfils" fullname="Clarence Filsfils">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <country>Belgium</country>
        </postal>
        <email>cf@cisco.com</email>
      </address>
    </author>
    <author initials="Z." surname="Li" fullname="Zhenbin Li">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>lizhenbin@huawei.com</email>
      </address>
    </author>
    <author initials="B." surname="Decraene" fullname="Bruno Decraene">
      <organization>Orange</organization>
      <address>
        <postal>
          <country>France</country>
        </postal>
        <email>bruno.decraene@orange.com</email>
      </address>
    </author>
    <author initials="F." surname="Clad" fullname="Francois Clad" role="editor">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <country>France</country>
        </postal>
        <email>fclad.ietf@gmail.com</email>
      </address>
    </author>

    <date year="2024" month="May" day="16"/>

    <area>General</area>
    <workgroup>SPRING</workgroup>
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 237?>

<t>Segment Routing over IPv6 (SRv6) is the instantiation of Segment Routing (SR) on the IPv6 dataplane. This document specifies new flavors for the SR segment endpoint behaviors defined in RFC 8986, which enable the compression of an SRv6 SID list. Such compression significantly reduces the size of the SRv6 encapsulation needed to steer packets over long segment lists.</t>



    </abstract>



  </front>

  <middle>


<?line 241?>

<section anchor="introduction"><name>Introduction</name>

<t>The Segment Routing (SR) architecture <xref target="RFC8402"/> describes two data plane instantiations of SR: SR over MPLS (SR-MPLS) and SR over IPv6 (SRv6).</t>

<t>SRv6 Network Programming <xref target="RFC8986"/> defines a framework to build a network program with topological and service segments (also referred to by their Segment Identifier (SID)) carried in a Segment Routing Header (SRH) <xref target="RFC8754"/>.</t>

<t>Some SRv6 applications such as strict path traffic engineering may require long segment lists. Compressing the encoding of these long segment lists in the packet header can significantly reduce the header size. This document specifies new flavors to the SR segment endpoint behaviors defined in <xref target="RFC8986"/> that enable a compressed encoding of the SRv6 segment list.</t>

<t>The flavors defined in this document leverage the SRv6 data plane defined in <xref target="RFC8754"/> and <xref target="RFC8986"/>, and are compatible with the SRv6 control plane extensions for IS-IS <xref target="RFC9352"/>, OSPF <xref target="RFC9513"/>, and BGP <xref target="RFC9252"/>.</t>

</section>
<section anchor="terminology"><name>Terminology</name>

<t>This document leverages the terms defined in <xref target="RFC8402"/>, <xref target="RFC8754"/>, and <xref target="RFC8986"/>. The reader is assumed to be familiar with this terminology.</t>

<t>This document introduces the following new terms:</t>

<t><list style="symbols">
  <t>Locator-Block: The most significant bits of a SID locator that represent the SRv6 SID block. The Locator-Block is referred to as &quot;B&quot; in Section 3.1 of <xref target="RFC8986"/>.</t>
  <t>Locator-Node: The least significant bits of a SID locator that identify the SR segment endpoint node instantiating the SID. The Locator-Node is referred to as &quot;N&quot; in Section 3.1 of <xref target="RFC8986"/>.</t>
  <t>Compressed-SID (C-SID): A compressed encoding of a SID. The C-SID includes the Locator-Node and Function bits of the SID being compressed.</t>
  <t>C-SID container: A 128-bit container holding a list of one or more C-SIDs.</t>
  <t>C-SID sequence: A group of one or more consecutive SID list entries carrying the common Locator-Block and at least one C-SID container.</t>
  <t>Uncompressed SID sequence: A group of one or more consecutive uncompressed SIDs in a SID list.</t>
  <t>Compressed SID list: A segment list encoding that reduces the packet header length thanks to one or more C-SID sequences. A compressed SID list also contains zero, one, or more uncompressed SID sequences.</t>
  <t>Global Identifiers Block (GIB): The pool of C-SID values available for global allocation.</t>
  <t>Local Identifiers Block (LIB): The pool of C-SID values available for local allocation.</t>
</list></t>

<t>In this document, the length of each constituent part of a SID is referred to as follows.</t>

<t><list style="symbols">
  <t>LBL is the Locator-Block length of the SID.</t>
  <t>LNL is the Locator-Node length of the SID.</t>
  <t>FL is the Function length of the SID.</t>
  <t>AL is the Argument length of the SID.</t>
</list></t>

<t>In addition, LNFL is the sum of the Locator-Node length and the Function length of the SID. It is also referred to as the C-SID length.</t>

<section anchor="requirements-language"><name>Requirements Language</name>

<t>The key words &quot;MUST&quot;, &quot;MUST NOT&quot;, &quot;REQUIRED&quot;, &quot;SHALL&quot;, &quot;SHALL NOT&quot;, &quot;SHOULD&quot;, &quot;SHOULD NOT&quot;, &quot;RECOMMENDED&quot;, &quot;NOT RECOMMENDED&quot;, &quot;MAY&quot;, and &quot;OPTIONAL&quot; 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.</t>

</section>
</section>
<section anchor="basic-concepts"><name>Basic Concepts</name>

<t>In an SR domain, all SRv6 SIDs instantiated from the same Locator-Block share the same most significant bits. In addition, when the combined length of the SRv6 SID Locator, Function, and Argument is smaller than 128 bits, the least significant bits of the SID are padded with zeros.
The compressed segment list encoding seeks to decrease the packet header length by avoiding the repetition of the same Locator-Block and reducing the use of padding bits.</t>

<t>The compressed segment list encoding is fully compatible with and builds upon the mechanisms specified in <xref target="RFC8754"/> and <xref target="RFC8986"/>. The compressed encoding leverages a SID list compression logic on the SR source node (<xref target="sec-source-node"/>) in combination with new flavors of the base SRv6 segment endpoint behaviors that process the compressed SID list (<xref target="sec-endpoint"/>).</t>

<t>A segment list can be encoded in the packet header using any combination of compressed and uncompressed sequences. The C-SID sequences leverage the flavors defined in this document, while the uncompressed sequences use behaviors and flavors defined in other documents, such as <xref target="RFC8986"/>. An SR source node constructs and compresses the SID list depending on the SIDs instantiated on each SR segment endpoint node that the packet should traverse, as well as its own compression capabilities.</t>

<t>The compressed segment list encoding works with any Locator-Block allocation. For example, each routing domain within the SR domain can be allocated a /48 Locator-Block from a global IPv6 block available to the operator, or from a prefix allocated to SRv6 SIDs as discussed in Section 5 of <xref target="I-D.ietf-6man-sids"/>.</t>

</section>
<section anchor="sec-endpoint"><name>SR Segment Endpoint Flavors</name>

<t>This section defines two SR segment endpoint flavors, NEXT-C-SID and REPLACE-C-SID, for the End, End.X, End.T, End.B6.Encaps, End.B6.Encaps.Red, and End.BM behaviors of <xref target="RFC8986"/>.
This section also defines a REPLACE-C-SID flavor for the End.DX6, End.DX4, End.DT6, End.DT4, End.DT46, End.DX2, End.DX2V, End.DT2U, and End.DT2M behaviors of <xref target="RFC8986"/>.
A counterpart NEXT-C-SID flavor is not defined for these SIDs because they can be included within a C-SID sequence that uses the NEXT-C-SID flavor without any modification of the procedure defined in <xref target="RFC8986"/>.
Future documents may extend the applicability of the NEXT-C-SID and REPLACE-C-SID flavors to other SR segment endpoint behaviors (see <xref target="sec-future"/>).</t>

<t>The use of these flavors, either individually or in combination, enables the compressed segment list encoding.</t>

<t>The NEXT-C-SID flavor and the REPLACE-C-SID flavor both leverage the SID Argument to determine the next SID to be processed, but employ different SID list compression schemes.
With the NEXT-C-SID flavor, each C-SID container is a fully formed SRv6 SID with the common Locator-Block for all the C-SIDs in the C-SID container, a Locator-Node and Function that are those of the first C-SID, and an Argument carrying the subsequent C-SIDs.
With the REPLACE-C-SID flavor, only the first element in a C-SID sequence is a fully formed SRv6 SID. It has the common Locator-Block for all the C-SIDs in the C-SID sequence, and a Locator-Node and Function that are those of the first C-SID. The remaining elements in the C-SID sequence are C-SID containers carrying the subsequent C-SIDs without the Locator-Block.</t>

<t>SRv6 is intended for use in a variety of networks that require different prefix lengths and SID numbering spaces. Each of the two flavors introduced in this document comes with its own recommendations for Locator-Block and C-SID length, as specified in <xref target="sec-next"/> and <xref target="sec-replace"/>. These flavors are best suited for different environments, depending on the requirements of the network. For instance, larger C-SID lengths may be more suitable for networks requiring ample SID numbering space, while smaller C-SID lengths are better for compression efficiency. The two compression flavors allow the compressed segment list encoding to adapt to a range of requirements, with support for multiple compression levels. Network operators can choose the flavor that best suits their use case, deployment design, and network scale.</t>

<t>The SIDs of both flavors can co-exist in the same SR domain, on the same SR segment endpoint node, and even in the same segment list. However, it is RECOMMENDED, for ease of operation, that a single compressed encoding flavor be used in a given routing domain. In a multi-domain deployment, different flavors may be used in different routing domains of the SR domain.</t>

<t>In the remainder of this document, the term &quot;a SID of this document&quot; refers to any End, End.X, End.T, End.B6.Encaps, End.B6.Encaps.Red, or End.BM SID with the NEXT-C-SID or the REPLACE-C-SID flavor, and with any combination of Penultimate Segment Pop (PSP), Ultimate Segment Pop (USP), and Ultimate Segment Decapsulation (USD) flavor, or any End.DX6, End.DX4, End.DT6, End.DT4, End.DT46, End.DX2, End.DX2V, End.DT2U, or End.DT2M with the REPLACE-C-SID flavor. All the SIDs introduced in this document are listed in <xref target="tbl-iana-endpoint-behaviors"/>.</t>

<t>In the remainder of this document, the terms &quot;NEXT-C-SID flavor SID&quot; and &quot;REPLACE-C-SID flavor SID&quot; refer to any SID of this document with the NEXT-C-SID flavor and with the REPLACE-C-SID flavor, respectively.</t>

<section anchor="sec-next"><name>NEXT-C-SID Flavor</name>

<t>A C-SID sequence using the NEXT-C-SID flavor comprises one or more C-SID containers. Each C-SID container is a fully formed 128-bit SID structured as shown in <xref target="fig-next-struct"/>. It carries a Locator-Block followed by a series of C-SIDs. The Locator-Node and Function of the C-SID container are those of the first C-SID, and its Argument is the contiguous series of subsequent C-SIDs. The second C-SID is encoded in the most significant bits of the C-SID container Argument, the third C-SID is encoded in the bits of the Argument that immediately follow the second C-SID, and so on. When all C-SIDs have the same length, a C-SID container can carry up to K C-SIDs, where K is computed as floor((128-LBL)/LNFL) (floor(x) is the greatest integer less than or equal to x <xref target="GKP94"/>). Each C-SID container for NEXT-C-SID is independent, such that contiguous C-SID containers in a C-SID sequence can be considered as separate C-SID sequences.</t>

<t>When a C-SID sequence comprises at least two C-SIDs, the last C-SID in the sequence is not required to have the NEXT-C-SID flavor. It can be bound to any behavior and flavor(s), including the REPLACE-C-SID flavor, as long as the updated destination address resulting from the processing of the previous C-SID in the sequence is a valid form for that last SID. Line S12 of the first pseudocode in <xref target="sec-source-compression"/> provides sufficient conditions to ensure this property.</t>

<figure title="Structure of a NEXT-C-SID flavor SID (scaled for a 48-bit Locator-Block, 16-bit combined Locator-Node and Function, and 64-bit Argument)" anchor="fig-next-struct"><artwork><![CDATA[
+------------------------------------------------------------------+
|     Locator-Block      |Loc-Node|            Argument            |
|                        |Function|                                |
+------------------------------------------------------------------+
 <-------- LBL ---------> < LNFL > <------------- AL ------------->
]]></artwork></figure>

<t>An implementation MUST support a 32-bit Locator-Block length (LBL) and a 16-bit C-SID length (LNFL) for NEXT-C-SID flavor SIDs, and may support any other Locator-Block and C-SID length.</t>

<t>A deployment should use a consistent Locator-Block length and C-SID length for all SIDs of the SR domain. Heterogeneous lengths, while possible, may impact the compression efficiency.</t>

<t>The Argument length (AL) for NEXT-C-SID flavor SIDs is equal to 128-LBL-LNFL.</t>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as a SID with the NEXT-C-SID flavor, the SR segment endpoint node applies the procedure specified in the following subsection that corresponds to the SID behavior. If the SID also has the PSP, USP, or USD flavor, the procedure is modified as described in <xref target="sec-next-flavors"/>.</t>

<t>An SR segment endpoint node instantiating a SID of this document with the NEXT-C-SID flavor MUST accept any Argument value for that SID.</t>

<t>At high level, for any SID with the NEXT-C-SID flavor, the SR segment endpoint node determines the next SID of the SID list as follows. If the Argument value of the active SID is non-zero, the SR segment endpoint node constructs the next SID from the active SID by copying the entire SID Argument value to the bits that immediately follow the Locator-Block, thus overwriting the active SID Locator-Node and Function with those of the next C-SID, and filling the least significant LNFL bits of the Argument with zeros. Otherwise (if the Argument value is 0), the SR segment endpoint node copies the next 128-bit Segment List entry from the SRH to the Destination Address field of the IPv6 header.</t>

<section anchor="sec-next-end"><name>End with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End SID with the NEXT-C-SID flavor, the procedure described in Section 4.1 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The below pseudocode is inserted between lines S01 and S02 of the SRH processing in Section 4.1 of <xref target="RFC8986"/>. In addition, this pseudocode is executed before processing any extension header that is not an SRH, a Hop-by-Hop header or a Destination Option header, or before processing the upper-layer header, whichever comes first.</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.   Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
N09. }
]]></artwork></figure>

<aside>
  <t>Notes:</t>

  <t><list style="symbols">
    <t><spanx style="verb">DA.Argument</spanx> identifies the value contained in the bits <spanx style="verb">[(LBL+LNFL)..127]</spanx> in the Destination Address of the IPv6 header.</t>
    <t>The value in the Segments Left field of the SRH is not modified when <spanx style="verb">DA.Argument</spanx> in the received packet has a non-zero value.</t>
  </list></t>
</aside>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-next-end-complete"/>.</t>

</section>
<section anchor="sec-next-endx"><name>End.X with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.X SID with the NEXT-C-SID flavor, the procedure described in Section 4.2 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-next-end"/> of this document is modified by replacing line N08 as shown below.</t>

<figure><artwork><![CDATA[
N08.   Submit the packet to the IPv6 module for transmission to the
         new destination via a member of J.
]]></artwork></figure>

<aside>
  <t>Note: the variable J is defined in Section 4.2 of <xref target="RFC8986"/>.</t>
</aside>

<t>The resulting pseudocode is inserted between lines S01 and S02 of the SRH processing in Section 4.1 of <xref target="RFC8986"/> after applying the modification described in Section 4.2 of <xref target="RFC8986"/>. In addition, this pseudocode is executed before processing any extension header that is not an SRH, a Hop-by-Hop header or a Destination Option header, or before processing the upper-layer header, whichever comes first.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-next-endx-complete"/>.</t>

</section>
<section anchor="sec-next-endt"><name>End.T with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.T SID with the NEXT-C-SID flavor, the procedure described in Section 4.3 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-next-end"/> of this document is modified by replacing line N08 as shown below.</t>

<figure><artwork><![CDATA[
N08.1.   Set the packet's associated FIB table to T.
N08.2.   Submit the packet to the egress IPv6 FIB lookup for
           transmission to the new destination.
]]></artwork></figure>

<aside>
  <t>Note: the variable T is defined in Section 4.3 of <xref target="RFC8986"/>.</t>
</aside>

<t>The resulting pseudocode is inserted between lines S01 and S02 of the SRH processing in Section 4.1 of <xref target="RFC8986"/> after applying the modification described in Section 4.3 of <xref target="RFC8986"/>. In addition, this pseudocode is executed before processing any extension header that is not an SRH, a Hop-by-Hop header or a Destination Option header, or before processing the upper-layer header, whichever comes first.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-next-endt-complete"/>.</t>

</section>
<section anchor="sec-next-endb6"><name>End.B6.Encaps with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.B6.Encaps SID with the NEXT-C-SID flavor, the procedure described in Section 4.13 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-next-end"/> of this document is modified by replacing line N08 as shown below.</t>

<figure><artwork><![CDATA[
N08.1.   Push a new IPv6 header with its own SRH containing B.
N08.2.   Set the outer IPv6 SA to A.
N08.3.   Set the outer IPv6 DA to the first SID of B.
N08.4.   Set the outer Payload Length, Traffic Class, Flow Label,
           Hop Limit, and Next Header fields.
N08.5.   Submit the packet to the egress IPv6 FIB lookup for
           transmission to the next destination.
]]></artwork></figure>

<aside>
  <t>Note: the variables A and B, as well as the values of the Payload Length, Traffic Class, Flow Label, Hop Limit, and Next Header are defined in Section 4.13 of <xref target="RFC8986"/>.</t>
</aside>

<t>The resulting pseudocode is inserted between lines S01 and S02 of the SRH processing in Section 4.13 of <xref target="RFC8986"/>. In addition, this pseudocode is executed before processing any extension header that is not an SRH, a Hop-by-Hop header or a Destination Option header, or before processing the upper-layer header, whichever comes first.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-next-endb6-complete"/>.</t>

<t>Similar to the base End.B6.Encaps SID defined in Section 4.13 of <xref target="RFC8986"/>, the NEXT-C-SID flavor variant updates the Destination Address field of the inner IPv6 header to the next SID in the original segment list before encapsulating the packet with the segment list of SR Policy B. At the endpoint of SR Policy B, the encapsulation is removed and the inner packet is forwarded towards the exposed destination address, which already contains the next SID in the original segment list.</t>

</section>
<section anchor="sec-next-endb6red"><name>End.B6.Encaps.Red with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.B6.Encaps.Red SID with the NEXT-C-SID flavor, the procedure described in Section 4.14 of <xref target="RFC8986"/> is executed with the same modifications as in <xref target="sec-next-endb6"/> of this document.</t>

</section>
<section anchor="sec-next-endbm"><name>End.BM with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.BM SID with the NEXT-C-SID flavor, the procedure described in Section 4.15 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-next-end"/> of this document is modified by replacing line N08 as shown below.</t>

<figure><artwork><![CDATA[
N08.1.   Push the MPLS label stack for B.
N08.2.   Submit the packet to the MPLS engine for transmission.
]]></artwork></figure>

<aside>
  <t>Note: the variable B is defined in Section 4.15 of <xref target="RFC8986"/>.</t>
</aside>

<t>The resulting pseudocode is inserted between lines S01 and S02 of the SRH processing in Section 4.15 of <xref target="RFC8986"/>. In addition, this pseudocode is executed before processing any extension header that is not an SRH, a Hop-by-Hop header or a Destination Option header, or before processing the upper-layer header, whichever comes first.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-next-endbm-complete"/>.</t>

</section>
<section anchor="sec-next-flavors"><name>Combination with PSP, USP and USD flavors</name>

<t>PSP: The PSP flavor defined in Section 4.16.1 of <xref target="RFC8986"/> is unchanged when combined with the NEXT-C-SID flavor.</t>

<t>USP: The USP flavor defined in Section 4.16.2 of <xref target="RFC8986"/> is unchanged when combined with the NEXT-C-SID flavor.</t>

<t>USD: The USP flavor defined in Section 4.16.3 of <xref target="RFC8986"/> is unchanged when combined with the NEXT-C-SID flavor.</t>

</section>
</section>
<section anchor="sec-replace"><name>REPLACE-C-SID Flavor</name>

<t>A C-SID sequence using the REPLACE-C-SID flavor starts with a C-SID container in fully formed 128-bit SID format. The Locator-Block of this SID is the common Locator-Block for all the C-SIDs in the C-SID sequence, its Locator-Node and Function are those of the first C-SID, and its Argument carries the index of the current C-SID in the current C-SID container. The Argument value is initially 0. When more segments are present in the segment list, the C-SID sequence continues with one or more C-SID containers in packed format carrying the subsequent C-SIDs in the sequence. Each container in packed format is a 128-bit Segment List entry split into K &quot;positions&quot; of LNFL bits, where K is computed as floor(128/LNFL). If LNFL does not divide into 128 perfectly, a zero pad is added in the least significant bits of the C-SID container to fill the bits left over. The second C-SID in the C-SID sequence is encoded in the least significant bit position of the first C-SID container in packed format (position K-1), the third C-SID is encoded in position K-2, and so on.</t>

<t>The last C-SID in the C-SID sequence is not required to have the REPLACE-C-SID flavor. It can be bound to any behavior and flavor(s), including the NEXT-C-SID flavor, as long as it meets the conditions defined in <xref target="sec-source-node"/>.</t>

<t>The structure of a SID with the REPLACE-C-SID flavor is shown in <xref target="fig-replace-struct"/>. The same structure is also that of the C-SID container for REPLACE-C-SID in fully formed 128-bit SID format.</t>

<figure title="Structure of a REPLACE-C-SID flavor SID (scaled for a 48-bit Locator-Block, 32-bit combined Locator-Node and Function, and 48-bit Argument)" anchor="fig-replace-struct"><artwork><![CDATA[
+-------------------------------------------------------------------+
|     Locator-Block      |  Locator-Node  |        Argument         |
|                        |   + Function   |                         |
+-------------------------------------------------------------------+
 <-------- LBL ---------> <---- LNFL ----> <--------- AL ---------->
]]></artwork></figure>

<t>The structure of a C-SID container for REPLACE-C-SID in packed format is shown in <xref target="fig-replace-container"/>.</t>

<figure title="Structure of a C-SID container for REPLACE-C-SID using a 32-bit C-SID length (K = 4)" anchor="fig-replace-container"><artwork><![CDATA[
+-------------------------------------------------------------------+
|  Fourth C-SID  |  Third C-SID   |  Second C-SID  |  First C-SID   |
|  (position 0)  |  (position 1)  |  (position 2)  |  (position 3)  |
+-------------------------------------------------------------------+
 <---- LNFL ----> <---- LNFL ----> <---- LNFL ----> <---- LNFL ---->
]]></artwork></figure>

<t>The REPLACE-C-SID flavor SIDs support any Locator-Block length (LBL), depending on the needs of the operator, as long as it does not exceed 128-LNFL-ceiling(log_2(128/LNFL)) (ceiling(x) is the least integer greater than or equal to x <xref target="GKP94"/>), so that enough bits remain available for the C-SID and Argument. A Locator-Block length of 48, 56, 64, 72, or 80 bits is recommended for easier reading in operation.</t>

<t>This document defines the REPLACE-C-SID flavor for 16-bit and 32-bit C-SID lengths (LNFL). An implementation MUST support a 32-bit C-SID length for REPLACE-C-SID flavor SIDs.</t>

<t>A deployment should use a consistent Locator-Block length and C-SID length for all SIDs of the SR domain. Heterogeneous C-SID lengths, while possible, may impact the compression efficiency.</t>

<t>The Argument length (AL) for REPLACE-C-SID flavor SIDs is equal to 128-LBL-LNFL. The index value is encoded in the least significant X bits of the Argument, where X is computed as ceiling(log_2(128/LNFL)).</t>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as a SID with the REPLACE-C-SID flavor, the SR segment endpoint node applies the procedure specified in the following subsection that corresponds to the SID behavior. If the SID also has the PSP, USP, or USD flavor, the procedure is modified as described in <xref target="sec-replace-flavors"/>.</t>

<t>At high level, at the start of a C-SID sequence using the REPLACE-C-SID flavor, the first C-SID container in fully formed 128-bit SID format is copied to the Destination Address of the IPv6 header. Then, for any SID with the REPLACE-C-SID flavor, the SR segment endpoint node determines the next SID of the SID list as follows. When an SRH is present, the SR segment endpoint node decrements the index value in the Argument of the active SID if the index value is not 0 or, if it is 0, decrements the Segments Left value in the SRH and sets the index value in the Argument of the active SID to K-1. The updated index value indicates the position of the next C-SID within the C-SID container in packed format at the &quot;Segment List&quot; index &quot;Segments Left&quot; in the SRH. The SR segment endpoint node then constructs the next SID by copying this next C-SID to the bits that immediately follow the Locator-Block in the Destination Address field of the IPv6 header, thus overwriting the active SID Locator-Node and Function with those of the next C-SID. If no SRH is present, the SR segment endpoint node ignores the index value in the SID Argument (except End.DT2M, see <xref target="sec-replace-enddx"/>) and processes the upper-layer header as per <xref target="RFC8986"/>. The C-SID sequence ends with a last C-SID in the last C-SID container that does not have the REPLACE-C-SID flavor, or with the special C-SID value 0, or when reaching the end of the segment list, whichever comes first.</t>

<section anchor="sec-replace-end"><name>End with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End SID with the REPLACE-C-SID flavor, the SRH processing described in Section 4.1 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>Line S02 of SRH processing in Section 4.1 of <xref target="RFC8986"/> is replaced as follows.</t>

<figure><artwork><![CDATA[
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
]]></artwork></figure>

<t>Lines S09 to S15 are replaced by the following pseudo code.</t>

<figure><artwork><![CDATA[
R01. If (DA.Arg.Index != 0) {
R02.   If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.     Send an ICMP Parameter Problem to the Source Address,
           Code 0 (Erroneous header field encountered),
           Pointer set to the Segments Left field,
           interrupt packet processing and discard the packet.
R04.   }
R05.   Decrement DA.Arg.Index by 1.
R06.   If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.     Decrement Segments Left by 1.
R08.     Decrement IPv6 Hop Limit by 1.
R09.     Update IPv6 DA with Segment List[Segments Left]
R10.     Submit the packet to the egress IPv6 FIB lookup for
          transmission to the new destination.
R11.   }
R12. } Else {
R13.   If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.     Send an ICMP Parameter Problem to the Source Address,
           Code 0 (Erroneous header field encountered),
           Pointer set to the Segments Left field,
           interrupt packet processing and discard the packet.
R15.   }
R16.   Decrement Segments Left by 1.
R17.   Set DA.Arg.Index to (floor(128/LNFL) - 1).
R18. }
R19. Decrement IPv6 Hop Limit by 1.
R20. Write Segment List[Segments Left][DA.Arg.Index] into the bits
       [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
       header.
R21. Submit the packet to the egress IPv6 FIB lookup for
       transmission to the new destination.
]]></artwork></figure>

<aside>
  <t>Notes:</t>

  <t><list style="symbols">
    <t><spanx style="verb">DA.Arg.Index</spanx> identifies the value contained in the bits <spanx style="verb">[(128-ceiling(log_2(128/LNFL)))..127]</spanx> in the Destination Address of the IPv6 header.</t>
    <t><spanx style="verb">Segment List[Segments Left][DA.Arg.Index]</spanx> identifies the value contained in the bits <spanx style="verb">[DA.Arg.Index*LNFL..(DA.Arg.Index+1)*LNFL-1]</spanx> in the SRH Segment List entry at index Segments Left.</t>
  </list></t>
</aside>

<t>The upper-layer header processing described in Section 4.1.1 of <xref target="RFC8986"/> is unchanged.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-replace-end-complete"/>.</t>

</section>
<section anchor="sec-replace-endx"><name>End.X with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.X SID with the REPLACE-C-SID flavor, the procedure described in Section 4.2 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-replace-end"/> of this document is modified by replacing lines R10 and R21 as shown below.</t>

<figure><artwork><![CDATA[
R10. Submit the packet to the IPv6 module for transmission to the
       new destination via a member of J.
]]></artwork></figure>

<figure><artwork><![CDATA[
R21. Submit the packet to the IPv6 module for transmission to the
       new destination via a member of J.
]]></artwork></figure>

<aside>
  <t>Note: the variable J is defined in Section 4.2 of <xref target="RFC8986"/>.</t>
</aside>

<t>The SRH processing in Section 4.2 of <xref target="RFC8986"/> is replaced with the resulting pseudocode. The upper-layer header processing is unchanged.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-replace-endx-complete"/>.</t>

</section>
<section anchor="sec-replace-endt"><name>End.T with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.T SID with the REPLACE-C-SID flavor, the procedure described in Section 4.3 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-replace-end"/> of this document is modified by replacing lines R10 and R21 as shown below.</t>

<figure><artwork><![CDATA[
R10.1. Set the packet's associated FIB table to T.
R10.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
]]></artwork></figure>

<figure><artwork><![CDATA[
R21.1. Set the packet's associated FIB table to T.
R21.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
]]></artwork></figure>

<aside>
  <t>Note: the variable T is defined in Section 4.3 of <xref target="RFC8986"/>.</t>
</aside>

<t>The SRH processing in Section 4.3 of <xref target="RFC8986"/> is replaced with the resulting pseudocode. The upper-layer header processing is unchanged.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-replace-endt-complete"/>.</t>

</section>
<section anchor="sec-replace-endb6"><name>End.B6.Encaps with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.B6.Encaps SID with the REPLACE-C-SID flavor, the procedure described in Section 4.13 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-replace-end"/> of this document is modified by replacing lines R10 and R21 as shown below.</t>

<figure><artwork><![CDATA[
R10.1. Push a new IPv6 header with its own SRH containing B.
R10.2. Set the outer IPv6 SA to A.
R10.3. Set the outer IPv6 DA to the first SID of B.
R10.4. Set the outer Payload Length, Traffic Class, Flow Label,
         Hop Limit, and Next Header fields.
R10.5. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
]]></artwork></figure>

<figure><artwork><![CDATA[
R21.1. Push a new IPv6 header with its own SRH containing B.
R21.2. Set the outer IPv6 SA to A.
R21.3. Set the outer IPv6 DA to the first SID of B.
R21.4. Set the outer Payload Length, Traffic Class, Flow Label,
         Hop Limit, and Next Header fields.
R21.5. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
]]></artwork></figure>

<aside>
  <t>Note: the variables A and B, as well as the values of the Payload Length, Traffic Class, Flow Label, Hop Limit, and Next Header are defined in Section 4.13 of <xref target="RFC8986"/>.</t>
</aside>

<t>The SRH processing in Section 4.13 of <xref target="RFC8986"/> is replaced with the resulting pseudocode. The upper-layer header processing is unchanged.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-replace-endb6-complete"/>.</t>

</section>
<section anchor="sec-replace-endb6red"><name>End.B6.Encaps.Red with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.B6.Encaps.Red SID with the REPLACE-C-SID flavor, the procedure described in Section 4.14 of <xref target="RFC8986"/> is executed with the same modifications as in <xref target="sec-replace-endb6"/> of this document.</t>

</section>
<section anchor="sec-replace-endbm"><name>End.BM with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.BM SID with the REPLACE-C-SID flavor, the procedure described in Section 4.15 of <xref target="RFC8986"/> is executed with the following modifications.</t>

<t>The pseudocode in <xref target="sec-replace-end"/> of this document is modified by replacing lines R10 and R21 as shown below.</t>

<figure><artwork><![CDATA[
R10.1. Push the MPLS label stack for B.
R10.2. Submit the packet to the MPLS engine for transmission.
]]></artwork></figure>

<figure><artwork><![CDATA[
R21.1. Push the MPLS label stack for B.
R21.2. Submit the packet to the MPLS engine for transmission.
]]></artwork></figure>

<aside>
  <t>Note: the variable B is defined in Section 4.15 of <xref target="RFC8986"/>.</t>
</aside>

<t>The SRH processing in Section 4.15 of <xref target="RFC8986"/> is replaced with the resulting pseudocode. The upper-layer header processing is unchanged.</t>

<t>A rendering of the complete pseudocode is provided in <xref target="sec-replace-endbm-complete"/>.</t>

</section>
<section anchor="sec-replace-enddx"><name>End.DX and End.DT with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.DX6, End.DX4, End.DT6, End.DT4, End.DT46, End.DX2, End.DX2V, or End.DT2U SID with the REPLACE-C-SID flavor, the corresponding procedure described in Sections 4.4 through 4.11 of <xref target="RFC8986"/> is executed.</t>

<t>These SIDs differ from those defined in <xref target="RFC8986"/> by the presence of an Argument as part of the SID structure. The Argument value is ignored by the SR segment endpoint node.</t>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.DT2M SID with the REPLACE-C-SID flavor, the procedure described in Section 4.12 of <xref target="RFC8986"/> is executed with the following modification.</t>

<t>For any End.DT2M SID with the REPLACE-C-SID flavor, the value of <spanx style="verb">Arg.FE2</spanx> is 16-bit long. The SR segment endpoint node obtains the value <spanx style="verb">Arg.FE2</spanx> from the 16 most significant bits of <spanx style="verb">DA.Argument</spanx> if <spanx style="verb">DA.Arg.Index</spanx> is zero, or from the 16 least significant bits of the next position in the current C-SID container (<spanx style="verb">Segment List[Segments Left][DA.Arg.Index-1]</spanx>) otherwise (<spanx style="verb">DA.Arg.Index</spanx> is non-zero).</t>

</section>
<section anchor="sec-replace-flavors"><name>Combination with PSP, USP, and USD flavors</name>

<t>PSP:
When combined with the REPLACE-C-SID flavor, the additional PSP flavor instructions defined in Section 4.16.1.2 of <xref target="RFC8986"/> are inserted after lines R09 and R20 of the pseudocode in <xref target="sec-replace-end"/>, and the first line of the inserted instructions after R20 is modified as follows.</t>

<figure><artwork><![CDATA[
R20.1.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
             Segment List[0][DA.Arg.Index-1] == 0)) {
]]></artwork></figure>

<aside>
  <t>Note: <spanx style="verb">Segment List[Segments Left][DA.Arg.Index-1]</spanx> identifies the value contained in the bits <spanx style="verb">[(DA.Arg.Index-1)*LNFL..DA.Arg.Index*LNFL-1]</spanx> in the SRH Segment List entry at index Segments Left.</t>
</aside>

<t>USP:
When combined with the REPLACE-C-SID flavor, the line S03 of the pseudocode in <xref target="sec-replace-end"/> are substituted by the USP flavor instructions S03.1 to S03.4 defined in Section 4.16.2 of <xref target="RFC8986"/>. Note that S03 is shown in the complete pseudocode in <xref target="sec-replace-end-complete"/>.</t>

<t>USD:
The USD flavor defined in Section 4.16.3 of <xref target="RFC8986"/> is unchanged when combined with the REPLACE-C-SID flavor.</t>

</section>
</section>
</section>
<section anchor="c-sid-allocation"><name>C-SID Allocation</name>

<t>The C-SID value of 0 is reserved. It is used to indicate the end of a C-SID container.</t>

<t>In order to efficiently manage the C-SID numbering space, a deployment may divide it into two non-overlapping sub-spaces: a Global Identifiers Block (GIB) and a Local Identifiers Block (LIB).</t>

<t>The C-SID values that are allocated from the GIB have a global semantic within the Locator-Block, while those that are allocated from the LIB have a local semantic on an SR segment endpoint node and within the scope of the Locator-Block.</t>

<t>The concept of LIB is applicable to SRv6 and specifically to its NEXT-C-SID and REPLACE-C-SID flavors. The shorter the C-SID, the more benefit the LIB brings.</t>

<t>The opportunity to use these sub-spaces, their size, and their C-SID allocation policy depends on the C-SID length relative to the size of the network (e.g., number of nodes, links, service routes). Some guidelines for a typical deployment scenario are provided in the below subsections.</t>

<section anchor="global-c-sid"><name>Global C-SID</name>

<t>A global C-SID is a C-SID allocated from the GIB.</t>

<t>A global C-SID identifies a segment defined at the Locator-Block level. The tuple (Locator-Block, C-SID) identifies the same segment across all nodes of the SR domain. A typical example is a prefix segment bound to the End behavior.</t>

<t>A node can have multiple global C-SIDs under the same Locator-Block (e.g., one per IGP flexible algorithm (<xref target="RFC9350"/>)). Multiple nodes may share the same global C-SID (e.g., anycast).</t>

</section>
<section anchor="local-c-sid"><name>Local C-SID</name>

<t>A local C-SID is a C-SID allocated from the LIB.</t>

<t>A local C-SID identifies a segment defined at the node level and within the scope of a particular Locator-Block. The tuple (Locator-Block, C-SID) identifies a different segment on each node of the SR domain. A typical example is a non-routed Adjacency segment bound to the End.X behavior.</t>

<t>Let N1 and N2 be two different physical nodes of the SR domain and I a local C-SID value, N1 may allocate value I to SID S1 and N2 may allocate the same value I to SID S2.</t>

</section>
<section anchor="sec-c-sid-lib-recommendation"><name>GIB/LIB Usage</name>

<t>GIB and LIB usage is a local implementation and/or configuration decision, however, some guidelines for determining usage for specific SID behaviors and recommendations are provided.</t>

<t>The GIB number space is shared among all SR segment endpoint nodes using SRv6 locators under a Locator-Block space.  The more SIDs assigned from this space, per node, the faster it is exhausted.  Therefore its use is prioritized for global segments, such as SIDs that identify a node.</t>

<t>The LIB number space is unique per node. Each node is able to fully utilize the entire LIB number space without consideration of assignments at other nodes.  Therefore its use is prioritized for local segments, such as SIDs that identify services (of which there may be many) at nodes, cross-connects, or adjacencies.</t>

<t>While a longer C-SID length permits more flexibility in which SID behaviors may be assigned from the GIB, it also reduces the compression efficiency.</t>

<t>Given the previous Locator-Block and C-SID length recommendations, the following GIB/LIB usage is recommended:</t>

<t><list style="symbols">
  <t>NEXT-C-SID:
  <list style="symbols">
      <t>GIB: End</t>
      <t>LIB: End.X, End.T, End.DT4/6/46/2U/2M, End.DX4/6/2/2V (including large-scale pseudowire), End.B6.Encaps, End.B6.Encaps.Red, End.BM</t>
    </list></t>
  <t>REPLACE-C-SID:
  <list style="symbols">
      <t>GIB: End, End.X, End.T, End.DT4/6/46/2U/2M, End.DX4/6/2/2V, End.B6.Encaps, End.B6.Encaps.Red, End.BM</t>
      <t>LIB: End.DX2/2V for large-scale pseudowire</t>
    </list></t>
</list></t>

<t>Any other allocation is possible but may lead to a suboptimal use of the C-SID numbering space.</t>

</section>
<section anchor="sec-c-sid-installation"><name>Recommended Installation of C-SIDs in FIB</name>

<t>Section 4.3 of <xref target="RFC8754"/> defines how an SR segment endpoint node identifies a locally instantiated SRv6 SID. To ensure that any valid argument value is accepted, an SR segment endpoint node instantiating a NEXT-C-SID or REPLACE-C-SID flavor SID should install a corresponding FIB entry that matches only the Locator and Function parts of the SID (i.e., with a prefix length of LBL + LNL + FL).</t>

<t>In addition, an SR segment endpoint node instantiating NEXT-C-SID flavor SIDs from both GIB and LIB may install combined &quot;Global + Local&quot; FIB entries to match a sequence of global and local C-SIDs in a single longest prefix match (LPM) lookup.</t>

<t>For example, let us consider an SR segment endpoint node 10 instantiating the following two NEXT-C-SID flavor SIDs according to the C-SID length, Locator-Block length, and GIB/LIB recommendations in this section.</t>

<t><list style="symbols">
  <t><spanx style="verb">2001:db8:b1:10::</spanx> bound to the End behavior with the NEXT-C-SID flavor is instantiated from GIB with
  <list style="symbols">
      <t>Locator-Block length (LBL) = 48 (Locator-Block value <spanx style="verb">0x20010db800b1</spanx>),</t>
      <t>Locator-Node length (LNL) = 16 (Locator-Node value <spanx style="verb">0x0010</spanx>),</t>
      <t>Function length (FL) = 0, and</t>
      <t>Argument length (AL) = 64.</t>
    </list></t>
  <t><spanx style="verb">2001:db8:b1:f123::</spanx> bound to the End.X behavior for its local IGP adjacency <spanx style="verb">123</spanx> with the NEXT-C-SID flavor is instantiated from LIB with
  <list style="symbols">
      <t>Locator-Block length (LBL) = 48 (Locator-Block value <spanx style="verb">0x20010db800b1</spanx>),</t>
      <t>Locator-Node length (LNL) = 0,</t>
      <t>Function length (FL) = 16 (Function value <spanx style="verb">0xf123</spanx>), and</t>
      <t>Argument length (AL) = 64.</t>
    </list></t>
</list></t>

<t>For SID <spanx style="verb">2001:db8:b1:10::</spanx>, Node 10 would install the FIB entry <spanx style="verb">2001:db8:b1:10::/64</spanx> bound the End SID with the NEXT-C-SID flavor.</t>

<t>For SID <spanx style="verb">2001:db8:b1:f123::</spanx>, Node 10 would install the FIB entry <spanx style="verb">2001:db8:b1:f123::/64</spanx> bound the End.X SID for adjacency <spanx style="verb">123</spanx> with the NEXT-C-SID flavor.</t>

<t>In addition, Node 10 may also install the combined FIB entry <spanx style="verb">2001:db8:b1:10:f123::/80</spanx> bound the End.X SID for adjacency <spanx style="verb">123</spanx> with the NEXT-C-SID flavor.</t>

<t>As another example, let us consider an SR segment endpoint node 20 instantiating the following two REPLACE-C-SID flavor SIDs according to the C-SID length, Locator-Block length, and GIB/LIB recommendations in this section.</t>

<t><list style="symbols">
  <t><spanx style="verb">2001:db8:b2:20:1::</spanx> from GIB with Locator-Block length (LBL) = 48, Locator-Node length (LNL) = 16, Function length (FL) = 16, Argument length (AL) = 48, and bound to the End behavior with the REPLACE-C-SID flavor.</t>
  <t><spanx style="verb">2001:db8:b2:20:123::</spanx> from GIB with Locator-Block length (LBL) = 48, Locator-Node length (LNL) = 16, Function length (FL) = 16, Argument length (AL) = 48, and bound to the End.X behavior for its local IGP adjacency <spanx style="verb">123</spanx> with the REPLACE-C-SID flavor.</t>
</list></t>

<t>For SID <spanx style="verb">2001:db8:b2:20:1::</spanx>, Node 20 would install the FIB entry <spanx style="verb">2001:db8:b2:20:1::/80</spanx> bound the End SID with the REPLACE-C-SID flavor.</t>

<t>For SID <spanx style="verb">2001:db8:b2:20:123::</spanx>, Node 20 would install the FIB entry <spanx style="verb">2001:db8:b2:20:123::/80</spanx> bound the End.X SID for adjacency <spanx style="verb">123</spanx> with the REPLACE-C-SID flavor.</t>

</section>
</section>
<section anchor="sec-source-node"><name>SR Source Node</name>

<t>An SR source node may learn from a control plane protocol (see <xref target="sec-control-plane"/>) or local configuration the SIDs that it can use in a segment list, along with their respective SR segment endpoint behavior, flavors, structure, and any other relevant attribute (e.g., the set of L3 adjacencies associated with an End.X SID).</t>

<section anchor="sid-validation-for-compression"><name>SID Validation for Compression</name>

<t>As part of the compression process or as a preliminary step, the SR source node MUST validate the SID structure of each SID of this document in the segment list. The SR source node does so regardless of whether the segment list is explicitly configured, locally computed, or advertised by a controller (e.g., via BGP <xref target="I-D.ietf-idr-sr-policy-safi"/> or PCEP <xref target="I-D.ietf-pce-segment-routing-ipv6"/>).</t>

<t>A SID structure is valid for compression if it meets all the following conditions.</t>

<t><list style="symbols">
  <t>The Locator-Block length is not 0.</t>
  <t>The sum of the Locator-Node length and Function length is not 0.</t>
  <t>The Argument length is equal to 128-LBL-LNL-FL.</t>
</list></t>

<t>When compressing a SID list, the SR source node MUST treat an invalid SID structure as unknown. A SID with an unknown SID structure is incompressible.</t>

<t><xref target="sec-control-plane"/> discusses how the SIDs of this document and their structure can be advertised to the SR source node through various control plane protocols. The SID structure may also be learned through configuration or
other management protocols. The details of such mechanisms are outside the scope of this document.</t>

</section>
<section anchor="sec-source-compression"><name>Segment List Compression</name>

<t>An SR source node MAY compress a SID list when it includes NEXT-C-SID and/or REPLACE-C-SID flavor SIDs in order to reduce the packet header length.</t>

<t>It is out of the scope of this document to describe the mechanism through which an uncompressed SID list is derived. As a general guidance for implementation or future specification, such a mechanism should aim to select the combination of SIDs that would result in the shortest compressed SID list. For example, by selecting a C-SID flavor SID over an equivalent non-C-SID flavor SID or by consistently selecting SIDs of the same C-SID flavor within each routing domain.</t>

<t>The SID list that the SR source node pushes onto the packet MUST comply with the rules in <xref target="sec-source-next"/> and <xref target="sec-source-replace"/> and express the same list of segments as the original SID list. If these rules are not followed, the packet may get dropped or misrouted.</t>

<t>If an SR source node chooses to compress the SID list, one method is described below for illustrative purposes. Any other method producing a compressed SID list of equal or shorter length than the uncompressed SID list is compliant.</t>

<t>This method walks the uncompressed SID list and compresses each series of consecutive NEXT-C-SID flavor SIDs and each series of consecutive REPLACE-C-SID flavor SIDs.</t>

<t><list style="symbols">
  <t>When the compression method encounters a series of one or more consecutive compressible NEXT-C-SID flavor SIDs, it compresses the series as follows. A SID with the NEXT-C-SID flavor is compressible if its structure is known to the SR source node and its Argument value is 0.</t>
</list></t>

<figure><artwork><![CDATA[
S01. Initialize a C-SID container equal to the first SID in the
       series, and initialize the remaining capacity of the C-SID
       container to the AL of that SID
S02. For each subsequent SID in the series {
S03.   If the current SID Locator-Block matches that of the C-SID
         container and the current SID LNFL is lower than or equal to
         the remaining capacity of the C-SID container {
S04.     Copy the current SID Locator-Node and Function to the most
           significant remaining Argument bits of the C-SID container
           and decrement the remaining capacity by LNFL
S05.   } Else {
S06.     Push the C-SID container onto the compressed SID list
S07.     Initialize a new C-SID container equal to the current SID in
           the series, and initialize the remaining capacity of the
           C-SID container to the AL of that SID
S08.   } // End If
S09. } // End For
S10. If at least one SID remains in the uncompressed SID list
       (following the series of compressible NEXT-C-SID flavor SIDs){
S11.   Set S to the next SID in the uncompressed SID list
S12.   If S is advertised with a SID structure, and the Locator-Block
         of S matches that of the C-SID container, and the sum of the
         Locator-Node, Function, and Argument length of S is lower
         than or equal to the remaining capacity of the C-SID
         container {
S13.     Copy the Locator-Node, Function, and Argument of S to the
           most significant remaining Argument bits of the C-SID
           container
S14.   } // End If
S15. } // End If
S16. Push the C-SID container onto the compressed SID list
]]></artwork></figure>

<t><list style="symbols">
  <t>When the compression method encounters a series of REPLACE-C-SID flavor SIDs of the same C-SID length in the uncompressed SID list, it compresses the series as per the following high-level pseudo code. A compression checking function ComCheck(F, S) is defined to check if two SIDs F and S share the same SID structure and Locator-Block value, and if S has either no Argument or an Argument with value 0. If the check passes, then ComCheck(F,S) returns true.</t>
</list></t>

<figure><artwork><![CDATA[
S01. Initialize the first C-SID container in full SID format equal to
       the first SID in the series
S02. Initialize the second C-SID container in packed format if there
       are more than one SIDs, and initialize the remaining capacity
       of the C-SID container to 128 bits
S03. For each subsequent SID in the uncompressed SID list {
S04.   Set S to the current SID in the uncompressed SID list
S05.   If ComCheck(First SID, S) {
S06.     If the LNFL of S is lower than or equal to
           the remaining capacity of the C-SID container {
S07.       Copy the Locator-Node and Function of S to the least
             significant remaining bits of the C-SID container
             and decrement the remaining capacity by LNFL  // Note
S08.     } Else {
S09.       Push the C-SID container onto the compressed SID list
S10.       Initialize a new C-SID container in packed format with all
             bits set to 0
S11        Copy the Locator-Node and Function of S to the least
             significant remaining bits of the C-SID container
             and decrement the remaining capacity by LNFL  // Note
S12.     }
S13.     If S is not a REPLACE-C-SID flavor SID, then break
S14.   } Else {
S15.     Break
S16.   } // End If
S17. } // End For
S18. Push the C-SID container (if it is not empty) onto the
       compressed SID list
]]></artwork></figure>

<aside>
  <t>Note: When the last C-SID is an End.DT2M SID with the REPLACE-C-SID flavor, if there is 0 or at least two C-SID positions left in the current C-SID container, the C-SID is encoded as described above and the value of the Arg.FE2 argument is placed in the 16 least significant bits of the next C-SID position. Otherwise (if there is only one C-SID position left in the current C-SID container), the current C-SID container is pushed onto the SID list (the value of the C-SID position 0 remains zero) and the End.DT2M SID with the REPLACE-C-SID flavor is encoded in full SID format with the value of the Arg.FE2 argument in the 16 most significant bits of the SID Argument.</t>
</aside>

<t><list style="symbols">
  <t>In all remaining cases (i.e., when the compression method encounters a SID in the uncompressed SID list that is not handled by any of the previous subroutines), it pushes this SID as is onto the compressed SID list.</t>
</list></t>

<t>Regardless of how a compressed SID list is produced, the SR source node writes it in the IPv6 packet as described in Sections 4.1 and 4.1.1 of <xref target="RFC8754"/>. The text is reproduced below for reference.</t>

<blockquote>
  <t>A source node steers a packet into an SR Policy. If the SR Policy
results in a Segment List containing a single segment, and there is
no need to add information to the SRH flag or add TLV; the DA is set
to the single Segment List entry, and the SRH MAY be omitted.</t>

  <t>When needed, the SRH is created as follows:</t>

  <t>The Next Header and Hdr Ext Len fields are set as specified in
  <xref target="RFC8200"></xref>.</t>

  <t>The Routing Type field is set to 4.</t>

  <t>The DA of the packet is set with the value of the first segment.</t>

  <t>The first element of the SRH Segment List is the ultimate segment.
  The second element is the penultimate segment, and so on.</t>

  <t>The Segments Left field is set to n-1, where n is the number of
  elements in the SR Policy.</t>

  <t>The Last Entry field is set to n-1, where n is the number of
  elements in the SR Policy.</t>

  <t>TLVs (including HMAC) may be set according to their specification.</t>

  <t>The packet is forwarded toward the packet&#39;s Destination Address
  (the first segment).</t>

  <t>When a source does not require the entire SID list to be preserved
in the SRH, a reduced SRH may be used.</t>

  <t>A reduced SRH does not contain the first segment of the related SR
Policy (the first segment is the one already in the DA of the IPv6
header), and the Last Entry field is set to n-2, where n is the
number of elements in the SR Policy.</t>
</blockquote>

</section>
<section anchor="sec-source-next"><name>Rules for segment lists containing NEXT-C-SID flavor SIDs</name>

<t><list style="numbers">
  <t>If a Destination Option header would follow an SRH with a segment list of more than one segment compressed as a single NEXT-C-SID container, the SR source node MUST NOT omit the SRH.</t>
  <t>When the last Segment List entry (index 0) in the SRH is a C-SID container representing more than one segment, the PSP operation is performed at the segment preceding the first segment of this C-SID container in the segment list. If the PSP behavior should instead be performed at the penultimate segment along the path, the SR source node MUST NOT compress the ultimate SID of the SID list into a C-SID container.</t>
  <t>If a Destination Option header would follow an SRH with a last Segment List entry being a NEXT-C-SID container representing more than one segment, the SR source node MUST ensure that the PSP operation is not performed before the penultimate SR segment endpoint node along the path.</t>
</list></t>

</section>
<section anchor="sec-source-replace"><name>Rules for segment lists containing REPLACE-C-SID flavor SIDs</name>

<t><list style="numbers">
  <t>All SIDs compressed in a REPLACE-C-SID sequence MUST share the same Locator-Block and the same compression scheme.</t>
  <t>All SIDs except the last one in a C-SID sequence for REPLACE-C-SID MUST have the REPLACE-C-SID flavor. If the last C-SID container is fully filled (i.e., the last C-SID is at position 0 in the C-SID container) and the last SID in the C-SID sequence is not the last segment in the segment list, the last SID in the C-SID sequence MUST NOT have the REPLACE-C-SID flavor.</t>
  <t>When a REPLACE-C-SID flavor C-SID is present as the last SID in a container that is not the last Segment List entry (index 0) in the SRH, the next element in the SID list MUST be a REPLACE-C-SID container in packed format carrying at least one C-SID.</t>
</list></t>

<t>The SR source node determines the compression scheme of REPLACE-C-SID flavor SIDs as follows.</t>

<t>When receiving a SID advertisement for a REPLACE-C-SID flavor SID with LNL=16, FL=0, AL=128-LBL-NL-FL, and the value of the Argument is all 0, the SR source node marks both the SID and its locator as using 16-bit compression. All other SIDs allocated from this locator with LNL=16, FL=16, AL=128-LBL-NL-FL, and the value of the Argument is all 0 are also marked as using 16-bit compression. When receiving a SID advertisement for a REPLACE-C-SID flavor SID with LNFL=32, AL=128-LBL-NL-FL, and the value of the Argument is all 0, the SR source node marks both the SID and its locator as using 32-bit compression.</t>

</section>
<section anchor="sec-source-checksum"><name>Upper-Layer Checksums</name>

<t>The Destination Address used in the IPv6 pseudo-header (Section 8.1 of <xref target="RFC8200"/>) is that of the ultimate destination.</t>

<t>At the SR source node, that address will be the Destination Address as it is expected to be received by the ultimate destination. When the last element in the compressed SID list is a C-SID container, this address can be obtained from the last element in the uncompressed SID list or by repeatedly applying the segment behavior as described in <xref target="sec-operations-icmp-error"/>. This applies regardless of whether an SRH is present in the IPv6 packet or omitted.</t>

<t>At the ultimate destination(s), that address will be in the Destination Address field of the IPv6 header.</t>

</section>
</section>
<section anchor="inter-domain-compression"><name>Inter-Domain Compression</name>

<t>Some SRv6 traffic may need to cross multiple routing domains, such as different Autonomous Systems (ASes) or different routing areas within an SR domain. Different routing domains may use different addressing schema and Locator-Blocks.</t>

<t>A property of a C-SID sequence is that all C-SIDs in the sequence share the same Locator-Block. Therefore, a segment list that spans across multiple routing domains using different Locator-Blocks may need a separate C-SID sequence for each domain.</t>

<t>This section defines an OPTIONAL solution to improve the efficiency of C-SID compression in multi-domain environments by enabling a C-SID sequence to combine C-SIDs having different Locator-Blocks.</t>

<t>The solution leverages two new SR segment endpoint behaviors, &quot;Endpoint with SRv6 Prefix Swap&quot; (&quot;End.PS&quot; for short) and &quot;Endpoint with L3 cross-connect and SRv6 Prefix Swap&quot; (&quot;End.XPS&quot; for short), that enable modifying the Locator-Block for the next C-SID in the C-SID sequence at the routing domain boundary.</t>

<section anchor="endps-prefix-swap"><name>End.PS: Prefix Swap</name>

<t>The End.PS behavior is a variant of the End behavior that modifies the Locator-Block of the active C-SID sequence. This document defines the End.PS behavior with the NEXT-C-SID flavor and the End.PS behavior with the REPLACE-C-SID flavor.</t>

<t>An End.PS SID is used to transition to a new Locator-Block when the routing domain boundary is on the SR segment endpoint node.</t>

<t>Each instance of an End.PS SID is associated with a target Locator-Block B2/m, where B2 is an IPv6 address prefix and m is the associated prefix length. The target Locator-Block is a local property of the End.PS SID on the SR segment endpoint node.</t>

<aside>
  <t>Note: a local SID property is an attribute associated with the SID when it is instantiated on the SR segment endpoint node. When the SR segment endpoint node identifies the destination address of a received packet as a locally instantiated SID, it also retrieves any local property associated with this SID. Other examples of local SID properties include the set of L3 adjacencies of an End.X SID (Section 4.2 of <xref target="RFC8986"/>) and the lookup table of an End.DT6 SID (Section 4.6 of <xref target="RFC8986"/>).</t>
</aside>

<t>The means by which an SR source node learns the target Locator-Block associated with an End.PS SID are outside the scope of this document. As examples, it could be learnt via configuration or signaled by a controller.</t>

<section anchor="sec-next-endps"><name>End.PS with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.PS SID with the NEXT-C-SID flavor and associated with the target Locator-Block B2/m, the SR segment endpoint node applies the procedure specified in <xref target="sec-next-end"/> with the lines N05 to N06 replaced as follows.</t>

<figure><artwork><![CDATA[
N05.1. Initialize an IPv6 address A equal to B2.
N05.2. Copy DA.Argument into the bits [m..(m+AL-1)] of A.
N06.   Copy A to the Destination Address of the IPv6 header.
]]></artwork></figure>

</section>
<section anchor="sec-replace-endps"><name>End.PS with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.PS SID with the REPLACE-C-SID flavor and associated with the target Locator-Block B2/m, the SR segment endpoint node applies the procedure specified in <xref target="sec-replace-end"/> with the line R20 replaced as follows.</t>

<figure><artwork><![CDATA[
R20.1. Initialize an IPv6 address A equal to B2.
R20.2. Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [m..m+LNFL-1] of the Destination Address of the IPv6 header.
R20.3. Copy A to the Destination Address of the IPv6 header.
]]></artwork></figure>

</section>
</section>
<section anchor="endxps-l3-cross-connect-and-prefix-swap"><name>End.XPS: L3 Cross-Connect and Prefix Swap</name>

<t>The End.XPS behavior is a variant of the End.X behavior that modifies the Locator-Block of the active C-SID sequence. This document defines the End.XPS behavior with the NEXT-C-SID flavor and the End.XPS behavior with the REPLACE-C-SID flavor.</t>

<t>An End.XPS SID is used to transition to a new Locator-Block when the routing domain boundary is on a link adjacent to the SR segment endpoint node.</t>

<t>Each instance of an End.XPS SID is associated with a target Locator-Block B2/m and a set, J, of one or more L3 adjacencies. The target Locator-Block and set of adjacencies are local properties of the End.XPS SID on the SR segment endpoint node.</t>

<t>The means by which an SR source node learns the target Locator-Block associated with an End.XPS SID are outside the scope of this document. As examples, it could be learnt via configuration or signaled by a controller.</t>

<section anchor="sec-next-endxps"><name>End.XPS with NEXT-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.XPS SID with the NEXT-C-SID flavor and associated with the target Locator-Block B2/m, the SR segment endpoint node applies the procedure specified in <xref target="sec-next-endx"/> with the lines N05 to N06 (of the pseudocode in <xref target="sec-next-end"/>) replaced as follows.</t>

<figure><artwork><![CDATA[
N05.1. Initialize an IPv6 address A equal to B2.
N05.2. Copy DA.Argument into the bits [m..(m+AL-1)] of A.
N06.   Copy A to the Destination Address of the IPv6 header.
]]></artwork></figure>

</section>
<section anchor="sec-replace-endxps"><name>End.XPS with REPLACE-C-SID</name>

<t>When processing an IPv6 packet that matches a FIB entry locally instantiated as an End.XPS SID with the REPLACE-C-SID flavor and associated with the target Locator-Block B2/m, the SR segment endpoint node applies the procedure specified in <xref target="sec-replace-endx"/> with the line R20 (of the pseudocode in <xref target="sec-replace-end"/>) replaced as follows.</t>

<figure><artwork><![CDATA[
R20.1. Initialize an IPv6 address A equal to B2.
R20.2. Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [m..m+LNFL-1] of the Destination Address of the IPv6 header.
R20.3. Copy A to the Destination Address of the IPv6 header.
]]></artwork></figure>

</section>
</section>
</section>
<section anchor="sec-control-plane"><name>Control Plane</name>

<t>This document does not require any new extensions to routing protocols.</t>

<t>Section 8 of <xref target="RFC8986"/> provides an overview of the control plane protocols used for signaling of the SRv6 SIDs introduced by that document.
The SRv6 SIDs introduced by this document are advertised using the same SRv6 extensions for various routing protocols, such as</t>

<t><list style="symbols">
  <t>IS-IS <xref target="RFC9352"/></t>
  <t>OSPFv3 <xref target="RFC9513"/></t>
  <t>BGP <xref target="RFC9252"/>, <xref target="RFC9514"/>, <xref target="I-D.ietf-idr-sr-policy-safi"/></t>
  <t>BGP-LS <xref target="I-D.ietf-idr-bgp-ls-sr-policy"/></t>
  <t>PCEP <xref target="I-D.ietf-pce-segment-routing-ipv6"/></t>
</list></t>

<t>The SR segment endpoint node MUST set the SID Argument bits to 0 when advertising a locally instantiated SID of this document in the routing protocol (e.g., IS-IS <xref target="RFC9352"/>, OSPF <xref target="RFC9513"/>, or BGP-LS <xref target="RFC9514"/>).</t>

<t>Signaling the SRv6 SID Structure is REQUIRED for all the SIDs introduced in this document. It is used by an SR source node to compress a SID list as described in <xref target="sec-source-node"/>.
The node initiating the SID advertisement MUST set the length values in the SRv6 SID Structure to match the format of the SID on the SR segment endpoint node. For example, for a SID of this document instantiated from a /48 SRv6 SID block and a /64 Locator, and having a 16-bit Function, the SRv6 SID Structure advertisement carries the following values.</t>

<t><list style="symbols">
  <t>Locator-Block length: 48</t>
  <t>Locator-Node length: 16</t>
  <t>Function length: 16</t>
  <t>Argument length: 48 (= 128-48-16-16)</t>
</list></t>

<t>A local C-SID may be advertised in the control plane individually and/or in combination with a global C-SID instantiated on the same SR segment endpoint node, with the End behavior, and the same Locator-Block and flavor as the local C-SID. A combined global and local C-SID is advertised as follows.</t>

<t><list style="symbols">
  <t>The SID Locator-Block is that shared by the global and local C-SIDs</t>
  <t>The SID Locator-Node is that of global C-SID</t>
  <t>The SID Function is that of the local C-SID</t>
  <t>The SID Argument length is equal to 128-LBL-LNL-FL and the SID Argument value is 0</t>
  <t>All other attributes of the SID (e.g., endpoint behavior or algorithm) are those of the local C-SID</t>
</list></t>

<t>The local C-SID combined advertisement is needed in particular for control plane protocols mandating that the SID is a subnet of a locator advertised in the same protocol (e.g., Section 8 of <xref target="RFC9352"/> and Section 9 of <xref target="RFC9513"/> for advertising Adjacency SIDs in IS-IS and OSPFv3, respectively).</t>

<t>For a segment list computed by a controller and signaled to an SR source node (e.g., via BGP <xref target="I-D.ietf-idr-sr-policy-safi"/> or PCEP <xref target="I-D.ietf-pce-segment-routing-ipv6"/>), the controller provides the ordered segment list comprising the uncompressed SIDs, with their respective behavior and structure, to the SR source node. The SR source node may then compress the SID list as described in <xref target="sec-source-node"/>.</t>

<t>When a node that does not support this specification receives an advertisement of a SID of this document, it handles it as described in the corresponding control plane specification (e.g., Sections 7.2, 8.1, and 8.2 of <xref target="RFC9352"/>, Sections 8, 9.1, and 9.2 of <xref target="RFC9513"/>, and Section 3.1 of <xref target="RFC9252"/>).</t>

</section>
<section anchor="operational-considerations"><name>Operational Considerations</name>

<section anchor="pinging-a-sid"><name>Pinging a SID</name>

<t>An SR source node may ping an SRv6 SID by sending an ICMPv6 echo request packet destined to the SRv6 SID, with or without intermediate segments. This operation is illustrated in Appendix A.1.2 of <xref target="RFC9259"/>.</t>

<t>When pinging a SID of this document, with or without intermediate segments, the SR source node MUST construct the IPv6 packet as described in <xref target="sec-source-node"/>, including computing the ICMPv6 checksum as described in <xref target="sec-source-checksum"/>.</t>

<t>In particular, when pinging a SID of this document without intermediate segments, the SR source node places the SID with Argument value 0 in the destination address of the ICMPv6 echo request and computes the ICMPv6 checksum using this SID as the destination address in the IPv6 pseudo-header. The Argument value 0 allows the SID SR segment endpoint node (<xref target="sec-endpoint"/>) to identify itself as the ultimate destination of the packet and process the ICMPv6 payload.</t>

<t>An operator originating ICMP echo requests to a NEXT-C-SID or REPLACE-C-SID flavor SID using the simplified SR source node processing described in the previous paragraph should ensure that the SID Argument is 0.</t>

</section>
<section anchor="sec-operations-icmp-error"><name>ICMP Error Processing</name>

<t>When an IPv6 node encounters an error while processing a packet, it may report that error by sending an IPv6 error message to the packet source with an enclosed copy of the invoking packet. For the source of an invoking packet to process the ICMP error message, the ultimate destination address of the IPv6 header may be required.</t>

<t>Section 5.4 of <xref target="RFC8754"/> defines the logic that an SR source node follows to determine the ultimate destination of an invoking packet containing an SRH.</t>

<t>For an SR source node that supports the compressed segment list encoding defined in this document, the logic to determine the ultimate destination is generalized as follows.</t>

<t><list style="symbols">
  <t>If the destination address of the invoking IPv6 packet matches a known SRv6 SID, modify the invoking IPv6 packet by applying the SID behavior associated with the matched SRv6 SID;</t>
  <t>Repeat until the application of the SID behavior would result in the processing of the upper-layer header.</t>
</list></t>

<t>The destination address of the resulting IPv6 packet may be used as the ultimate destination of the invoking IPv6 packet.</t>

<t>Since the SR source node that needs to determine the ultimate destination is the same node that originally built the SID list in the invoking packet, it is able to perform this operation for all the SIDs in the packet.</t>

</section>
<section anchor="upper-layer-checksum-considerations"><name>Upper Layer Checksum Considerations</name>

<t>Upper layer checksums are computed by the originator of an IPv6 packet and verified by the ultimate destination(s) as it processes the upper layer protocol.</t>

<t>As specified in <xref target="sec-source-checksum"/>, SR source nodes originating TCP/UDP packets ensure that the upper layer checksum is correctly calculated based on the ultimate destination of the session, which may be different from the address placed in the IPv6 destination address. Such SR source nodes leveraging TCP/UDP offload engines may require enhancements to convey the ultimate destination address. These implementation enhancements are outside the scope of this document.</t>

<t>It was reported that some network node implementations, including middleboxes such as packet sniffers and one software router implementation, may attempt to verify the upper layer checksum of transit IPv6 packets. These nodes, if deployed inside the SR domain, may fail to verify the upper layer checksum of transit SRv6 traffic, possibly resulting in dropped packets or in the inability to carry out their function. Making these implementations SRv6 aware in general or C-SID aware in particular is out of the scope of this document.</t>

</section>
</section>
<section removeInRFC="true" anchor="implementation-status"><name>Implementation Status</name>

<t>RFC-Editor: Please clean up the references cited by this section before publication.</t>

<t>This section records the status of known implementations of the
protocol defined by this specification at the time of posting of
this Internet-Draft, and is based on a proposal described in
<xref target="RFC7942"/>.  The description of implementations in this section is
intended to assist the IETF in its decision processes in
progressing drafts to RFCs.  Please note that the listing of any
individual implementation here does not imply endorsement by the
IETF.  Furthermore, no effort has been spent to verify the
information presented here that was supplied by IETF contributors.
This is not intended as, and must not be construed to be, a
catalog of available implementations or their features.  Readers
are advised to note that other implementations may exist.</t>

<t>According to <xref target="RFC7942"/>, &quot;this will allow reviewers and working
groups to assign due consideration to documents that have the
benefit of running code, which may serve as evidence of valuable
experimentation and feedback that have made the implemented
protocols more mature.  It is up to the individual working groups
to use this information as they see fit&quot;.</t>

<t>This section is provided in compliance with the SPRING working group policies (<xref target="SPRING-WG-POLICIES"/>).</t>

<section anchor="cisco-systems"><name>Cisco Systems</name>

<t>Cisco Systems reported the following implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>) and the SR source node efficient SID list encoding (<xref target="sec-source-node"/>) for NEXT-C-SID flavor SIDs. These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities.</t>

<t><list style="symbols">
  <t>Cisco NCS 540 Series routers running IOS XR 7.3.x or above <xref target="IMPL-CISCO-NCS540"/></t>
  <t>Cisco NCS 560 Series routers running IOS XR 7.6.x or above <xref target="IMPL-CISCO-NCS560"/></t>
  <t>Cisco NCS 5500 Series routers running IOS XR 7.3.x or above <xref target="IMPL-CISCO-NCS5500"/></t>
  <t>Cisco NCS 5700 Series routers running IOS XR 7.5.x or above <xref target="IMPL-CISCO-NCS5700"/></t>
  <t>Cisco 8000 Series routers running IOS XR 7.5.x or above <xref target="IMPL-CISCO-8000"/></t>
  <t>Cisco ASR 9000 Series routers running IOS XR 7.5.x or above <xref target="IMPL-CISCO-ASR9000"/></t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID flavor.</t>

<t>This report was last updated on January 11, 2023.</t>

</section>
<section anchor="huawei-technologies"><name>Huawei Technologies</name>

<t>Huawei Technologies reported the following implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>).
These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities.</t>

<t><list style="symbols">
  <t>Huawei ATN8XX,ATN910C,ATN980B routers running VRPV800R021C00 or above.</t>
  <t>Huawei CX600-M2 routers running VRPV800R021C00 or above.</t>
  <t>Huawei NE40E,ME60-X1X2,ME60-X3X8X16 routers running VRPV800R021C00 or above.</t>
  <t>Huawei NE5000E,NE9000 routers running VRPV800R021C00 or above.</t>
  <t>Huawei NCE-IP Controller running V1R21C00 or above.</t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the REPLACE-C-SID flavor.</t>

<t>This report was last updated on January 11, 2023.</t>

</section>
<section anchor="nokia"><name>Nokia</name>

<t>Nokia reported the following implementations (<xref target="IMPL-NOKIA-20.10"/>) of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>).  These are used as part of its shortest path forwarding (in algorithm 0 and Flex-Algo), remote and TI-LFA repair tunnel, and Traffic Engineering functionalities.</t>

<t><list style="symbols">
  <t>Nokia 7950 XRS 20/20e routers running SROS Release 22.10 or above</t>
  <t>Nokia 7750 SR-12e routers running SROS Release 22.10 or above</t>
  <t>Nokia 7750 SR-7/12 routers running SROS Release 22.10 or above</t>
  <t>Nokia 7750 SR-7s/14s routers running SROS Release 22.10 or above</t>
  <t>Nokia 7750 SR-1/1s/2s routers running SROS Release 22.10 or above</t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID flavor.</t>

<t>This report was last updated on February 3, 2023.</t>

</section>
<section anchor="arrcus"><name>Arrcus</name>

<t>Arrcus reported the following implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>). These are used as part of its SRv6 shortest path forwarding (in algorithm 0 and Flex-Algo),  TI-LFA, micro-loop avoidance and Traffic Engineering functionalities.</t>

<t><list style="symbols">
  <t>Arrcus running on Ufi Space routers S9510-28DC, S9710-76D, S9600-30DX and S9700-23D with ArcOS v5.2.1 or above</t>
  <t>Arrcus running n Ufi Space routers S9600-72XC and S9700-53DX with ArcOS v5.1.1D or above</t>
  <t>Arrcus running on Quanta router IXA and IXAE with ArcOS v5.1.1D or above</t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID flavor.</t>

<t>This report was last updated on March 11, 2023.</t>

</section>
<section anchor="juniper-networks"><name>Juniper Networks</name>

<t>Juniper Networks reported the following implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>). These are used as part of its SRv6 shortest path forwarding (in algorithm 0 and Flex-Algo), TI-LFA, micro-loop avoidance, and Traffic Engineering functionalities.</t>

<t>Juniper release 23.3 onwards supports this functionality.</t>

<t>At the time of this report, all the implementations listed above are in development and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID flavor.</t>

<t>This report was last updated on May 30, 2023.</t>

</section>
<section anchor="marvell"><name>Marvell</name>

<t>Marvell reported support in the Marvell Prestera Packet Processor for the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>) and REPLACE-C-SID flavor (<xref target="sec-replace"/>).</t>

<t>This report was last updated on February 15, 2023.</t>

</section>
<section anchor="broadcom"><name>Broadcom</name>

<t>Broadcom reported the following implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>) and REPLACE-C-SID flavor (<xref target="sec-replace"/>).  These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities. All implementation of the following list is in general availability for customers using BCM SDK 6.5.26 or above.</t>

<t><list style="symbols">
  <t>88850 (Jericho2c+) series</t>
  <t>88690 (Jericho2) series</t>
  <t>88800 (Jericho2c) series</t>
  <t>88480 (Qunran2a) series</t>
  <t>88280 (Qunran2u) series</t>
  <t>88295 (Qunran2n) series</t>
  <t>88830 (Jericho2x) series</t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID and REPLACE-C-SID flavors.</t>

<t>For 78900 (Tomahawk) series-related support, please contact the Broadcom team.</t>

<t>This report was last updated on February 21, 2023.</t>

</section>
<section anchor="zte-corporation"><name>ZTE Corporation</name>

<t>ZTE Corporation reported the following implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>). These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities.</t>

<t><list style="symbols">
  <t>ZTE M6000-18S(BRAS), M6000-8S Plus(BRAS) routers running V5.00.10.09 or above.</t>
  <t>ZTE M6000-18S(SR), M6000-8S Plus(SR) routers running V5.00.10.80 or above.</t>
  <t>ZTE T8000-18 routers running V5.00.10.07 or above.</t>
</list></t>

<t>This report was last updated on March 29, 2023.</t>

</section>
<section anchor="new-h3c-technologies"><name>New H3C Technologies</name>

<t>New H3C Technologies reported the following implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>). These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities.</t>

<t><list style="symbols">
  <t>H3C CR16000-F, SR8800-X routers running Version 7.1.075 or above.</t>
  <t>H3C CR18000, CR19000 routers running Version 7.1.071 or above.</t>
</list></t>

<t>This report was last updated on March 29, 2023.</t>

</section>
<section anchor="ruijie-network"><name>Ruijie Network</name>

<t>Ruijie Network reported the following implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>). These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities.</t>

<t><list style="symbols">
  <t>RUIJIE RG-N8018-R, RG-N8010-R routers running N8000-R_RGOS 12.8(3)B0801 or above.</t>
</list></t>

<t>This report was last updated on March 29, 2023.</t>

</section>
<section anchor="ciena"><name>Ciena</name>

<t>Ciena reported the following implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>). These are used as part of its shortest path forwarding (in algorithm 0 and Flex-Algo), remote and TI-LFA repair tunnel, and Traffic Engineering functionalities.</t>

<t>The following platforms support implementation of the above.</t>

<t><list style="symbols">
  <t>Ciena 5162, 5164, 5166, 5168 routers running SAOS 10.10 or above</t>
  <t>Ciena 8110, 8112, 8190 routers running SAOS 10.10 or above</t>
</list></t>

<t>At the time of this report, all the implementations listed above are in production and follow the specification in the latest version of this document, including all the &quot;MUST&quot; and &quot;SHOULD&quot; clauses for the NEXT-C-SID flavor.</t>

<t>This report was last updated on February 6, 2024.</t>

</section>
<section anchor="centec"><name>Centec</name>

<t>Centec reported the following implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>). These are used as part of its SRv6 TI-LFA, micro-loop avoidance, and traffic engineering functionalities. All implementation of the following list is in general availability for customers using Centec SDK 5.6.8 or above.</t>

<t><list style="symbols">
  <t>CTC7132 (TsingMa) Series</t>
  <t>CTC8180 (TsingMa.MX) Series</t>
</list></t>

<t>This report was last updated on February 14, 2024.</t>

</section>
<section anchor="open-source"><name>Open Source</name>

<t>The authors found the following open source implementations of the SR segment endpoint node NEXT-C-SID flavor (<xref target="sec-next"/>).</t>

<t><list style="symbols">
  <t>The Linux kernel, version 6.1 <xref target="IMPL-OSS-LINUX"/></t>
  <t>The Software for Open Networking in the Cloud (SONiC), version 202212 <xref target="IMPL-OSS-SONIC"/>, and Switch Abstraction Interface (SAI), version  1.9.0 <xref target="IMPL-OSS-SAI"/></t>
  <t>The Vector Packet Processor (VPP), version 20.05 <xref target="IMPL-OSS-VPP"/></t>
  <t>A generic P4 implementation <xref target="IMPL-OSS-P4"/></t>
</list></t>

<t>The authors found the following open source implementations of the SR segment endpoint node REPLACE-C-SID flavor (<xref target="sec-replace"/>).</t>

<t><list style="symbols">
  <t>ONOS and P4 Programmable Switch based <xref target="IMPL-OSS-ONOS"/></t>
  <t>Open SRv6 Project <xref target="IMPL-OSS-OPEN-SRV6"/></t>
</list></t>

<t>This section was last updated on January 11, 2023.</t>

</section>
<section anchor="interoperability-reports"><name>Interoperability Reports</name>

<section anchor="bell-canada-ciena-2023"><name>Bell Canada / Ciena 2023</name>

<t>Bell Canada is currently evaluating interoperability between Ciena and Cisco implementations of the NEXT-C-SID flavor defined in this document. Further information will be added to this section when the evaluation is complete.</t>

</section>
<section anchor="eantc-2023"><name>EANTC 2023</name>

<t>In April 2023, the European Advanced Networking Test Center (EANTC) successfully validated multiple implementations of SRv6 NEXT-C-SID flavor (a.k.a., SRv6 uSID) <xref target="EANTC-23"/>.</t>

<t>The participating vendors included Arista, Arrcus, Cisco, Huawei, Juniper, Keysight, Nokia, and Spirent.</t>

</section>
<section anchor="china-mobile-2020"><name>China Mobile 2020</name>

<t>In November 2020, China Mobile successfully validated multiple interoperable implementations of the NEXT-C-SID and REPLACE-C-SID flavors defined in this document.</t>

<t>This testing covered two different implementations of the SRv6 endpoint flavors defined in this document:</t>

<t><list style="symbols">
  <t>Hardware implementation in Cisco ASR 9000 running IOS XR</t>
  <t>Software implementation in Cisco IOS XRv9000 virtual appliance</t>
  <t>Hardware implementation in Huawei NE40E and NE5000E running VRP</t>
</list></t>

<t>The interoperability testing consisted of a packet flow sent by an SR source node N0 via an SR traffic engineering policy with a segment list <spanx style="verb">&lt;S1, S2, S3, S4, S5, S6, S7&gt;</spanx>, where S1..S7 are SIDs instantiated on SR segment endpoint nodes N1..N7, respectively.</t>

<figure><artwork><![CDATA[
N0 --- N1 --- N2 --- N3 --- N4 --- N5 --- N6 --- N7
      (S1)   (S2)   (S3)   (S4)   (S5)   (S6)   (S7)
]]></artwork></figure>

<t><list style="symbols">
  <t>N0 is a generic packet generator.</t>
  <t>N1, N2, and N3 are Huawei routers.</t>
  <t>N4, N5, and N6 are Cisco routers.</t>
  <t>N7 is a generic traffic generator acting as a packet receiver.</t>
</list></t>

<t>The SR source node N0 steers the packets onto the SR policy by setting the IPv6 destination address and creating an SRH (as described in Section 4.1 of <xref target="RFC8754"/>) using a compressed segment list encoding. The length of the compressed segment list encoding varies for each scenario.</t>

<t>All SR segment endpoint nodes execute a variant of the End behavior: regular End behavior (as defined in Section 4.1 of <xref target="RFC8986"/>), End behavior with NEXT-C-SID flavor, and End behavior with REPLACE-C-SID flavor. The variant being used at each SR segment endpoint node varies for each scenario.</t>

<t>The interoperability was validated for the following scenarios:</t>

<t><strong>Scenario 1:</strong></t>

<t><list style="symbols">
  <t>S1 and S2 are associated with the End behavior with the REPLACE-C-SID flavor</t>
  <t>S3 is associated with the regular End behavior (no flavor)</t>
  <t>S4, S5, and S6 are associated with the End behavior with the NEXT-C-SID flavor</t>
  <t>The SR source node imposes a compressed segment list encoding of 3 SIDs.</t>
</list></t>

<t><strong>Scenario 2:</strong></t>

<t><list style="symbols">
  <t>S1, S2..., S6 are associated with the End behavior with the NEXT-C-SID flavor</t>
  <t>The SR source node imposes a compressed segment list encoding of 2 SIDs.</t>
</list></t>

<t><strong>Scenario 3:</strong></t>

<t><list style="symbols">
  <t>S1, S2..., S6 are associated with the End behavior with the REPLACE-C-SID flavor</t>
  <t>The SR source node imposes a compressed segment list encoding of 3 SIDs.</t>
</list></t>

</section>
</section>
</section>
<section anchor="sec-future"><name>Applicability to other SR Segment Endpoint Behaviors</name>

<t>Future documents may extend the applicability of the NEXT-C-SID and REPLACE-C-SID flavors to other SR segment endpoint behaviors.</t>

<t>For an SR segment endpoint behavior that can be used before the last position of a segment list, a C-SID flavor is defined by reproducing the same logic as described in <xref target="sec-next"/> and <xref target="sec-replace"/> of this document to determine the next SID in the SID list.</t>

</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>Section 8 of <xref target="RFC8402"/> discusses the security considerations for Segment Routing.</t>

<t>Section 5 of <xref target="RFC8754"/> describes the intra-SR-domain deployment model and how to secure it. Section 7 of <xref target="RFC8754"/> describes the threats applicable to SRv6 and how to mitigate them.</t>

<t>Section 9 of <xref target="RFC8986"/> discusses the security considerations applicable to the SRv6 network programming framework, as well as the SR source node and SR segment endpoint node behaviors that it defines.</t>

<t>This document introduces two new flavors for some of the SR segment endpoint behaviors defined in <xref target="RFC8986"/> and a method by which an SR source node may leverage the SIDs of these flavors to produce a compressed segment list encoding.</t>

<t>An SR source node constructs an IPv6 packet with a compressed segment list encoding as defined in Sections 3.1 and 4.1 of <xref target="RFC8754"/> and Section 5 of <xref target="RFC8986"/>. The paths that an SR source node may enforce using a compressed segment list encoding are the same, from a topology and service perspective, as those that an SR source node could enforce using the SIDs of <xref target="RFC8986"/>.</t>

<t>An SR segment endpoint node processes an IPv6 packet matching a locally instantiated SID as defined in <xref target="RFC8986"/>, with the pseudocode modifications in Section 4 of this document. These modifications change how the SR segment endpoint node determines the next SID in the packet, but not the semantic of either the active or the next SID. For example, an adjacency segment instantiated with the End.X behavior remains an adjacency segment regardless of whether it uses the unflavored End.X behavior defined in Section 4.2 of <xref target="RFC8986"/> or a C-SID flavor of that behavior. This document does not introduce any new SID semantic.</t>

<t>Any other transit node processes the packet as described in Section 4.2 of <xref target="RFC8754"/>.</t>

<t>This document defines a new method of encoding the SIDs inside a SID list at the SR source node and decoding them at the SR segment endpoint node, but it does not change how the SID list itself is encoded in the IPv6 packet nor the semantic of any segment that it comprises. Therefore, this document is subject to the same security considerations that are discussed in <xref target="RFC8402"/>, <xref target="RFC8754"/>, and <xref target="RFC8986"/>.</t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<section anchor="srv6-endpoint-behaviors"><name>SRv6 Endpoint Behaviors</name>

<t>This I-D. requests the IANA to update the reference of the following registrations from the &quot;SRv6 Endpoint Behaviors&quot; registry under the top-level &quot;Segment Routing&quot; registry-group (https://www.iana.org/assignments/segment-routing/) with the RFC number of this document once it is published, and transfer change control to the IETF.</t>

<texttable title="Registration List" anchor="tbl-iana-endpoint-behaviors">
      <ttcol align='left'>Value</ttcol>
      <ttcol align='left'>Description</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>43</c>
      <c>End with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>44</c>
      <c>End with NEXT-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>45</c>
      <c>End with NEXT-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>46</c>
      <c>End with NEXT-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>47</c>
      <c>End with NEXT-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>48</c>
      <c>End with NEXT-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>49</c>
      <c>End with NEXT-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>50</c>
      <c>End with NEXT-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>52</c>
      <c>End.X with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>53</c>
      <c>End.X with NEXT-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>54</c>
      <c>End.X with NEXT-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>55</c>
      <c>End.X with NEXT-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>56</c>
      <c>End.X with NEXT-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>57</c>
      <c>End.X with NEXT-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>58</c>
      <c>End.X with NEXT-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>59</c>
      <c>End.X with NEXT-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>85</c>
      <c>End.T with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>86</c>
      <c>End.T with NEXT-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>87</c>
      <c>End.T with NEXT-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>88</c>
      <c>End.T with NEXT-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>89</c>
      <c>End.T with NEXT-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>90</c>
      <c>End.T with NEXT-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>91</c>
      <c>End.T with NEXT-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>92</c>
      <c>End.T with NEXT-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>93</c>
      <c>End.B6.Encaps with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>94</c>
      <c>End.B6.Encaps.Red with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>95</c>
      <c>End.BM with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>96</c>
      <c>End.PS with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>97</c>
      <c>End.XPS with NEXT-CSID</c>
      <c>This I-D.</c>
      <c>101</c>
      <c>End with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>102</c>
      <c>End with REPLACE-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>103</c>
      <c>End with REPLACE-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>104</c>
      <c>End with REPLACE-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>105</c>
      <c>End.X with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>106</c>
      <c>End.X with REPLACE-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>107</c>
      <c>End.X with REPLACE-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>108</c>
      <c>End.X with REPLACE-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>109</c>
      <c>End.T with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>110</c>
      <c>End.T with REPLACE-CSID &amp; PSP</c>
      <c>This I-D.</c>
      <c>111</c>
      <c>End.T with REPLACE-CSID &amp; USP</c>
      <c>This I-D.</c>
      <c>112</c>
      <c>End.T with REPLACE-CSID, PSP &amp; USP</c>
      <c>This I-D.</c>
      <c>114</c>
      <c>End.B6.Encaps with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>115</c>
      <c>End.BM with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>116</c>
      <c>End.DX6 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>117</c>
      <c>End.DX4 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>118</c>
      <c>End.DT6 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>119</c>
      <c>End.DT4 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>120</c>
      <c>End.DT46 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>121</c>
      <c>End.DX2 with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>122</c>
      <c>End.DX2V with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>123</c>
      <c>End.DT2U with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>124</c>
      <c>End.DT2M with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>127</c>
      <c>End.B6.Encaps.Red with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>128</c>
      <c>End with REPLACE-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>129</c>
      <c>End with REPLACE-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>130</c>
      <c>End with REPLACE-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>131</c>
      <c>End with REPLACE-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>132</c>
      <c>End.X with REPLACE-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>133</c>
      <c>End.X with REPLACE-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>134</c>
      <c>End.X with REPLACE-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>135</c>
      <c>End.X with REPLACE-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>136</c>
      <c>End.T with REPLACE-CSID &amp; USD</c>
      <c>This I-D.</c>
      <c>137</c>
      <c>End.T with REPLACE-CSID, PSP &amp; USD</c>
      <c>This I-D.</c>
      <c>138</c>
      <c>End.T with REPLACE-CSID, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>139</c>
      <c>End.T with REPLACE-CSID, PSP, USP &amp; USD</c>
      <c>This I-D.</c>
      <c>140</c>
      <c>End.PS with REPLACE-CSID</c>
      <c>This I-D.</c>
      <c>141</c>
      <c>End.XPS with REPLACE-CSID</c>
      <c>This I-D.</c>
</texttable>

</section>
</section>
<section anchor="acknowledgements"><name>Acknowledgements</name>

<t>The authors would like to thank Kamran Raza, Xing Jiang, YuanChao Su, Han Li, Yisong Liu, Martin Vigoureux, Joel Halpern, and Tal Mizrahi for their insightful feedback and suggestions.</t>

<t>The authors would also like to thank Andrew Alston, Linda Dunbar, Adrian Farrel, Boris Hassanov, and Alvaro Retana for their thorough review of this document.</t>

</section>


  </middle>

  <back>


    <references title='Normative References' anchor="sec-normative-references">

&RFC8200;
&RFC8402;
&RFC8754;
&RFC8986;
&RFC2119;
&RFC8174;


    </references>

    <references title='Informative References' anchor="sec-informative-references">

&RFC7942;
&RFC9252;
&RFC9259;
&RFC9350;
&RFC9352;
&RFC9513;
&RFC9514;
&I-D.ietf-6man-sids;
&I-D.ietf-idr-bgp-ls-sr-policy;
&I-D.ietf-idr-sr-policy-safi;
&I-D.ietf-pce-segment-routing-ipv6;
<reference anchor="GKP94" >
  <front>
    <title>Concrete Mathematics: A Foundation for Computer Science</title>
    <author initials="R." surname="Graham" fullname="Ronald Graham">
      <organization></organization>
    </author>
    <author initials="D." surname="Knuth" fullname="Donald Knuth">
      <organization></organization>
    </author>
    <author initials="O." surname="Patashnik" fullname="Oren Patashnik">
      <organization></organization>
    </author>
    <date year="1994"/>
  </front>
  <seriesInfo name="ISBN" value="9780201558029"/>
</reference>
<reference anchor="SPRING-WG-POLICIES" target="https://wiki.ietf.org/en/group/spring/WG_Policies">
  <front>
    <title>SPRING Working Group Policies</title>
    <author >
      <organization>SPRING Working Group Chairs</organization>
    </author>
    <date year="2022" month="October" day="14"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-NCS540" target="https://www.cisco.com/c/en/us/td/docs/iosxr/ncs5xx/segment-routing/73x/b-segment-routing-cg-73x-ncs540/configure-srv6.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco NCS 540 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="November" day="02"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-NCS560" target="https://www.cisco.com/c/en/us/td/docs/iosxr/ncs560/segment-routing/76x/b-segment-routing-cg-76x-ncs560/m-configure-srv6-usid-ncs5xx.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco NCS 560 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="October" day="14"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-NCS5500" target="https://www.cisco.com/c/en/us/td/docs/iosxr/ncs5500/segment-routing/73x/b-segment-routing-cg-ncs5500-73x/configure-srv6-micro-sid.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco NCS 5500 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="November" day="06"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-NCS5700" target="https://www.cisco.com/c/en/us/td/docs/iosxr/ncs5500/segment-routing/75x/b-segment-routing-cg-ncs5500-75x/configure-srv6-micro-sid.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco NCS 5700 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="November" day="06"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-8000" target="https://www.cisco.com/c/en/us/td/docs/iosxr/cisco8000/segment-routing/75x/b-segment-routing-cg-cisco8000-75x/configuring-segment-routing-over-ipv6-srv6-micro-sids.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco 8000 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="November" day="04"/>
  </front>
</reference>
<reference anchor="IMPL-CISCO-ASR9000" target="https://www.cisco.com/c/en/us/td/docs/routers/asr9000/software/asr9k-r7-5/segment-routing/configuration/guide/b-segment-routing-cg-asr9000-75x/configure-srv6-micro-sid.html">
  <front>
    <title>Segment Routing Configuration Guide for Cisco ASR 9000 Series Routers</title>
    <author >
      <organization>Cisco Systems</organization>
    </author>
    <date year="2022" month="November" day="06"/>
  </front>
</reference>
<reference anchor="IMPL-NOKIA-20.10" target="https://documentation.nokia.com/sr/22-10/books/Segment%20Routing%20and%20PCE%20User%20Guide/segment-rout-with-ipv6-data-plane-srv6.html">
  <front>
    <title>Segment Routing and PCE User Guide</title>
    <author >
      <organization>Nokia</organization>
    </author>
    <date year="2022" month="December"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-LINUX" target="https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next.git/commit/?id=cec9d59e89362809f17f2d854faf52966216da13">
  <front>
    <title>Add NEXT-C-SID support for SRv6 End behavior</title>
    <author initials="P." surname="Abeni" fullname="Paolo Abeni">
      <organization></organization>
    </author>
    <date year="2022" month="September" day="20"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-SONIC" target="https://github.com/sonic-net/SONiC/blob/master/doc/srv6/SRv6_uSID.md">
  <front>
    <title>SONiC uSID</title>
    <author initials="S." surname="Shah" fullname="Shitanshu Shah">
      <organization></organization>
    </author>
    <author initials="R." surname="Sudarshan" fullname="Reshma Sudarshan">
      <organization></organization>
    </author>
    <date year="2022" month="August" day="21"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-SAI" target="https://github.com/opencomputeproject/SAI/pull/1231/commits/02e58d95ad966ca9efc24eb9e0c0fa10b21de2a4">
  <front>
    <title>Added new behaviors to support uSID instruction</title>
    <author initials="A." surname="Agrawal" fullname="Ashutosh Agrawal">
      <organization></organization>
    </author>
    <date year="2021" month="June" day="08"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-VPP" target="https://s3-docs.fd.io/vpp/23.02/cli-reference/clis/clicmd_src_vnet_srv6.html">
  <front>
    <title>Srv6 cli reference</title>
    <author >
      <organization>FD.io</organization>
    </author>
    <date year="n.d."/>
  </front>
</reference>
<reference anchor="IMPL-OSS-P4" target="https://github.com/netgroup/p4-srv6-usid">
  <front>
    <title>SRv6 uSID (micro SID) implementation on P4</title>
    <author initials="S." surname="Salsano" fullname="Stefano Salsano">
      <organization></organization>
    </author>
    <author initials="A." surname="Tulumello" fullname="Angelo Tulumello">
      <organization></organization>
    </author>
    <date year="2021" month="January" day="03"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-ONOS" target="https://wiki.opennetworking.org/display/COM/Stratum+CMCC+G-SRv6+Project">
  <front>
    <title>Stratum CMCC G-SRv6 Project</title>
    <author >
      <organization>Open Networking Foundation</organization>
    </author>
    <date year="2021" month="March" day="24"/>
  </front>
</reference>
<reference anchor="IMPL-OSS-OPEN-SRV6" target="http://opensrv6.org.cn/en/srv6-2/">
  <front>
    <title>Open SRv6 Project</title>
    <author >
      <organization></organization>
    </author>
    <date year="n.d."/>
  </front>
</reference>
<reference anchor="EANTC-23" target="https://eantc.de/fileadmin/eantc/downloads/events/2023/EANTC-InteropTest2023-TestReport.pdf">
  <front>
    <title>Multi-Vendor MPLS SDN Interoperability Test Report</title>
    <author >
      <organization>European Advanced Networking Test Center (EANTC)</organization>
    </author>
    <date year="2023" month="April" day="18"/>
  </front>
</reference>


    </references>


<?line 1444?>

<section anchor="complete-pseudocodes"><name>Complete pseudocodes</name>

<t>The content of this section is purely informative rendering of the pseudocodes of <xref target="RFC8986"/> with the modifications in this document. This rendering may not be used as a reference.</t>

<section anchor="sec-next-end-complete"><name>End with NEXT-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address
           with Code 0 (Hop limit exceeded in transit),
           interrupt packet processing, and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.   Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
N09. }
S02. If (Segments Left == 0) {
S03.   Stop processing the SRH, and proceed to process the next
         header in the packet, whose type is identified by
         the Next Header field in the routing header.
S04. }
S05. If (IPv6 Hop Limit <= 1) {
S06.   Send an ICMP Time Exceeded message to the Source Address
         with Code 0 (Hop limit exceeded in transit),
         interrupt packet processing, and discard the packet.
S07. }
S08. max_LE = (Hdr Ext Len / 2) - 1
S09. If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
S10.   Send an ICMP Parameter Problem to the Source Address
         with Code 0 (Erroneous header field encountered)
         and Pointer set to the Segments Left field,
         interrupt packet processing, and discard the packet.
S11. }
S12. Decrement IPv6 Hop Limit by 1.
S13. Decrement Segments Left by 1.
S14. Update IPv6 DA with Segment List[Segments Left].
S15. Submit the packet to the egress IPv6 FIB lookup for
       transmission to the new destination.
]]></artwork></figure>

<t>Before processing the Upper-Layer header or any IPv6 extension header other than Hop-by-Hop or Destination Option of a packet matching a FIB entry locally instantiated as an End SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.   Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
N09. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
         with Code 4 (SR Upper-layer Header Error)
         and Pointer set to the offset of the Upper-Layer header,
         interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-next-endx-complete"><name>End.X with NEXT-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.X SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address
           with Code 0 (Hop limit exceeded in transit),
           interrupt packet processing, and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.   Submit the packet to the IPv6 module for transmission to the
         new destination via a member of J.
N09. }
S02. If (Segments Left == 0) {
S03.   Stop processing the SRH, and proceed to process the next
         header in the packet, whose type is identified by
         the Next Header field in the routing header.
S04. }
S05. If (IPv6 Hop Limit <= 1) {
S06.   Send an ICMP Time Exceeded message to the Source Address
         with Code 0 (Hop limit exceeded in transit),
         interrupt packet processing, and discard the packet.
S07. }
S08. max_LE = (Hdr Ext Len / 2) - 1
S09. If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
S10.   Send an ICMP Parameter Problem to the Source Address
         with Code 0 (Erroneous header field encountered)
         and Pointer set to the Segments Left field,
         interrupt packet processing, and discard the packet.
S11. }
S12. Decrement IPv6 Hop Limit by 1.
S13. Decrement Segments Left by 1.
S14. Update IPv6 DA with Segment List[Segments Left].
S15. Submit the packet to the IPv6 module for transmission
       to the new destination via a member of J.
]]></artwork></figure>

<t>Before processing the Upper-Layer header or any IPv6 extension header other than Hop-by-Hop or Destination Option of a packet matching a FIB entry locally instantiated as an End.X SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.   Submit the packet to the IPv6 module for transmission to the
         new destination via a member of J.
N09. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.X SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
         with Code 4 (SR Upper-layer Header Error)
         and Pointer set to the offset of the Upper-Layer header,
         interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-next-endt-complete"><name>End.T with NEXT-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.T SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address
           with Code 0 (Hop limit exceeded in transit),
           interrupt packet processing, and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Set the packet's associated FIB table to T.
N08.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
N09. }
S02. If (Segments Left == 0) {
S03.   Stop processing the SRH, and proceed to process the next
         header in the packet, whose type is identified by
         the Next Header field in the routing header.
S04. }
S05. If (IPv6 Hop Limit <= 1) {
S06.   Send an ICMP Time Exceeded message to the Source Address
         with Code 0 (Hop limit exceeded in transit),
         interrupt packet processing, and discard the packet.
S07. }
S08. max_LE = (Hdr Ext Len / 2) - 1
S09. If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
S10.   Send an ICMP Parameter Problem to the Source Address
         with Code 0 (Erroneous header field encountered)
         and Pointer set to the Segments Left field,
         interrupt packet processing, and discard the packet.
S11. }
S12. Decrement IPv6 Hop Limit by 1.
S13. Decrement Segments Left by 1.
S14. Update IPv6 DA with Segment List[Segments Left].
S15.1. Set the packet's associated FIB table to T.
S15.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
]]></artwork></figure>

<t>Before processing the Upper-Layer header or any IPv6 extension header other than Hop-by-Hop or Destination Option of a packet matching a FIB entry locally instantiated as an End.T SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Set the packet's associated FIB table to T.
N08.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
N09. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.T SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
         with Code 4 (SR Upper-layer Header Error)
         and Pointer set to the offset of the Upper-Layer header,
         interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-next-endb6-complete"><name>End.B6.Encaps with NEXT-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.B6.Encaps SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Push a new IPv6 header with its own SRH containing B.
N08.2. Set the outer IPv6 SA to A.
N08.3. Set the outer IPv6 DA to the first SID of B.
N08.4. Set the outer Payload Length, Traffic Class, Flow Label,
         Hop Limit, and Next Header fields.
N08.5. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
N09. }
S02. If (Segments Left == 0) {
S03.   Stop processing the SRH, and proceed to process the next
         header in the packet, whose type is identified by
         the Next Header field in the routing header.
S04. }
S05. If (IPv6 Hop Limit <= 1) {
S06.   Send an ICMP Time Exceeded message to the Source Address
         with Code 0 (Hop limit exceeded in transit),
         interrupt packet processing, and discard the packet.
S07. }
S08. max_LE = (Hdr Ext Len / 2) - 1
S09. If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
S10.   Send an ICMP Parameter Problem to the Source Address
         with Code 0 (Erroneous header field encountered)
         and Pointer set to the Segments Left field,
         interrupt packet processing, and discard the packet.
S11. }
S12. Decrement IPv6 Hop Limit by 1.
S13. Decrement Segments Left by 1.
S14. Update IPv6 DA with Segment List[Segments Left].
S15. Push a new IPv6 header with its own SRH containing B.
S16. Set the outer IPv6 SA to A.
S17. Set the outer IPv6 DA to the first SID of B.
S18. Set the outer Payload Length, Traffic Class, Flow Label,
       Hop Limit, and Next Header fields.
S19. Submit the packet to the egress IPv6 FIB lookup for
       transmission to the new destination.
]]></artwork></figure>

<t>Before processing the Upper-Layer header or any IPv6 extension header other than Hop-by-Hop or Destination Option of a packet matching a FIB entry locally instantiated as an End.B6.Encaps SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Push a new IPv6 header with its own SRH containing B.
N08.2. Set the outer IPv6 SA to A.
N08.3. Set the outer IPv6 DA to the first SID of B.
N08.4. Set the outer Payload Length, Traffic Class, Flow Label,
         Hop Limit, and Next Header fields.
N08.5. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
N09. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.B6.Encaps SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
         with Code 4 (SR Upper-layer Header Error)
         and Pointer set to the offset of the Upper-Layer header,
         interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-next-endbm-complete"><name>End.BM with NEXT-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.BM SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Push the MPLS label stack for B.
N08.2. Submit the packet to the MPLS engine for transmission.
N09. }
S02. If (Segments Left == 0) {
S03.   Stop processing the SRH, and proceed to process the next
         header in the packet, whose type is identified by
         the Next Header field in the routing header.
S04. }
S05. If (IPv6 Hop Limit <= 1) {
S06.   Send an ICMP Time Exceeded message to the Source Address
         with Code 0 (Hop limit exceeded in transit),
         interrupt packet processing, and discard the packet.
S07. }
S08. max_LE = (Hdr Ext Len / 2) - 1
S09. If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
S10.   Send an ICMP Parameter Problem to the Source Address
         with Code 0 (Erroneous header field encountered)
         and Pointer set to the Segments Left field,
         interrupt packet processing, and discard the packet.
S11. }
S12. Decrement IPv6 Hop Limit by 1.
S13. Decrement Segments Left by 1.
S14. Update IPv6 DA with Segment List[Segments Left].
S15. Push the MPLS label stack for B.
S16. Submit the packet to the MPLS engine for transmission.
]]></artwork></figure>

<t>Before processing the Upper-Layer header or any IPv6 extension header other than Hop-by-Hop or Destination Option of a packet matching a FIB entry locally instantiated as an End.BM SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
N01. If (DA.Argument != 0) {
N02.   If (IPv6 Hop Limit <= 1) {
N03.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
N04.   }
N05.   Copy DA.Argument into the bits [LBL..(LBL+AL-1)] of the
         Destination Address.
N06.   Set the bits [(LBL+AL)..127] of the Destination Address to
         zero.
N07.   Decrement IPv6 Hop Limit by 1.
N08.1. Push the MPLS label stack for B.
N08.2. Submit the packet to the MPLS engine for transmission.
N09. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.BM SID with the NEXT-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
         with Code 4 (SR Upper-layer Header Error)
         and Pointer set to the offset of the Upper-Layer header,
         interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-replace-end-complete"><name>End with REPLACE-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. When an SRH is processed {
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
S03.     Stop processing the SRH, and proceed to process the next
           header in the packet, whose type is identified by
           the Next Header field in the routing header.
S04.   }
S05.   If (IPv6 Hop Limit <= 1) {
S06.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
S07.   }
S08.   max_LE = (Hdr Ext Len / 2) - 1
R01.   If (DA.Arg.Index != 0) {
R02.     If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R04.     }
R05.     Decrement DA.Arg.Index by 1.
R06.     If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.       Decrement Segments Left by 1.
R08.       Decrement IPv6 Hop Limit by 1.
R09.       Update IPv6 DA with Segment List[Segments Left]
R10.       Submit the packet to the egress IPv6 FIB lookup for
            transmission to the new destination.
R11.     }
R12.   } Else {
R13.     If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R15.     }
R16.     Decrement Segments Left by 1.
R17.     Set DA.Arg.Index to (128/LNFL - 1).
R18.   }
R19.   Decrement IPv6 Hop Limit by 1.
R20.   Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
         header.
R21.   Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
S16. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
          with Code 4 (SR Upper-layer Header Error)
          and Pointer set to the offset of the Upper-Layer header,
          interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-replace-endx-complete"><name>End.X with REPLACE-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.X SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. When an SRH is processed {
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
S03.     Stop processing the SRH, and proceed to process the next
           header in the packet, whose type is identified by
           the Next Header field in the routing header.
S04.   }
S05.   If (IPv6 Hop Limit <= 1) {
S06.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
S07.   }
S08.   max_LE = (Hdr Ext Len / 2) - 1
R01.   If (DA.Arg.Index != 0) {
R02.     If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R04.     }
R05.     Decrement DA.Arg.Index by 1.
R06.     If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.       Decrement Segments Left by 1.
R08.       Decrement IPv6 Hop Limit by 1.
R09.       Update IPv6 DA with Segment List[Segments Left]
R10.       Submit the packet to the IPv6 module for transmission to
             the new destination via a member of J.
R11.     }
R12.   } Else {
R13.     If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R15.     }
R16.     Decrement Segments Left by 1.
R17.     Set DA.Arg.Index to (128/LNFL - 1).
R18.   }
R19.   Decrement IPv6 Hop Limit by 1.
R20.   Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
         header.
R21.   Submit the packet to the IPv6 module for transmission to the
         new destination via a member of J.
S16. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.X SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
          with Code 4 (SR Upper-layer Header Error)
          and Pointer set to the offset of the Upper-Layer header,
          interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-replace-endt-complete"><name>End.T with REPLACE-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.T SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. When an SRH is processed {
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
S03.     Stop processing the SRH, and proceed to process the next
           header in the packet, whose type is identified by
           the Next Header field in the routing header.
S04.   }
S05.   If (IPv6 Hop Limit <= 1) {
S06.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
S07.   }
S08.   max_LE = (Hdr Ext Len / 2) - 1
R01.   If (DA.Arg.Index != 0) {
R02.     If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R04.     }
R05.     Decrement DA.Arg.Index by 1.
R06.     If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.       Decrement Segments Left by 1.
R08.       Decrement IPv6 Hop Limit by 1.
R09.       Update IPv6 DA with Segment List[Segments Left]
R10.1.     Set the packet's associated FIB table to T.
R10.2.     Submit the packet to the egress IPv6 FIB lookup for
             transmission to the new destination.
R11.     }
R12.   } Else {
R13.     If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R15.     }
R16.     Decrement Segments Left by 1.
R17.     Set DA.Arg.Index to (128/LNFL - 1).
R18.   }
R19.   Decrement IPv6 Hop Limit by 1.
R20.   Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
         header.
R21.1. Set the packet's associated FIB table to T.
R21.2. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the new destination.
S16. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.T SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
          with Code 4 (SR Upper-layer Header Error)
          and Pointer set to the offset of the Upper-Layer header,
          interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-replace-endb6-complete"><name>End.B6.Encaps with REPLACE-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.B6.Encaps SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. When an SRH is processed {
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
S03.     Stop processing the SRH, and proceed to process the next
           header in the packet, whose type is identified by
           the Next Header field in the routing header.
S04.   }
S05.   If (IPv6 Hop Limit <= 1) {
S06.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
S07.   }
S08.   max_LE = (Hdr Ext Len / 2) - 1
R01.   If (DA.Arg.Index != 0) {
R02.     If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R04.     }
R05.     Decrement DA.Arg.Index by 1.
R06.     If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.       Decrement Segments Left by 1.
R08.       Decrement IPv6 Hop Limit by 1.
R09.       Update IPv6 DA with Segment List[Segments Left]
R10.1.     Push a new IPv6 header with its own SRH containing B.
R10.2.     Set the outer IPv6 SA to A.
R10.3.     Set the outer IPv6 DA to the first SID of B.
R10.4.     Set the outer Payload Length, Traffic Class, Flow Label,
             Hop Limit, and Next Header fields.
R10.5.     Submit the packet to the egress IPv6 FIB lookup for
             transmission to the next destination.
R11.     }
R12.   } Else {
R13.     If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R15.     }
R16.     Decrement Segments Left by 1.
R17.     Set DA.Arg.Index to (128/LNFL - 1).
R18.   }
R19.   Decrement IPv6 Hop Limit by 1.
R20.   Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
         header.
R21.1. Push a new IPv6 header with its own SRH containing B.
R21.2. Set the outer IPv6 SA to A.
R21.3. Set the outer IPv6 DA to the first SID of B.
R21.4. Set the outer Payload Length, Traffic Class, Flow Label,
         Hop Limit, and Next Header fields.
R21.5. Submit the packet to the egress IPv6 FIB lookup for
         transmission to the next destination.
S16. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.B6.Encaps SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
          with Code 4 (SR Upper-layer Header Error)
          and Pointer set to the offset of the Upper-Layer header,
          interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
<section anchor="sec-replace-endbm-complete"><name>End.BM with REPLACE-C-SID</name>

<t>When processing the SRH of a packet matching a FIB entry locally instantiated as an End.BM SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. When an SRH is processed {
S02.   If (Segments Left == 0 and (DA.Arg.Index == 0 or
           Segment List[0][DA.Arg.Index-1] == 0)) {
S03.     Stop processing the SRH, and proceed to process the next
           header in the packet, whose type is identified by
           the Next Header field in the routing header.
S04.   }
S05.   If (IPv6 Hop Limit <= 1) {
S06.     Send an ICMP Time Exceeded message to the Source Address,
           Code 0 (Hop limit exceeded in transit),
           interrupt packet processing and discard the packet.
S07.   }
S08.   max_LE = (Hdr Ext Len / 2) - 1
R01.   If (DA.Arg.Index != 0) {
R02.     If ((Last Entry > max_LE) or (Segments Left > Last Entry)) {
R03.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R04.     }
R05.     Decrement DA.Arg.Index by 1.
R06.     If (Segment List[Segments Left][DA.Arg.Index] == 0) {
R07.       Decrement Segments Left by 1.
R08.       Decrement IPv6 Hop Limit by 1.
R09.       Update IPv6 DA with Segment List[Segments Left]
R10.1.     Push the MPLS label stack for B.
R10.2.     Submit the packet to the MPLS engine for transmission.
R11.     }
R12.   } Else {
R13.     If((Last Entry > max_LE) or (Segments Left > Last Entry+1)){
R14.       Send an ICMP Parameter Problem to the Source Address,
             Code 0 (Erroneous header field encountered),
             Pointer set to the Segments Left field,
             interrupt packet processing and discard the packet.
R15.     }
R16.     Decrement Segments Left by 1.
R17.     Set DA.Arg.Index to (128/LNFL - 1).
R18.   }
R19.   Decrement IPv6 Hop Limit by 1.
R20.   Write Segment List[Segments Left][DA.Arg.Index] into the bits
         [LBL..LBL+LNFL-1] of the Destination Address of the IPv6
         header.
R21.1. Push the MPLS label stack for B.
R21.2. Submit the packet to the MPLS engine for transmission.
S16. }
]]></artwork></figure>

<t>When processing the Upper-Layer header of a packet matching a FIB entry locally instantiated as an End.BM SID with the REPLACE-C-SID flavor:</t>

<figure><artwork><![CDATA[
S01. If (Upper-Layer header type is allowed by local configuration) {
S02.   Proceed to process the Upper-Layer header
S03. } Else {
S04.   Send an ICMP Parameter Problem to the Source Address
          with Code 4 (SR Upper-layer Header Error)
          and Pointer set to the offset of the Upper-Layer header,
          interrupt packet processing, and discard the packet.
S05. }
]]></artwork></figure>

</section>
</section>

    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
        <name>Contributors</name>
    <contact initials="L." surname="Aihua" fullname="Liu Aihua">
      <organization>ZTE Corporation</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>liu.aihua@zte.com.cn</email>
      </address>
    </contact>
    <contact initials="D." surname="Cai" fullname="Dennis Cai">
      <organization>Alibaba</organization>
      <address>
        <postal>
          <country>USA</country>
        </postal>
        <email>d.cai@alibaba-inc.com</email>
      </address>
    </contact>
    <contact initials="D." surname="Dukes" fullname="Darren Dukes">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <country>Canada</country>
        </postal>
        <email>ddukes@cisco.com</email>
      </address>
    </contact>
    <contact initials="J." surname="Guichard" fullname="James N Guichard">
      <organization>Futurewei Technologies Ltd.</organization>
      <address>
        <postal>
          <country>USA</country>
        </postal>
        <email>james.n.guichard@futurewei.com</email>
      </address>
    </contact>
    <contact initials="C." surname="Li" fullname="Cheng Li">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>c.l@huawei.com</email>
      </address>
    </contact>
    <contact initials="R." surname="Raszuk" fullname="Robert Raszuk">
      <organization>NTT Network Innovations</organization>
      <address>
        <postal>
          <country>USA</country>
        </postal>
        <email>robert@raszuk.net</email>
      </address>
    </contact>
    <contact initials="K." surname="Talaulikar" fullname="Ketan Talaulikar">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <country>India</country>
        </postal>
        <email>ketant.ietf@gmail.com</email>
      </address>
    </contact>
    <contact initials="D." surname="Voyer" fullname="Daniel Voyer">
      <organization>Bell Canada</organization>
      <address>
        <postal>
          <country>Canada</country>
        </postal>
        <email>daniel.voyer@bell.ca</email>
      </address>
    </contact>
    <contact initials="S." surname="Zadok" fullname="Shay Zadok">
      <organization>Broadcom</organization>
      <address>
        <postal>
          <country>Israel</country>
        </postal>
        <email>shay.zadok@broadcom.com</email>
      </address>
    </contact>
    </section>

  </back>

<!-- ##markdown-source:
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
Xh4fsEPvgcqveoQ301sWX7WqrlJlpXshmCfy5B5S9X2SQPctCbRUtnuzhHBn
B/Z/TPHuzR3ku/I+9QLem48o4fmUylXxVFPF+PZC35s7SX2SrRi4e9P7qZkP
VXK5fY1cR2/0LCE4QfFJ4AoloUlnaa95scD3Mbn+my+E7b9ZyPfffUwy/+Yr
4Pzvaln/Sk16dyM7rP7RRIQ3S8oInxZ7vlgpoYBDJCbU4Y4jYtShz7+5RAGd
OUXCCaVIkISQTuoGsR0anp53KEI9FrkpXNcgSsmtEbMCCBM1qRFMUsmdfAkD
yehLqIkx7VchjKeTqpQmcWDGfq7ptFX3SaWVRHU4006TkrPRpFg4q23q5KRI
nOQTbJ/VJmAaw9o8rklloChAQVvMyal20DoceCodeO/DB/js1eDk+dW6fLjZ
XacPOV0KftLDZk399Qb/UZtIhfu3jgb5hsOLWWuSmvbUdPmUK+bxt/Sisz+D
FKi0/YmZwGKsAotcCrJsJK6yoFTmu8mDWKWZKQC3SbC1IUsJazRsNETRZjHQ
SGVjlDewY69PD/779eHpgeRykjwyeWRSCc2MMGKVzyDP5kIWEytHgJWvo/zJ
ys799IFxWjKBhnY+t+J7rXM8EkEndS20R0Fh0zrlJ34v/gGWH9JC65uT3IJf
jCuONp970ffWNnbMkoZahoUvtjYUG+J3ZHlG8NVTtomurNiWCxl0eFAcykQE
MmzIF74sG9Cet7FjfWUl/tmDZcA3udQ/8mkuEnWPMkd+R7l+NnZasP7u1mo+
Pb9KJW0Ikn59tSkl1mUBojqn2yQJXUJVG8YqIOXnSjyUmFOFzJWfatOwZvuZ
wIrOLfdkUvKF+MOYDUqUJedRLM8mmwszdrh6S2f3KRiy+Q2OU8PLI3dFttqS
UY4lPbp6pbehZjXX55x70LdGt1ovn/DJeLjb3UxGB0Qm7UqiDehu3mEmjIWX
MXK9V+UpVj1+34xNrml76URh7JPQJ+VeInRhIm97dijSdSA4FVc5R5/6lAaS
SJZv+AbZLNL5MBJt1Xh1FG4AoVqeERSlDuYH/GgnX+6aL4k1SH4+w5lMwQj1
LMwMBgdhnt20EtpNblZVFT33GVjlSiskRyN9XGmcOkDD5gsfNX1a06YgE660
ySIZfk65noJxcStJqGWhvF9GagiDm+vPOGHglk1agNIkJqUZ7JACZnb2M40r
y3PKhnjtSeIw3xJs0zmVFfKkloPlv68effiVykF4wswyZkYGBw5lIseb/OoY
7naWcfd+uAtwcTr1ttu9JvoTMbndsd5wlNCjm+40vV3VcNduKLKQfR3WLQ8l
ljkpI6L3SnnI4P23qz2kZJ48CbH6rDiIVaWinIkOa5g5ZqPiraPytf8S9ZRg
dBmTikF5wlnT5bc4O/0bjyCYJvZBzDMWorvLNBiHlt91KtZJx51YJ1Xiw+jP
sPpT+A7UfbtqIYBg1yDNzN5lyXkvtZhqF2jMNkS3wihtFWFkJYjd9Ex4CtMa
dT8FrsqNrX4w7ez2gdMfGwouwX71MLjD1klBNxeZYJhjc9pHuOJN1tqlgz0q
9xTxwzJQKIXOxA1WzVLp3FdaVrZD7pzXZleVytIKQ199iDYL9MNRpU1AYQom
52phZR5juUgx3LLKQGrteObfTGJ/zIZyvgfE/ikfGmEKNnSgl7K5fMn6CZZq
jFn22KSTP2ljySoQQh3ciX5NF4k/u1RBFvnAAEcMkpRWQIFo/Qfot+edmHnY
rlHu3qc4gZh9aIl2zGrkUTspzmeb4QTYROCRsCWBsA1076E+OcpGmElfTGEM
qnropMQTKClLN6xiEiM3HaGFJ1YFTa9iyjnCfVinIoBzZ35eyLXCefLo4K6k
WY1Z+RtmrEhKFRFL0Ngy8Wy2N3LhrM5j0CS+CEee1PrII4jI8pwOUnzJaxG/
ZMN2kGrEoUpS1LiYNNTXLN/1WM8LPBR9zWirS3PmSL+1t6UWD50lRSVVPMop
MhJlUXMYets2mzC2YEnZqtkke5tV9xzm/GaJOxuf2aIVmKcylVz+C2vxkBMu
yINZyCYRqRlpkyln4LIkmdY9Ux7RhWrw8shUAx5TW96Fj45gXIaklkGKLESR
ZD0tQyhUfpbF4NDKWWlGUFkqQXsfzsOJoXoS7VVGDZriE6VKeEmgFGOpkXtK
7FUWGbI84j3XI74g8nEjPpORdpv3k8DRc1iDYB4TJ3JhHbkGuBXI0swtarzP
V9JV8V4X9BBqMreWobQ/roxQ8q5QkHCauQNMHYZ4tn+y9vrZiSw1LfCheQkI
OHMjiPQjSpntT1ByImD4qbGq1OFcyt61TXk4FYw1jrHaQ157+zkZNQi4Jfei
7Q3Q+pzfrzjS2tuNz89RUoDtXhDRZv7GBv8gusSXbH7sIGtldBVUn5qZ/IxS
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
4YjKnCo9ocnIFqdB1VpGkr/DXo19XPbONPhLcdQECubOgdIQ8C4r80f6VQhn
JbCzUslyBvSRiXDUQmZJfmm2ULtdRpd+BIh5KYb/yk3lyiXmqa8K7B/OM10U
Mg2muLURriQIiYERH+T8WnHiDJTLukiJq1QqM1Mk0wKWLTTYieGTgMtTlY5Q
XhQNqMhcB+lHfCODcX7gUkk+X4yETOYuk6Rz8A1FKWSf16GeimLpXLWctJ6h
SEh3I4KAipHO4Zs5iQLHLV0yXeIC5dR1t2gNQuHwDNUN1NdC4r3t9J9llf/o
Uo4D03tqtyvP1oiIFFrAyeOpzjDBOYcwIyEuL5dcQIARqeQzFkYijNXcipdI
rjjJSK9KpOWSfuIz4ZAsv8LySM6p4pBMbVAuFIZq3WuSPJr2WTRFGLJJzTfe
Yf+4X5bHjHhtUTCV88R8elZ6JAQJjoMxnGSDFq1IAseLL0hwV0LKOcaSj0rl
8KRi1ieqww3cobHcdSDLLWR+E+jmik2meYtjPVcus2yW7q2tXV9ft0Fr9dtx
crHGQbYkT6/lcgKurVoqwvN9qyi6e2Axlcyjg6Pw9/QyGOvHtig9p/QDhFwq
o52cK0VYNxr/8n6hNFn/wqTVOr78X96pBt2/oE0L//PkZ6vwF7XZWIePUMex
9HtE5H955sCo3UZ5u/9LdaYLrTerWr8ua71V2rpJQ1d02a6eoGTxOwsmKOmy
W9HldWWXzU71LLX9etyv/WbRIWyuV7UsP4bNjer2ZVDd3KxoX3cUm1t1k5Rs
YnvhJCWddio71QB2t26mup47ChBni45kZ6uqZfmR7GxXty+D7s5ORfu6I9nZ
rZukuIndzsJJSjp1KztVA3a3VzdTbU+F+0+32gfRyJ+li45mdyPfo30aLCR0
u+ron75c2FSdvVvLpLSpRvrFbbudrk1ItP2lvG2vsm05AnY76zU9yrCp29mo
6lGHhN1Ojpos2MhWTeuqrWzX9ilf1U51n/rt5C5V/Xa6nZrWFdvpdmv7lK6q
26vuU7udbuF2LLWt/O1Y0Fwd6rM3W0u139btN5Zqrw4T6yku035Xt19q/F7H
tF9qgl5Xb6C3VPueaf/LUh3W9Yp6r5fqsGE6LHVmve08YhiyuaCnI2YVsLes
x25VjzrO013vVHer5iDd9Uq6upD7oJNZPakp67Ne3ad+fxt1HetWWUNyl9hj
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
AA==

-->

</rfc>

