<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.39 (Ruby 3.0.2) -->
<?rfc tocompact="yes"?>
<?rfc tocindent="yes"?>
<?rfc rfcedstyle="yes"?>
<?rfc subcompact="no"?>
<?rfc compact="yes"?>
<?rfc iprnotified="Yes"?>
<?rfc strict="no"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-pce-segment-routing-ipv6-18" category="std" consensus="true" submissionType="IETF" tocDepth="4" tocInclude="true" sortRefs="false" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.18.0 -->
  <front>
    <title abbrev="PCEP-SRv6">Path Computation Element Communication Protocol (PCEP) Extensions for Segment Routing leveraging the IPv6 dataplane</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-pce-segment-routing-ipv6-18"/>
    <author initials="C." surname="Li" fullname="Cheng Li(Editor)">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <street>Huawei Campus, No. 156 Beiqing Rd.</street>
          <city>Beijing</city>
          <code>100095</code>
          <country>China</country>
        </postal>
        <email>c.l@huawei.com</email>
      </address>
    </author>
    <author initials="M." surname="Negi" fullname="Mahendra Singh Negi">
      <organization>RtBrick Inc</organization>
      <address>
        <postal>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <country>India</country>
        </postal>
        <email>mahend.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="S." surname="Sivabalan" fullname="Siva Sivabalan">
      <organization>Ciena Corporation</organization>
      <address>
        <email>msiva282@gmail.com</email>
      </address>
    </author>
    <author initials="M." surname="Koldychev" fullname="Mike Koldychev">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <country>Canada</country>
        </postal>
        <email>mkoldych@cisco.com</email>
      </address>
    </author>
    <author initials="P." surname="Kaladharan" fullname="Prejeeth Kaladharan">
      <organization>RtBrick Inc</organization>
      <address>
        <postal>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <country>India</country>
        </postal>
        <email>prejeeth@rtbrick.com</email>
      </address>
    </author>
    <author initials="Y." surname="Zhu" fullname="Yongqing Zhu">
      <organization>China Telecom</organization>
      <address>
        <postal>
          <street>109 West Zhongshan Ave, Tianhe District</street>
          <city>Bangalore</city>
          <region>Guangzhou</region>
          <country>P.R. China</country>
        </postal>
        <email>zhuyq8@chinatelecom.cn</email>
      </address>
    </author>
    <date year="2023" month="August" day="28"/>
    <area>Routing</area>
    <workgroup>PCE Working Group</workgroup>
    <abstract>
      <?line 112?>

<t>Segment Routing (SR) can be used to steer packets through an IPv6 or MPLS network using the source routing paradigm. SR enables
any head-end node to select any path without relying on a hop-by-hop signaling technique (e.g., LDP or RSVP-TE).</t>
      <t>A Segment Routed Path can be derived from a variety of mechanisms, including an IGP Shortest Path Tree (SPT), explicit configuration, or a PCE.</t>
      <t>Since SR can be applied to both MPLS and IPv6 forwarding planes, a PCE should be able to compute SR-Path for both MPLS and IPv6 forwarding planes. The PCEP extension and mechanisms to support SR-MPLS have been defined. This document describes the extensions required for SR support for IPv6 data plane in the Path Computation Element communication Protocol (PCEP).</t>
    </abstract>
  </front>
  <middle>
    <?line 122?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>As defined in <xref target="RFC8402"/>, Segment Routing (SR) architecture allows the source node to steer a packet through a path indicated by an ordered list of instructions, called segments. A segment can represent any instruction, topological or service-based, and it can have a semantic local to an SR node or global within an SR domain.</t>
      <t>When the SR architecture is applied to the MPLS forwarding plane, it is called SR-MPLS. When the SR architecture is applied to the IPv6 data plane, is is called SRv6 (Segment Routing over IPv6 data plane) <xref target="RFC8754"/>.</t>
      <t>An SR path can be derived from an IGP Shortest Path Tree (SPT), but SR-TE (Segment Routing Traffic Engineering) paths may not follow IGP SPT. Such paths may be chosen by a suitable network planning tool, or a PCE and provisioned on the ingress node.</t>
      <t><xref target="RFC5440"/> describes Path Computation Element communication Protocol (PCEP) for communication between a Path Computation Client (PCC) and a Path Computation Element (PCE) or between a pair of PCEs. A PCE or a PCC operating as a PCE (in hierarchical PCE environment) computes paths for MPLS Traffic Engineering LSPs (MPLS-TE LSPs) based on various constraints and optimization criteria.</t>
      <t><xref target="RFC8231"/> specifies extensions to PCEP that allow a stateful PCE to compute and recommend network paths in compliance with <xref target="RFC4657"/> and defines objects and TLVs for MPLS-TE LSPs. Stateful PCEP extensions provide synchronization of LSP state between a PCC and a PCE or between a pair of PCEs, delegation of LSP control, reporting of LSP state from a PCC to a PCE, controlling the setup and path routing of an LSP from a PCE to a PCC. Stateful PCEP extensions are intended for an operational model in which LSPs are configured on the PCC, and control over them is delegated to the PCE.</t>
      <t>A mechanism to dynamically initiate LSPs on a PCC based on the requests from a stateful PCE or a controller using stateful PCE is specified in <xref target="RFC8281"/>. As per <xref target="RFC8664"/>, it is possible to use a stateful PCE for computing one or more SR-TE paths taking into account various constraints and objective functions. Once a path is chosen, the stateful PCE can initiate an SR-TE path on a PCC using PCEP extensions specified in <xref target="RFC8281"/> using the SR specific PCEP extensions specified in <xref target="RFC8664"/>. <xref target="RFC8664"/> specifies PCEP extensions for supporting a SR-TE LSP for the MPLS data plane. This document extends <xref target="RFC8664"/> to support SR for the IPv6 data plane. Additionally, using procedures described in this document, a PCC can request an SRv6 path from either a stateful or stateless PCE. This specification relies on the PATH-SETUP-TYPE TLV and procedures specified in <xref target="RFC8408"/>.</t>
      <t>This specification provides a mechanism for a network controller (acting as a PCE) to instantiate candidate paths for an SR Policy onto a
head-end node (acting as a PCC) using PCEP. For more information on the SR Policy Architecture, see <xref target="RFC9256"/> which is applicable to both SR-MPLS and SRv6.</t>
      <section anchor="requirements-language">
        <name>Requirements Language</name>
        <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
        <?line -18?>

</section>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <t>This document uses the following terms defined in <xref target="RFC5440"/>: PCC, PCE, PCEP, PCEP Peer.</t>
      <t>This document uses the following terms defined in <xref target="RFC8051"/>: Stateful PCE, Delegation.</t>
      <t>The message formats in this document are specified using Routing
Backus-Naur Format (RBNF) encoding as specified in <xref target="RFC5511"/>.</t>
      <t>Further, following terms are used in the document,</t>
      <dl>
        <dt>MSD:</dt>
        <dd>
          <t>Maximum SID Depth.</t>
        </dd>
        <dt>PST:</dt>
        <dd>
          <t>Path Setup Type.</t>
        </dd>
        <dt>SR:</dt>
        <dd>
          <t>Segment Routing.</t>
        </dd>
        <dt>SID:</dt>
        <dd>
          <t>Segment Identifier.</t>
        </dd>
        <dt>SRv6:</dt>
        <dd>
          <t>Segment Routing for IPv6 forwarding plane.</t>
        </dd>
        <dt>SRH:</dt>
        <dd>
          <t>IPv6 Segment Routing Header.</t>
        </dd>
        <dt>SRv6 Path:</dt>
        <dd>
          <t>IPv6 Segment List (List of IPv6 SIDs representing a path in IPv6 SR domain in the context of this document)</t>
        </dd>
      </dl>
      <t>Further, note that the term LSP used in the PCEP specifications,
would be equivalent to an SRv6 Path (represented as a list of SRv6
segments) in the context of supporting SRv6 in PCEP.</t>
    </section>
    <section anchor="Overview">
      <name>Overview of PCEP Operation in SRv6 Networks</name>
      <t>Basic operations for PCEP speakers are as per <xref target="RFC8664"/>. SRv6 Paths computed by a PCE can be represented as an ordered list of SRv6 segments of 128-bit value.</t>
      <t><xref target="RFC8664"/> defined a new Explicit Route Object (ERO) subobject denoted by "SR-ERO subobject" capable of carrying a SID as well as the identity of the node/adjacency represented by the SID for SR-MPLS. SR-capable PCEP speakers can generate and/or process such an ERO subobject. An ERO containing SR-ERO subobjects can be included in the PCEP Path Computation Reply (PCRep) message defined in <xref target="RFC5440"/>, the PCEP LSP Initiate Request message (PCInitiate) defined in <xref target="RFC8281"/>, as well as in the PCEP LSP Update Request (PCUpd) and PCEP LSP State Report (PCRpt) messages defined in <xref target="RFC8231"/>. <xref target="RFC8664"/> also defines a new Reported Route Object(RRO) called SR-RRO to represents the SID list that was applied by the PCC, that is, the actual path taken by the LSP in SR-MPLS network.</t>
      <t>This document defines new subobjects "SRv6-ERO" and "SRv6-RRO" in the ERO and the RRO respectively to carry the SRv6 SID (IPv6 Address). SRv6-capable
