<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" category="std" docName="draft-ietf-pce-pcep-extension-pce-controller-sr-13" obsoletes="" updates="" submissionType="IETF" xml:lang="en" tocInclude="true" tocDepth="3" symRefs="true" sortRefs="true" version="3">
  <front>
    <title abbrev='PCECC-SR'>PCE Communication Protocol (PCEP) Extensions for Using PCE as a Central Controller (PCECC) for Segment Routing (SR) MPLS Segment Identifier (SID) Allocation and Distribution</title>
    <author initials='Z' surname='Li' fullname='Zhenbin Li'>
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <street>Huawei Bld., No.156 Beiqing Rd.</street>
          <city>Beijing  </city>
          <region/>
          <code>100095</code>
          <country>China</country>
        </postal>
        <email>robinli314@163.com</email>
      </address>
    </author>
    <!--<author fullname="Dhruv Dhody"
            initials="D"
            surname="Dhody">
      <organization abbrev="Huawei Technologies">Huawei
      Technologies</organization>
      <address>
        <postal>
          <street>Divyashree Techno Park, Whitefield</street>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <code>560066</code>
          <country>India</country>
        </postal>
        <email>dhruv.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="S" surname="Karunanithi" fullname="Satish Karunanithi">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <street>Divyashree Techno Park, Whitefield</street>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <code>560066</code>
          <country>India</country>
        </postal>
        <email>satishk@huawei.com</email>
      </address>
    </author>-->

    <author initials='S' surname='Peng' fullname='Shuping Peng'>
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <street>Huawei Bld., No.156 Beiqing Rd.</street>
          <city>Beijing</city>
          <region/>
          <code>100095</code>
          <country>China</country>
        </postal>
        <email>pengshuping@huawei.com</email>
      </address>
    </author>
    <!--<author initials="A"
            surname="Farrel"
            fullname="Adrian Farrel">
      <organization>Juniper Networks, Inc</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <region/>
          <code/>
          <country>UK</country>
        </postal>
        <email>adrian@olddog.co.uk</email>
      </address>
    </author>-->
    <author initials='M' surname='Negi' fullname='Mahendra Singh Negi'>
      <organization>RtBrick Inc</organization>
      <address>
        <postal>
          <street>N-17L, 18th Cross Rd, HSR Layout</street>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <code>560102</code>
          <country>India</country>
        </postal>
        <email>mahend.ietf@gmail.com</email>
      </address>
    </author>
    <author initials='Q' surname='Zhao' fullname='Quintin Zhao'>
      <organization>Etheric Networks</organization>
      <address>
        <postal>
          <street>1009 S CLAREMONT ST</street>
          <city>SAN MATEO</city>
          <region>CA</region>
          <code>94402</code>
          <country>USA</country>
        </postal>
        <email>qzhao@ethericnetworks.com</email>
      </address>
    </author>
    <author initials='C' surname='Zhou' fullname='Chao Zhou'>
      <organization>HPE</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <region/>
          <code/>
          <country/>
        </postal>
        <email>chaozhou_us@yahoo.com</email>
      </address>
    </author>
    <date year='2026'/>
    <area>Routing</area>
    <workgroup>PCE Working Group</workgroup>
    <abstract>
   <t>The Path Computation Element (PCE) is a core component of Software-Defined Networking (SDN) systems.</t>

   <t>A PCE-based Central Controller (PCECC) can simplify the processing of a distributed control plane by blending it with elements of SDN and without necessarily completely replacing it.  Thus, the Label Switched Path (LSP) can be calculated/set up/initiated and the label forwarding entries can also be downloaded through a centralized PCE server to each network
   device along the path while leveraging the existing PCE technologies as much as possible.</t>

   <t>This document specifies the procedures and PCE Communication Protocol (PCEP) extensions
   when a PCE-based controller is also responsible for configuring the
   forwarding actions on the routers, in addition to computing the paths
   for packet flows in a segment routing (SR) network and telling the edge
   routers what instructions to attach to packets as they enter the
   network. PCECC as defined in RFC 9050 is further enhanced for SR-MPLS SID (Segment Identifier) allocation and distribution.</t>

   </abstract>
  </front>
  <middle>
