| Internet-Draft | PCEP SR P2MP Policy | October 2025 | 
| Bidgoli, et al. | Expires 22 April 2026 | [Page] | 
Segment Routing (SR) Point-to-Multipoint (P2MP) Policies are a set of policies that enable architecture for P2MP service delivery. This document specifies extensions to the Path Computation Element Communication Protocol (PCEP) that allow a stateful PCE to compute and initiate P2MP paths from a Root to a set of Leaf nodes.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 22 April 2026.¶
Copyright (c) 2025 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
The document [draft-ietf-pim-sr-p2mp-policy] defines a variant of the SR Policy called SR Point-to-Multipoint (P2MP) Policy for creation of P2MP trees.¶
A SR P2MP Policy is constructed using one or more Replication segments ([RFC9524]) from a Root node to a set of Leaf nodes, optionally through a set of intermediate transit nodes that perform replication.¶
A SR P2MP Policy is installed only on the Root node of a P2MP tree and consists of one or more Candidate paths (CP). Each CP is made up of P2MP Tree Instances (PTI), and each PTI is constructed in the network via Replication segments.¶
A Replication segment [RFC9524], corresponds to the forwarding state of a P2MP segment on a particular node and provides forwarding instructions for the segment.¶
As per [draft-ietf-pim-sr-p2mp-policy] a P2MP service can be realized by two types of a P2MP Trees, Ingress Replication or a P2MP tree.¶
For Ingress Replication [RFC7988]. Dataplane packet replication only occurs on the Root, which forwards individual copies of traffic to each leaf directly over a segment routed path. The corresponding SR P2MP Policy consists of Replication segments only for the Root node and the Leaf nodes.¶
A P2MP service delivery can be more efficient using a P2MP Tree. In this case, corresponding SR P2MP policy consists of Replication segments on the Root, Leaf, and Transit nodes which exist in the topology between the Root and Leaf nodes. The Root and Transit nodes perform dataplane packet replication along the tree as a packet traverses from the root towards each leaf.¶
The PCE discovers the root and the leaves via different methods. As an example, the leaves and the root can be explicitly configured on the PCE or PCC can update the PCE with the identity of the root and the leaves when it discovers them via multicast protocols like MP-BGP and MVPN procedures [RFC6513] or PIM. Once the controller is informed of the Root node and Leaf nodes, it can calculate the SR P2MP Policy and any of the required Replication segments from the Root node to the Leaf nodes. The computation may include traffic engineering criteria and any additional Service Leave Agreements (SLAs) that is used to construct the tree.¶
This document defines PCEP objects, TLVs and the procedures to instantiate a P2MP Policy and Replication Segments.¶
Only Stateful PCE is within scope of this document and Stateless PCE only is out of scope.¶
The readers of this document should familiarize themselves with the following documents and sections for terminology and details implementation of the SR P2MP Policy¶
[RFC9524] section 1.1 defines terms specific to SR Replication Segment and also explains the Node terminology in a Multicast domain, including the Root Node, Leaf Node and a Bud Node. [draft-ietf-pim-sr-p2mp-policy] section 2, defines terms and concepts specific to SR P2MP Policy including the CP and the PTI.¶
In addition, below section defines terms used frequently in this document. Refer to Terminology sections of [RFC9256], and [RFC9524] for other terms used in Segment Routing.¶
Unicast Segment Routing (SR): Standard Segment Routing constructs, capabilities and behavior which is not multicast or replication aware.¶
Replication segment: A segment in SR domain that replicates packets. See [RFC9524], for details.¶
Replication node: A node in SR domain which replicates packets based on Replication segment.¶
Downstream nodes: A Replication segment replicates packets to a set of nodes. These nodes are Downstream nodes.¶
Replication state: State held for a Replication segment at a Replication node. It is conceptually a list of replication branches to Downstream nodes. The list can be empty.¶
Replication SID: Data plane identifier of a Replication segment. This is a SR-MPLS label or SRv6 Segment Identifier (SID).¶
Point-to-Multipoint Service: A service that has one ingress node and one or more egress nodes. A packet is delivered to all the egress nodes¶
Transit node: alternative name for Replication node¶
Root node: An ingress node of a P2MP service,¶
Leaf node: An egress node of a P2MP service.¶
Bud node: A node that is both a Replication node and a Leaf node.¶
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 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
After discovering the Root node and Leaf nodes, the PCE programs the PCCs with relevant information needed to create a P2MP Tree.¶
A SR P2MP policy is a variant of SR policy as such it inherits similar concept as draft [draft-ietf-pce-segment-routing-policy-cp]. A SR P2MP Policy is composed of a collection of CPs. CPs are computed by the PCE and can be used for P2MP Tree redundancy. Only a single CP may be active at each time. Each CP can be globally optimized, therefore it consists of multiple PTIs. A PTI can be considered as a P2MP LSP. If a CP needs to be globally optimized two PTIs can be programmed from the root to a set of leaves and via make before break procedures the CP can switch from the original PTI to the new optimized PTI. The forwarding states of these PTIs are build via replication segments. Each PTI initiated on the root has its own set of replication segments on the Root, Transit and Leaf nodes.¶
A replication segment is set of forwarding instructions on a specific node. Each instruction may be a PUSH or SWAP operation before forwarding out of an interface, or a POP action on bud and leaf nodes.¶
PCE MAY also calculate and download additional information for the replication segments, such as protections next-hops for link protection.¶
[RFC8231] The bases for a stateful PCE, and reuses the following objects or a variant of them¶
[draft-ietf-pce-segment-routing-policy-cp] Candidate paths for SR P2MP Policy is used for Tree Redundancy. As an example, a SR P2MP Policy can have multiple candidate paths. Each protecting the primary candidate path. The active CP is chosen via the preference of the candidate path.¶
[RFC3209] Defines the instance-ID, instance-ID is used for global optimization of a CP with in a SR P2MP policy. Each CP can have two PTIs. These PTIs are equivalent to sub-lsps (instance-IDs). There are used for Make Before Break (MBB) and global optimization procedures. Instance-ID is equivalent to LSP ID¶
[RFC9256] Segment-list, used for connecting two non-adjacent replication policy via a unicast binding SID or Segment-list.¶
[RFC8306] P2MP End Point objects, used for the PCC to update the PCE with discovered Leaves.¶
[RFC9050] for programming and identifying the Replication Segment. A new PCE CC Capability sub Tlv is introduced to indicated the support to handle PCE CC based label download for SR P2MP.¶
[draft-ietf-pce-pcep-extension-pce-controller-sr]defines CCI object-type for SR-MPLS. This document redefines a new version of the SR-MPLS CCI object-type.¶
[draft-ietf-pce-multipath] Forwarding instruction for a P2MP LSP is defined by a set of SR-ERO sub-objects in the ERO object, ERO-ATTRIBUTES object and MULTIPATH-BACKUP TLV as defined in this draft.¶
It should be noted that the [draft-hb-spring-sr-p2mp-policy-yang] can provide further details of the high level P2MP Policy Model.¶
SR P2MP Policy¶
Is only relevant on the Root of the P2MP tree and is a policy on PCE. It is downloaded only on the root node and is identified via <Root, Tree-ID> It contains the following information:¶
Candidate Path (CP):¶
Is used for P2MP Tree redundancy where the candidate path with the highest preference is the active path.¶
Each CP can contain two P2MP Tree Instance (PTI) for global optimization procedures (i.e. make before break)¶
Contains information regarding originator, discriminator, preference, P2MP Tree Instances¶
Tree Instance:¶
Replication Segment:¶
Is the forwarding information needed on each replication node for building the forwarding path for each PTI of the CP.¶
Explained further in upcoming sections, there are 2 ways to identify the replication segment, depending on the type of replication segment (shared replication segment or non-shared replication segment)¶
It is identified via Tree-ID and Root and PTI for non-shared replication segment.¶
It is identified via Node-ID, Replication-ID, for shared replication segment. As per [draft-ietf-pim-sr-p2mp-policy] a shared replication segment is not associated to a single tree and can be used for constructing by-pass tunnels for local protectoin on a Replication node.¶
Contains forwarding instructions, in the form of a list of outgoing segments each of which may be a segment list or a single replication segment with next-hop information.¶
On the forwarding plane the Replication Segment is identified via the incoming Replication SID.¶
Is established on every node that may replicate (e.g., Root, Transit, Bud) or receive (e.g., Leaf) the packet in an SR P2MP tree.¶
A SR P2MP Policy and its CP can be identified on the root via the P2MP LSP Object. This Object is a variation of the LSP ID Object defined in [RFC8231] and is as follow:¶
PLSP-ID: [RFC8231], is assigned by PCC and is unique per candidate path. It is constant for the lifetime of a PCEP session. Each additional Candidate path is assigned a new PLSP-ID by PCC. Multiple Candidate paths can co-exist but only one is active.¶
Root: is equivalent to the first node on the SR P2MP Policy path.¶
Tree-ID: an identifier that is unique in context of the Root node. This value may be assigned manually on the Root node or advertised via the Provider Tunnel Association(PTA) in a multicast BGP Auto-Discovery(AD) route.¶
Instance-ID: serves as the PTI identifier and is assigned by the PCE. A CP can have up to two PTIs for global optimization. Instance-IDs are unique within the SR P2MP Policy and are assigned by the PCE per PTI within that Policy. While different P2MP policies may use the same Instance-ID for their PTI, each PTI within a CP of an SR P2MP Policy should use the same Instance-ID across the tree on its Root, Transit, and Leaf nodes when programming its replication segments on the PCC.¶
The key to identify a replication segment is also a P2MP LSP Object. With varying encoding rules for the SR-P2MP-LSP- IDENTIFIER TLV which will be explained in later sections.¶
PCECC and a variant of CCI object is used in Replication Segment to identify a cross connect. A cross connect is a incoming SID and set of outgoing interfaces and their corresponding SID or SID List. The CCI objects contains the incoming SID and the outgoing interfaces which are presented via the ERO objects, which each may contain a segment list.¶
A SR P2MP policy on the Root can be either PCE-initiated or PCC-initiated, depending on how the Root and Leaf nodes are discovered. A PCE-initiated SR P2MP policy is configured directly on the PCE, while a PCC-initiated SR P2MP policy may be triggered by the PCC, sourced from local configuration or discovered with multicast protocols such as MVPN (see [RFC6513]), PIM, IGMP etc. In both cases, PCE-initiated mechanisms are used to install Replication segments on Transit, Bud and Leaf nodes.¶
Note: Algorithms and techniques to compute the P2MP tree replicating nodes are out of scope of this document.¶
PCE is informed through its API or configuration mechanism to instantiate a SR P2MP Policy. PCE is configured with the Root and a set of Leaf nodes.¶
PCE computes a P2MP tree from the Root node to all Leaf nodes which satisfy the configured constraints.¶
PCE sends a PcInitiate message to the Root. The PcInitiate message is configured with a unique Instance-ID for the PTI within the CP of the SR P2MP Policy. The PcInitiate message sent to the root MUST set the Tree-ID to 0. The endpoint-object MAY optionally be included in the PcInitiate message for providing list of Leaf nodes to the PCC for informational purposes.¶
In response to the PcInitiate message, the PCC will assign the PLSP-ID and Tree-ID for the CP. The PCC uses the Instance-ID defined in the PcInitiate message for the PTI contained within the CP. The PCC sends a PcRpt back to PCE containing the PLSP-ID, Tree-ID and Instance-ID. PCC MAY optionally include additional Leaf nodes that were also discovered by multicast procedures¶
PCE will send a PCInitiate message to the Root, Transit and the Leaf nodes to download the Replication Segment information. These messages will utilize the CCI object to identify the p2mp cross connect and encode the forwarding instruction information.¶
PCE then sends a PCUpdate to the Root node indicating the association information (CP) and implicitly binds the CP to the installed CCI information.¶
Root node PCC discovers the leaf nodes via MVPN procedures or other mechanism¶
Root sends a PCRpt message for SR P2MP policy to PCE including the Root, Tree-ID, PLSP-ID, symbolic-path-name, association object and any leaf nodes discovered. In addition:¶
Since the Instance-ID is set by the PCE, the root will set the Instance-ID to value to 0 in the RCRpt message¶
For the association object, root will fill the association type according to the association type defined in this document. The association ID SHOULD be set to value 1 similar to [draft-ietf-pce-segment-routing-policy-cp]. The association source is set to the Root PCC Address.¶
PCE receives the PcRpt and generates a unique Instance-ID for this PTI of the CP and compute the P2MP Policy and its replication segments.¶
PCE will send a PCInitiate message to the Root, Transit and the Leaf nodes to download the Replication Segment information. These messages will utilize the CCI object to encode the forwarding instruction information.¶
PCE will then send a PCUpdate to the root indicating the association information (Candidate path) , and implicitly indicate it to bind to the latest CCI information downloaded.¶
The following procedures are the same for PCE-init or PCC-init SR P2MP Policy.¶
PCE distributes the Replication segments for each CP's PTI to all Transit, Bud and Leaf nodes in the SR P2MP Tree using a PcInitiate message.¶
PLSP-ID: value MUST be set to zero and will be assigned by PCC.¶
Symbolic path name: generated by PCE, MUST be unique for the each candidate path on PCC.¶
Root: the same value of the SR P2MP Policy¶
Tree-ID: it is RECOMMENDED the Tree-ID be set to the same Tree-ID defined on the Root node (which was assigned by the Root node PCC).¶
Instance-ID: set to the same value of path-instance on the Root.¶
The PcInitiate message includes the EROs and utilizes the CCI object to encode the Replication segment forwarding instruction information.¶
In response to the PcInitiate message, each Transit, Bud and Leaf node PCC generates a local PLSP-ID and sends a PcRpt to PCE informing PCE of the Replication segment state.¶
Any new CP for the SR P2MP Policy is downloaded by PCE to the Root by sending a PcInitiate message.¶
PLSP-ID: value MUST be set to zero and will be assigned by PCC.¶
Symbolic path name: generated by PCE, MUST be unique for each CP on PCC.¶
Root: the same value of the SR P2MP Policy¶
Tree-ID: the same value of the SR P2MP Policy¶
Instance-ID: value MUST be set to zero. The PCC generates the PTI's Instance-ID of the CP¶
The PCE distributes the necessary Replication segment for the CP and its PTIs to the Root, Leaf nodes and the Transit nodes as described in section "Replication Segment Instantiation".¶
Any update to the CP or Replication segments is performed via the PCUpd message. Association object MUST be present forCP PCUpdate and PCRpt message. CCI object MUST be present in the Replication segment updates.¶
New Leaf nodes may be locally configured or discovered via multicast protocol procedures. New Replication segments may be instantiated or existing one updated to reach new Leaf nodes.¶
If the new Leaf nodes reside on routers that are part of the existing SR P2MP Tree, then PCUpd is sent from PCE to necessary PCCs (Leaf, Bud or Root nodes) with the existing PLSP-ID, Instance-ID, Tree-ID and CC-ID.¶
If the new Leaf nodes are residing on routers that are not part of the existing SR P2MP Tree, then a PcInitiate message is sent from PCE to each new Leaf and any necessary Transit nodes following section "Replication Segment Instantiation".¶
The active CP is indicated by the PCC through the operational bits(Up/Active) of the LSP object in the PCRpt message. If a CP needs to be removed, PCE sends PCInitiate message, setting the R-flag in the LSP object and R bit in the SRP-object.¶
A CP is made active based on the preference of the path. If the Root is programed with multiple CPs from different sources, as an example PCE and CLI, based on its tie-breaking rules, if it selects the CLI path, it will send a report to PCE for the PCE path indicating the status of label-download and sets operational bit of the LSP object to UP and Not Active. At any instance, only one PTI is permitted be active¶
To remove a single CP, PCE sends PC Initiate message, setting the R-flag in the LSP object and R bit in the SRP-object.¶
To remove the entire SR P2MP Policy, PCE needs to send PcInitiate remove messages for every CP of the SR P2MP Policy to the Root and send PcInitiate remove messages for every Replication segment on all the PCCs in the SR P2MP Tree. The R bit in the LSP Object as defined in [RFC8231], refers to the removal of the LSP as identified by the SR-P2MP-INSTANCE-ID-TLV (defined in this document). An all zero (SR-P2MP-LSP-ID-TLV defines to remove all the state of the corresponding PLSP-ID.¶
When a P2MP LSP needs to be optimized for any reason (i.e. it is taking a FRR tunnel or new routers are added to the network) a global optimization of the CP is possible.¶
Each CP MAY contain two PTIs. The current unoptimized PTI is the active instance and its replication segments are forwarding the multicast packets from the root to the leaves. However the second optimized PTI will be setup with its own unique Replication Segments throughout the network, from the Root to the leaf nodes. These two PTIs MAY co-exist. The two PTIs are uniquely identified by their Instance-ID in the SR-P2MP-INSTANCE-ID-TLV (defined in this document).¶
After the optimized PTI has been downloaded successfully, PCC MUST send two reports, reporting UP of the new PTI the new LSP-ID, and a second reporting the tear down of the old PTI with the R bit of the LSP Object SET with the old Instance-ID in the SR-P2MP-INSTANCE-ID-TLV. This MBB procedure will move the multicast PDUs to the optimized Path-Instance.¶
The transit and leaf nodes SHOULD be able to accept traffic from both PTIs to minimize the traffic outage by the Make Before Break process.¶
It is recommended for the optimized PTI to be setup up by PCE from the leaf nodes to transit nodes and finally the root nodes to ensure the entire PTI's path is programmed before the MBB procedure is initiated.¶
When one of the PCCs involved in the LSP lacks the capability to support more than one PTI, the possibility of achieving global make before break (MBB) is not feasible. However, with knowledge of the PCCs' advertised capabilities, the PCE can detect this limitation and instead opt for local re-optimization of the CP. In such cases, the PCE can compute the optimized LSP by send the PCUpd message using the existing PTI and its Instance-ID for CP, specifically targeting the PCCs where the optimized LSP triggers a change in forwarding state.¶
This document identifies Facility Fast Reroute (FRR) procedures. Only Link Protection procedures are defined. How the Facility Path is computed and instantiated is outside of scope of this document.¶
          R
         | |
          T
          |
         ---
        |   |
        L1 L2
Figure 1: Redundant directly connected interfaces
¶
As an example, in figure 1 both R and T are configured with replication segments. There are two interface between R and T. One can be used as primary and second as a bypass in case the primary interface is down. There can be 2 method to protect the primary interface.¶
The two replication segments on R and T can take advantage of unicast SR to connect to each other. In this case the LFA of unicast SR can be utilize to protect the primary interface between R and T.¶
The replication segment provides protection nexthop, the protection nexthop can be programmed to take the alternate interface between R and T to protect the primary interface.¶
        R---F1
        |   |
        T---F2
        |
         ---
        |   |
        L1 L2
Figure 2: Protection through alternative network path¶
As a second example, in Figure 2 R and T connected directly and via network F1..F2. In this example as per example 1, unicast SR can be used to connect the two Replication segments, including using SR LFA or R-LFA or TI-LFA to protect the direct link between R-T via F1. If unicast SR is not available within the network, the PCE optionally can establish a shared replication point on F1 and F2 and protect all path-instances that are traversing R-T via this shared Replication segment.¶
In addition, Penultimate Hop Popping (PHP) and implicit null label on the bypass path can be implemented to reduce the PCE programming on the merge point (MP) PCC.¶
There could be many nodes between two Replication Segments that do not support SR P2MP Policy or Replication Segment. It is possible to connect two non-adjacent Replication segments via a SR Policy or similar technoloty using a SID list and rely on IGP forwarding. The SID list can be comprised of any IGP supported segment types (ex: Binding, Adjacency, Node). This information is encoded via the SR-ERO sub-objects and ERO-attributes objects. The last segment in an encoding SID list MUST be a Replication segment¶
The SR P2MP Policy and its Replication segment can be delete by the PCC or by the PCE. to delete the SR P2MP Policy all the CP associated to that P2MP policy need to be deleted. The last CP that is being deleted, will delete the SR P2MP Policy Instance as well on the PCE or PCC.¶
To delete the CPs there are two methods:¶
The CPs can be deleted by deleting all the PTIs associated with them and the last PTI that is deleted will trigger the CP to be deleted.¶
The CP can be deleted entirely and this will delete all the associated PTIs as well.¶
For PCC to delete a CP, Root send a PCRpt message with the R bit of the LSP object set and all the fields of the SR-P2MP- LSP-ID TLV set to 0 (indicating to remove all state and PTIs associated with this SR P2MP Policy). The PCE in response sends a PcInitiate message with R bit in the SRP object set to all nodes along the path to indicate deletion of the entries. In this case the Instance-ID can be set 0 with the R bit set to indicate removing the entire CP and all its PTIs.¶
For PCC to delete a PTI, Root send a PCRpt message with the R bit of the LSP object set and all the fields of the SR-P2MP- LSP-ID TLV set to 0 but the Instance-ID value (indicating to remove the specific PTI associated with this P2MP tunnel). The PCE in response sends a PCInitiate message with R bit in the SRP object SET to all nodes along the path to indicate deletion of the entries. Note in this case the Instance-ID has to be set accordingly with the R bit set to indicate removing the specific PTI. This is useful for the global optimization case where after downloading the optimize PTI and ensuring the PTI is operational the PCC removes the old PTI.¶
When PCE is deleting a CP or a PTI it should delete all the replication segments of that CP or PTI as well before it moves to the next CP or PTI.¶
The Fragmentation bit in the LSP object (F bit) can be used to indicate a fragmented PCEP message.¶
The objects and TLV's defined in this document can be included in PCRpt, PcInitiate and PCUpd messages. The inclusion of the Objects and TLVs differ between SR P2MP Policy and Replication segment.¶
The format of the PCRpt message is updated as follows:¶
<PCRpt Message> ::= <Common Header>
                    <state-report-list>
Where:
 <state-report-list> ::=
      <state-report>[<state-report-list>]
 <state-report> ::= [<SRP>]
                     <LSP>
                    [<association-list>]
                    [<end-point-list>]
where:
 <SRP> is defined in RFC8231
 <LSP> is defined in [RFC8231] section 5.5.1
 <association-list> ::=
      <ASSOCIATION> [<association-list>]
 <end-point-list> ::= [<P2MP-END-POINTS>]
Where:
 <ASSOCIATION>
        is described in this doc
 <P2MP-END-POINTS>
        is described in this doc
¶
The format of the PCUpd message is updated as follows:¶
<PCUpd Message> ::= <Common Header>
                    <update-request-list>
Where:
 <update-request-list> ::= <update-request>
                          [<update-request-list>]
 <update-request> ::= <SRP>
                      <LSP>
                     [<end-point-list>]
Where:
 <SRP> is defined in [RFC8231]
 <LSP> is defined in [RFC8231]section 5.5.1
 <end-point-list> ::= [<P2MP-END-POINTS>]
Where:
 <P2MP-END-POINTS> is described in this doc
¶
The format of the PCInitiate message is updated as follows:¶
<PCInitiate Message> ::= <Common Header>
                         <PCE-initiated-lsp-list>
Where:
 <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-instantiation> ::= <SRP>
                                       <LSP>
                                       <association-list>
                                       <end-point-list>
Where:
 <SRP> is defined in RFC8231
 <LSP> is defined in [RFC8231] in section 5.5.1
 <association-list> ::=
             <ASSOCIATION> [<association-list>]
 <end-point-list> ::= [<P2MP-END-POINTS>]
Where:
 <ASSOCIATION> is described in this doc
 <P2MP-END-POINTS> is described in in this doc
¶
The Replication Segment can be constructed via the following PCRpt, PCUpd and PCInitiate messages¶
NOTE:¶
Replication segment does not use a association object¶
The format of the PCRpt message is updated as follows:¶
<PCRpt Message> ::= <Common Header>
                    <state-report-list>
Where:
 <state-report-list> ::=
         <state-report>[<state-report-list>]
 <state-report> ::= [<SRP>]
                     <LSP>
                     <CCI>
                     <intended-path>
Where:
 <SRP> is defined in [RFC8231]
 <LSP> is defined in [RFC8231] section 5.5.1
 <CCI> is defined in this doc
 <intended-path> ::=
        ((<PATH-ATTRIB><ERO>)[<intended-path>])
Where:
 <PATH-ATTRIB-ERO> is defined in [draft-ietf-pce-multipath]
 <ERO> is defined in [RFC8664]
¶
The format of the PCUpd message is updated as follows:¶
<PCUpd Message> ::= <Common Header>
                    <update-request-list>
Where:
 <update-request-list> ::= <update-request>
                          [<update-request-list>]
 <update-request> ::= <SRP>
                      <LSP>
                      <CCI>
                      <intended-path>
Where:
 <SRP> is defined in [RFC8231]
 <LSP> is defined in [RFC8231] section 5.5.1
 <CCI> is defined in this doc
 <intended-path> ::=
       ((<PATH-ATTRIB><ERO>)[<intended-path>])
Where:
 <PATH-ATTRIB-ERO> is defined in [draft-ietf-pce-multipath]
 <ERO> is defined in [RFC8664]
¶
The format of the PCInitiate message is updated as follows:¶
<PCInitiate Message> ::= <Common Header>
                         <PCE-initiated-lsp-list>
Where:
 <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-instantiation> ::= <SRP>
                                       <LSP>
                                       [<CCI>]
                                       [<intended-path>]
Where:
 <SRP> is defined in RFC8231
 <LSP> is defined in [RFC8231] section 5.5.1
 <CCI> is defined in section 4.4.3.3
 <intended-path> ::=
            ((<PATH-ATTRIB><ERO>)[<intended-path>])
Where:
 <PATH-ATTRIB-ERO> is defined in [draft-ietf-pce-multipath]
 <ERO> is defined in [RFC8664]
 <PCE-initiated-lsp-deletion> is as per [RFC8281].
 <attribute-list> is as per [RFC8281].
¶
A SR P2MP Policy supports add, remove, and full replace of Leaf nodes in a message, described further in section 5.5.2 and with an example in section 8.1. However, a CP and Replication Segment MUST NOT carry delta information. Every PcRpt, PcInitiate and PCUpd message MUST contain the full list of the Leaf nodes, and Segment forwarding information that is needed to build the CP and its Replication segments. This is necessary to ensure that PCE or any new PCE is in sync with the PCC.¶
This document uses [draft-ietf-pce-multipath] to identify each out-going interface in the Replication Segment. In addition each out-going interface can be protected by a backup path. The Path Attributes Object is used to provide the relation between the primary path and its backup path as per draft [draft-ietf-pce-multipath].¶
Note: Multipath weight TLV MUST NOT be used and SHOULD be ignored when revived. Composite Candidate Path TLV SHOULD NOT be present and SHOULD BE ignored if present.¶
When a replication segment is being updated or new out-going interfaces are added to a specific replication segment, the PCRpt, PCInitiate and PCUpd messages sent via PCEP, maintains the previous ERO Path IDs and generates new Path IDs for new instructions. The PATH IDs are maintained for each specific forwarding instructions until the instructions are deleted. For example: When the first leaf is added, the PCE will update with Path ID 1 to the PCC. When the second leaf is added, according to the path calculated, PCE might just append the existing instruction Path ID 1 with a new Path ID 2 to construct the new PCUpd message.¶
The Central Control Instruction (CCI) Object is used to identify the entire cross connect of Explicit Route Object (ERO) which consist of incoming Replication SID and the set of outgoing Interfaces and their corresponding SIDs and/or SID lists. Any modification to this instruction should use this CCI ID to identify the cross connect uniquely. Leaf nodes and their corresponding Path IDs can be removed from the cross connect identified via the CCI. The CC-ID is assigned by the PCE.¶
The CCI Object used by the PCE to specify the controller instructions is defined in [RFC9050]. [draft-ietf-pce-pcep-extension-pce-controller-sr] defines CCI object-type for SR-MPLS. This document redefines a new version of the SR-MPLS CCI object-type for SR P2MP Policy in upcoming sections.¶
A PCEP speaker indicates its ability to support SR P2MP Policy and Replication Segment during the PCEP initialization phase. Speakers which support SR P2MP Policy and Replication segment object MUST include SR-P2MP-POLICY-CAPABILITY TLV in the OPEN Object.¶
This draft defines a new SR-P2MP capability TLV with type TBD¶
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=TBD | Length=4 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Number of Instances | number of replication | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Flags | reserved | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+¶
Type: TBD¶
Length: 4¶
Number of Instances 16 bits - Number of instances the advertising PCEP speaker supports. This is meaningful for PCEs. PCEs can determine the least number of instances that could be created for a SR P2MP policy.¶
Number of replication 16 bits - number of out going interfaces that the system is capable of having per multicast state.¶
Flags 16 bits - No Flags currently defined¶
Upon the receipt of an Open message, the receiving PCEP peer MUST determine whether the suggested PCEP session characteristics (leaf-types) are acceptable. If the suggested leaf-types are not acceptable to the receiving peer, it MUST send an PCEP Error message (PCErr) with Error-Type=2 (Capability not supported) and error-value X (new error type assigned by IANA incompatible SR P2MP leaf types) (See Section 5.5.2 for leaf-types)¶
If a PCEP speaker advertises SR P2MP Policy Capability then it MUST include the PST = 1 in the PATH-SETUP-TYPE-CAPABILITY TLV as per [RFC8664]¶
A Assoc-Type-List TLV as per [RFC8697] section 3.4 should be send via PCEP open object with following association type¶
+-------------------+----------------------------+------------------+ | Association Type | Association Name | Reference | | Value | | | +-------------------+----------------------------+------------------+ | TBD1 | P2MP SR Policy Association | This document | +-------------------+----------------------------+------------------+¶
OP-CONF-Assoc-RANGE (Operator-configured Association Range)should not be set for this association type and must be ignored.¶
This document reuses symbolic path name from [RFC8231] section 7.3.2. For SR P2MP Policy a symbolic path is unique on the PCC. It is RECOMMENDED for the symbolic path name to be Root, Tree-ID and CP Discriminator values.¶
Two ASSOCIATION object types for IPv4 and IPv6 are defined in [RFC8697]. The ASSOCIATION object includes "Association type" indicating the type of the association group. This document adds a new Association type. Association type = TBD1 "SR P2MP Policy Association Type" for SR Policy Association Group (P2MP SRPAG).¶
For PCC-initiated SR P2MP Policy, the ASSOCIATION object is present in the first PCRpt message that is sent by the PCC to PCE to indicate the existence of the SR P2MP Policy and its CP. This first PCRpt message does not have a corresponding PCUpdate message but it does include the Association object accordingly.¶
The Association Source SHOULD be set to the root address of the P2MP tree.¶
In par with [draft-ietf-pce-segment-routing-policy-cp] section 4.2, P2MP policy reuses the four TLVs used in the SRPA object. P2MP policy also redefines the extended association ID TLV:¶
SRPOLICY-POL-NAME TLV: (optional) encodes SR P2MP Policy Name¶
SRPOLICY-CPATH-ID TLV: (mandatory) encodes SR P2MP Policy Candidate Path Identifier¶
SRPOLICY-CPATH-NAME TLV: (optional) encodes SR P2MP Policy Candidate Path name.¶
SRPOLICY-CPATH-PREFRENCE TLV: (optional) encodes SR P2MP Policy Candidate path preference value.¶
In addition to above the extended association ID TLV has been modified to address the SR P2MP Policy¶
In par with [draft-ietf-pce-segment-routing-policy-cp] the Extended Association ID TLV MUST be included and it MUST be in the following format for the SR P2MP Policy¶
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 = 31 | Length = 4 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | TREE-ID | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+¶
Length: 4 byte¶
Tree-ID: identifies the P2MP Tree which the Replication segment is part of¶
In order for the Root node to indicate operations of its Leaf nodes (Add/Remove/Replace-all), the PcRpt and PcInit messages are extended to include P2MP End Point <P2MP End-points> Object which is defined in [RFC8306]¶
The absence of the P2MP-END-POINTS Object means that there is no change in the leaf endpoint of the policy and the PCEP speaker MUST NOT consider the absence of the object as an indication of removal of the endpoints.¶
IPV4-P2MP END-POINTS: 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 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Leaf type | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Source IPv4 address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Destination IPv4 address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ ~ ... ~ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Destination IPv4 address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ IPV6-P2MP END-POINTS: 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 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Leaf type | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | | Source IPv6 address (16 bytes) | | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | | Destination IPv6 address (16 bytes) | | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ ~ ... ~ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | | Destination IPv6 address (16 bytes) | | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+¶
Leaf Types (derived from [RFC8306] section 3.3.2) :¶
New leaves to add (leaf type = 1)¶
Old leaves to remove (leaf type = 2)¶
the entire pce leaf list is overwritten and replaced with the new leaf list (leaf type = 5)¶
Note a PCE speaking node MUST NOT combine leaf type 1 and 2 with leaf type 5.¶
Note a PCE speaking node SHOULD NOT have the same node present in the leaf type 1 and 2 if both leaf types are present.¶
A given P2MP END-POINTS object gathers the Leaf nodes of a given type. A SR P2MP PcRpt MAY mix different types of Leaf nodes by including several P2MP END-POINTS objects. The END-POINTS object body has a variable length. These are multiples of 4 bytes for IPv4, multiples of 16 bytes, plus 4 bytes, for IPv6.¶
Both SR P2MP Policy and Replication Segment are identified via the LSP object and more precisely via the SR-P2MP-LSPID-TLV¶
The SR P2MP Policy uses the PLSP-ID to identify the CP and the Instance-ID to identify a PTI with in the CP.¶
A Replication Segment uses the SR-P2MP-LSPID-TLV to identify and correlate a Replication Segment to a P2MP Policy¶
As it was noted previously, for the Root the SR P2MP Policy and the Replication Segment is downloaded via the same PCUpd message.¶
The LSP Object is defined in Section 7.3 of [RFC8231]. It specifies the PLSP-ID to uniquely identify an LSP that is constant for the life time of a PCEP session. Similarly, for a P2MP Policy, the PLSP-ID identify a Candidate Path uniquely with in the SR P2MP policy.¶
The LSP Object MUST include the new SR-P2MP-INSTANCE-ID-TLV (IPV4/IpV6) defined in this document below. This is a variation to the P2MP object defined in [draft-ietf-pce-stateful-pce-p2mp]¶
IPV4-SR-P2MP-INSTANCE-ID-TLV: 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=TBD | Length=10 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Root | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Tree-ID | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Instance-ID | Reserved | Flags |R|A| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ IPv6-SR-P2MP-INSTANCE-ID-TLV : 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=TBD | Length=22 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | + + | Root | + (16 octets) + | | + + | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Tree-ID | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Instance-ID | Reserved | Flags |R|A| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+¶
The type (16-bit) of the TLV is TBD (need allocation by IANA).¶
Root: Source Router IP Address¶
Tree-ID: Unique Identifier of this P2MP LSP on the Root.¶
Instance-ID : Identifier of PTI, Contains 32 Bit instance ID. Instance-id 0 is reserved.¶
Reserved: 8 bits reserved for future use.¶
Flags: 8 bits, A - Activate the Instance-ID, R - Remove the Instance-ID¶
At any given time, only one PTI MUST be active. Activating one PTI entails deactivating the other PTI, with the condition that the active PTI Instance-ID MUST have a non-zero value.¶
The (A) flag is meaningful for Root PCC and PCE. PCE MUST be setting (A) flag in the PCUpd containing SR-P2MP-INSTANCE-ID TLV for activating the PTI. The decision regarding when to set the (A) flag can be made locally on the PCE. E.g., this decision can be based on factors such as receiving PCRpt messages from all PCCs for the new PTI or utilizing a timer-based approach to ensure that the data plane is completely configured on all PCCs. It's important to note that determining the appropriate timing for activating the new PTI is not within the scope of this document. After the activation of the SR P2MP Policy any PCUpd MUST include the (A) flag in the P2MP-Instance TLV.¶
Root PCC MUST set the (A) flag in the PCRpt as a response to receiving a PCUpd message with the (A) flag set.¶
If a PCE receives a PCRpt with the (A) flag set in response to a PCUpd message that did not have the (A) flag set, then PCE MUST treat this as an error. In such a case, PCE MUST send an PCEP Error message (PCErr) with Error-Type=10 (Reception of an Invalid Object) and error-value (X) (Invalid active instance).¶
For Transit or Leaf PCCs, receipt of a PCUpd message with the (A) flag MUST be treated as an error. Transit or Leaf PCCs MUST send an PCEP Error message (PCErr) with Error-Type=19 (Invalid Operation) and error-value (X) (Attempted activating instance on Transit or leaf PCC).¶
Figure 3 presents an example exchange of SR-P2MP-LSPID-TLV.¶
                  +-+-+                    +-+-+
                  |PCC|                    |PCE|
                  +-+-+                    +-+-+
                    |                        |
1) LSP state Report | -------- PCRpt ------> |
   With PLSP-ID and |  (SRP,                 |
   Instance-ID      |   LSP (SR-P2MP-LSPID), |
                    |   P2MP-END-POINT)      |
                    |                        |
                    | <------- PCUpd ------- |2) PCUpd message sent
                    |  (SRP,                 |   to the PCC with
                    |   LSP (SR-P2MP-LSPID), |   Path info and activating
                    |   Association,         |   instance.
                    |   P2MP SR Pol. ID TLV, |
                    |   CPATH_ID TLV,        |
                    |   P2MP-END-POINT,      |
                    |   CCI, PATH_ATTRIB,    |
                    |   SR-ERO)              |
                    |                        |
                    |                        |