PCEP speakers <bcp14>MUST</bcp14> be able to generate and/or process these subobjects.</t>
      <t>When a PCEP session between a PCC and a PCE is established, both PCEP speakers exchange their capabilities to indicate their ability to support SRv6 specific functionality as described in <xref target="SRv6-PCE-Capability-sub-TLV"/>.</t>
      <t>In summary, this document,</t>
      <ul spacing="normal">
        <li>Defines a new PCEP capability for SRv6.</li>
        <li>Defines a new subobject SRv6-ERO in ERO.</li>
        <li>Defines a new subobject SRv6-RRO in RRO.</li>
        <li>Defines a new path setup type (PST) <xref target="RFC8408"/> carried in the
PATH-SETUP-TYPE TLV and the PATH-SETUP-TYPE-CAPABILITY TLV.</li>
      </ul>
      <section anchor="Operation-overview">
        <name>Operation Overview</name>
        <t>In SR networks, an SR source node encodes all packets being steered onto an SR path with a list of segments. The segment list has all necessary information to guide the packets from the ingress node to the egress node of the path, and hence there is no need for any signaling protocol.</t>
        <t>For the use of an IPv6 control plane but an MPLS data plane, mechanism remains the same as specified in <xref target="RFC8664"/>.</t>
        <t>This document describes the extension to support SRv6 in PCEP. A PCC or PCE indicates its ability to support SRv6 during the PCEP
session Initialization Phase via a new SRv6-PCE-CAPABILITY sub-TLV
(see details in <xref target="SRv6-PCE-Capability-sub-TLV"/>).</t>
      </section>
      <section anchor="SRv6-Specific-PCEP-Message-Extensions">
        <name>SRv6-Specific PCEP Message Extensions</name>
        <t>As defined in <xref target="RFC5440"/>, a PCEP message consists of
a common header followed by a variable length body made up of
mandatory and/or optional objects. This document does not require any
changes in the format of PCReq and PCRep messages specified in <xref target="RFC5440"/>,
PCInitiate message specified in <xref target="RFC8281"/>, and PCRpt and PCUpd messages
specified in <xref target="RFC8231"/>. However, PCEP messages pertaining to SRv6 <bcp14>MUST</bcp14>
include PATH-SETUP-TYPE TLV in the RP (Request Parameters) or SRP (Stateful PCE Request Parameters) object to clearly
identify that SRv6 is intended.</t>
        <!-- In other words, a PCEP speaker MUST NOT infer whether or
   not a PCEP message pertains to SRv6 from any other object or
   TLV. -->

</section>
    </section>
    <section anchor="Object-Formats">
      <name>Object Formats</name>
      <section anchor="The-OPEN-Object">
        <name>The OPEN Object</name>
        <section anchor="SRv6-PCE-Capability-sub-TLV">
          <name>The SRv6 PCE Capability sub-TLV</name>
          <t>This document defines a new Path Setup Type (PST) <xref target="RFC8408"/> for SRv6, as follows.</t>
          <ul spacing="normal">
            <li>PST = 3 : Path is setup using SRv6.</li>
          </ul>
          <t>A PCEP speaker indicates its support of the function described in this document by sending a PATH-SETUP-TYPE-CAPABILITY TLV in the OPEN object with this new PST "3" included in the PST list.</t>
          <t>This document also defines the SRv6-PCE-CAPABILITY sub-TLV. PCEP speakers use this sub-TLV to exchange information about their SRv6 capability. If a PCEP speaker includes PST=3 in the PST List of the PATH-SETUP-TYPE-CAPABILITY TLV then it <bcp14>MUST</bcp14> also include the SRv6-PCE-CAPABILITY sub-TLV inside the PATH-SETUP-TYPE-CAPABILITY TLV. For further error handling, please see <xref target="Procedures"/>.</t>
          <t>The format of the SRv6-PCE-CAPABILITY sub-TLV is shown in the following figure.</t>
          <figure anchor="SRv6-PCE-CAPABILITY-sub-TLV-format">
            <name>SRv6-PCE-CAPABILITY sub-TLV format</name>
            <artwork><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|            Type=27            |            Length             |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|            Reserved           |             Flags         |N|X|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   MSD-Type    | MSD-Value     |   MSD-Type    | MSD-Value     |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
//                             ...                             //
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   MSD-Type    | MSD-Value     |           Padding             |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </figure>
          <t>The code point for the TLV type is 27 and the format is compliant with the PCEP TLV format defined in <xref target="RFC5440"/>. That is, the sub-TLV is composed of 2 octets for the type, 2 octets specifying the length, and a Value field. The Type field when set to 27 identifies the SRv6-PCE-CAPABILITY sub-TLV and the presence of the sub-TLV indicates the support for the SRv6 paths in PCEP. The Length field defines the length of the value portion in octets. The TLV is padded to 4-octet alignment, and padding is not included in the Length field. The (MSD-Type,MSD-Value) pairs are <bcp14>OPTIONAL</bcp14>. The number of (MSD-Type,MSD-Value) pairs can be determined from the Length field of the TLV.</t>
          <t>The value comprises of -</t>
          <ul empty="true">
            <li>
              <t>Reserved: 2 octet, this field <bcp14>MUST</bcp14> be set to 0 on
transmission, and ignored on receipt.</t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>Flags: 2 octet, two bits are currently assigned in this
document. <xref target="SRv6-PCE-Capability-Flags"/></t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <ul spacing="normal">
                <li>N bit: A PCC sets this flag bit to 1 to indicate that it
is capable of resolving a Node or Adjacency Identifier (NAI)
to an SRv6-SID.</li>
                <li>X bit: A PCC sets this bit to 1 to indicate that it does
not impose any limit on MSD (irrespective of the
MSD-Type).</li>
                <li>Unassigned bits <bcp14>MUST</bcp14> be set to 0 and ignored on
receipt.</li>
              </ul>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>A pair of (MSD-Type, MSD-Value): Where MSD-Type (1 octet) is