<section toc='default'><name>Introduction</name>
<t>The PCE <xref target='RFC4655'/> was developed to offload
   the path computation function from routers in an MPLS traffic-engineered
   network.  It can compute optimal paths for
   traffic across a network and can also update the paths to reflect
   changes in the network or traffic demands. Since then, the role and function of the PCE has grown to
   cover a number of other uses (such as GMPLS <xref target='RFC7025'/>) and to allow
   delegated control <xref target='RFC8231'/> and PCE-initiated use of network
   resources <xref target='RFC8281'/>.</t>

   <t>According to <xref target='RFC7399'/>, Software-Defined Networking (SDN) refers to a separation between the control elements and the forwarding components
   so that software running in a centralized system, called a
   controller, can act to program the devices in the network to behave
   in specific ways.  A required element in an SDN architecture is a
   component that plans how the network resources will be used and how
   the devices will be programmed.  It is possible to view this
   component as performing specific computations to place traffic flows
   within the network given knowledge of the availability of the network
   resources, how other forwarding devices are programmed, and the way
   that other flows are routed.  This is the function and purpose of a
   PCE, and the way that a PCE integrates into a wider network control
   system (including an SDN system) is presented in <xref target='RFC7491'/>.</t>

   <t>In early PCE implementations, where the PCE was used to derive paths
   for MPLS Label Switched Paths (LSPs), paths were requested by the network
   elements (known as Path Computation Clients (PCCs)), and the results
   of the path computations were supplied to network elements using the
   PCE Communication Protocol (PCEP) <xref target='RFC5440'/>.
   This protocol was later extended to allow a PCE to send unsolicited
   requests to the network for LSP establishment <xref target='RFC8281'/>.</t>

   <t>PCE was developed to derive paths for MPLS Label Switched Paths
   (LSPs), which are supplied to the head end of the LSP using PCEP.
    But SDN has a
   broader applicability than signaled (G)MPLS traffic-engineered (TE)
   networks, and the PCE may be used to determine paths in a range of
   use cases.  PCEP has been proposed as a control protocol for use in
   these environments to allow the PCE to be fully enabled as a central
   controller.</t>

   <t><xref target='RFC8283'/> introduces the architecture for PCE as a central
   controller as an extension of the architecture described in <xref target='RFC4655'/>
   and assumes the continued use of PCEP as the protocol used between
   PCE and PCC. <xref target='RFC8283'/>  further examines the motivations and applicability
   of PCEP as a Southbound Interface (SBI), and introduces the implications for the
   protocol.  <xref target='RFC9689'/> describes the use cases for
   the PCE-based Central Controller (PCECC) architecture. As described in <xref target='RFC8283'/>, PCECC simplifies the processing of a distributed IGP-based control plane by blending it with elements of SDN, without replacing it.</t>

   <t><xref target='RFC9050'/> specify the procedures and PCEP extensions for
   using the PCE as the central controller for static LSPs, where
   LSPs can be provisioned as explicit label instructions at each
   hop on the end-to-end path.</t>

   <t>Segment Routing (SR) technology leverages the source routing and tunneling paradigms.
   A source node can choose a path without relying on hop-by-hop
   signaling protocols such as LDP or RSVP-TE.  Each path is specified
   as a set of "segments" advertised by link-state routing protocols
   (Intermediate System-to-Intermediate System (IS-IS) or Open Shortest Path First(OSPF)).  <xref target='RFC8402'/> provides an
   introduction to SR architecture. The corresponding IS-IS and OSPF extensions are
   specified in <xref target='RFC8667'/> and
   <xref target='RFC8665'/> , respectively.
   It relies on a series of
   forwarding instructions being placed in the header of a packet.
   The segment routing architecture supports operations that can be used
   to steer packet flows in a network, thus providing a form of traffic
   engineering. <xref target='RFC8664'/> specify the SR-specific PCEP
   extensions.
 </t>

 <t>Segment Routing Policy for Traffic Engineering
   <xref target='RFC9256'/> details the concepts of SR
   Policy and approaches to steering traffic into an SR Policy. An SR Policy contains one or more SR Policy Candidate Paths where one
   or more such paths can be computed via PCE.  <xref target='I-D.ietf-pce-segment-routing-policy-cp'/> specifies
   PCEP extensions to signal additional information to map candidate
   paths to their SR policies.</t>

   <t>PCECC may further use PCEP for SR SID (Segment Identifier) allocation and distribution to all the SR nodes
    with some benefits. The SR nodes continue to rely on IGP for distributed computation (nexthop selection, protection etc) where PCE (and PCEP) does only the allocation and distribution of SIDs in the network. Note that the topology at PCE is still learned via existing mechanisms. </t>

   <t>This document specifies the procedures and PCEP extensions when
   a PCE-based controller is also responsible for configuring
   the forwarding actions on the routers (i.e. the SR SID allocation and distribution in this case), in addition to computing
   the SR paths for packet flows in a segment routing network and telling the edge routers
   what instructions to attach to packets as they enter the network as described in <xref target='RFC8283'/>.
   </t>
   <t>Only SR using MPLS dataplane (SR-MPLS) is in the scope of this document. Refer <xref target='I-D.ietf-pce-pcep-extension-pce-controller-srv6'/> for use of PCECC technique for SR in IPv6 (SRv6) dataplane.</t>

      <!--<t>[Important Note - Note that this document achieves by extending the new PCEP message defined in <xref target='RFC9050'/>.
    The authors and WG also debated on the use of existing PCEP messages.
    <xref target="Procedures"/> defines the first approach where as <xref target="appendix"/>
    defines the latter. The authors are open to either of the approach and
    will follow the direction of the WG.]</t>-->

    </section>

    <section toc='default'><name>Terminology</name>
      <t>Terminologies used in this document are the same as described in the
       <xref target='RFC8283'/>.</t>
             <section toc='default'><name>Requirements Language</name>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
      NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
      "MAY", and "OPTIONAL" in this document are to be interpreted as
      described in BCP 14 <xref target='RFC2119'/> <xref target='RFC8174'/> when, and only when, they
      appear in all capitals, as shown here.</t>
      </section>
    </section>

    <section toc='default' anchor='SEC_M'><name>PCECC SR-MPLS</name>

    <t><xref target='RFC8664'/> specifies extensions to
    PCEP that allows a stateful PCE to
   compute, update, or initiate SR-TE paths. An ingress node of an SR-TE path appends
   all outgoing packets with a list of MPLS labels (SIDs). This is encoded in
   SR-ERO subobject, capable of carrying a label (SID) as well as the identity of the
   node/adjacency.</t>

   <t>The notion of segment and SID is defined in
   <xref target='RFC8402'/>, which fits the MPLS architecture
   <xref target='RFC3031'/> as the label which
   is managed by a local allocation process of LSR (similar to
   other MPLS signaling protocols) <xref target='RFC8660'/>.
   The SR information such as node/adjacency label (SID) is flooded via IGP as specified in <xref target='RFC8667'/> and
   <xref target='RFC8665'/>.</t>

   <t><xref target='RFC8283'/> examines the motivations and applicability for
   PCECC and use of PCEP as an SBI. Section 3.1.5. of <xref target='RFC8283'/>
   highlights the use of PCECC for configuring the forwarding actions on the routers and
   assumes responsibility for managing the label space. It simplifies the processing of a distributed
   control plane by blending it with elements of SDN without
   necessarily completely replacing it. This allows the operator to introduce
   the advantages of SDN (such as programmability) into the network. Further Section 3.2. of <xref target='RFC9689'/> describes some of the scenarios where the PCECC technique could be useful. Section 4 of <xref target='RFC8283'/>
   also describe the implications of the protocol when used as an SDN SBI. The operator needs to evaluate the advantages offered by PCECC against the operational and scalability needs of the PCECC.  </t>


   <t>
   Thus, PCE as a central controller can allocate and provision the node/prefix/adjacency label (SID) via PCEP. The rest of the
   processing is similar to existing stateful PCE with SR mechanism.</t>
   <t>For the purpose
   of this document, it is assumed that the label/SID range to be used by a PCE
   is set on both PCEP peers. The PCC MUST NOT make allocations from the label space set aside for the PCE to avoid overlap and collisions of label allocations. Further, a global label/SID range is assumed to be
   set on all PCEP peers in the SR domain. A future extension could add the capability to
   advertise this range via a possible PCEP extension as well (see <xref target='I-D.li-pce-controlled-id-space'/>).  This document also allows a case where the label/SID space is maintained by PCC and the labels/SID are
     allocated by it. In this case, the PCE should request the allocation from
     PCC as described in <xref target='PCC'/>.</t>
   </section>

    <section toc='default' anchor='SEC_R'><name>PCEP Requirements</name>
   <t>Following key requirements for PCECC-SR should be considered when
   designing the PCECC-based solution:</t>
      <t>
        </t><ul >
   <li>A PCEP speaker supporting this document needs to have the capability to
       advertise its PCECC-SR capability to its peers.</li>

    <!--<t>A PCEP speaker need means to identify PCECC-based SR path in the PCEP
       messages.</t>-->

   <li>PCEP procedures need to allow for PCC-based label/SID allocations.</li>

   <!--<t>A PCEP speaker not supporting this draft needs to be able to reject
       PCECC-SR related message with a reason code that indicates no
       support for PCECC.</t>-->

   <li>PCEP procedures need to provide a means to update (or clean up) label-mapping entries downloaded to the PCC.</li>

   <li>PCEP procedures need to provide a means to synchronize the SR label/SID allocations between
       the PCE to the PCC via PCEP messages.</li>



        </ul><t>
      </t>
    </section>


    <section toc='default' anchor='Procedures'><name>Procedures for Using the PCE as a Central Controller (PCECC) in Segment Routing</name>

    <section toc='default'><name>Stateful PCE Model</name>
    <t>Active stateful PCE is described in <xref target='RFC8231'/>. PCE
    as a Central Controller (PCECC) reuses the existing active stateful PCE
    mechanism as much as possible to control the LSPs.</t>
    </section>

    <section toc='default'><name>New LSP Functions</name>
   <t>Several new functions are required in PCEP to support PCECC as described in <xref target='RFC9050'/>. This document reuses the existing messages to support PCECC-SR.</t>

   <t>The PCEP messages PCRpt, PCInitiate, and PCUpd are used to send
   LSP Reports, LSP setup, and LSP update respectively. The extended PCInitiate message described in
   <xref target='RFC9050'/> is used to download
   or clean up the central controller's instructions (CCIs) (SR SID in the scope of this document). The extended PCRpt message described in
   <xref target='RFC9050'/> is also used to report
   the CCIs (SR SIDs) from PCC to PCE.</t>

    <!--<t>[Editor's Note: <xref target='RFC9050'/> defines new messages PCLabelUpd and
      PCLabelRpt. The authors and WG also debated on the use of existing PCEP messages. Further
      the document also includes an appendix
      on how the existing messages can be extended
      to add this functionality. WG needs to decide the final direction i.e. new specific messages
      are needed or existing PCEP messages can be extended. See See <xref target="appendix"/>
      to see the extension of existing message for PCECC-SR functionality.]</t>-->

        <t><xref target='RFC9050'/> specify an object called CCI for the encoding of the central controller's instructions for Label. This document extends the CCI by defining a new object-type for SR-MPLS. The PCEP messages are extended in this document to handle the PCECC operations for SR.</t>
    </section>

    <section toc='default'><name>PCECC Capability Advertisement</name>

   <t>During PCEP Initialization Phase, PCEP Speakers (PCE or PCC)
   advertise their support of PCECC extensions.  A PCEP Speaker includes
   the "PCECC Capability" sub-TLV, described in
   <xref target='RFC9050'/>.</t>

   <t>A new S-bit is added in the PCECC-CAPABILITY sub-TLV to indicate support for
   PCECC-SR for SR-MPLS.  A PCC MUST set the S-bit in the PCECC-CAPABILITY sub-TLV and include
   the SR-PCE-CAPABILITY sub-TLV (<xref target='RFC8664'/>) in the OPEN Object
   (inside the PATH-SETUP-TYPE-CAPABILITY TLV)
   to support the PCECC SR-MPLS extensions defined in this document.  If
   the S-bit is set in the PCECC-CAPABILITY sub-TLV and the SR-PCE-CAPABILITY sub-TLV is not
   advertised in the OPEN Object, PCE SHOULD send a PCErr message with
   Error-Type=19 (Invalid Operation) and Error-value=TBD4 (SR capability
   was not advertised) and terminate the session.</t>

   <t>The rest of the processing is as per <xref target='RFC9050'/>.</t>
   </section>

   <section toc='default' anchor='SEC_SESSION'><name>PCEP session IP address and TED Router ID</name>
   <t>A PCE may construct its Traffic Engineering Database (TED) by participating in the IGP (<xref target='RFC3630'/>
   and <xref target='RFC5305'/> for MPLS-TE; <xref target='RFC4203'/> and <xref target='RFC5307'/> for GMPLS).  An
   alternative is offered by BGP-LS <xref target='RFC9552'/> or
   <xref target='I-D.ietf-pce-pcep-ls'/>.</t>

   <t>A PCEP <xref target='RFC5440'/> speaker could use any local IP address while creating a TCP
   session.  It is important to link the session IP address with the
   Router ID in TED for successful PCECC operations.</t>

   <t>During the PCEP Initialization Phase, the PCC SHOULD advertise the TE mapping
   information by including the "Router-ID TLVs"
   <xref target='sec-routerid'/> with the IPv4/IPv6 Router-ID of Local Node,
   in the OPEN Object for this purpose.  <xref target='RFC9552'/>
   describes the usage as auxiliary Router-IDs that the IGP might be
   using, e.g., for TE purposes.  If there are more than one auxiliary
   Router-ID of a given type, then multiple TLVs can be used to encode
   them.</t>

   <t>If Router-ID TLVs are not present, the TCP session IP
   address is directly used for the mapping purpose.</t>

   </section>


    <section toc='default'><name>LSP Operations</name>
            <t><xref target='RFC8664'/> specify the PCEP extension to allow a stateful PCE
        to compute and initiate SR-TE paths, as well as a PCC to request a
        path subject to certain constraint(s) and optimization criteria in SR
        networks.</t>
                <t>The Path Setup Type for segment routing (PST=1) is used on the PCEP session with the Ingress as per
        <xref target='RFC8664'/>.</t>
    <!--<t> The PCEP messages pertaining to PCECC-SR MUST include PATH-SETUP-TYPE
   TLV <xref target='RFC8408'/> with PST=TBD2 in the SRP object
   to clearly identify the PCECC-SR LSP is intended.</t>-->

    <section toc='default' anchor='SEC_SR_SETUP'><name>PCECC Segment Routing (SR)</name>
   <t>Segment Routing (SR) as described in
   <xref target='RFC8402'/> depends on "segments" that are
   advertised by Interior Gateway Protocols (IGPs).  The SR-node
   allocates and advertises the SID (node, adj, etc) and floods them via the
   IGP.  This document proposes a new mechanism where PCE allocates the
   SID (label/index/SID) centrally and uses PCEP to distribute them to all nodes.  In some
   deployments, PCE (and PCEP) are better suited than IGP because of
   the centralized nature of PCE and direct TCP-based PCEP sessions to all the
   nodes. Note that only the SID allocation and distribution is done by the PCEP, all other SR operations (nexthop selection, protection, etc) are still done by the node (and the IGPs).</t>

       <section toc='default' anchor='SEC_NODE_ALLOC'><name>PCECC SR Node/Prefix SID Allocation</name>
        <t>Each node (PCC) is allocated a node-SID by the PCECC.  The
         PCECC sends PCInitiate message to update the label mapping of each node to all
         the nodes in the domain.  The TE router ID is determined from the
         TED or from the Router-ID TLVs
         <xref target='sec-routerid'/>, in the OPEN Object <xref target='SEC_SESSION'/>.  The LSP object is included in the central controller instructions to continue using the flag field of the LSP object as per <xref target='RFC8231'/> and <xref target='RFC8281'/>. The PLSP-ID is set to the reserved value 0. As per <xref target='RFC8281'/>, the LSP
   object also includes the SPEAKER-ENTITY-ID TLV to identify the
   PCE that initiated these instructions.</t>

         <!--<t>Note: See <xref target="appendix"/> for how
   we could use PCInitiate message instead.]</t>-->

        <t>It is RECOMMENDED that the PCEP session with PCECC-SR capability use a
         different session IP address during TCP session establishment than
         the node Router ID in TEDB, to make sure that the PCEP session does
         not get impacted by the SR Node/Prefix Label mappings (<xref target='SEC_SESSION'/>). Otherwise, the PCEP session itself might get impacted when the label mapping is downloaded for the node.</t>

         <t>If a node (PCC) receives a PCInitiate message with a CCI object-type=TBD6 encoding a SID, out
      of the range set aside for the SR Global Block (SRGB), it MUST send a PCErr message with Error-type=31
   (PCECC failure) and Error-value=1 (Label out of range) (defined in <xref target='RFC9050'/>) and MUST include the
   SRP object to specify the error is for the corresponding central control instruction via the PCInitiate message.</t>

        <t>On receiving the label mapping, each node (PCC) uses the local
         routing information via IGP to determine the next-hop and download the label
         forwarding instructions accordingly as shown in <xref target='SEC_FIG1'/>.  The PCInitiate message in this
         case uses a new FEC object defined in <xref target='SEC_FEC'/>.</t>

        <figure align='left' suppress-title='false' anchor='SEC_FIG1'
          title='PCECC SR Node/Prefix SID allocation'>
         <artwork align='left' alt='' name='' type=''>