3) LSP State Report |---- PCRpt message ---->|
  (echoing Instance |                        |
    Active)         |                        |
                    |                        |
¶
As per [RFC9524] a replication segment has a next-hop-group which MAY contain a single outgoing replication SID or a list of SIDs (sr-policy-sid-list) In either case there needs to be a replication SID identifying the replication state on a downstream replication node. Two replication segments can be directly connected or connected via a unicast SR domain.¶
The format of a Replication Segment message encoding is similar to SR P2MP Policy. However, the SR P2MP Policy contains the association object and the Replication Segment message does not contain the association object. In addition, the Replication Segment carries the CCI object to identify a P2MP cross connect. The Replication Segment is distributed individually to the Root, Transit and Leaf nodes without the SR P2MP Policy. The Replication Segment uses SR-P2MP-LSPID-TLV as its identifier. The TLV is coded differently for shared and non-shared case¶
The CCI Object as defined in [RFC9050] is used to identify a forwarding instruction in the Replication Segment. A forwarding instruction is incoming SID and a set of outgoing branches.¶
The CCI Object can be include in Reports, initiate and Update messages for Replication Segments.¶
This document redefines a new version of the SR-MPLS CCI object-type [draft-ietf-pce-pcep-extension-pce-controller-sr] for P2MP Policy. The label in the CCI Object is the incoming SID. The outgoing SIDs are defined by the ERO Objects.¶
CCI Object-Type is TBD6 for SR P2MP Policy.¶
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 | role | flags |V|L| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | SID/Label/Index | +---------------------------------------------------------------+ | | // Optional TLV // | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+¶
Flags:¶
The V and the L flags are defined as per [draft-ietf-pce-pcep-extension-pce-controller-sr]¶
The node action and role of ingress, transit, leaf or bud, is indicated via the 4 bit roles field¶
Forwarding information of a Replication Segment can be configured and steered via many different mechanisms. RFC [RFC8664] defines the NAI types.¶
As an example a replication SID can be steered via:¶
Replication SID steered with an IPv4/IPv6 directly connected nexthop (RFC 8664 NAI type 3, 4, 6 (adjacency))¶
In this case there will two SR-ERO in the ERO Object, with the Replication SID SR-ERO at the bottom and the IPv4/IPv6 SR-ERO on the top.¶
Replication SID steered with an IPv4/IPv6 loopback address that reside on the directly connected router. (NAI type 1..2 (node))¶
In this case there will two SR-ERO in the ERO Object, with the Replication SID SR-ERO at the bottom and the IPv4/IPv6 SR-ERO on the top.¶
Replication SID steered with unnumbered IPv4/IPv6 directly connected Interface (NAI type 5 (adjacency unnumbered)¶
Replication SID steered via a SR adjacency or node SID¶
This draft defines a new Association type for SR P2MP Policy. IANA is requested to allocate a new value from the existing IANA Registry "ASSOCIATION TYPE Field" within the "Path Computation Element Protocol (PCEP) Numbers" registry group.¶
+----------+----------------------------+-----------------+ | Type | Name | Reference | +----------+----------------------------+-----------------+ | TBD1 | SR P2MP Policy Association | This document | +----------+----------------------------+-----------------+¶
[RFC8306] specified the P2MP END-POINTS object but did not create a registry for the 32-bit Leaf type field. This document establishes the registry and populates it with values from [RFC8306] and adds a new Leaf type. IANA is requested to create a new "Endpoint Leaf Types" registry with the allocation policy as IETF Review [RFC8126]. This new registry contains the following values:¶
+----------+----------------------------+-----------------+ | Value | Description | Reference | +----------+----------------------------+-----------------+ | 0 | Reserved | This document | +----------+----------------------------+-----------------+ | 1 | New leaves to add | RFC 8306 | +----------+----------------------------+-----------------+ | 2 | Old leaves to remove | RFC 8306 | +----------+----------------------------+-----------------+ | 3 | Old leaves whose path can | RFC 8306 | | | be modified/reoptimized | | +----------+----------------------------+-----------------+ | 4 | Old leaves whose path must | RFC 8306 | | | be left unchanged | | +----------+----------------------------+-----------------+ | 5 | All old leaves overwritten | This document | | | and replaced with the new | | +----------+----------------------------+-----------------+¶
To keep it consistent with the Generalized Endpoint Types [RFC8779], this draft defines a new Endpoint Type in the "Generalized Endpoint Types" registry as follows:¶
    +-----------+---------------------+-----------------+
    | Value     | Type                | Reference       |
    +-----------+---------------------+-----------------+
    | TBD2      | Point-to-Multipoint | This document   |
    |           | with leaf type 5    |                 |
    +-----------+---------------------+-----------------+
¶
The Authors are requesting value 5 for this new endpoint type.¶
This draft extends the PCEP OPEN object by defining a new optional TLV to indicate the PCE's capability to perform SR-P2MP path computation.¶
Further, this draft defines two new TLVs for Identifying the SR P2MP Policy and the Replication Segment with IPv4 or IPv6 root address.¶
IANA is requested to allocate a new value from the IANA Registry "PCEP TLV Type Indicators"¶
    +------------+------------------------------+----------------+
    | TLV Type   | Description                  | Reference      |
    | Value      |                              |                |
    +------------+------------------------------+----------------+
    | TBD3       | SR-P2MP-POLICY-CAPABILITY    | This document  |
    +------------+------------------------------+----------------+
    | TBD4       | IPV4-SR-P2MP-INSTANCE-ID TLV | This document  |
    +------------+------------------------------+----------------+
    | TBD5       | IPV6-SR-P2MP-INSTANCE-ID TLV | This document  |
    +------------+------------------------------+----------------+
¶
This draft defines a new CCI Object type SR P2MP Policy.¶
IANA is requested to allocate new codepoints in the "PCEP Objects" sub-registry as follows:¶
    +-------------+----------------------+----------------+
    | Object Class| Name                 | Reference      |
    | Value       |                      |                |
    +-------------+----------------------+----------------+
    | 44          | CCI Object           |                |
    |             | Object-Type          |                |
    |             | TBD6: SR P2MP Policy | This document  |
    +-------------+----------------------+----------------+
¶
The security considerations described in [RFC5440], [RFC8231], [RFC8281], [RFC8664], [RFC8697], [RFC9256] and [RFC9524] are applicable to this specification.¶
As per [RFC8231], it is RECOMMENDED that these PCEP extensions can only be activated on authenticated and encrypted sessions across PCEs and PCCs belonging to the same administrative authority, using Transport Layer Security (TLS) [RFC8253].¶
No additional security measures are required for SR P2MP Policy.¶
Note to the RFC Editor: please remove this section before publication. 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 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. According to 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".¶
Cisco has implemented this document on both IOS XR PCE and PCC. Both PCE-Initiated and PCC-Initiated SR P2MP Policy types have been implemented. Only one candidate path can be created with the SR P2MP Policy and only one PTI is supported within a CP.¶
All manageability requirements and considerations listed in [RFC5440], [RFC8231], [RFC8664], and [RFC9256] apply to PCEP protocol extensions defined in this document. In addition, requirements and considerations listed in this section apply.¶
TBD¶
TBD¶
Mechanisms defined in this document do not imply any new liveness detection and monitoring requirements in addition to those already listed in [RFC5440], [RFC8664] and [RFC9256].¶
Operation verification requirements already listed in [RFC5440], [RFC8231], [RFC8664], [RFC9256] are applicable to mechanisms defined in this document.¶
An implementation MUST allow the operator to view SR P2MP Policy Identifier and each SR Replication segment Candidate path Identifier advertised in PCEP.¶
An implementation SHOULD allow the operator to view the capabilities defined in this document.¶
An implementation SHOULD allow the operator to view each Replication segment Candidate path associated with specific SR P2MP Policy.¶
The PCEP extensions defined in this document do not imply any new requirements on other protocols.¶
The mechanisms defined in [RFC5440], [RFC8231], [RFC9256] also apply to the PCEP extensions defined in this document.¶
The authors would like to thank Tanmoy Kundu and Stone Andrew at Nokia and Tarek Saad at Cisco for their feedback and major contribution to this draft.¶
Tarek Saad
                    Cisco Systems
                    Email: tsaad.net@gmail.com
Saranya Rajarathinam
                    Saranya Rajarathinam
                    Nokia
                    Email: saranya.Rajarathinam@nokia.com
¶
This is an example of PCC initiated P2MP Policy. The PCC will send a Report message to the PCE to initiat a P2MP Policy with a set of leaves that are discovered via Next Generation MVPN procedures as per [RFC6513].¶
In addition, since the PCC is initiating the P2MP Policy, it does populate the PLSP-ID for the candidate path. PCC will leave the Instance-ID for the PTI to 0 and the Instance-ID is assigned by the PCE.¶
 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
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Flags = 0                            |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                        SRP-ID-number  = 0                     |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  TLV Type = 28 (PathSetupType)| TLV Len = 4                   |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                                             | PST = TBD       |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                           <LSP OBJECT>
|                PLSP-ID = 1            |     A:1,D:1,N:1       |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|           Type=17             |           Length=<var>        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                            symbolic path name                 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|             Type=TBD          |  Length                       |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                   Root = A                                    |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                  Tree-ID = Y                                  |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                        Instance-ID = 0                        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                       <P2MP END POINT OBJECT>
|                          Leaf type = 5                        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                     Source IPv4 address = A                   |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                  Destination IPv4 address = D                 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                  Destination IPv4 address = E                 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
¶
The following packet is the PCE creating the CP for the SR P2MP Policy and downloading the Replication Segment with the same message on the root.¶
It should be noted combining the SR P2MP Policy CP creation and Replication Segment only is possible on the root.¶
As such this message contains both association object and the CCI object. The CCI Object contains the incoming Binding SID and wraps all the Path Attribute messages and their corresponding EROs.¶
The PLSP-ID are populated with the same ID as the previous PCC report message and the Instance-ID is assigned by the PCE.¶
       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
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                          Flags = 0                            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                        SRP-ID-number  = 1                     |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |  TLV Type = 28 (PathSetupType)| TLV Len = 4                   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                             | PST = TBD       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                             <LSP OBJECT>
      |                PLSP-ID = 1            |     A:1,D:1,N:1,C:0   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=17             |           Length=<var>        |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                            symbolic path name                 |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type=TBD          |  Length                       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                   Root =A                                     |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                  Tree-ID = Y                                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Instance-ID = L1                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                            <ASSOCIATION OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |         Reserved              |            Flags            |0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      | Association type= SR-P2MP-PAG |      Association ID = z       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |              IPv4 Association Source = <pce-address>          |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |     Type=P2MP SR Policy ID    |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Root  = A                             |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                           TREE-ID = 0                         |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |    Type=P2MP SR Policy Name   |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                                               |
      ~                     P2MP SR Policy Name                       ~
      |                                                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Type=P2MP SR Pol Cand-path ID  |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |ProtOrigin 10  |    Reserved                                   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Originator ASN                        |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                                               |
      |                       Originator Address = <pce-address>      |
      |                                                               |
      |                                                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Discriminator = 1                     |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Type=P2MP SR Pol Cand-path Name|             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                                               |
      ~               P2MP SR Policy Candidate Path Name              ~
      |                                                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Type=P2MP SR Pol Cand-Path Pre |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                           Preference = 100 <default>          |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                              <P2MP END POINT OBJECT>
      |                          Leaf type = 5                        |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                     Source IPv4 address = A                   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                  Destination IPv4 address = D                 |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                  Destination IPv4 address = E                 |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                            <CCI OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                            CC-ID = X                          |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |          Reserved1            |             Flags         |0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                 Label = 0             |     Reserved2         |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                       <PATH-ATTRIBUTES OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Flags                           | Oper|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                              ERO-path Id = 1                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type              |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |       Backup Path Count = 1   |             Flags           |0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Backup Path ID 2                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=Node Role      |           Length=4            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Role = ingress |                 Reserved                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                           <ERO-OBJECT>
                         <SR-ERO-SUB OBJECT>
      |L|   Type=36   |     Length    |  NT= 1|     Flags   |0|0|1|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                ipv4-address  = NHD1           |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |L|   Type=36   |     Length    |  NT= 0|     Flags   |0|1|0|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         SID = d1                              |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                       <PATH-ATTRIBUTES OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Flags                           | Oper|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                              ERO-path Id = 2                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type              |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |       Backup Path Count = 0   |             Flags           |1|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=TBD            |           Length=4            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Role = ingress |                 Reserved                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                           <ERO-OBJECT>
                         <SR-ERO-SUB OBJECT>
      |L|   Type=36   |     Length    |  NT= 1|     Flags   |0|0|1|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                ipv4-address  = NHD2           |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |L|   Type=36   |     Length    |  NT= 0|     Flags   |0|1|0|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         SID = d2                              |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
¶
The following packet examples shows the Replication Segment initiation via a PCE on transit nodes and/or leaves node.¶
Note:¶
This packet is generated from PCE to instantiate the Replication segment, as such the PLSP-ID is set to zero. PCC will assign these value and report them back to PCE.¶
The Instance-ID was assigned by the PCE for the entire PTI path on the root, transit and leaves (P2MP tree)¶
This is a Replication Segment instantiation as such there is no association object.¶
The LSP Object Root A and Tree-ID Y associates this Replication Segment to the corresponding CP and PTI on the root node.¶
there is no association object present in the packet.¶
       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
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                          Flags = 0                            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                        SRP-ID-number  = 1                     |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |  TLV Type = 28 (PathSetupType)| TLV Len = 4                   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                             | PST = TBD       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                             <LSP OBJECT>
      |                PLSP-ID = 0            |     A:1,D:1,N:1,C:0   |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=17             |           Length=<var>        |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                            symbolic path name                 |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type=TBD          |  Length                       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                   Root =A                                     |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                  Tree-ID = Y                                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                        Instance-ID = L1                       |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                            <CCI OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                            CC-ID = X                          |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |          Reserved1            |             Flags         |0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                 Label = d1            |     Reserved2         |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                       <PATH-ATTRIBUTES OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Flags                           | Oper|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                              ERO-path Id = 1                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type              |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |       Backup Path Count = 1   |             Flags           |0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Backup Path ID 2                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=TBD            |           Length=4            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Role           |                 Reserved                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                           <ERO-OBJECT>
                         <SR-ERO-SUB OBJECT>
      |L|   Type=36   |     Length    |  NT= 1|     Flags   |0|0|1|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                ipv4-address  = NHE1           |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |L|   Type=36   |     Length    |  NT= 0|     Flags   |0|1|0|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         SID = e1                            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                       <PATH-ATTRIBUTES OBJECT>
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         Flags                           | Oper|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                              ERO-path Id = 2                  |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |             Type              |             Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |       Backup Path Count = 0   |             Flags           |1|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |           Type=TBD            |           Length=4            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |Role           |                 Reserved                      |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                           <ERO-OBJECT>
                         <SR-ERO-SUB OBJECT>
      |L|   Type=36   |     Length    |  NT= 1|     Flags   |0|0|1|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                ipv4-address  = NHE2           |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |L|   Type=36   |     Length    |  NT= 0|     Flags   |0|1|0|0|0|
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                         SID = e2                              |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
¶
                +-------+                             +-------+
                  |PCC    |                             |  PCE  |
                  |Root   |                             +-------+
           +------|       |                                 |
           | PCC  +-------+                                 |
           | Transit| |                                     |
    +------|        | |---PCRpt,PLSP-ID=1,SRP-ID=1--------->| PCECC LSP
    |PCC   +--------+ |   N=1,root-addr,Tree-ID=a,          | SR-Policy
    |        |  |     |   Instance-ID =0,                   | Report to
    |Leaf    |  |     |   P2MP-end-points(LeafType=5)(optnl)| PCE
    +--------+  |     |   association-obj                   |
        |       |     |                                     |
        |       |     |<--PCUpdate,PLSP-ID=1, SRP-ID =1,    | Update
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| CP
        |       |     |   P2MP-end-points, association-obj  |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1, SRP-ID = 1,->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      association-object             |
        |       |     |                                     |
        |<---------------PcInitiate,PLSP-ID=0, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Leaf
        |       |     |  CC-ID=Z,C=0,                       | Replication
        |       |     |  O=0,L=z,path-attribute,ERO,SR-ERO  | Segment(RS)
        |       |     |                                     |
        |---------------------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Z,Label=z,O=0,          |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |<-------PcInitiate,PLSP-ID=0, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Transit
        |       |     |  CC-ID=Y,C=0,                       | RS
        |       |     |  O=0,L=y,path-attribute,ERO,SR-ERO  |
        |       |     |                                     |
        |       |-------------PCRpt,PLSP-ID=2-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Y,Label=y,O=0,          |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |     |<--PcInitiate,PLSP-ID=1,             | Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Root
        |       |     |   CC-ID=X,C=0,                      | RS
        |       |     | O=0,L=x,P2MP-end-                   |
        |       |     |   points(LeafType=5),path-attribute,|
        |       |     |   ERO,SR-ERO                        |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |    CC-ID=X,Label=x,O=0,             |
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      path-attriute,ERO,SR-ERO       |
        |       |     |                                     |
        |       |     |<--PCUpdate,PLSP-ID=1, SRP-ID =2,    |
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Activate
        |       |     |   P2MP-end-points                   | CP to last
        |       |     |                                     | RS
        |       |     |-------PCRpt,PLSP-ID=1, SRP-ID =2, ->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |                                     |
¶
Note that on transit / leaf Initiate is with PLSP-ID = 0. Therefore PLSP-ID is locally unique to a node. It should be noted that the CC-ID does not need to be constant across all nodes that make up the path.¶
PCE-Initiated workflow¶
                 +-------+                             +-------+
                  |PCC    |                             |  PCE  |
                  |Root   |                             +-------+
           +------|       |                                 |
           | PCC  +-------+                                 |
           | Transit| |                                     |
    +------|        | |                                     | PCECC LSP
    |PCC   +--------+ |                                     |
    |        |  |     |                                     |
    |Leaf    |  |     |                                     |
    +--------+  |     |                                     |
        |       |     |<--PcInitiate,PLSP-ID=0,             | Initiate
        |       |     |   root-addr,Tree-ID=0,Instance-ID=b,| CP
        |       |     |   P2MP-end-points, association-obj  |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1,------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      association-object,            |
        |       |     |                                     |
        |       |     |<--PCUpdt,PLSP-ID=1,                 | Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Root RS
        |       |     |   CC-ID=X,C=0,                      |
        |       |     | O=0,L=x,P2MP-end-                   |
        |       |     |   points(LeafType=5),path-attribute,|
        |       |     |   ERO,SR-ERO                        |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |    CC-ID=X,Label=x,O=0,             |
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      path-attriute,ERO,SR-ERO       |
        |       |     |                                     |
        |<---------------PcInitiate,PLSP-ID=0, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Leaf RS
        |       |     |  CC-ID=Z,C=0,                       |
        |       |     |  O=0,L=z,path-attribute,ERO,SR-ERO  |
        |       |     |                                     |
        |---------------------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Z,Label=z,O=0,          |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |<-------PcInitiate,PLSP-ID=0, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Transit RS
        |       |     |  CC-ID=Y,C=0,                       |
        |       |     |  O=0,L=y,path-attribute,ERO,SR-ERO  |
        |       |     |                                     |
        |       |-------------PCRpt,PLSP-ID=2-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=c,|
        |       |     |       CC-ID=Y,Label=y,O=0,          |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |<-------PcInitiate,PLSP-ID=0, -------------|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |  CC-ID=Y,C=0,                       |
        |       |     |  O=0,L=y,path-attribute,ERO,SR-ERO  |
        |       |     |                                     |
        |       |-------------PCRpt,PLSP-ID=2-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Y,Label=y,O=0,          |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |     |<--PCUpdate,PLSP-ID=1, SRP-ID =1,    | Bind and
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Activate
        |       |     |   P2MP-end-points,                  | CP to last
        |       |     |                                     | RS
        |       |     |-------PCRpt,PLSP-ID=1, SRP-ID = 1,->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |      P2MP-end-points(LeafType=5)    |
¶
MBB Workflow:¶
Common (PCE-INIT, PCC-INIT) MBB
                 +-------+                             +-------+
                  |PCC    |                             |  PCE  |
                  |Root   |                             +-------+
           +------|       |                                 |
           | PCC  +-------+                                 |
           | Transit| |                                     |
    +------|        | |                                     | PCECC LSP
    |PCC   +--------+ |                                     |
    |        |  |     |                                     |
    |Leaf    |  |     |                                     |
    +--------+  |     |                                     |
        |<---------------PcInitiate,PLSP-ID=1, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| new RS on
        |       |     |  CC-ID=Z1,C=0,                      | Leaf
        |       |     |  O=0,L=z1,path-attribute,ERO,SR-ERO |
        |       |     |                                     |
        |---------------------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Z1,Label=z1,O=0,        |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |<-------PcInitiate,PLSP-ID=2, -------------| Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| new RS on
        |       |     |  CC-ID=Y1,C=0,                      | Transit
        |       |     |  O=0,L=y1,path-attribute,ERO,SR-ERO |
        |       |     |                                     |
        |       |-------------PCRpt,PLSP-ID=2-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Y1,Label=y1,O=0,        |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |       |     |<--PcInitiate,PLSP-ID=1,             | Download
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| new RS on
        |       |     |   CC-ID=X1,C=0,                     | Root
        |       |     | O=0,L=x1,P2MP-end-                  |
        |       |     |   points(LeafType=5),path-attribute,|
        |       |     |   ERO,SR-ERO                        |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1-------------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |    CC-ID=X1,Label=x1,O=0,           |
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      path-attriute,ERO,SR-ERO       |
        |       |     |                                     |
        |       |     |<--PCUpdate,PLSP-ID=1, SRP-ID =1,    | Bind and
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| Activate
,       |       |     |   P2MP-end-points,                  | CP to last
        |       |     |                                     | RS
        |       |     |-------PCRpt,PLSP-ID=1, SRP-ID = 1,->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |                                     |
        |       |     |<--PcInitiate,PLSP-ID=1,R=1          | Remove
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| the old RS
        |       |     |   CC-ID=X1,C=0                      | from Leaf
        |       |     | O=0,L=x1,P2MP-end-                  |
        |       |     |   points(LeafType=5),path-attribute,|
        |       |     |   ERO,SR-ERO                        |
        |       |     |                                     |
        |       |     |-------PCRpt,PLSP-ID=1, R=1--------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |    CC-ID=X1,Label=x1,O=0,           |
        |       |     |      P2MP-end-points(LeafType=5)    |
        |       |     |      path-attriute,ERO,SR-ERO       |
        |       |     |                                     |
        |       |<-------PcInitiate,PLSP-ID=2, R=1----------| Remove the
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| old RS from
        |       |     |  CC-ID=Y1,C=0,                      | Transit
        |       |     |  O=0,L=y1,path-attribute,ERO,SR-ERO |
        |       |     |                                     |
        |       |-------------PCRpt,PLSP-ID=2, R=1--------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Y1,Label=y1,O=0,        |
        |       |     |      path-attribute,ERO,SR-ERO      |
        |       |     |                                     |
        |<---------------PcInitiate,PLSP-ID=1,R=1-----------| Remove the
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,| old RS from
        |       |     |  CC-ID=Z1,C=0,                      | Root
        |       |     |  O=0,L=z1,path-attribute,ERO,SR-ERO |
        |       |     |                                     |
        |---------------------PCRpt,PLSP-ID=1,R=1---------->|
        |       |     |   root-addr,Tree-ID=a,Instance-ID=b,|
        |       |     |       CC-ID=Z1,Label=z1,O=0,        |
        |       |     |      path-attribute,ERO,SR-ERO      |
¶