as per the IGP MSD Type registry created by <xref target="RFC8491"/> and populated
with SRv6 MSD types as per <xref target="RFC9352"/>;
MSD-Value (1 octet) is as per <xref target="RFC8491"/>.</t>
            </li>
          </ul>
          <t>The SRv6 MSD information advertised via SRv6-PCE-Capability sub-TLV conveys the SRv6 capabilities of the PCEP speaker alone. However, when it comes to the computation of an SR Policy for the SRv6 dataplane, the SRv6 MSD capabilities of all the intermediate SRv6 Endpoint node as well as the tailend node also need to be considered to ensure those midpoints are able to correctly process their segments and for the tailend to dispose of the SRv6 encapsulation. The SRv6 MSD capabilities of these other nodes <bcp14>MAY</bcp14> be learned as part of the topology information via IGP/BGP-LS or via PCEP if the PCE also happens to have PCEP sessions to those nodes.</t>
          <t>It is <bcp14>RECOMMENDED</bcp14> that the SRv6 MSD information be not included in the SRv6-PCE-Capability sub-TLV in deployments where the PCE is able to obtain this via IGP/BGP-LS as part of the topology information.</t>
        </section>
      </section>
      <section anchor="The-SRP-Object">
        <name>The RP/SRP Object</name>
        <t>This document defines a new Path Setup Type (PST=3) for SRv6. In order to indicate that the path is for SRv6, any RP or SRP object <bcp14>MUST</bcp14> include the PATH-SETUP-TYPE TLV as specified in <xref target="RFC8408"/>, where PST is set to 3.</t>
      </section>
      <section anchor="ERO">
        <name>ERO</name>
        <t>In order to support SRv6, a new "SRv6-ERO" subobject is defined for inclusion in the ERO.</t>
        <section anchor="SRv6-ERO-Subobject">
          <name>SRv6-ERO Subobject</name>
          <t>An SRv6-ERO subobject is formatted as shown in the following figure.</t>
          <figure anchor="SRv6-ERO-Subobject-Format">
            <name>SRv6-ERO Subobject Format</name>
            <artwork><![CDATA[
    0                   1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |L|   Type=40   |     Length    | NT    |     Flags     |V|T|F|S|
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |              Reserved         |      Endpoint Behavior        |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   |                      SRv6 SID (optional)                      |
   |                     (128-bit)                                 |
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   //                    NAI (variable, optional)                 //
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   |                     SID Structure (optional)                  |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
          </figure>
          <t>The fields in the SRv6-ERO subobject are as follows:</t>
          <t>The 'L' Flag: Indicates whether the subobject represents a
loose-hop (see <xref target="RFC3209"/>). If this flag is set to
zero, a PCC <bcp14>MUST NOT</bcp14> overwrite the SID value present in the SRv6-ERO
subobject. Otherwise, a PCC <bcp14>MAY</bcp14> expand or replace one or more SID
values in the received SRv6-ERO based on its local policy.</t>
          <t>Type: indicates the content of the subobject, i.e. when the field
is set to 40, the suboject is an SRv6-ERO subobject
representing an SRv6 SID.</t>
          <t>Length: Contains the total length of the subobject in octets. The
Length <bcp14>MUST</bcp14> be at least 24, and <bcp14>MUST</bcp14> be a multiple of 4. An SRv6-ERO
subobject <bcp14>MUST</bcp14> contain at least one of an SRv6-SID or an NAI. The S
and F bit in the Flags field indicates whether the SRv6-SID or NAI
fields are absent.</t>
          <t>NAI Type (NT): Indicates the type and format of the NAI contained
in the object body, if any is present. If the F bit is set to one
(see below) then the NT field has no meaning and <bcp14>MUST</bcp14> be ignored by
the receiver. This document reuses NT types defined in <xref target="RFC8664"/>, but assigns them new meanings appropriate to SRv6.</t>
          <ul empty="true">
            <li>
              <t>If NT value is 0, the NAI <bcp14>MUST NOT</bcp14> be included.</t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>When NT value is 2, the NAI is as per the 'IPv6 Node ID'
format defined in <xref target="RFC8664"/>, which specifies an
IPv6 address. This is used to identify the owner of the SRv6
Identifier. This is optional, as the LOC (the locator portion)
of the SRv6 SID serves a similar purpose (when present).</t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>When NT value is 4, the NAI is as per the 'IPv6 Adjacency'
format defined in <xref target="RFC8664"/>, which specify a pair
of IPv6 addresses. This is used to identify the IPv6 Adjacency
and used with the SRv6 Adj-SID.</t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>When NT value is 6, the NAI is as per the 'link-local IPv6
addresses' format defined in <xref target="RFC8664"/>, which
specify a pair of (global IPv6 address, interface ID) tuples. It
is used to identify the IPv6 Adjacency and used with the SRv6
Adj-SID.</t>
            </li>
          </ul>
          <ul empty="true">
            <li>
              <t>SR-MPLS specific NT types are not valid in SRv6-ERO.</t>
            </li>
          </ul>
          <t>Flags: Used to carry additional information pertaining to the
SRv6-SID. This document defines the following flag bits. The other
bits <bcp14>MUST</bcp14> be set to zero by the sender and <bcp14>MUST</bcp14> be ignored by the
receiver.</t>
          <ul spacing="normal">
            <li>S: When this bit is set to 1, the SRv6-SID value in the
subobject body is absent. In this case, the PCC is responsible
for choosing the SRv6-SID value, e.g., by looking up in the
SR-DB using the NAI which, in this case, <bcp14>MUST</bcp14> be present in the
subobject. If the S bit is set to 1 then F bit <bcp14>MUST</bcp14> be set to
zero.</li>
            <li>F: When this bit is set to 1, the NAI value in the subobject
body is absent. The F bit <bcp14>MUST</bcp14> be set to 1 if NT=0, and
otherwise <bcp14>MUST</bcp14> be set to zero. The S and F bits <bcp14>MUST NOT</bcp14> both be
set to 1.</li>
            <li>T: When this bit is set to 1, the SID Structure value in the
subobject body is present. The T bit <bcp14>MUST</bcp14> be set to 0 when S bit
is set to 1. If the T bit is set when the S bit is set, the T
bit <bcp14>MUST</bcp14> be ignored. Thus, the T bit indicates the presence of
an optional 8-byte SID Structure when SRv6 SID is included. The
SID Structure is defined in <xref target="SID-Structure"/>.</li>
            <li>V: The "SID verification" bit usage is as per Section 5.1 of <xref target="RFC9256"/>. If a PCC "Verification fails" for a SID, it <bcp14>MUST</bcp14> report this error by
 including the LSP-ERROR-CODE TLV with LSP error-value "SID Verification fails" in the LSP object in the PCRpt message to the PCE.</li>
          </ul>
          <t>Reserved: <bcp14>MUST</bcp14> be set to zero while sending and ignored on receipt.</t>
          <t>Endpoint Behavior: A 16-bit field representing the behavior
associated with the SRv6 SIDs. This information is optional, but it is recommended to signal it always if possible. It could be used for maintainability and diagnostic purpose. If behavior is not known, the opaque value '0xFFFF' is used <xref target="RFC8986"/>.</t>
          <t>SRv6 SID: SRv6 Identifier is an 128-bit IPv6 address representing the SRv6 segment.</t>
          <t>NAI: The NAI associated with the SRv6-SID. The NAI's format
depends on the value in the NT field, and is described in <xref target="RFC8664"/>.</t>
          <t>At least one SRv6-SID or the NAI <bcp14>MUST</bcp14> be included in the SRv6-ERO subobject, and both <bcp14>MAY</bcp14> be included.</t>
          <section anchor="SID-Structure">
            <name>SID Structure</name>
            <t>The SID Structure is an optional part of the SR-ERO subobject,
as described in <xref target="SRv6-ERO-Subobject"/>.</t>
            <t><xref target="RFC8986"/> defines an SRv6 SID as consisting of LOC:FUNCT:ARG,
where a locator (LOC) is encoded in the L most significant bits of
the SID, followed by F bits of function (FUNCT) and A bits of
arguments (ARG).  A locator may be represented as B:N where B is
the SRv6 SID locator block (IPv6 prefix allocated for SRv6 SIDs by
the operator) and N is the identifier of the parent node
instantiating the SID called locator node.</t>
            <t>It is
formatted as shown in the following figure.</t>
            <figure anchor="SID-Structure-Format">
              <name>SID Structure Format</name>
              <artwork><![CDATA[
    0                   1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |    LB Length  |  LN Length    | Fun. Length   |  Arg. Length  |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                 Reserved                      |   Flags       |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+


]]></artwork>
            </figure>
            <t>where:</t>
            <t>LB Length: 1 octet. SRv6 SID Locator Block length in bits.</t>
            <t>LN Length: 1 octet. SRv6 SID Locator Node length in bits.</t>
            <t>Fun. Length: 1 octet. SRv6 SID Function length in bits.</t>
            <t>Arg. Length: 1 octet. SRv6 SID Arguments length in bits.</t>
            <t>The sum of all four sizes in the SID Structure must be lower or
equal to 128 bits. If the sum of all four sizes advertised in the
SID Structure is larger than 128 bits, the corresponding SRv6 SID
<bcp14>MUST</bcp14> be considered invalid and a PCErr message with Error-Type =
10 ("Reception of an invalid object") and Error-Value = 37 ("Invalid SRv6 SID Structure") is returned.</t>
            <t>Reserved: <bcp14>MUST</bcp14> be set to zero while sending and ignored on
receipt.</t>
            <t>Flags: Currently no flags are defined. Unassigned bits must be
set to zero while sending and ignored on receipt.</t>
            <t>The SRv6 SID Structure provides the detailed encoding
information of an SRv6 SID, which is useful in the use cases that
require to know the SRv6 SID structure. When a PCEP speaker
receives the SRv6 SID and its structure information, the SRv6 SID
can be parsed based on the SRv6 SID Structure and/or possible
local policies. The SRv6 SID Structure could be used by the PCE for ease
of operations and monitoring.  For example, this information could be
used for validation of SRv6 SIDs being instantiated in the network
and checked for conformance to the SRv6 SID allocation scheme chosen
by the operator as described in Section 3.2 of <xref target="RFC8986"/>.  In the future, PCE can also be utilized to verify and automate the security of the SRv6 domain by provisioning filtering rules at the domain boundaries as described in Section 5 of <xref target="RFC8754"/>.  The details of these potential applications are outside the scope of this document.</t>
          </section>
          <section anchor="order">
            <name>Order of the Optional fields</name>
            <t>The optional elements in the SRv6-ERO subobject i.e. SRv6 SID, NAI and the
SID Structure <bcp14>MUST</bcp14> be encoded in the order as depicted in <xref target="SRv6-ERO-Subobject-Format"/>.
The presence of each of them is indicated by the respective flags i.e.
S flag, F flag and T flag.</t>
            <t>In order to ensure future compatibility, any optional elements added to the SRv6-ERO subobject in the future must specify their order and request the Internet Assigned Numbers Authority (IANA) to allocate a flag to indicate their presence from the subregistry created in <xref target="SRv6-ERO-flag"/>.</t>
          </section>
        </section>
      </section>
      <section anchor="RRO">
        <name>RRO</name>
        <t>In order to support SRv6, a new "SRv6-RRO" subobject is defined for inclusion in the RRO.</t>
        <section anchor="SRv6-RRO-Subobject">
          <name>SRv6-RRO Subobject</name>
          <t>A PCC reports an SRv6 path to a PCE by sending a PCRpt message,
per <xref target="RFC8231"/>. The RRO on this message represents the
SID list that was applied by the PCC, that is, the actual path
taken. The procedures of <xref target="RFC8664"/> with respect to
the RRO apply equally to this specification without change.</t>
          <t>An RRO contains one or more subobjects called "SRv6-RRO
subobjects" whose format is shown below.</t>
          <figure anchor="SRv6-RRO-Subobject-Format">
            <name>SRv6-RRO Subobject Format</name>
            <artwork><![CDATA[
    0                   1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |   Type=40     |     Length    |  NT   |     Flags     |V|T|F|S|
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |              Reserved         |      Endpoint Behavior        |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   |                      SRv6 SID(optional)                       |
   |                           (128-bit)                           |
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   //                    NAI (variable)                           //
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   |                     SID Structure (optional)                  |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

]]></artwork>
          </figure>
          <t>The format of the SRv6-RRO subobject is the same as that of the
SRv6-ERO subobject, but without the L flag.</t>
          <t>The V flag has no meaning in the SRv6-RRO and is ignored on
receipt at the PCE.</t>
          <t>Ordering of SRv6-RRO subobjects by PCC in PCRpt message remains
as per <xref target="RFC8664"/>.</t>
          <t>The ordering of optional elements in the SRv6-RRO subobject is the same as described in <xref target="order"/>.</t>
        </section>
      </section>
    </section>
    <section anchor="Procedures">
      <name>Procedures</name>
      <section anchor="Exchanging-SRv6-Capability">
        <name>Exchanging the SRv6 Capability</name>
        <t>A PCC indicates that it is capable of supporting the head-end
functions for SRv6 by including the SRv6-PCE-CAPABILITY sub-TLV in the
Open message that it sends to a PCE. A PCE indicates that it is
capable of computing SRv6 paths by including the SRv6-PCE-CAPABILITY
sub-TLV in the Open message that it sends to a PCC.</t>
        <t>If a PCEP speaker receives a PATH-SETUP-TYPE-CAPABILITY TLV with a
PST list containing PST=3, but the SRv6-PCE-CAPABILITY sub-TLV is absent, then the PCEP speaker <bcp14>MUST</bcp14> send a PCErr message with Error-Type = 10 (Reception of an invalid object) and Error-Value = 34 (Missing PCE-SRv6-CAPABILITY sub-TLV) and <bcp14>MUST</bcp14> then close the PCEP session. If a PCEP speaker receives a PATH-SETUP-TYPE-CAPABILITY TLV with an SRv6-PCE-CAPABILITY sub-TLV, but the PST list does not contain PST=3, then the PCEP speaker <bcp14>MUST</bcp14> ignore the SRv6-PCE-CAPABILITY sub-TLV.</t>
        <t>If a PCC sets the X flag to 1
then the MSD is not used and <bcp14>MUST NOT</bcp14> be included. If a PCE receives
an SRv6-PCE-CAPABILITY sub-TLV with the X flag set to 1 then it <bcp14>MUST</bcp14>
ignore any MSD-Type, MSD-Value fields and assume that the sender
can impose any length of SRH. If a PCC sets the X flag to zero, then
it sets the SRv6 MSD-Type, MSD-Value fields that it can impose on a
packet. If a PCE receives an SRv6-PCE-CAPABILITY sub-TLV with the X
flag as set, and SRv6 MSD-Type or MSD-Value fields are set then it
is considered as an error and the PCE <bcp14>MUST</bcp14> respond with a PCErr message
(Error-Type = 1 "PCEP session establishment failure" and Error-Value = 1
"reception of an invalid Open message or a non Open message."). In
case the MSD-Type in SRv6-PCE-CAPABILITY sub-TLV received by the PCE
does not correspond to one of the SRv6 MSD types, the PCE <bcp14>MUST</bcp14> respond
with a PCErr message (Error-Type = 1 "PCEP session establishment
failure" and Error-Value = 1 "reception of an invalid Open message or a
non Open message.").</t>
        <t>Note that the MSD-Type, MSD-Value exchanged via the
SRv6-PCE-CAPABILITY sub-TLV indicates the SRv6 SID imposition limit
for the sender PCC node only. However, if a PCE learns these via alternate mechanisms, e.g routing protocols <xref target="RFC9352"/>, then it ignores the values in the SRv6-PCE-CAPABILITY sub-TLV. Furthermore, whenever a PCE learns any other SRv6 MSD types that may be defined in the future via alternate mechanisms, it <bcp14>MUST</bcp14> use those values regardless of the values exchanged in the SRv6-PCE-CAPABILITY sub-TLV.</t>
        <t>During path computation, PCE must consider the MSD information of all the nodes along the path instead of only the MSD information of the ingress PCC since a packet may be dropped on any node in a forwarding path because of MSD exceeding. The MSD capabilities of all SR nodes along the path can be learned as part of the topology information via IGP/BGP-LS or via PCEP if the PCE also happens to have PCEP sessions to those nodes.</t>
        <t>A PCE <bcp14>MUST NOT</bcp14> send SRv6 paths exceeding the SRv6 MSD capabilities of the PCC. If a PCC needs to modify the SRv6 MSD value signaled via the Open message, it <bcp14>MUST</bcp14> close the PCEP session and re-establish it with the new value. If the PCC receives an SRv6 path that exceed its SRv6 MSD capabilties, the PCC <bcp14>MUST</bcp14> send a PCErr message with Error-Type = 10 (Reception of an invalid object) and Error-Value = 39 (Unsupported number of SRv6-ERO subobjects).</t>
        <t>The N flag, X flag and (MSD-Type,MSD-Value) pair inside the SRv6-PCE-CAPABILITY sub-TLV are meaningful only in the Open message sent to a PCE. As such,the flags <bcp14>MUST</bcp14> be set to zero and a (MSD-Type,MSD-Value) pair <bcp14>MUST NOT</bcp14> be present in the SRv6-PCE-CAPABILITY sub-TLV in an Open message sent to a PCC.  Similarly, a PCC <bcp14>MUST</bcp14> ignore flags and any (MSD-Type,MSD-Value) pair in a received Open message. If a PCE receives multiple SRv6-PCE-CAPABILITY sub-TLVs in an Open message, it processes only the first sub-TLV received.</t>
      </section>
      <section anchor="ERO-Processing">
        <name>ERO Processing</name>
        <t>The processing of ERO remains unchanged in accordance with both <xref target="RFC5440"/> and <xref target="RFC8664"/>.</t>
        <section anchor="srv6-ero-validation">
          <name>SRv6 ERO Validation</name>
          <t>If a PCC does not support the SRv6 PCE Capability and thus cannot
recognize the SRv6-ERO or SRv6-RRO subobjects. It should respond according to the rules for a malformed object as described in <xref target="RFC5440"/>.</t>
          <t>On receiving an SRv6-ERO, a PCC <bcp14>MUST</bcp14> validate that the Length
field, the S bit, the F bit, the T bit, and the NT field are
consistent, as follows.</t>
          <ul spacing="normal">
            <li>If NT=0, the F bit <bcp14>MUST</bcp14> be 1, the S bit <bcp14>MUST</bcp14> be zero and the
Length <bcp14>MUST</bcp14> be 24.</li>
            <li>If NT=2, the F bit <bcp14>MUST</bcp14> be zero. If the S bit is 1, the
Length <bcp14>MUST</bcp14> be 24, otherwise the Length <bcp14>MUST</bcp14> be 40.</li>
            <li>If NT=4, the F bit <bcp14>MUST</bcp14> be zero. If the S bit is 1, the
Length <bcp14>MUST</bcp14> be 40, otherwise the Length <bcp14>MUST</bcp14> be 56.</li>
            <li>If NT=6, the F bit <bcp14>MUST</bcp14> be zero. If the S bit is 1, the
Length <bcp14>MUST</bcp14> be 48, otherwise the Length <bcp14>MUST</bcp14> be 64.</li>
            <li>NT types (1,3, and 5) are not valid for SRv6.</li>
            <li>If T bit is 1, then S bit <bcp14>MUST</bcp14> be zero.</li>
          </ul>
          <t>If a PCC finds that the NT field, Length field, S bit, F bit, and
T bit are not consistent, it <bcp14>MUST</bcp14> consider the entire ERO invalid
and <bcp14>MUST</bcp14> send a PCErr message with Error-Type = 10 ("Reception of an
invalid object") and Error-Value = 11 ("Malformed object").</t>
          <t>If a PCC does not recognize or support the value in the NT field, it
<bcp14>MUST</bcp14> consider the entire ERO invalid and send a PCErr message
with Error-Type = 10 ("Reception of an invalid object") and Error-
value = 40 ("Unsupported NAI Type in the SRv6-ERO/SRv6-RRO subobject").</t>
          <t>If a PCC receives an SRv6-ERO subobject in which the S and F bits are
both set to 1 (that is, both the SID and NAI are absent), it <bcp14>MUST</bcp14>
consider the entire ERO invalid and send a PCErr message with Error-
Type = 10 ("Reception of an invalid object") and Error-value = 41
("Both SID and NAI are absent in the SRv6-ERO subobject").</t>
          <t>If a PCC receives an SRv6-ERO subobject in which the S bit is set to 1
and the F bit is set to zero (that is, the SID is absent and the NAI
is present), but the PCC does not support NAI resolution, it <bcp14>MUST</bcp14>
consider the entire ERO invalid and send a PCErr message with Error-
Type = 4 ("Not supported object") and Error-value = 4 ("Unsupported
parameter").</t>
          <t>If a PCC detects that the subobjects of an ERO are a mixture of SRv6-
ERO subobjects and subobjects of other types, then it <bcp14>MUST</bcp14> send a
PCErr message with Error-Type = 10 ("Reception of an invalid object")
and Error-value = 42 ("ERO mixes SRv6-ERO subobjects with other
subobject types").</t>
          <t>In case a PCEP speaker receives an SRv6-ERO subobject, when the PST is not set to 3 or SRv6-PCE-CAPABILITY sub-TLV was not exchanged, it <bcp14>MUST</bcp14> send a PCErr message with Error-Type = 19 ("Invalid Operation") and Error-Value = 19 ("Attempted SRv6 when the capability was not advertised").</t>
          <t>If a PCC receives an SRv6 path that exceeds the SRv6 MSD capabilities, it <bcp14>MUST</bcp14> send a PCErr message with Error-Type = 10 ("Reception of an invalid object") and Error-Value = 43 ("Unsupported number of SRv6-ERO subobjects") as per <xref target="RFC8664"/>.</t>
        </section>
        <section anchor="interpreting-the-srv6-ero">
          <name>Interpreting the SRv6-ERO</name>
          <t>The SRv6-ERO contains a sequence of subobjects. According to <xref target="RFC9256"/>, each
SRv6-ERO subobject in the sequence identifies a segment that the
traffic will be directed to, in the order given. That is, the first
subobject identifies the first segment the traffic will be directed
to, the second SRv6-ERO subobject represents the second segment, and
so on.</t>
        </section>
      </section>
      <section anchor="RRO-Processing">
        <name>RRO Processing</name>
        <t>The syntax checking rules that apply to the SRv6-RRO subobject are
identical to those of the SRv6-ERO subobject, except as noted
below.</t>
        <t>If a PCEP speaker receives an SRv6-RRO subobject in which both SRv6
SID and NAI are absent, it <bcp14>MUST</bcp14> consider the entire RRO invalid and
send a PCErr message with Error-Type = 10 ("Reception of an invalid
object") and Error-Value = 35 ("Both SID and NAI
are absent in
SRv6-RRO subobject").</t>
        <t>If a PCE detects that the subobjects of an RRO are a mixture of
SRv6-RRO subobjects and subobjects of other types, then it <bcp14>MUST</bcp14> send a
PCErr message with Error-Type = 10 ("Reception of an invalid object")
and Error-Value = 36 ("RRO mixes SRv6-RRO subobjects
with other
subobject types").</t>
        <t>The mechanism by which the PCC learns the path is outside the scope of this document.</t>
      </section>
    </section>
    <section anchor="Security-Considerations">
      <name>Security Considerations</name>
      <t>The security considerations described in <xref target="RFC5440"/>, section 2.5 of <xref target="RFC6952"/>, <xref target="RFC8231"/>, <xref target="RFC8281"/>, <xref target="RFC8253"/> and <xref target="RFC8664"/> are applicable to this specification. No additional security measure is required.</t>
      <t>Note that this specification enables a network controller to
instantiate an SRv6 path in the network.  This creates an additional
vulnerability if the security mechanisms of <xref target="RFC5440"/>, <xref target="RFC8231"/>, and <xref target="RFC8281"/>
are not used.  If there is no integrity protection on the
session, then an attacker could create an SRv6 path that may not subjected
to the further verification checks. Further, the MSD field in the Open message
could disclose node forwarding capabilities if suitable security mechanisms
are not in place.</t>
    </section>
    <section anchor="Manage">
      <name>Manageability Considerations</name>
      <t>All manageability requirements and considerations listed in <xref target="RFC5440"/>, <xref target="RFC8231"/>,
<xref target="RFC8281"/>, and <xref target="RFC8664"/> apply to PCEP protocol extensions defined in this
document. In addition, requirements and considerations listed in this
section apply.</t>
      <section anchor="control-of-function-and-policy">
        <name>Control of Function and Policy</name>
        <t>A PCEP implementation <bcp14>SHOULD</bcp14> allow the operator to configure the SRv6 capability.
Further a policy to accept NAI only for the SRv6 <bcp14>SHOULD</bcp14> be allowed to be set.</t>
      </section>
      <section anchor="information-and-data-models">
        <name>Information and Data Models</name>
        <t>The PCEP YANG module is out of the scope of this document and defined in other drafts. An augmented YANG module for SRv6 is also specified in another draft that allows for SRv6 capability and MSD configurations as well as to monitor the SRv6 paths set in the network.</t>
      </section>
      <section anchor="liveness-detection-and-monitoring">
        <name>Liveness Detection and Monitoring</name>
        <t>Mechanisms defined in this document do not imply any new liveness
detection and monitoring requirements in addition to those already
listed in <xref target="RFC5440"/>.</t>
      </section>
      <section anchor="verify-correct-operations">
        <name>Verify Correct Operations</name>
        <t>Verification of the mechanisms defined in this document can be built on those already listed in <xref target="RFC5440"/>, <xref target="RFC8231"/>, and <xref target="RFC8664"/>.</t>
      </section>
      <section anchor="requirements-on-other-protocols">
        <name>Requirements On Other Protocols</name>
        <t>Mechanisms defined in this document do not imply any new
requirements on other protocols.</t>
      </section>
      <section anchor="impact-on-network-operations">
        <name>Impact On Network Operations</name>
        <t>Mechanisms defined in <xref target="RFC5440"/>, <xref target="RFC8231"/>, and <xref target="RFC8664"/> also apply to PCEP
extensions defined in this document.</t>
      </section>
    </section>
    <section anchor="implementation-status">
      <name>Implementation Status</name>
      <t>[Note to the RFC Editor - remove this section before publication, as
well as remove the reference to <xref target="RFC7942"/>.</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"/>, "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".</t>
      <section anchor="ciscos-commercial-delivery">
        <name>Cisco's Commercial Delivery</name>
        <ul spacing="normal">
          <li>Organization: Cisco Systems, Inc.</li>
          <li>Implementation: IOS-XR PCE and PCC.</li>
          <li>Description: Implementation with experimental codepoints.</li>
          <li>Maturity Level: Production</li>
          <li>Coverage: Partial</li>
          <li>Contact: ssidor@cisco.com</li>
        </ul>
      </section>
    </section>
    <section anchor="IANA-Considerations">
      <name>IANA Considerations</name>
      <section anchor="PCEP-ERO-and-RRO-subobjects">
        <name>PCEP ERO and RRO subobjects</name>
        <t>This document defines a new subobject type for the PCEP explicit
route object (ERO), and a new subobject type for the PCEP reported route
object (RRO). The code points for subobject types of these objects is
maintained in the RSVP parameters registry, under the EXPLICIT_ROUTE
and REPORTED_ROUTE objects. IANA is requested to confirm the following allocations in the RSVP Parameters registry for each of the new subobject types
defined in this document.</t>
        <artwork><![CDATA[
  Object                Subobject                  Subobject Type
  --------------------- -------------------------- ------------------
  EXPLICIT_ROUTE        SRv6-ERO (PCEP-specific)     40
  REPORTED_ROUTE        SRv6-RRO (PCEP-specific)     40

]]></artwork>
      </section>
      <section anchor="SRv6-ERO-flag">
        <name>New SRv6-ERO Flag Registry</name>
        <t>IANA is requested to create a new sub-registry, named "SRv6-ERO
Flag Field", within the "Path Computation Element Protocol (PCEP)
Numbers" registry to manage the 12-bit Flag field of the SRv6-ERO subobject.
New values are to be assigned by Standards Action <xref target="RFC8126"/>.
Each bit should be tracked with the following qualities.</t>
        <ul spacing="normal">
          <li>Bit (counting from bit 0 as the most significant
bit)</li>
          <li>Description</li>
          <li>Reference</li>
        </ul>
        <t>The following values are defined in this document.</t>
        <artwork><![CDATA[
                Bit     Description            Reference
                -----   ------------------     --------------
                 0-7      Unassigned
                   8      SID Verification (V)  This document
                   9      SID Structure is      This document
                          present (T)
                  10      NAI is absent (F)     This document
                  11      SID is absent (S)     This document
]]></artwork>
      </section>
      <section anchor="lsp-error-code-tlv">
        <name>LSP-ERROR-CODE TLV</name>
        <t>This document defines a new value in the sub-registry "LSP-ERROR-CODE TLV Error Code Field" in the "Path Computation Element Protocol(PCEP) Numbers" registry.</t>
        <artwork><![CDATA[
    Value      Meaning                     Reference
    ---       -----------------------     -----------
     9        SID Verification fails      This document
]]></artwork>
      </section>
      <section anchor="sub-TLV-Type-Indicators">
        <name>PATH-SETUP-TYPE-CAPABILITY Sub-TLV Type Indicators</name>
        <t>IANA maintains a sub-registry, named "PATH-SETUP-TYPE-CAPABILITY
Sub-TLV Type Indicators", within the "Path Computation Element
Protocol (PCEP) Numbers" registry to manage the type indicator space
for sub-TLVs of the PATH-SETUP-TYPE-CAPABILITY TLV. IANA is requested to
confirm the following allocations in the sub-registry.</t>
        <artwork><![CDATA[
   Value     Meaning                     Reference
   -----     -------                     ---------
   27        SRv6-PCE-CAPABILITY         This Document
]]></artwork>
      </section>
      <section anchor="SRv6-PCE-Capability-Flags">
        <name>SRv6 PCE Capability Flags</name>
        <t>IANA is requested to create a new sub-registry, named "SRv6
Capability Flag Field", within the "Path Computation Element Protocol (PCEP) Numbers" registry to manage the 16-bit Flag field of the SRv6-PCE-CAPABILITY sub-TLV. New values are to be assigned by Standards Action <xref target="RFC8126"/>. Each bit should be tracked with the following qualities.</t>
        <ul spacing="normal">
          <li>Bit (counting from bit 0 as the most significant
bit)</li>
          <li>Description</li>
          <li>Reference</li>
        </ul>
        <t>The following values are defined in this document.</t>
        <artwork><![CDATA[
                 Bit     Description           Reference
                -----   ------------------     --------------
                 0-13    Unassigned
                  14     Node or Adjacency     This document
                         Identifier (NAI) is
                         supported (N)
                  15     Unlimited Maximum SID This document
                         Depth (X)
]]></artwork>
      </section>
      <section anchor="New-Path-Setup-Type">
        <name>New Path Setup Type</name>
        <t><xref target="RFC8408"/> created a sub-registry within the "Path
Computation Element Protocol (PCEP) Numbers" registry called "PCEP
Path Setup Types". IANA is requested to confirm the following allocations
in the sub-registry.</t>
        <artwork><![CDATA[
Value             Description                  Reference
-----             -----------                  ---------
3                 Traffic engineering path is  This Document
                  setup using SRv6.

]]></artwork>
      </section>
      <section anchor="ERROR-Objects">
        <name>ERROR Objects</name>
        <t>IANA is requested to confirm the following allocations in the PCEP-ERROR
Object
Error Types and Values registry for the following new error-values.</t>
        <artwork><![CDATA[
   Error-Type   Meaning
   ----------   -------
   10           Reception of an invalid object
                Error-value = 34 (Missing
                PCE-SRv6-CAPABILITY sub-TLV)
                Error-value = 35 (Both SID and NAI are absent
                in SRv6-RRO subobject)
                Error-value = 36 (RRO mixes SRv6-RRO subobjects
                with other subobject types)
                Error-value = 37 (Invalid SRv6 SID Structure)
   19           Invalid Operation
                Error-value = 19 (Attempted SRv6 when the
                capability was not advertised)

]]></artwork>
        <t>IANA is requested to make a new allocations in the PCEP-ERROR Object
Error Types and Values registry for the following new error-values.</t>
        <artwork><![CDATA[
   Error-Type   Meaning
   ----------   -------
   10           Reception of an invalid object
                Error-value = 39 (Unsupported number of
                SRv6-ERO subobjects)
                Error-value = 40 (Unsupported NAI Type
                in the SRv6-ERO/SRv6-RRO subobject)
                Error-value = 41 (Both SID and NAI are
                absent in the SRv6-ERO subobject)
                Error-value = 42 (ERO mixes SRv6-ERO
                subobjects with other subobject types)
                Error-value = 43 (Unsupported number
                of SRv6-ERO subobjects)

]]></artwork>
      </section>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="RFC3209">
          <front>
            <title>RSVP-TE: Extensions to RSVP for LSP Tunnels</title>
            <author fullname="D. Awduche" initials="D." surname="Awduche"/>
            <author fullname="L. Berger" initials="L." surname="Berger"/>
            <author fullname="D. Gan" initials="D." surname="Gan"/>
            <author fullname="T. Li" initials="T." surname="Li"/>
            <author fullname="V. Srinivasan" initials="V." surname="Srinivasan"/>
            <author fullname="G. Swallow" initials="G." surname="Swallow"/>
            <date month="December" year="2001"/>
            <abstract>
              <t>This document describes the use of RSVP (Resource Reservation Protocol), including all the necessary extensions, to establish label-switched paths (LSPs) in MPLS (Multi-Protocol Label Switching). Since the flow along an LSP is completely identified by the label applied at the ingress node of the path, these paths may be treated as tunnels. A key application of LSP tunnels is traffic engineering with MPLS as specified in RFC 2702. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3209"/>
          <seriesInfo name="DOI" value="10.17487/RFC3209"/>
        </reference>
        <reference anchor="RFC5440">
          <front>
            <title>Path Computation Element (PCE) Communication Protocol (PCEP)</title>
            <author fullname="JP. Vasseur" initials="JP." role="editor" surname="Vasseur"/>
            <author fullname="JL. Le Roux" initials="JL." role="editor" surname="Le Roux"/>
            <date month="March" year="2009"/>
            <abstract>
              <t>This document specifies the Path Computation Element (PCE) Communication Protocol (PCEP) for communications between a Path Computation Client (PCC) and a PCE, or between two PCEs. Such interactions include path computation requests and path computation replies as well as notifications of specific states related to the use of a PCE in the context of Multiprotocol Label Switching (MPLS) and Generalized MPLS (GMPLS) Traffic Engineering. PCEP is designed to be flexible and extensible so as to easily allow for the addition of further messages and objects, should further requirements be expressed in the future. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5440"/>
          <seriesInfo name="DOI" value="10.17487/RFC5440"/>
        </reference>
        <reference anchor="RFC5511">
          <front>
            <title>Routing Backus-Naur Form (RBNF): A Syntax Used to Form Encoding Rules in Various Routing Protocol Specifications</title>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <date month="April" year="2009"/>
            <abstract>
              <t>Several protocols have been specified in the Routing Area of the IETF using a common variant of the Backus-Naur Form (BNF) of representing message syntax. However, there is no formal definition of this version of BNF.</t>
              <t>There is value in using the same variant of BNF for the set of protocols that are commonly used together. This reduces confusion and simplifies implementation.</t>
              <t>Updating existing documents to use some other variant of BNF that is already formally documented would be a substantial piece of work.</t>
              <t>This document provides a formal definition of the variant of BNF that has been used (that we call Routing BNF) and makes it available for use by new protocols. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5511"/>
          <seriesInfo name="DOI" value="10.17487/RFC5511"/>
        </reference>
        <reference anchor="RFC6952">
          <front>
            <title>Analysis of BGP, LDP, PCEP, and MSDP Issues According to the Keying and Authentication for Routing Protocols (KARP) Design Guide</title>
            <author fullname="M. Jethanandani" initials="M." surname="Jethanandani"/>
            <author fullname="K. Patel" initials="K." surname="Patel"/>
            <author fullname="L. Zheng" initials="L." surname="Zheng"/>
            <date month="May" year="2013"/>
            <abstract>
              <t>This document analyzes TCP-based routing protocols, the Border Gateway Protocol (BGP), the Label Distribution Protocol (LDP), the Path Computation Element Communication Protocol (PCEP), and the Multicast Source Distribution Protocol (MSDP), according to guidelines set forth in Section 4.2 of "Keying and Authentication for Routing Protocols Design Guidelines", RFC 6518.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6952"/>
          <seriesInfo name="DOI" value="10.17487/RFC6952"/>
        </reference>
        <reference anchor="RFC8126">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton"/>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <author fullname="T. Narten" initials="T." surname="Narten"/>
            <date month="June" year="2017"/>
            <abstract>
              <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters. To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper. For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
              <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed. This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
              <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="26"/>
          <seriesInfo name="RFC" value="8126"/>
          <seriesInfo name="DOI" value="10.17487/RFC8126"/>
        </reference>
        <reference anchor="RFC8231">
          <front>
            <title>Path Computation Element Communication Protocol (PCEP) Extensions for Stateful PCE</title>
            <author fullname="E. Crabbe" initials="E." surname="Crabbe"/>
            <author fullname="I. Minei" initials="I." surname="Minei"/>
            <author fullname="J. Medved" initials="J." surname="Medved"/>
            <author fullname="R. Varga" initials="R." surname="Varga"/>
            <date month="September" year="2017"/>
            <abstract>
              <t>The Path Computation Element Communication Protocol (PCEP) provides mechanisms for Path Computation Elements (PCEs) to perform path computations in response to Path Computation Client (PCC) requests.</t>
              <t>Although PCEP explicitly makes no assumptions regarding the information available to the PCE, it also makes no provisions for PCE control of timing and sequence of path computations within and across PCEP sessions. This document describes a set of extensions to PCEP to enable stateful control of MPLS-TE and GMPLS Label Switched Paths (LSPs) via PCEP.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8231"/>
          <seriesInfo name="DOI" value="10.17487/RFC8231"/>
        </reference>
        <reference anchor="RFC8281">
          <front>
            <title>Path Computation Element Communication Protocol (PCEP) Extensions for PCE-Initiated LSP Setup in a Stateful PCE Model</title>
            <author fullname="E. Crabbe" initials="E." surname="Crabbe"/>
            <author fullname="I. Minei" initials="I." surname="Minei"/>
            <author fullname="S. Sivabalan" initials="S." surname="Sivabalan"/>
            <author fullname="R. Varga" initials="R." surname="Varga"/>
            <date month="December" year="2017"/>
            <abstract>
              <t>The Path Computation Element Communication Protocol (PCEP) provides mechanisms for Path Computation Elements (PCEs) to perform path computations in response to Path Computation Client (PCC) requests.</t>
              <t>The extensions for stateful PCE provide active control of Multiprotocol Label Switching (MPLS) Traffic Engineering Label Switched Paths (TE LSPs) via PCEP, for a model where the PCC delegates control over one or more locally configured LSPs to the PCE. This document describes the creation and deletion of PCE-initiated LSPs under the stateful PCE model.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8281"/>
          <seriesInfo name="DOI" value="10.17487/RFC8281"/>
        </reference>
        <reference anchor="RFC8408">
          <front>
            <title>Conveying Path Setup Type in PCE Communication Protocol (PCEP) Messages</title>
            <author fullname="S. Sivabalan" initials="S." surname="Sivabalan"/>
            <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
            <author fullname="I. Minei" initials="I." surname="Minei"/>
            <author fullname="R. Varga" initials="R." surname="Varga"/>
            <author fullname="J. Hardwick" initials="J." surname="Hardwick"/>
            <date month="July" year="2018"/>
            <abstract>
              <t>A Path Computation Element (PCE) can compute Traffic Engineering (TE) paths through a network; these paths are subject to various constraints. Currently, TE paths are Label Switched Paths (LSPs) that are set up using the RSVP-TE signaling protocol. However, other TE path setup methods are possible within the PCE architecture. This document proposes an extension to the PCE Communication Protocol (PCEP) to allow support for different path setup methods over a given PCEP session.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8408"/>
          <seriesInfo name="DOI" value="10.17487/RFC8408"/>
        </reference>
        <reference anchor="RFC8491">
          <front>
            <title>Signaling Maximum SID Depth (MSD) Using IS-IS</title>
            <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
            <author fullname="U. Chunduri" initials="U." surname="Chunduri"/>
            <author fullname="S. Aldrin" initials="S." surname="Aldrin"/>
            <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
            <date month="November" year="2018"/>
            <abstract>
              <t>This document defines a way for an Intermediate System to Intermediate System (IS-IS) router to advertise multiple types of supported Maximum SID Depths (MSDs) at node and/or link granularity. Such advertisements allow entities (e.g., centralized controllers) to determine whether a particular Segment ID (SID) stack can be supported in a given network. This document only defines one type of MSD: Base MPLS Imposition. However, it defines an encoding that can support other MSD types. This document focuses on MSD use in a network that is Segment Routing (SR) enabled, but MSD may also be useful when SR is not enabled.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8491"/>
          <seriesInfo name="DOI" value="10.17487/RFC8491"/>
        </reference>
        <reference anchor="RFC8253">
          <front>
            <title>PCEPS: Usage of TLS to Provide a Secure Transport for the Path Computation Element Communication Protocol (PCEP)</title>
            <author fullname="D. Lopez" initials="D." surname="Lopez"/>
            <author fullname="O. Gonzalez de Dios" initials="O." surname="Gonzalez de Dios"/>
            <author fullname="Q. Wu" initials="Q." surname="Wu"/>
            <author fullname="D. Dhody" initials="D." surname="Dhody"/>
            <date month="October" year="2017"/>
            <abstract>
              <t>The Path Computation Element Communication Protocol (PCEP) defines the mechanisms for the communication between a Path Computation Client (PCC) and a Path Computation Element (PCE), or among PCEs. This document describes PCEPS -- the usage of Transport Layer Security (TLS) to provide a secure transport for PCEP. The additional security mechanisms are provided by the transport protocol supporting PCEP; therefore, they do not affect the flexibility and extensibility of PCEP.</t>
              <t>This document updates RFC 5440 in regards to the PCEP initialization phase procedures.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8253"/>
          <seriesInfo name="DOI" value="10.17487/RFC8253"/>
        </reference>
        <reference anchor="RFC8664">
          <front>
            <title>Path Computation Element Communication Protocol (PCEP) Extensions for Segment Routing</title>
            <author fullname="S. Sivabalan" initials="S." surname="Sivabalan"/>
            <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
            <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
            <author fullname="W. Henderickx" initials="W." surname="Henderickx"/>
            <author fullname="J. Hardwick" initials="J." surname="Hardwick"/>
            <date month="December" year="2019"/>
            <abstract>
              <t>Segment Routing (SR) enables any head-end node to select any path without relying on a hop-by-hop signaling technique (e.g., LDP or RSVP-TE). It depends only on "segments" that are advertised by link-state Interior Gateway Protocols (IGPs). An SR path can be derived from a variety of mechanisms, including an IGP Shortest Path Tree (SPT), an explicit configuration, or a Path Computation Element (PCE). This document specifies extensions to the Path Computation Element Communication Protocol (PCEP) that allow a stateful PCE to compute and initiate Traffic-Engineering (TE) paths, as well as a Path Computation Client (PCC) to request a path subject to certain constraints and optimization criteria in SR networks.</t>
              <t>This document updates RFC 8408.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8664"/>
          <seriesInfo name="DOI" value="10.17487/RFC8664"/>
        </reference>
        <reference anchor="RFC8986">
          <front>
            <title>Segment Routing over IPv6 (SRv6) Network Programming</title>
            <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
            <author fullname="P. Camarillo" initials="P." role="editor" surname="Camarillo"/>
            <author fullname="J. Leddy" initials="J." surname="Leddy"/>
            <author fullname="D. Voyer" initials="D." surname="Voyer"/>
            <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
            <author fullname="Z. Li" initials="Z." surname="Li"/>
            <date month="February" year="2021"/>
            <abstract>
              <t>The Segment Routing over IPv6 (SRv6) Network Programming framework enables a network operator or an application to specify a packet processing program by encoding a sequence of instructions in the IPv6 packet header.</t>
              <t>Each instruction is implemented on one or several nodes in the network and identified by an SRv6 Segment Identifier in the packet.</t>
              <t>This document defines the SRv6 Network Programming concept and specifies the base set of SRv6 behaviors that enables the creation of interoperable overlays with underlay optimization.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8986"/>
          <seriesInfo name="DOI" value="10.17487/RFC8986"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
      </references>
      <references>
        <name>Informative References</name>
        <reference anchor="RFC4657">
          <front>
            <title>Path Computation Element (PCE) Communication Protocol Generic Requirements</title>
            <author fullname="J. Ash" initials="J." role="editor" surname="Ash"/>
            <author fullname="J.L. Le Roux" initials="J.L." role="editor" surname="Le Roux"/>
            <date month="September" year="2006"/>
            <abstract>
              <t>The PCE model is described in the "PCE Architecture" document and facilitates path computation requests from Path Computation Clients (PCCs) to Path Computation Elements (PCEs). This document specifies generic requirements for a communication protocol between PCCs and PCEs, and also between PCEs where cooperation between PCEs is desirable. Subsequent documents will specify application-specific requirements for the PCE communication protocol. This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4657"/>
          <seriesInfo name="DOI" value="10.17487/RFC4657"/>
        </reference>
        <reference anchor="RFC7942">
          <front>
            <title>Improving Awareness of Running Code: The Implementation Status Section</title>
            <author fullname="Y. Sheffer" initials="Y." surname="Sheffer"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <date month="July" year="2016"/>
            <abstract>
              <t>This document describes a simple process that allows authors of Internet-Drafts to record the status of known implementations by including an Implementation Status section. 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.</t>
              <t>This process is not mandatory. Authors of Internet-Drafts are encouraged to consider using the process for their documents, and working groups are invited to think about applying the process to all of their protocol specifications. This document obsoletes RFC 6982, advancing it to a Best Current Practice.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="205"/>
          <seriesInfo name="RFC" value="7942"/>
          <seriesInfo name="DOI" value="10.17487/RFC7942"/>
        </reference>
        <reference anchor="RFC8051">
          <front>
            <title>Applicability of a Stateful Path Computation Element (PCE)</title>
            <author fullname="X. Zhang" initials="X." role="editor" surname="Zhang"/>
            <author fullname="I. Minei" initials="I." role="editor" surname="Minei"/>
            <date month="January" year="2017"/>
            <abstract>
              <t>A stateful Path Computation Element (PCE) maintains information about Label Switched Path (LSP) characteristics and resource usage within a network in order to provide traffic-engineering calculations for its associated Path Computation Clients (PCCs). This document describes general considerations for a stateful PCE deployment and examines its applicability and benefits, as well as its challenges and limitations, through a number of use cases. PCE Communication Protocol (PCEP) extensions required for stateful PCE usage are covered in separate documents.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8051"/>
          <seriesInfo name="DOI" value="10.17487/RFC8051"/>
        </reference>
        <reference anchor="RFC8402">
          <front>
            <title>Segment Routing Architecture</title>
            <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
            <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
            <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
            <author fullname="B. Decraene" initials="B." surname="Decraene"/>
            <author fullname="S. Litkowski" initials="S." surname="Litkowski"/>
            <author fullname="R. Shakir" initials="R." surname="Shakir"/>
            <date month="July" year="2018"/>
            <abstract>
              <t>Segment Routing (SR) leverages the source routing paradigm. A node steers a packet through an ordered list of instructions, called "segments". A segment can represent any instruction, topological or service based. A segment can have a semantic local to an SR node or global within an SR domain. SR provides a mechanism that allows a flow to be restricted to a specific topological path, while maintaining per-flow state only at the ingress node(s) to the SR domain.</t>
              <t>SR can be directly applied to the MPLS architecture with no change to the forwarding plane. A segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels. The segment to process is on the top of the stack. Upon completion of a segment, the related label is popped from the stack.</t>
              <t>SR can be applied to the IPv6 architecture, with a new type of routing header. A segment is encoded as an IPv6 address. An ordered list of segments is encoded as an ordered list of IPv6 addresses in the routing header. The active segment is indicated by the Destination Address (DA) of the packet. The next active segment is indicated by a pointer in the new routing header.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8402"/>
          <seriesInfo name="DOI" value="10.17487/RFC8402"/>
        </reference>
        <reference anchor="RFC8754">
          <front>
            <title>IPv6 Segment Routing Header (SRH)</title>
            <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
            <author fullname="D. Dukes" initials="D." role="editor" surname="Dukes"/>
            <author fullname="S. Previdi" initials="S." surname="Previdi"/>
            <author fullname="J. Leddy" initials="J." surname="Leddy"/>
            <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
            <author fullname="D. Voyer" initials="D." surname="Voyer"/>
            <date month="March" year="2020"/>
            <abstract>
              <t>Segment Routing can be applied to the IPv6 data plane using a new type of Routing Extension Header called the Segment Routing Header (SRH). This document describes the SRH and how it is used by nodes that are Segment Routing (SR) capable.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8754"/>
          <seriesInfo name="DOI" value="10.17487/RFC8754"/>
        </reference>
        <reference anchor="RFC9256">
          <front>
            <title>Segment Routing Policy Architecture</title>
            <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
            <author fullname="K. Talaulikar" initials="K." role="editor" surname="Talaulikar"/>
            <author fullname="D. Voyer" initials="D." surname="Voyer"/>
            <author fullname="A. Bogdanov" initials="A." surname="Bogdanov"/>
            <author fullname="P. Mattes" initials="P." surname="Mattes"/>
            <date month="July" year="2022"/>
            <abstract>
              <t>Segment Routing (SR) allows a node to steer a packet flow along any path. Intermediate per-path states are eliminated thanks to source routing. SR Policy is an ordered list of segments (i.e., instructions) that represent a source-routed policy. Packet flows are steered into an SR Policy on a node where it is instantiated called a headend node. The packets steered into an SR Policy carry an ordered list of segments associated with that SR Policy.</t>
              <t>This document updates RFC 8402 as it details the concepts of SR Policy and steering into an SR Policy.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9256"/>
          <seriesInfo name="DOI" value="10.17487/RFC9256"/>
        </reference>
        <reference anchor="RFC9352">
          <front>
            <title>IS-IS Extensions to Support Segment Routing over the IPv6 Data Plane</title>
            <author fullname="P. Psenak" initials="P." role="editor" surname="Psenak"/>
            <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
            <author fullname="A. Bashandy" initials="A." surname="Bashandy"/>
            <author fullname="B. Decraene" initials="B." surname="Decraene"/>
            <author fullname="Z. Hu" initials="Z." surname="Hu"/>
            <date month="February" year="2023"/>
            <abstract>
              <t>The Segment Routing (SR) architecture allows a flexible definition of the end-to-end path by encoding it as a sequence of topological elements called "segments". It can be implemented over the MPLS or the IPv6 data plane. This document describes the IS-IS extensions required to support SR over the IPv6 data plane.</t>
              <t>This document updates RFC 7370 by modifying an existing registry.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9352"/>
          <seriesInfo name="DOI" value="10.17487/RFC9352"/>
        </reference>
      </references>
    </references>
    <?line 980?>

<section numbered="false" anchor="acknowledgements">
      <name>Acknowledgements</name>
      <t>The authors would like to thank Jeff Tantsura, Adrian Farrel, Aijun
Wang, Khasanov Boris, Ketan Talaulikar, Martin Vigoureux, Hariharan Ananthakrishnan, Julien Meuric and Robert Varga for valuable suggestions.</t>
    </section>
    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
      <name>Contributors</name>
      <contact initials="D." surname="Dhody" fullname="Dhruv Dhody">
        <organization>Huawei</organization>
        <address>
          <postal>
            <country>India</country>
          </postal>
          <email>dhruv.ietf@gmail.com</email>
        </address>
      </contact>
      <contact initials="H." surname="Wumin" fullname="Huang Wumin">
        <organization>Huawei Technologies</organization>
        <address>
          <postal>
            <street>Huawei Building, No. 156 Beiqing Rd.</street>
            <city>Beijing</city>
            <code>100095</code>
            <country>China</country>
          </postal>
          <email>huangwumin@huawei.com</email>
        </address>
      </contact>
      <contact initials="S." surname="Peng" fullname="Shuping Peng">
        <organization>Huawei Technologies</organization>
        <address>
          <postal>
            <street>Huawei Building, No. 156 Beiqing Rd.</street>
            <city>Beijing</city>
            <code>100095</code>
            <country>China</country>
          </postal>
          <email>pengshuping@huawei.com</email>
        </address>
      </contact>
      <contact initials="R." surname="Chen" fullname="Ran Chen">
        <organization>ZTE Corporation</organization>
        <address>
          <postal>
            <country>China</country>
          </postal>
          <email>chen.ran@zte.com.cn</email>
        </address>
      </contact>
    </section>
  </back>
  <!-- ##markdown-source:
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
XUGEIjhBDmoikI1lF9CdghY7IKvxuMeFzLOdRWeA/8BWlYtFaotG4nCkf0Yj
PfznIdFI9wUj3R9I9JCYpP//opG2zeaf0Uit06mFI43vC0cabwtHaiYXjusR
nCRbpQgA8X/JCWjzhqLL23Bq9gaKUoKDvWFZXouk8PWzsRQoQUWoYR8aJZWP
BkgnFFdlE2701vGJY1o7X5DSBqqlwJFokF7H27XJrZiqeWVZR/3AxZtclido
AV7KJ8f3cmZs4D/3wq7fP3If0A0pXky2VR/8062otCWfbQ6KV1oKxzBFCpUt
welcn9N17SBoe0osUcbFCoxWe6AjEBTkuzc6jCkV3Aap8ms02WKjXnrWQ2BS
IUz6fpgOUXduJBlbY/vepGuuI6JMCrVfqomizHl33ItCcwjc44NnofhaMj8C
fr/zR6PzZ7vvp9X1s6c7rzH3iitTCpU1QO26AAOCdLbIitiDl5MS2hK3Pxan
6TaMObRazNvyFCbETfC/BaHMbu5bHUchNucq1j9ZE2Wo7AiUWMFAkH/Coqoe
h2XRY7Gits/XHZXJwGGggpzqKpkQ2ngt6VXGeCYnQlGAta1tjgNHj5CPyM8R
s4GKl+MfvFPmFjRwCClCo2iPlZ6nagssZlN6A2PClOJSOi2IuocwPEQptpIl
UMDUP3W5ZVhSu4GaXFyYjFWVFL4Tlmvb8XG5rXUEsMmJOjlyTWWhYJeqTrhD
9U5Q9cqWtqKYIDw6R2dryyYdqp18w84OWB1XuMXSSt7TwQ4GAKcKHZKGXBmi
ZDtKbSCuc+cpb7cZF7aEVAaeKJte12tFlmpDlv4IZKltyNIPR5ZqQ5ZS50GR
yDYyNiUtOLPPakgbRaUfgOKCSZDwEz4JwaxMZXLWJKYLtxzXi0oXay/VLzGb
g/LOTJE1qnyEnr6UK+m4m1biwbW7P0YKSBV+xmPPshPmJIU7cw+1oE01QKS8
JtrjnImIgIZAuooytQRMwrMc6nqhM57fafPMTFgLVx1BLiJA5/F1lM+pBrWf
sl14C/eAeSl1xLWn+J4Kl0zJTlvyhxk+4SRB7bxAMiZTqVSWiRojtUyLEvQx
Uj+xGPGGPujMWWqKER9OTM10ugvFIC/PVit27iOyiXIw5Duo2BpRINgskqJh
OBigJI7n5IafyPhtaZ9ya0ljDnK+8N8jB/LA8RoUvqQ6ecqknWrIqtqTbQ89
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

-->

</rfc>