<![CDATA[
               +---------+                           +-------+
               |PCC      |                           |  PCE  |
               |192.0.2.3|                           +-------+
        +------|         |                               |
        | PCC  +---------+                               |
        | 192.0.2.2| |                                   |
 +------|          | |                                   |
 |PCC   +----------+ |                                   |
 |192.0.2.1| |       |                                   |
 +---------+ |       |                                   |
     |       |       |                                   |
     |<--------PCInitiate,FEC=192.0.2.1------------------| Label mapping
     |       |       |    CC-ID=X,SID                    | update
     |--------PCRpt,CC-ID=X----------------------------->| CCI
     |Find   |       |                                   |
     |Nexthop|<--------PCInitiate,FEC=192.0.2.1----------| Label mapping
     |locally|       |            CC-ID=Y,SID            | update
     |       |-------PCRpt,CC-ID=Y---------------------->| CCI
     |       |       |                                   |
     |       |       |<----PCInitiate,FEC=192.0.2.1------| Label mapping
     |       |       |                CC-ID=Z,SID        | update
     |       |       |-----PCRpt,CC-ID=Z---------------->| CCI
     |       |       |                                   |
]]>
        </artwork>
        </figure>

        <t>The forwarding behavior and the end result are similar to IGP-based
        "Node-SID" in SR.  Thus, from anywhere in the domain, it enforces the
        ECMP-aware shortest-path forwarding of the packet towards the related
        node as per <xref target='RFC8402'/>.</t>

        <t>PCE relies on the Node/Prefix Label clean up using the same PCInitiate
        message as per <xref target='RFC8281'/>.</t>

        <t>The above example <xref target='SEC_FIG1'/> depicts the FEC and PCEP speakers that uses IPv4 address. Similarly, an IPv6 address (such as 2001:db8::1) can be used during PCEP session establishment in the FEC object as described in this specification.</t>

        <t>In the case where the label/SID allocation is made by the PCC itself (see <xref target='PCC'/>), the PCE could request an allocation to be made by the PCC, and where the PCC would send a PCRpt with the allocated
          label/SID encoded in the CC-ID object as shown in <xref target='SEC_FIG1b'/>.</t>
 <figure align='left' suppress-title='false' anchor='SEC_FIG1b'
  title='PCECC SR Node/Prefix SID (PCC allocation)'>
         <artwork align='left' alt='' name='' type=''>
<![CDATA[
               +---------+                           +-------+
               |PCC      |                           |  PCE  |
               |192.0.2.3|                           +-------+
        +------|         |                               |
        | PCC  +---------+                               |
        | 192.0.2.2| |                                   |
 +------|          | |                                   |
 |PCC   +----------+ |                                   |
 |192.0.2.1| |       |                                   |
 +---------+ |       |                                   |
     |       |       |                                   |
     |<--------PCInitiate,FEC=192.0.2.1------------------| Label mapping
     |       |       |    CC-ID=X,C=1                    | request
     |--------PCRpt,CC-ID=X,SID------------------------->| CCI
     |Find   |       |                                   |
     |Nexthop|<--------PCInitiate,FEC=192.0.2.1----------| Label mapping
     |locally|       |            CC-ID=Y,C=0,SID        | update
     |       |-------PCRpt,CC-ID=Y---------------------->| CCI
     |       |       |                                   |
     |       |       |<----PCInitiate,FEC=192.0.2.1------| Label mapping
     |       |       |                CC-ID=Z,C=0,SID    | update
     |       |       |-----PCRpt,CC-ID=Z---------------->| CCI
     |       |       |                                   |
]]>
        </artwork>
        </figure>
        <t>It should be noted that in this example (<xref target='SEC_FIG1b'/>), the request is made to the node 192.0.2.1 with C bit set in the CCI object to indicate that the allocation needs to be done by this PCC and it responds with the allocated label/SID to the PCE. The PCE would further inform the other nodes (PCCs) in the network about the label mapping allocation without setting the C bit as before.</t>

        <t>All other distributed operations such as nexthop change, protection, etc are handled by the local node as before.</t>


       </section>

       <section toc='default' anchor='SEC_ADJ_ALLOC'><name>PCECC SR Adjacency Label/SID Allocation</name>



        <t>For PCECC-SR, apart from node-SID, Adj-SID is used where each adjacency
         is allocated an Adj-SID by the PCECC.  The PCECC sends
         the PCInitiate message to update the label mapping of each adjacency to all
         the nodes in the domain as shown in <xref target='SEC_FIG2'/>. Each node (PCC) downloads the label forwarding
         instructions accordingly.  Similar to SR Node/Prefix Label allocation, the
         PCInitiate message in this case does not use the LSP object but uses
         the new FEC object defined in this document. </t>

        <figure align='left' suppress-title='false' anchor='SEC_FIG2'
          title='PCECC SR Adjacency Label allocation'>
         <artwork align='left' alt='' name='' type=''>
<![CDATA[
                 +---------+                         +-------+
                 |PCC      |                         |  PCE  |
                 |192.0.2.3|                         +-------+
          +------|         |                             |
          | PCC  +---------+                             |
          | 192.0.2.2| |                                 |
   +------|          | |                                 |
   |PCC   +----------+ |                                 |
   |192.0.2.1|  |      |                                 |
   +---------+  |      |                                 |
       |        |      |                                 |
       |<-------PCInitiate,FEC=198.51.100.1--------------| Label mapping
       |        |      |       198.51.100.2              | update
       |        |      |   CC-ID=A,SID                   | CCI
       |--------PCRpt,CC-ID=A--------------------------->|
       |        |      |                                 |
       |        |<------PCInitiate,FEC=198.51.100.1------| Label mapping
       |        |      |               198.51.100.2      | update
       |        |      |           CC-ID=B,SID           | CCI
       |        |-------PCRpt,CC-ID=B------------------->|
       |        |      |                                 |
       |        |      |                                 |
       |        |      |<---PCInitiate,FEC=198.51.100.1--| Label mapping
       |        |      |                   198.51.100.2  | update
       |        |      |               CC-ID=C,SID       | CCI
       |        |      |-------PCRpt,CC-ID=C------------>|
]]>
        </artwork>
        </figure>

        <t>The forwarding behavior and the end result are similar to Interior Gateway Protocol (IGP) based
        "Adj-SID" in SR. The Adj-SID is distributed to all nodes to enable SR-TE and TI-LFA.</t>



        <t>PCE relies on the Adj SID/label clean up using the same PCInitiate
        message as per <xref target='RFC8281'/>.</t>

                <t>The above example (<xref target='SEC_FIG2'/>) depicts FEC object and PCEP speakers that uses an IPv4 address. Similarly, an IPv6 address (such as 2001:db8::1, 2001:db8::2) can be used during the PCEP session establishment in the FEC object as described in this specification.</t>

<t>The handling of adjacencies on the LAN subnetworks is specified in <xref target='RFC8402'/>. PCECC MUST assign Adj-SID for every pair of routers in the LAN. The rest of the protocol mechanism remains the same.</t>

          <t>In the case where the label/SID mapping allocation is made by the PCC itself (see <xref target='PCC'/>), the PCE could request an allocation to be made by the PCC, and where the PCC would send a PCRpt with the allocated
          label/SID encoded in the CC-ID object as shown in <xref target='SEC_FIG2b'/>.</t>
        <figure align='left' suppress-title='false' anchor='SEC_FIG2b'
          title='PCECC SR Adjacency Label/SID (PCC allocation)'>
         <artwork align='left' alt='' name='' type=''>
<![CDATA[
                 +---------+                         +-------+
                 |PCC      |                         |  PCE  |
                 |192.0.2.3|                         +-------+
          +------|         |                             |
          | PCC  +---------+                             |
          | 192.0.2.2| |                                 |
   +------|          | |                                 |
   |PCC   +----------+ |                                 |
   |192.0.2.1|  |      |                                 |
   +---------+  |      |                                 |
       |        |      |                                 |
       |<-------PCInitiate,FEC=198.51.100.1--------------| Label mapping
       |        |      |        198.51.100.2             | request
       |        |      |    CC-ID=A,C=1                  | CCI
       |--------PCRpt,CC-ID=A,SID----------------------->|
       |        |      |                                 |
       |        |<------PCInitiate,FEC=198.51.100.1------| Label mapping
       |        |      |               198.51.100.2      | update
       |        |      |           CC-ID=B,SID,C=0       | CCI
       |        |-------PCRpt,CC-ID=B------------------->|
       |        |      |                                 |
       |        |      |<---PCInitiate,FEC=198.51.100.1--| Label mapping
       |        |      |                   198.51.100.2  | update
       |        |      |               CC-ID=C,SID,C=0   | CCI
       |        |      |-------PCRpt,CC-ID=C------------>|
]]>
        </artwork>
        </figure>
        <t>In this example (<xref target='SEC_FIG2b'/>), the request is made to the node 192.0.2.1 with the C bit set in the CCI object to indicate that the allocation needs to be done by this PCC for the adjacency (198.51.100.1 - 198.51.100.2) and it responds with the allocated label/SID to the PCE. The PCE further distributes this to other nodes without setting the C bit as before.</t>


       </section>

        <section toc='default' anchor='SEC_REDUND'><name>Redundant PCEs </name>

       <t><xref target='I-D.ietf-pce-state-sync'/> describes the synchronization
       mechanism between the stateful PCEs. As per <xref target='RFC9050'/>, the SR SIDs allocated by a PCE must also be
       synchronized among PCEs for PCECC SR state synchronization. Note that the SR SIDs
       are independent of the SR-TE LSPs, and remains intact till any topology
       change. The redundant PCEs need to maintain a common view of all SR SIDs allocated in the |domain.
     </t>

       </section>

       <section toc='default' anchor='SEC_SES_TERMIN'><name>Re-Delegation and Clean up</name>

   <t>As described in <xref target='RFC8281'/>, a new PCE can gain control over an
   orphaned LSP.  In the case of a PCECC, the new PCE MUST also gain
   control over the central controller instructions in the same way by
   sending a PCInitiate message that includes the SRP, LSP, CCI, and FEC
   objects and carries the CC-ID and SPEAKER-ENTITY-ID TLV (original PCE) identifying the instruction
   that it wants to take control of.</t>

   <t>Further, as described in <xref target='RFC8281'/>, the State Timeout Interval timer
   ensures that a PCE crash does not result in automatic and immediate
   disruption for the services using PCE-initiated LSPs.  Similarly, as per <xref target='RFC9050'/>, the
   central controller instructions are not removed immediately upon PCE
   failure.  Instead, they could be cleaned up on the expiration of this
   timer.  This allows for network clean up without manual intervention.
   The PCC MUST support the removal of CCI as one of the behaviors
   applied on the expiration of the State Timeout Interval timer. Note that the
   usual policy would be for the CCI Object-Type=TBD6 to remain intact until
   explicitly removed by a PCE or
   via manual intervention.</t>



       </section>

       <section toc='default' anchor='SEC_DB_SYNC'><name>Synchronization of Label Allocations</name>
        <t><xref target='RFC9050'/> describes the synchronization of Central Controller's Instructions (CCI) via LSP state synchronization
   as described in <xref target='RFC8231'/> and
   <xref target='RFC8232'/>.
        Same procedures are applied for the CCI for SR SID as well.</t>
        <!--<t>See <xref target="I-D.palle-pce-controller-labeldb-sync"/> for the optimizations for LABEL-DB synchronization procedure.</t>          -->
       </section>

       <section toc='default' anchor='PCC'><name>PCC-Based Allocations</name>
             <t>
             The PCE can request the PCC to allocate the label/SID using the
     PCInitiate message.  The C flag in the
     CCI object is set to 1 to indicate that the allocation needs to be done by the PCC.
     The PCC would allocate the SID/Label/Index
     and would report to the PCE using the PCRpt
     message.
             </t>
             <t>If the value of the SID/Label/Index is 0 and the C flag is set to 1, it
     indicates that the PCE is requesting the allocation to be done by the PCC.  If the
     SID/Label/Index is 'n' and the C flag is set to 1 in the CCI object, it
     indicates that the PCE requests a specific value 'n' for the SID/Label/Index.
     If
     the allocation is successful, the PCC should report
     via PCRpt message with the CCI object.  Otherwise, it MUST send a PCErr message with Error-Type=31 ("PCECC failure") and Error Value=3 ("Invalid CCI") (defined in <xref target='RFC9050'/>).  If
     the value of the SID/Label/Index in the CCI object is valid, but the PCC is unable to
     allocate it, it MUST send a PCErr message with Error-Type=31 ("PCECC failure") and Error Value=4 ("Unable to
     allocate the specified CCI") (defined in <xref target='RFC9050'/>).
   </t>
  <t>If the PCC wishes to withdraw or modify the previously assigned label/SID, it MUST send a PCRpt message without any SID/Label/Index
     or with the SID/Label/Index containing the new value respectively in
     the CCI object.  The PCE would further trigger the removal of the
     central controller instruction as per this document.</t>

           </section>
       <section toc='default' anchor='BSID'><name>Binding SID</name>

   <t>A PCECC can allocate and
   provision the node/prefix/adjacency label (SID) via PCEP. Another SID called binding SID is described in <xref target='RFC9604'/>, the PCECC mechanism can also be used to allocate the binding SID.</t>

   <t>A procedure for binding label/SID allocation is described in <xref target='RFC9050'/> and is applicable for all path setup types (including SR paths).</t>

   <!--Moved to RFC9050<t>The PCECC Capability as per
   <xref target="I-D.zhao-pce-pcep-extension-pce-controller-sr"/> should also be
   advertised on the PCEP session, along with the SR sub-TLVs before using this procedure.</t>-->

   <!--<t>A P flag in LSP object is introduced in <xref target="I-D.li-pce-sr-path-segment"/> to indicate the allocation needs to be made by the PCE. The same flag can also be used to indicate that the allocation needs to be made by the PCE. A PCC would set this bit to 1 (and carry the TE-PATH-BINDING TLV <xref target="I-D.sivabalan-pce-binding-label-sid"/> in LSP object) to request for
      allocation of the binding label/SID by the PCE in the PCReq or PCRpt
      message.  A PCE would also set this bit to 1 to indicate that the
      binding label/SID is allocated by PCE and encoded in the PCRep,
      PCUpd or PCInitiate message (the TE-PATH-BINDING TLV is present in
      LSP object).  Further, a PCE would set this bit to 0 to indicate
      that the allocation is done by the PCC instead.</t>

   <t>The ingress PCC could request the binding label/SID to be allocated by the PCE
   via PCRpt message as per <xref target="RFC8231"/>.  The delegate flag (D-flag) MUST
   also be set for this LSP.  The TE-PATH-BINDING TLV MUST be included with no Binding
   Value. The PCECC would allocated the binding label/SID and further respond to
   Ingress PCC with PCUpd message as per <xref target="RFC8231"/> and MUST include the
   TE-PATH-BINDING TLV in a LSP object.  The P flag in the LSP object would be set to 1 to indicate that the allocation is made by the PCE.</t>

   <t>The PCE could allocate the binding label/SID on its own accord for a PCE-
   Initiated (or delegated LSP).  The allocated binding label/SID needs to be
   informed to the PCC.  The PCE would use the
   PCInitiate message <xref target="RFC8281"/> or PCUpd message <xref target="RFC8231"/> towards the
   PCC and MUST include the TE-PATH-BINDING TLV in the LSP object. The P flag in the LSP object would be set to 1 to indicate that the allocation is made by the PCE.</t>

   <t>The PCECC capability MUST be exchanged on the PCEP session, before PCE could allocate binding label/SID. Note that the CCI object is not used for binding allocation; this is done to maintain consistency with the rest of the binding label/SID procedures as per <xref target="I-D.sivabalan-pce-binding-label-sid"/>.</t>-->
 </section>

       <section toc='default' anchor='anycast'><name>Anycast SID</name>
        <t>As per <xref target='RFC8402'/>, an anycast segment or Anycast-SID enforces the ECMP-aware shortest-path forwarding towards the closest node of the anycast set. Note that the anycast prefix segments can also be allocated and distributed in the same way as described in <xref target="SEC_NODE_ALLOC"/>.</t>
      </section>

       </section>
    </section>
    </section>


    <section toc='default'><name>PCEP Messages</name>
    <t>As defined in <xref target='RFC5440'/>, a PCEP message consists of a common header
   followed by a variable-length body made of a set of objects that can
   be either mandatory or optional.  An object is said to be mandatory
   in a PCEP message when the object must be included for the message to
   be considered valid.  For each PCEP message type, a set of rules is
   defined that specify the set of objects that the message can carry.
   An implementation MUST form the PCEP messages using the object
   ordering specified in this document.</t>

   <t>Message formats in this section are presented
   using Routing Backus-Naur Format (RBNF) as specified in <xref target='RFC5511'/>.</t>

    <section toc='default' anchor='SEC_LabelOp'><name>Central Control Instructions</name>
    <!--<t>[Editor's Note: <xref target='RFC9050'/> defines new messages PCLabelUpd and
      PCLabelRpt. The authors and WG also debated on the use of existing PCEP messages.  Further
      the document also includes an appendix
      on how the existing messages can be extended
      to add this functionality. WG needs to decide the final direction i.e. new specific messages
      are needed or existing PCEP messages can be extended. See See <xref target="appendix"/>
      to see the extension of existing message for PCECC-SR functionality.]</t>-->
    <section toc='default' anchor='SEC_PCInitiate'><name>The PCInitiate Message</name>
        <t>The PCInitiate message defined in <xref target='RFC8281'/> and extended in <xref target='RFC9050'/>
        is further extended to support SR-based central control instructions. </t>
        <t>The format of the extended PCInitiate message is as follows:</t>
    <figure suppress-title='false' align='left'>
       <artwork name='' type='' align='left' alt=''><![CDATA[
     <PCInitiate Message> ::= <Common Header>
                              <PCE-initiated-lsp-list>
  Where:
     <Common Header> is defined in [RFC5440]

     <PCE-initiated-lsp-list> ::= <PCE-initiated-lsp-request>
                                  [<PCE-initiated-lsp-list>]

     <PCE-initiated-lsp-request> ::=
                          (<PCE-initiated-lsp-instantiation>|
                           <PCE-initiated-lsp-deletion>|
                           <PCE-initiated-lsp-central-control>)

     <PCE-initiated-lsp-central-control> ::= <SRP>
                                             <LSP>
                                             (<cci-list>|
                                             (<FEC>
                                             <CCI>))

     <cci-list> ::=  <CCI>
                     [<cci-list>]

  Where:
      <PCE-initiated-lsp-instantiation> and
      <PCE-initiated-lsp-deletion> are as per
      [RFC8281].

     The LSP and SRP object is defined in [RFC8231].

]]></artwork>
        </figure>


    <t>When the PCInitiate message is used to distribute SR SIDs, the SRP, the LSP, the FEC and the CCI object of object-type=TBD6  MUST be present. The error handling for missing SRP, LSP, or CCI objects is as per <xref target='RFC9050'/>. If the FEC object is missing, the receiving PCC MUST send a PCErr message with Error-type=6
    (Mandatory Object missing) and Error-value=TBD5 (FEC object missing). The LSP Object is included with PLSP-ID set to the reserved value 0. The flags in the LSP object are set as per <xref target='RFC8281'/>.</t>
    <t>To clean up, the R (remove) bit in the SRP object and the corresponding FEC and the CCI object are included.</t>
    </section>

    <section toc='default' anchor='SEC_PCRpt'><name>The PCRpt message</name>
       <t>The PCRpt message can be used to report the SR central controller instructions received from the PCECC during the state synchronization phase or as an acknowledgment to the PCInitiate message.</t>

       <t>The format of the PCRpt message is as follows:</t>
<figure suppress-title='false' align='left'>
       <artwork name='' type='' align='left' alt=''><![CDATA[
      <PCRpt Message> ::= <Common Header>
                          <state-report-list>
   Where:

      <state-report-list> ::= <state-report>[<state-report-list>]

      <state-report> ::= (<lsp-state-report>|
                          <central-control-report>)

      <lsp-state-report> ::= [<SRP>]
                             <LSP>
                             <path>

      <central-control-report> ::= [<SRP>]
                                   <LSP>
                                   (<cci-list>|
                                   (<FEC>
                                   <CCI>))

      <cci-list> ::=  <CCI>
                      [<cci-list>]


    Where:
      <path> is as per [RFC8231] and the LSP and SRP objects are
      also defined in [RFC8231].
]]></artwork>
        </figure>
        <t>When the PCRpt message is used to report the label mapping allocations, the LSP, the FEC, and CCI object of object-type=TBD6 MUST be present.
          The error handling for the missing LSP and CCI object is as per <xref target='RFC9050'/>. If the FEC object is
    missing, the receiving PCE MUST send a PCErr message with Error-type=6
    (Mandatory Object missing) and Error-value=TBD5 (FEC object missing). The LSP Object is included with PLSP-ID set to the reserved value 0. The flags in the LSP object are set as per <xref target='RFC8231'/> and <xref target='RFC8281'/>.</t>

   </section>
   </section>
    </section>


    <section toc='default'><name>PCEP Objects</name>

    <section toc='default'><name>OPEN Object</name>

    <section toc='default' anchor='SEC_PCECC_CAP_TLV'><name>PCECC Capability sub-TLV</name>
    <t><xref target='RFC9050'/> defined
    the PCECC-CAPABILITY sub-TLV.</t>
    <t>A new S-bit is added in PCECC-CAPABILITY sub-TLV for PCECC-SR:</t>

    <t>S (PCECC-SR-CAPABILITY - 1 bit - TBD1):  If set to 1 by a PCEP speaker, it
      indicates that the PCEP speaker is capable of PCECC-SR for SR-MPLS
      and the PCE allocates the Node and Adj label/SID on this session.</t>
    </section>
    <section toc='default' anchor='sec-routerid'><name>Router-ID TLVs</name>

<t>The Router-ID TLV described in this document is generic and not specific to any specific path-setup type or use case. One or more Router-ID TLV MAY be carried in the OPEN object and does not require the exchange of the capability described in Section 5.3.</t>

    <t>As described in <xref target="SEC_SESSION"/>, for the purposes of this document, the PCC SHOULD advertise the TE
   mapping information by including the Router-ID TLVs in the OPEN object. Two new TLVs are defined:</t>
   <t>Type: IPv4-ROUTER-ID (TBD7) </t>
   <t>Length: 4</t>
   <t>Value: IPv4 32-bit Router ID</t>
<figure align='left' suppress-title='true' >
          <artwork align='left' alt='' name='' type=''>
<![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=TBD7       |            Length=4           |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                        IPv4 Router ID                         |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]>
        </artwork>
        </figure>
   <t>Type: IPv6-ROUTER-ID (TBD8) </t>
   <t>Length: 16</t>
   <t>Value: IPv6 128-bit Router ID</t>
<figure align='left' suppress-title='true' >
          <artwork align='left' alt='' name='' type=''>
<![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=TBD8       |            Length=4           |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   |                        IPv6 Router ID                         |
   |                                                               |
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]>
        </artwork>
        </figure>
    </section>
    </section>

    <section toc='default' anchor='SEC_PATH'><name>SR-TE Path Setup</name>

    <t>The PATH-SETUP-TYPE TLV is defined in <xref target='RFC8408'/>.
   A PST value of 1 is used
   when Path is setup via SR mode as per <xref target='RFC8664'/>. The procedure for SR-TE path setup as specified in <xref target='RFC8664'/> remains unchanged.</t>

   <!--<t>On a PCRpt/PCUpd/PCInitiate message, the PST=TBD2 indicates that this
   LSP was setup via a PCECC-SR based mechanism where either the SIDs were
   allocated/instructed by PCE via PCECC mechanism.</t>-->


    </section>
    <section toc='default' anchor='SEC_CCI'><name>CCI Object</name>
    <t>The Central Control Instructions (CCI) Object used by the PCE to specify the controller instructions is defined in <xref target='RFC9050'/>.
    This document defines another object-type for SR-MPLS. </t>
    <t>CCI Object-Type is TBD6 for SR-MPLS as below - </t>
      <figure align='left' suppress-title='true' anchor='SEC_FIG9'>
          <artwork align='left' alt='' name='' type=''>
<![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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                            CC-ID                              |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      MT-ID    |    Algorithm  |    Flags      |B|P|G|C|N|E|V|L|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                       SID/Label/Index                         |
+---------------------------------------------------------------+
|                                                               |
//                        Optional TLV                         //
|                                                               |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]>
        </artwork>
        </figure>

       <t>The field CC-ID is as described in <xref target='RFC9050'/>. The following new fields are defined for CCI Object-Type TBD6 -
       </t>
       <dl newline="true">
        <dt>MT-ID:</dt><dd> Multi-Topology ID (as defined in <xref target='RFC4915'/>).</dd>
        <dt>Algorithm:</dt><dd> Single octet identifying the algorithm the SID is associated with. See <xref target='RFC8665'/>.</dd>
        <dt>Flags:</dt><dd> is used to carry any additional information
    pertaining to the CCI. The following bits are defined - </dd>
  </dl>

    <ul indent="2">
    <li>L-Bit (Local/Global): If set, then the value/index
         carried by the CCI object has local significance.  If not set,
         then the value/index carried by this object has a global
         significance.</li>
     <li>V-Bit (Value/Index): If set, then the CCI carries
         an absolute value.  If not set, then the CCI carries an
         32-bit index.</li>
     <li>E-Bit (Explicit-Null): If set, any upstream neighbor of the node
         that advertised the SID MUST replace the SID with the
         Explicit-NULL label (0 for IPv4) before forwarding the packet.</li>
     <li>N-Bit (No-PHP): If set, then the penultimate hop MUST
         NOT pop the SID before delivering packets to the node
         that advertised the SID.</li>
     <li>C-Bit (PCC Allocation): If the bit is set to 1, it indicates that
        the SR SID/label allocation needs to be done by the PCC for this central
        controller instruction.  A PCE set this bit to request the PCC to
        make an allocation from its SR label/ID space.  A PCC would set
        this bit to indicate that it has allocated the SR SID/label and report it
        to the PCE.</li>
    <li>The following bits are applicable when the SID represents an Adj-SID only, it MUST be ignored for others -</li></ul>
        <ul indent="2">
          <li>G-Bit (Group): When set, the G-Flag indicates that
             the Adj-SID refers to a group of adjacencies (and
             therefore MAY be assigned to other adjacencies as well).</li>
          <li>P-Bit (Persistent):  When set, the P-Flag indicates
            that the Adj-SID is persistently allocated, i.e., the
            Adj-SID value remains consistent across router restart
            and/or interface flap.</li>
          <li>B-Bit (Backup):  If set, the Adj-SID refers to an
            adjacency that is eligible for protection (e.g., using IP
            Fast Reroute or MPLS-FRR (MPLS-Fast Reroute) as described
            in Section 2.1 of <xref target='RFC8402'/>.</li>
      <li>All unassigned bits MUST be set to zero at transmission and ignored at receipt.</li>

  </ul>
      <dl newline="true">
      <dt>SID/Label/Index:</dt><dd> A 32-bit field. According to the V flags, it contains
      either:</dd>
       </dl>

      <ul indent="2">

         <li> 32-bit SID index defining the offset in the SID/Label space
         advertised by this router.</li>

         <li>A 20-bit label where the 20 rightmost bits are used for
         encoding the label value. Other bits are ignored.</li>
       </ul>

     <!--<t>The Address TLVs (see Section 7.3.1 of <xref target='RFC9050'/>) could be optionally used in the PCRpt message to include the next-hop information.</t>-->
    </section>
    <section toc='default' anchor='SEC_FEC'><name>FEC Object</name>
    <t>The FEC Object is used to specify the FEC information and MAY be
   carried within PCInitiate or PCRpt message.</t>
    <t>FEC Object-Class is TBD3.</t>


   <!--<figure align="left"
                alt=""
                height=""
                suppress-title="true"
                title=""
                width=""
                anchor="SEC_FEC_OBJ">
          <artwork align="left"
         alt=""
         height=""
         name=""
         type=""
         width=""
         xml:space="preserve">
<![CDATA[
   FEC Object-Type is 1 'IPv4 Node ID'.

    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                      IPv4 Node ID                             |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+


   FEC Object-Type is 2 'IPv6 Node ID'.

    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   //                      IPv6 Node ID (16 bytes)                //
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   FEC Object-Type is 3 'IPv4 Adjacency'.

    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                      Local IPv4 address                       |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                     Remote IPv4 address                       |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   FEC Object-Type is 4 'IPv6 Adjacency'.

    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   //               Local IPv6 address (16 bytes)                 //
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   //               Remote IPv6 address (16 bytes)                //
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   FEC Object-Type is 5 'Unnumbered Adjacency with IPv4 NodeIDs'.

    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                      Local Node-ID                            |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                    Local Interface ID                         |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                      Remote Node-ID                           |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                   Remote Interface ID                         |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

FEC Object-Type is 6 'Linklocal IPv6 Adjacency'.


    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
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   //               Local IPv6 address (16 octets)                //
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                    Local Interface ID                         |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   //               Remote IPv6 address (16 octets)               //
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                   Remote Interface ID                         |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

]]>
        </artwork>
        </figure>-->
    <t>The FEC objects are as follows:</t>
    <t>1 - IPv4 Node ID:  where IPv4 Node ID is specified as an IPv4 address of
      the Node. The FEC Object-type is 1, and the Object-Length is 4 in
      this case. The object body is same as NAI field of IPv4 Node ID <xref target='RFC8664'/>.</t>

    <t>2- IPv6 Node ID:  where IPv6 Node ID is specified as an IPv6 address of
      the Node. The FEC Object-type is 2, and the Object-Length is 16 in
      this case. The object body is same as NAI field of IPv6 Node ID <xref target='RFC8664'/>.</t>

    <t>3 - IPv4 Adjacency:  where Local and Remote IPv4 address is specified as
      pair of IPv4 addresses of the adjacency. The FEC Object-type is 3, and
      the Object-Length is 8 in this case. The object body is same as NAI field of IPv4 Adjacency <xref target='RFC8664'/>.</t>

    <t>4 - IPv6 Global Adjacency:  where Local and Remote global IPv6 address is specified as
      pair of IPv6 addresses of the adjacency. The FEC Object-type is 4, and
      the Object-Length is 32 in this case. The object body is same as NAI field of IPv6 Global Adjacency <xref target='RFC8664'/>.</t>

    <t>5 - Unnumbered Adjacency with IPv4 NodeID:  where a pair of Node ID /
      Interface ID tuple is used. The FEC Object-type is 5, and the
      Object-Length is 16 in this case. The object body is same as NAI field of Unnumbered Adjacency with IPv4 NodeIDs <xref target='RFC8664'/>.</t>

    <t>6 - IPv6 Linklocal Adjacency: where a pair of (global IPv6
      address, interface ID) tuple is used. The FEC object-type is 6, and the
      Object-Length is 40 in this case. The object body is same as NAI field of IPv6 Link-Local Adjacency <xref target='RFC8664'/>.</t>

    </section>
    </section>
    <section anchor='Imp'><name>Implementation Status</name>
<t>[Note to the RFC Editor - remove this section before publication, as well as remove the reference to RFC 7942.]</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='Onos'><name>Huawei's Proof of Concept based on ONOS</name>
  <t>The PCE function was developed in the ONOS open source platform. This extension was implemented on a private version as a proof of concept for PCECC.
  </t><ul spacing='compact'>
    <li>Organization: Huawei</li>
    <li>Implementation: Huawei's PoC based on ONOS</li>
    <li>Description: PCEP as a southbound plugin was added to ONOS. To support PCECC-SR, an earlier version of this I-D was implemented. Refer https://wiki.onosproject.org/display/ONOS/PCEP+Protocol</li>
    <li>Maturity Level: Prototype</li>
    <li>Coverage: Partial</li>
    <li>Contact: pengshuping@huawei.com</li>
  </ul><t></t>
</section>
</section>

    <section toc='default'><name>Security Considerations</name>
      <t>As per <xref target='RFC8283'/>, the security considerations for a PCE-based controller is a little
   different from those for any other PCE system.  That is, the
   operation relies heavily on the use and security of PCEP, so
   consideration should be given to the security features discussed in
   <xref target='RFC5440'/> and the additional mechanisms described in <xref target='RFC8253'/>. It further lists the vulnerability of a central controller architecture, such as a central
   point of failure, denial-of-service, and a focus for
   interception and modification of messages sent to individual NEs.</t>
    <t>The PCECC extension builds on the existing PCEP messages and thus the security considerations described in <xref target='RFC5440'/>, <xref target='RFC8231'/>,
       <xref target='RFC8281'/>, and <xref target='RFC9050'/> continue to apply.</t>
     <t>As per <xref target='RFC8231'/>, it is RECOMMENDED that these PCEP extensions
      only be activated on mutually-authenticated and encrypted sessions across
      PCEs and PCCs belonging to the same administrative authority,
      using Transport Layer Security (TLS) <xref target='RFC8253'/><xref target='I-D.ietf-pce-pceps-tls13'/> as per the
      recommendations and best current practices in <xref target='RFC9325'/>.</t>
    </section>

    <section toc='default'><name>Manageability Considerations</name>
      <section toc='default'><name>Control of Function and Policy</name>
        <t> A PCE or PCC implementation SHOULD allow to configure to
   enable/disable PCECC SR capability as a global configuration. The implementation SHOULD also allow setting the local IP address used by the PCEP session.</t>
      </section>
      <section toc='default'><name>Information and Data Models</name>
        <t><xref target='RFC7420'/> describes the PCEP MIB, this MIB can be extended to get the
           PCECC SR capability status.</t>

        <t>The PCEP YANG module <xref target='RFC9826'/> could be extended
           to enable/disable PCECC SR capability.</t>
      </section>
      <section toc='default'><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 toc='default'><name>Verify Correct Operations</name>
        <t>Mechanisms defined in this document do not imply any new operation
   verification requirements in addition to those already listed in
   <xref target='RFC5440'/>, <xref target='RFC8231'/>, and <xref target='RFC9050'/>.</t>
      </section>
      <section toc='default'><name>Requirements On Other Protocols</name>
        <t>PCEP extensions defined in this document do not put new requirements
   on other protocols.</t>
      </section>
      <section toc='default'><name>Impact On Network Operations</name>
        <t>PCEP extensions defined in this document allow SR SID Label allocation to be done from a central controller, thus simplifying the initial network operations. </t>
      </section>
    </section>


    <section toc='default'><name>IANA Considerations</name>

      <section toc='default'><name>PCECC-CAPABILITY sub-TLV</name>
      <t><xref target='RFC9050'/> defines the
      PCECC-CAPABILITY sub-TLV and requests that IANA to create a new sub-registry to
      manage the value of the PCECC-CAPABILITY sub-TLV's Flag field. </t>
     <t>IANA
      is requested to allocate a new bit in the PCECC-CAPABILITY sub-TLV Flag
      Field sub-registry, as follows:</t>
<table anchor='CAP-TLV'>
      <name>The PCECC-CAPABILITY sub-TLV</name>
      <thead>
      <tr>
        <th align='left'>Bit</th>
        <th align='left'>Description</th>
        <th align='left'>Reference</th>
       </tr>
     </thead>
     <tbody>
       <tr><td align='left'>TBD1</td>
       <td align='left'>SR-MPLS</td>
       <td align='left'>This document</td></tr></tbody>
     </table>
      </section>

      <!--<section title="New Path Setup Type Registry" toc="default">
        <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 allocate a new code point within this registry,
   as follows:</t>
     <texttable anchor="PCEP-PATH-TYPE" style="none" suppress-title="true" title="" align="center">
      <ttcol align="left" width="20%">Value</ttcol>
      <ttcol align="left" width="30%">Description</ttcol>
      <ttcol align="left" width="20%">Reference</ttcol>
       <c>TBD2</c>
       <c>Traffic engineering path is</c>
       <c>This document</c>
       <c> </c>
       <c>setup using PCECC-SR mode</c>
       <c> </c>
     </texttable>
      </section>-->

      <section toc='default'><name>PCEP Object</name>
        <t>IANA is requested to allocate new code-points for the new FEC object and a new Object-Type for the CCI object in the "PCEP Objects" sub-registry as follows:</t>
     <table anchor='PCEP-OBJECT'>
      <name>The PCEP Objects</name>
      <thead>
      <tr>
        <th align='left'>Object-Class Value</th>
        <th align='left'>Name</th>
        <th align='left'>Object-Type</th>
        <th align='left'>Reference</th>
       </tr>
     </thead>
     <tbody>

       <tr><td align='left'>TBD3</td>
       <td align='left'>FEC</td>
       <td align='left'>1: IPv4 Node ID</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>2: IPv6 Node ID</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>3: IPv4 Adjacency</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>4: IPv6 Global Adjacency</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>5: Unnumbered Adjacency with IPv4 NodeID</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>6: IPv6 Linklocal Adjacency</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>44</td>
       <td align='left'>CCI</td>
       <td align='left'> </td>
       <td align='left'><xref target='RFC9050'/></td></tr>

       <tr><td align='left'> </td>
       <td align='left'> </td>
       <td align='left'>TBD6: SR-MPLS</td>
       <td align='left'>This document</td></tr>
     </tbody>
     </table>
      </section>

      <section toc='default'><name>PCEP-Error Object</name>
      <t>IANA is requested to allocate new error-values within
        the "PCEP-ERROR Object Error Types and Values" sub-registry of the
        PCEP Numbers registry for the following errors:</t>

      <table anchor='PCEP-Error'>
      <name>The PCEP-Error</name>
      <thead>
      <tr>
        <th align='left'>Error-Type</th>
        <th align='left'>Meaning</th>
        <th align='left'>Error-value</th>
        <th align='left'>Reference</th>
       </tr>
     </thead>
     <tbody>
     <tr>
              <td align="left" colspan="1" rowspan="1">6</td>
              <td align="left" colspan="1" rowspan="1">Mandatory Object missing</td>
              <td align="left" colspan="1" rowspan="1">TBD5: FEC object missing</td>
              <td align="left" colspan="1" rowspan="1">This document</td>
            </tr>
     <tr>
              <td align="left" colspan="1" rowspan="1">19</td>
              <td align="left" colspan="1" rowspan="1">Invalid Operation</td>
              <td align="left" colspan="1" rowspan="1">TBD4: SR capability was not advertised</td>
              <td align="left" colspan="1" rowspan="1">This document</td>
            </tr></tbody></table>

      </section>
      <section toc='default'><name>CCI Object Flag Field for SR</name>
        <t>IANA is requested to create a new sub-registry to manage the Flag field
           of the CCI Object-Type=TBD6 for SR called "CCI Object Flag Field for SR". New
   values are to be assigned by Standards Action <xref target='RFC8126'/>.  Each bit
   should be tracked with the following qualities:</t><ul spacing='compact'>

   <li>Bit number (counting from bit 0 as the most significant bit)</li>

   <li>Capability description</li>

   <li>Defining RFC</li></ul>

        <t>Following bits are defined for the CCI Object flag field for SR in this document as follows:</t>

<table anchor='CCI-FLAG'>
      <name>The CCI Object Flag Field for SR</name>
      <thead>
      <tr>
        <th align='left'>Bit</th>
        <th align='left'>Description</th>
        <th align='left'>Reference</th>
       </tr>
     </thead>
     <tbody>

       <tr><td align='left'>0-7</td>
       <td align='left'>Unassigned</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>8</td>
       <td align='left'>B-Bit - Backup</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>9</td>
       <td align='left'>P-Bit - Persistent</td>
       <td align='left'>This document</td></tr>


       <tr><td align='left'>10</td>
       <td align='left'>G-Bit - Group</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>11</td>
       <td align='left'>C-Bit - PCC Allocation</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>12</td>
       <td align='left'>N-Bit - No-PHP</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>13</td>
       <td align='left'>E-Bit - Explicit-Null</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>14</td>
       <td align='left'>V-Bit - Value/Index</td>
       <td align='left'>This document</td></tr>

       <tr><td align='left'>15</td>
       <td align='left'>L-Bit - Local/Global</td>
       <td align='left'>This document</td></tr>

     </tbody>

     </table>
      </section>
      <section toc='default'><name>PCEP TLV Type Indicators</name>

   <t>IANA maintains a subregistry called "PCEP TLV Type Indicators".  IANA is requested to
      make an assignment from this subregistry as follows:</t>

<table anchor='TLV'>
      <name>The PCEP TLV</name>
      <thead>
      <tr>
        <th align='left'>Value</th>
        <th align='left'>Meaning</th>
        <th align='left'>Reference</th>
       </tr>
     </thead>
     <tbody>
       <tr><td align='left'>TBD7 (IPv4-ROUTER-ID)</td>
       <td align='left'>IPv4 Router ID</td>
       <td align='left'>This document</td></tr>
       <tr><td align='left'>TBD8 (IPv6-ROUTER-ID)</td>
       <td align='left'>IPv6 Router ID</td>
       <td align='left'>This document</td></tr>

       </tbody>
     </table>
 </section>

    </section>



    <section toc='default'><name>Acknowledgments</name>
      <t>We would like to thank Robert Tao, Changjing Yan, Tieying Huang, Avantika, and Aijun Wang for
   their useful comments and suggestions.</t>
   <t>Further thanks to Stephane Litkowski, Robert Sawaya, Zafar Ali, and Mike Koldychev for useful discussion and ideas to improve the document.</t>
    </section>
  </middle>
  <back>
    <references><name>Normative References</name>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.2119.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.3630.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.4203.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.4915.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.5305.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.5307.xml'/>

      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.5440.xml'/>



      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9552.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.7942.xml'/>

      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8174.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8231.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8253.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8281.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8408.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8664.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9050.xml'/>

      </references>

    <references><name>Informative References</name>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.3031.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.4655.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.5511.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.7025.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.7399.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.7420.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.7491.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9325.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8126.xml'/>
      <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9256.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8232.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8283.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8402.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8660.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8665.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.8667.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9604.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9689.xml'/>



    <xi:include href='http://xml.resource.org/public/rfc/bibxml/reference.RFC.9826.xml'/>





    <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.ietf-pce-state-sync.xml'/>

    <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.ietf-pce-pcep-extension-pce-controller-srv6.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.li-pce-controlled-id-space.xml'/>
    <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.ietf-pce-segment-routing-policy-cp.xml'/>

          <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.ietf-pce-pcep-ls.xml'/>


                    <xi:include href='http://xml.resource.org/public/rfc/bibxml3/reference.I-D.ietf-pce-pceps-tls13.xml'/>
    <!--<?rfc include="reference.I-D.palle-pce-controller-labeldb-sync"?>-->

      </references>
<!--<section title="Using existing PCEP message" toc="default" anchor="appendix">
  <t>This is a temporary section added to this document, till the
    time a decision on the use of new messages v/s extending existing message is resolved. This section should be removed before the final publication of the document.</t>
    <t>The PCInitiate message can be used to download or remove the labels -
    <figure title="" suppress-title="false" align="left" alt="" width="" height="">
       <artwork xml:space="preserve" name="" type="" align="left" alt="" width="" height=""><![CDATA[
     <PCInitiate Message> ::= <Common Header>
                              <PCE-initiated-lsp-list>
  Where:
     <Common Header> is defined in [RFC5440]

     <PCE-initiated-lsp-list> ::= <PCE-initiated-lsp-request>
                                  [<PCE-initiated-lsp-list>]

     <PCE-initiated-lsp-request> ::=
                          (<PCE-initiated-lsp-instantiation>|
                           <PCE-initiated-lsp-deletion>|
                           <PCE-initiated-lsp-label-download>|
                           <PCE-initiated-label-map>)

     <PCE-initiated-lsp-label-download> ::= <SRP>
                                            <LSP>
                                            <label-list>

     <label-list> ::=  <LABEL>
                       [<label-list>]

    <PCE-initiated-label-map> ::= <SRP>
                                  <LABEL>
                                  <FEC>

  Where:
      <PCE-initiated-lsp-instantiation> and
      <PCE-initiated-lsp-deletion> are as per
      [RFC8281].

     The LSP and SRP object is defined in [RFC8231].

]]></artwork>
        </figure>
      </t>

   <t>The PCRpt message can be used to report the labels that were allocated by the PCE, to be used during the state synchronization phase.
    <figure title="" suppress-title="false" align="left" alt="" width="" height="">
       <artwork xml:space="preserve" name="" type="" align="left" alt="" width="" height=""><![CDATA[

The format of the PCRpt message is as follows:

      <PCRpt Message> ::= <Common Header>
                          <state-report-list>
   Where:

      <state-report-list> ::= <state-report>[<state-report-list>]

      <state-report> ::= (<lsp-state-report>|
                          <pce-label-report>)

      <lsp-state-report> ::= [<SRP>]
                             <LSP>
                             <path>

      <pce-label-report> ::= (<pce-label-delegate>|
                              <pce-label-map>)

      <pce-label-delegate> ::= <SRP>
                               <LSP>
                               <label-list>

      <label-list> ::=  <LABEL>
                        [<label-list>]

      <pce-label-map> ::= <SRP>
                          <LABEL>
                          <FEC>


    Where:
      <path> is as per [RFC8231] and the LSP and SRP object are
      also defined in [RFC8231].
]]></artwork>
        </figure>
   </t>

   <t>The procedure for LSP-DB synchronization would also change, in-case we use the existing message. It will be the PCCs that would first report all the
    labels downloaded by the PCE during the state synchronization from PCC towards PCE, and then in case of any discrepancies PCE would use the PCInitiate
    message to add/remove labels.</t>

</section>  -->


<section toc='default'><name>Contributor Addresses</name>

    <figure suppress-title='false' align='left'>
       <artwork name='' type='' align='left' alt=''><![CDATA[
Dhruv Dhody
Huawei
India

EMail: dhruv.ietf@gmail.com

Satish Karunanithi
India

EMail: satish.karunanithi@gmail.com

Adrian Farrel
Old Dog Consulting
UK

EMail: adrian@olddog.co.uk

Xuesong Geng
Huawei Technologies
China

Email: gengxuesong@huawei.com

Udayasree Palle

EMail: udayasreereddy@gmail.com

Katherine Zhao

EMail:

Boris Zhang
Amazon

EMail: zhangyud@amazon.com

Zoey Rose

EMail: atokar@cisco.com


        ]]></artwork>
        </figure>

    </section>


  </back>
</rfc>
