PCE Working Group | Q. Zhao |
Internet-Draft | Z. Li |
Intended status: Experimental | D. Dhody |
Expires: September 17, 2016 | Huawei Technologies |
C. Zhou | |
Cisco Systems | |
March 16, 2016 |
PCEP Procedures and Protocol Extensions for Using PCE as a Central Controller (PCECC) of LSPs
draft-zhao-pce-pcep-extension-for-pce-controller-03
In certain networks deployment scenarios, service providers would like to keep all the existing MPLS functionalities in both MPLS and GMPLS while removing the complexity of existing signalling protocols such as LDP and RSVP-TE. In [I-D.zhao-pce-central-controller-user-cases], we propose to use the PCE [RFC5440] as a central controller (PCECC) so that LSP can be calculated/ signalled/initiated and label forwarding entries are downloaded through a centralized PCE server to each network devices along the LSP path while leveraging the existing PCE technologies as much as possible.
This draft specify the procedures and PCEP protocol extensions for using the PCE as the central controller and user cases where LSPs are calculated/setup/initiated and label forwarding entries are downloaded through extending the existing PCE architectures and PCEP.
This document also discuss the role of PCECC in Segment Routing (SR).
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 http://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 September 17, 2016.
Copyright (c) 2016 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 (http://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 Simplified BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Simplified BSD License.
In certain network deployment scenarios, service providers would like to have the ability to dynamically adapt to a wide range of customer's requests for the sake of flexible network service delivery, Software Defined Networks(SDN) has provides additional flexibility in how the network is operated compared to the traditional network.
The existing networking ecosystem has become awfully complex and highly demanding in terms of robustness, performance, scalability, flexibility, agility, etc. By migrating to the SDN enabled network from the existing network, service providers and network operators must have a solution which they can evolve easily from the existing network into the SDN enabled network while keeping the network services remain scalable, guarantee robustness and availability etc.
Taking the smooth transition between traditional network and the new SDN enabled network into account, especially from a cost impact assessment perspective, using the existing PCE components from the current network to function as the central controller of the SDN network is one choice, which not only achieves the goal of having a centralized controller, but also leverage the existing PCE network components.
The Path Computation Element communication Protocol (PCEP) provides mechanisms for Path Computation Elements (PCEs) to perform route computations in response to Path Computation Clients (PCCs) requests. PCEP Extensions for PCE-initiated LSP Setup in a Stateful PCE Model [I-D.ietf-pce-stateful-pce] describes a set of extensions to PCEP to enable active control of MPLS-TE and GMPLS tunnels.
[I-D.ietf-pce-pce-initiated-lsp] describes the setup and tear down of PCE-initiated LSPs under the active stateful PCE model, without the need for local configuration on the PCC, thus allowing for a dynamic MPLS network that is centrally controlled and deployed.
[I-D.ietf-pce-remote-initiated-gmpls-lsp] complements [I-D.ietf-pce-pce-initiated-lsp] by addressing the requirements for remote-initiated GMPLS LSPs.
Segment Routing (SR) technology leverage the source routing and tunnelling paradigms. A source node can choose a path without relying on hop-by-hop signalling protocols such as LDP or RSVP-TE. Each path is specified as a set of "segments" advertised by link-state routing protocols (IS-IS or OSPF). [I-D.ietf-spring-segment-routing] provides an introduction to SR technology. The corresponding IS-IS and OSPF extensions are specified in [I-D.ietf-isis-segment-routing-extensions] and [I-D.ietf-ospf-segment-routing-extensions], respectively.
A Segment Routed path (SR path) can be derived from an IGP Shortest Path Tree (SPT). Segment Routed Traffic Engineering paths (SR-TE paths) may not follow IGP SPT. Such paths may be chosen by a suitable network planning tool and provisioned on the source node of the SR-TE path.
It is possible to use a stateful PCE for computing one or more SR-TE paths taking into account various constraints and objective functions. Once a path is chosen, the stateful PCE can instantiate an SR-TE path on a PCC using PCEP extensions specified in [I-D.ietf-pce-pce-initiated-lsp] using the SR specific PCEP extensions described in [I-D.ietf-pce-segment-routing].
PCECC may further use PCEP protocol for SR label distribution instead of IGP extensions with some benefits.
Current MPLS label has local meaning. That is, MPLS label is always allocated by the downstream node to the upstream node. Then the MPLS label is only identified by the neighbouring upstream node and downstream node. The label allocation is done locally and signalled through the LDP/RSVP-TE/BGP protocol. To ease the label allocation and signalling mechanism, PCE can be conveniently used as a central controller with Label download capability. Further PCE can also be used to manage the label range and Segment Routing Global Block (SRGB) etc.
The PCECC solution introduced in [I-D.zhao-pce-central-controller-user-cases] allow for a dynamic MPLS network that is eventually controlled and deployed without the deployment of RSVP-TE protocol or extended IGP protocol with node/adjacency segment identifiers signalling capability while providing all the key MPLS functionalities needed by the service providers.
This draft specify the procedures and PCEP protocol extensions for using the PCE as the central controller and user cases where LSPs are calculated/setup/initiated/downloaded through extending the existing PCE architectures and PCEP.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC2119].
The following terminology is used in this document.
The following PCECC modes are supported -
In basic PCECC mode, the forwarding is similar to RSVP-TE signalled LSP without the RSVP-TE signalling. The PCECC allocates and download the label entries along the LSP. The rest of processing is similar to the existing stateful PCE mechanism.
In case of SR, there are two modes for SR-BE and SR-TE. For SR-BE, the forwarding is similar to LDP LSP without LDP signalling or IGP-SR extension. The SR Node label are allocated and distributed in the domain centrally by the PCE via PCEP. Each node (PCC) relies on local IGP for the nexthop calculation. For SR-TE, the forwarding uses label stack similar to IGP based SR-TE without IGP-SR extension. The SR node and adjacency labels are allocated and distributed in the domain centrally by the PCE via PCEP by PCECC. Rest of the processing is similar to existing stateful PCE with SR mechanism.
Following key requirements associated PCECC should be considered when designing the PCECC based solution:
Active stateful PCE is described in [I-D.ietf-pce-stateful-pce]. PCE as a central controller (PCECC) reuses existing Active stateful PCE mechanism as much as possible to control the LSP.
This document defines the following new PCEP messages and extends the existing messages to support PCECC:
The new LSP functions defined in this document are mapped onto the messages as shown in the following table.
+----------------------------------------+--------------------------+ | Function | Message | +----------------------------------------+--------------------------+ | PCECC Capability advertisement | Open | | Label entry Update | PCLabelUpd/PCInitiate | | Label entry Cleanup | PCLabelUpd/PCInitiate | | PCECC Initiated LSP | PCInitiate | | PCECC LSP Update | PCUpd | | PCECC LSP State Report | PCRpt | | PCECC LSP Delegation | PCRpt | +----------------------------------------+--------------------------+
During PCEP Initialization Phase, PCEP Speakers (PCE or PCC) advertise their support of PCECC extensions. A PCEP Speaker includes the "PCECC Capability" TLV, described in Section 7.1.1 of this document, in the OPEN Object to advertise its support for PCECC extensions.
The presence of the PCECC Capability TLV in PCC's OPEN Object indicates that the PCC is willing to function as a PCECC client.
The presence of the PCECC Capability TLV in PCE's OPEN message indicates that the PCE is interested in function as a PCECC server.
The PCEP protocol extensions for PCECC MUST NOT be used if one or both PCEP Speakers have not included the PCECC Capability TLV in their respective OPEN message. If the PCEP Speakers support the extensions of this draft but did not advertise this capability then a PCErr message with Error-Type=19(Invalid Operation) and Error-Value=[TBD] (Attempted LSP setup/download/label-range reservation if PCECC capability was not advertised) will be generated and the PCEP session will be terminated.
A PCC or a PCE MUST include both PCECC-CAPABILITY TLV and STATEFUL-PCE-CAPABILITY TLV ([I-D.ietf-pce-stateful-pce]) in OPEN Object to support the extensions defined in this document. If PCECC-CAPABILITY TLV is advertised and STATEFUL-PCE-CAPABILITY TLV is not advertised in OPEN Object, it SHOULD send a PCErr message with Error-Type=19 (Invalid Operation) and Error-value=[TBD](stateful PCE capability was not advertised) and terminate the session.
PCECC-CAPABILITY TLV includes a S-bit to indicate support for PCECC-SR. A PCEP speaker MUST set S-bit in PCECC-CAPABILITY TLV and include SR-PCE-CAPABILITY TLV ([I-D.ietf-pce-segment-routing]) in OPEN Object to support the PCECC SR-TE extensions defined in this document. If S-bit is set in PCECC-CAPABILITY TLV and SR-PCE-CAPABILITY TLV is not advertised in OPEN Object, PCEP speaker SHOULD send a PCErr message with Error-Type=19 (Invalid Operation) and Error-value=[TBD](SR capability was not advertised) and terminate the session.
PCE may construct its TEDB by participating in the IGP ([RFC3630] and [RFC5305] for MPLS-TE; [RFC4203] and [RFC5307] for GMPLS). An alternative is offered by BGP-LS [I-D.ietf-idr-ls-distribution] and [I-D.dhodylee-pce-pcep-ls].
PCEP [RFC5440] speaker MAY use any IP address while creating a TCP session. It is important to link the session IP address with the Router ID in TEDB for successful PCECC operations.
During PCEP Initialization Phase, PCC SHOULD advertise the TE mapping information. Thus a PCC includes the "Node Attributes TLV" [I-D.dhodylee-pce-pcep-ls] with "IPv4/IPv6 Router-ID of Local Node", in the OPEN Object for this purpose. [I-D.ietf-idr-ls-distribution] 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 are used to encode them.
If "IPv4/IPv6 Router-ID" TLV is not present, the TCP session IP address is directly used for the mapping purpose.
The PCEP messages pertaining to PCECC MUST include PATH-SETUP-TYPE TLV [I-D.ietf-pce-lsp-setup-type] in the SRP object to clearly identify the PCECC LSP is intended.
In order to setup a LSP based on PCECC mechanism, a PCC MUST delegate the LSP by sending a PCRpt message with Path Setup Type set for basic PCECC (see Section 7.2) and D (Delegate) flag (see [I-D.ietf-pce-stateful-pce]) set in the LSP object.
LSP-IDENTIFIER TLV MAY be included for PCECC LSP, the LSP-ID SHOULD be generated by the PCE for PCECC LSP. In the first PCRpt message of PCECC LSP, LSP ID of LSP-IDENTIFIER TLV is set to zero.
When a PCE receives PCRpt message with P and D flags set, it MAY generates LSP ID; calculates the path and assigns labels along the path; and setups the path by sending PCLabelUpd or PCInitiate message to each node along the path of the LSP.
In response to the delegate PCRpt message, the PCE SHOULD send the PCUpd message with the same PLSP-ID to the Ingress PCC.
The PCECC LSPs MUST be delegated to a PCE at all times.
LSP deletion operation for PCECC LSP is same as defined in [I-D.ietf-pce-stateful-pce]. If the PCE receives PCRpt message for LSP deletion then it does Label cleanup operation as described in Section 5.5.1.2.1.2 for the corresponding LSP.
The Basic PCECC LSP setup sequence is as shown below using a new message PCLabelUpd.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | |--- PCRpt,PLSP-ID=1, P=1, D=1 --->| PCECC LSP |PCC +--------+ | (LSP ID=0) |(LSPID=1) |Egress | | | | +--------+ | | | | | | | |<------ PCLabelUpd,PLSP-ID=1 ------------------ | Label | | | (LSP ID=1) | download | | | | | |<----- PCLabelUpd,PLSP-ID=1 ----------- | Label | | | (LSP ID=1) | download | | | | | | |<--- PCLabelUpd,PLSP-ID=1 ------- | Label | | | (LSP ID=1) | download | | | | | | |<-- PCUpd,PLSP-ID=1, P=1, D=1 ---- | PCECC LSP | | | (LSP ID=1) | Update | | | |
Figure 2: Using PCLabelUpd For Label Operations
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | |--- PCRpt,PLSP-ID=1, P=1, D=1 --->| PCECC LSP |PCC +--------+ | (LSP ID=0) |(LSPID=1) |Egress | | | | +--------+ | | | | | | | |<------ PCInitiate,PLSP-ID=1 ------------------ | Label | | | (LSP ID=1) | download |------- PCRpt ---------------------------------->| | | | | | |<----- PCInitiate,PLSP-ID=1 ----------- | Label | | | (LSP ID=1) | download | |----- -PCRpt---------------------------->| | | | | | | |<--- PCInitiate,PLSP-ID=1 ------- | Label | | | (LSP ID=1) | download | | |-----PCRpt------------------------>| | | | | | | |<-- PCUpd,PLSP-ID=1, P=1, D=1 ---- | PCECC LSP | | | (LSP ID=1) | Update | | | | Some open issue - * PCC send PCRpt messages for each PCInitiate message? * Should one use PCInitiate at Ingress too? How to link this with existing tunnel at the PCC?
Figure 3: Using PCInitiate For Label Operations
The PCECC LSP are considered to be 'up' by default. The Ingress MAY further choose to deploy a data plane check mechanism and report the status back to the PCE via PCRpt message.
The new label operations in PCEP can be done via a new message and by defining new PCEP Objects for Label operations and FEC.
In order to setup an LSP based on PCECC, the PCE sends a PCLabelUpd message to each node of the LSP to download the Label entry as described in Section 5.5.1.1.
The LSP object in PCLabelUpd MUST include the LSP-IDENTIFIER TLV.
If a node (PCC) receives a PCLabelUpd message but failed to download the Label entry, it MUST send a PCErr message with Error-type=[TBD] (label download failed) and Error-value=[TBD].
Two new PCEP objects for LABEL and FEC are defined in Section 7.3 and Section 7.4 to encode the Label operations and its associated FEC.
In order to delete an LSP based on PCECC, the PCE sends a PCLabelUpd message to each node along the path of the LSP to cleanup the Label entry.
If the PCC receives a PCLabelUpd message but does not recognize the label, the PCC MUST generate a PCErr message with Error-Type 19(Invalid operation) and Error-Value=3, "Unknown Label".
The R flag in SRP object defined in [I-D.ietf-pce-pce-initiated-lsp] specifies the deletion of Label Entry in the new PCLabelUpd message.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | |--- PCRpt,PLSP-ID=1,P=1,D=1,R=1--->| PCECC LSP |PCC +--------+ | (LSP ID=1) | remove |Egress | | | | +--------+ | | | | | | | |<------ PCLabelUpd, PLSP-ID=1 ------------------ | Label | | | (LSP ID=1, R=1) | cleanup | | | | | |<----- PCLabelUpd, PLSP-ID=1 ----------- | Label | | | (LSP ID=1, R=1) | cleanup | | | | | | |<--- PCLabelUpd, PLSP-ID=1 ------- | Label | | | (LSP ID=1, R=1) | cleanup | | | |
The new label operations in PCEP can be done via existing PCInitiate message and by reusing PCEP Objects (and subobjects) to encode Label operations and FEC. A TE LSP can be envisioned as a series of "cross-connects" and ERO in the PCInitiate message can be used to indicate each such cross-connect along the path. The use of PCInitiate message would also require each node to send the PCRpt message. The handling of PLSP-ID, LSP Identifiers, Symbolic path name would need to be taken into consideration.
The PATH-SETUP-TYPE TLV [I-D.ietf-pce-lsp-setup-type] in the SRP object can identify the PCECC LSP.
In order to setup an LSP based on PCECC, the PCE sends a PCInitiate message to each node of the LSP to download the Label entry as described in Section 5.5.1.1 represented as a "cross-connect".
If a node (PCC) receives a PCInitiate message with setup type indicated as PCECC, it should not try to initiate a complete tunnel. The error-handling and other processing would remain unchanged.
The ERO in the PCInitiate message would indicate the cross-connect as {input interface, input label, output interface, output label}. For Egress only input interface/label would be present and for Ingress only output interface/label. For Ingress either PCInitiate is used or the same information can be put in PCUpd message as well.
In order to delete an LSP based on PCECC, one can use existing PCInitiate message (with R flag) to each node along the path of the LSP to cleanup the Label entry. The R flag in SRP object defined in [I-D.ietf-pce-pce-initiated-lsp] is used during cleanup.
The error-handling and other processing would remain unchanged.
The LSP Instantiation operation is same as defined in [I-D.ietf-pce-pce-initiated-lsp].
In order to setup a PCE Initiated LSP based on PCECC mechanism, a PCE sends PCInitiate message with Path Setup Type set for basic PCECC (see Section 7.2) to the Ingress PCC.
The Ingress PCC MUST also set D (Delegate) flag (see [I-D.ietf-pce-stateful-pce]) and C (Create) flag (see [I-D.ietf-pce-pce-initiated-lsp]) in LSP object of PCRpt message. The PCC responds with first PCRpt message with the status as "GOING-UP" and assigned PLSP-ID.
The rest of the PCECC LSP setup operations are same as those described in Section 5.5.1.1.
The LSP deletion operation for PCE Initiated PCECC LSP is same as defined in [I-D.ietf-pce-pce-initiated-lsp]. The PCE should further perform Label entry cleanup operation as described in Section 5.5.1.2.1.2 for the corresponding LSP.
The PCE Initiated PCECC LSP setup sequence is shown below using a new PCLabelUpd message.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | |<---PCInitiate,PLSP-ID=0,P=1,D=1---| PCECC LSP |PCC +--------+ | | Initiate |Egress | | |--- PCRpt,PLSP-ID=2,P=1,D=1,C=1--->| PCECC LSP +--------+ | | (LSP ID=0,GOING-UP) |(LSPID=2 | | | | assigned) |<------ PCLabelUpd, PLSP-ID=2 ------------------ | Label | | | (LSP ID=2) | download | | | | | |<----- PCLabelUpd, PLSP-ID=2 ----------- | Label | | | (LSP ID=2) | download | | | | | | |<--- PCLabelUpd, PLSP-ID=2 ------- | Label | | | (LSP ID=2) | download | | | | | | |<-- PCUpd, PLSP-ID=2, P=1, D=1---- | PCECC LSP | | | (LSP ID=2) | Update | | | |
The PCE Initiated PCECC LSP setup sequence is shown below using existing PCInitiate message.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | |<---PCInitiate,PLSP-ID=0,P=1,D=1---| PCECC LSP |PCC +--------+ | | Initiate |Egress | | |--- PCRpt,PLSP-ID=2,P=1,D=1,C=1--->| PCECC LSP +--------+ | | (LSP ID=0,GOING-UP) |(LSPID=2 | | | | assigned) |<------ PCInitiate, PLSP-ID=2 ------------------ | Label | | | (LSP ID=2) | download |------- PCRpt ---------------------------------->| | | | | | |<----- PCInitiate, PLSP-ID=2 ----------- | Label | | | (LSP ID=2) | download | |----- -PCRpt---------------------------->| | | | | | | |<--- PCInitiate, PLSP-ID=2 ------- | Label | | | (LSP ID=2) | download | | |-----PCRpt------------------------>| | | | | | | |<-- PCUpd, PLSP-ID=2, P=1, D=1---- | PCECC LSP | | | (LSP ID=2) | Update | | | | Some open issue - * PCC send PCRpt messages for each PCInitiate message? * How to link 2 PCInitiate message at Ingress one to initiate the full tunnel, and one to download the cross-connect (label)?
Incase of a modification of PCECC LSP with a new path, a PCE sends a PCUpd message to the Ingress PCC.
When a PCC receives a PCUpd message for an existing LSP, a PCC MAY follow the make-before-break procedure i.e. first download labels for the updated LSP and then switch traffic, before cleaning up the old labels. On successful traffic switch over to the new LSP, PCC sends a PCRpt message to the PCE for the deletion of old LSP. Further the PCE does cleanup operation for the old LSP as described in Section 5.5.1.2.1.2.
The PCECC LSP Update and make-before-break sequence is shown below using a new PCLabelUpd message.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | | | |PCC +--------+ | | |Egress | | | | +--------+ | | | | | | | Modify LSP |<------ PCLabelUpd, PLSP-ID=1 ------------------ | (LSPID=3 | | | (LSP ID=3) | assigned) | | | | | |<----- PCLabelUpd, PLSP-ID=1 ----------- | Label | | | (LSP ID=3) | download | | | | | | |<--- PCLabelUpd, PLSP-ID=1 ------- | Label | | | (LSP ID=3) | download | | | | | | |<-- PCUpd, PLSP-ID=1, P=1, D=1---- | PCECC | | | (LSP ID=3) | LSP Update | | | | | | |--- PCRpt,PLSP-ID=1,P=1,D=1,R=1--->| Delete | | | (LSP ID=1) | old LSP | | | | |<------ PCLabelUpd, PLSP-ID=1 ------------------ | Label | | | (LSP ID=1, R=1) | cleanup | | | | | |<----- PCLabelUpd, PLSP-ID=1 ----------- | Label | | | (LSP ID=1, R=1) | cleanup | | | | | | |<--- PCLabelUpd, PLSP-ID=1 ------- | Label | | | (LSP ID=1, R=1) | cleanup
The PCECC LSP Update and make-before-break sequence is shown below using existing PCInitiate message.
+-------+ +-------+ |PCC | | PCE | |Ingress| +-------+ +------| | | | PCC +-------+ | | Transit| | | +------| | | | |PCC +--------+ | | |Egress | | | | +--------+ | | | | | | | Modify LSP |<------ PCInitiate, PLSP-ID=1 ------------------ | (LSPID=3 | | | (LSP ID=3) | assigned) |------- PCRpt ---------------------------------->| | | | | | |<----- PCInitiate, PLSP-ID=1 ----------- | Label | | | (LSP ID=3) | download | |----- -PCRpt---------------------------->| | | | | | | |<--- PCInitiate, PLSP-ID=1 ------- | Label | | | (LSP ID=3) | download | | |-----PCRpt------------------------>| | | | | | | |<-- PCUpd, PLSP-ID=1, P=1, D=1---- | PCECC | | | (LSP ID=3) | LSP Update | | | | | | |--- PCRpt,PLSP-ID=1,P=1,D=1,R=1--->| Delete | | | (LSP ID=1) | old LSP | | | | |<------ PCInitiate, PLSP-ID=1 ------------------ | Label | | | (LSP ID=1, R=1) | cleanup |------- PCRpt ---------------------------------->| | | | | | |<----- PCInitiate, PLSP-ID=1 ----------- | Label | | | (LSP ID=1, R=1) | cleanup | |----- -PCRpt---------------------------->| | | | | | | |<--- PCInitiate, PLSP-ID=1 ------- | Label | | | (LSP ID=1, R=1) | cleanup | | |-----PCRpt------------------------>|
The modified PCECC LSP are considered to be 'up' by default. The Ingress MAY further choose to deploy a data plane check mechanism and report the status back to the PCE via PCRpt message.
As mentioned before, an Ingress PCC MAY choose to apply any OAM mechanism to check the status of LSP in the Data plane and MAY further send its status in PCRpt message to the PCE.
Segment Routing (SR) as described in [I-D.ietf-spring-segment-routing] depends on "segments" that are advertised by Interior Gateway Protocols (IGPs). The SR-node allocates and advertises the SID (node, adj etc) and flood via the IGP. This document proposes a new mechanism where PCE allocates the SID (label) centrally and uses PCEP to advertise the SID. In some deployments PCE (and PCEP) are better suited than IGP because of centralized nature of PCE and direct TCP based PCEP session to the node.
PCECC SR capability (S-bit) MUST be advertised in Open message.
[EDITOR NOTE: Currently only the use of a new message PCLabelUpd is discussed in this section, the editors feel that use of existing PCInitiate message for SR node and adjacency label would be problematic.]
Each node (PCC) is allocated a node-SID (label) by the PCECC. The PCECC sends PCLabelUpd to update the label map of each node to all the nodes in the domain. The TE router ID is determined from the TEDB or from "IPv4/IPv6 Router-ID" Sub-TLV [I-D.dhodylee-pce-pcep-ls], in the OPEN Object Section 5.4.
It is RECOMMENDED that PCEP session with PCECC SR capability to 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-BE node label maps (Section 5.4).
On receiving the label map, each node (PCC) uses the local information to determine the next-hop and download the label forwarding instructions accordingly. The PCLabelUpd message in this case MUST NOT have LSP object but use the new FEC object.
+-------+ +-------+ |PCC | | PCE | |3.3.3.3| +-------+ +------| | | | PCC +-------+ | | 2.2.2.2| | | +------| | | | |PCC +--------+ | | |1.1.1.1 | | | | +--------+ | | | | | | | |<------ PCLabelUpd, FEC=1.1.1.1----------------- | Label Map | | | Label=X | update |Find | | | |Nexthop|<----- PCLabelUpd, FEC=1.1.1.1---------- | Label Map |locally| | Label=X | update | | | | | | |<--- PCLabelUpd, FEC=1.1.1.1------ | Label Map | | | Label=X | update | | | |
The forwarding behaviour and the end result is 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.
PCE relies on the Node label cleanup using the same PCLabelUpd message.
A Segment Routed Best Effort path (SR-BE path) can be derived from an IGP Shortest Path Tree (SPT) as explained above. On the other hand, SR-TE paths may not follow IGP SPT. Such paths may be chosen by a PCE and provisioned on the source node of the SR-TE path.
[I-D.ietf-pce-segment-routing] extends PCEP 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.
For SR-TE, apart from node-SID, Adj-SID is used where each adjacency is allocated an Adj-SID (label) by the PCECC. The PCECC sends PCLabelUpd to update the label map of each Adj to the corresponding nodes in the domain. Each node (PCC) download the label forwarding instructions accordingly. Similar to SR-BE, the PCLabelUpd message in this case MUST NOT have LSP object but use the new FEC object.
+-------+ +-------+ |PCC | | PCE | |3.3.3.3| +-------+ +------| | | | PCC +-------+ | | 2.2.2.2| | | +------| | | | |PCC +--------+ | | |1.1.1.1 | | | | +--------+ | | | | | | | |<------ PCLabelUpd, FEC=10.1.1.1 / ------------- | Label Map | | | 10.1.1.2 | update | | | Label=A | | | | | | |<----- PCLabelUpd, FEC=10.1.1.2--------- | Label Map | | | 10.1.1.1 | update | | | Label=B | | | | |
The forwarding behavior and the end result is similar to IGP based "Adj-SID" in SR.
The Path Setup Type for segment routing MUST be set for PCECC SR-TE (see Section 7.2). All PCEP procedures and mechanism are similar to [I-D.ietf-pce-segment-routing].
PCE relies on the Adj label cleanup using the same PCLabelUpd message.
As defined in [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.
LSP-IDENTIFIERS TLV MAY be included in the LSP object for PCECC LSP.
A new Label Update Message (also referred to as PCLabelUpd) is a PCEP message sent by a PCE to a PCC to download label or update the label map. The same message is also used to cleanup the Label entry. The Message-Type field of the PCEP common header for the PCLabelUpd message is set to [TBD].
The format of the PCLabelUpd message is as follows:
<PCLabelUpd Message> ::= <Common Header> <pce-label-update-list> Where: <pce-label-update-list> ::= <pce-label-update> [<pce-label-update-list>] <pce-label-update> ::= (<pce-label-download>|<pce-label-map>) Where: <pce-label-download> ::= <SRP> <LSP> <label-list> <pce-label-map> ::= <SRP> <LABEL> <FEC> <label-list > ::= <LABEL> [<label-list>]
The PCLabelUpd message is used to download label along the path of the LSP for the basic PCECC mode, as well as to update the label map for the Node and Adjacency Label in case of SR.
The SRP object is defined in [I-D.ietf-pce-stateful-pce] and this document extends the use of SRP object in PCLabelUpd message. The SRP object is mandatory and MUST be included in PCLabelUpd message. If the SRP object is missing, the receiving PCC MUST send a PCErr message with Error-type=6 (Mandatory Object missing) and Error-value=10 (SRP object missing).
The LSP object is defined in [I-D.ietf-pce-stateful-pce] and this document extends the use of LSP object in PCLabelUpd message. The LSP is an optional object and used in the basic PCECC mode in PCLabelUpd message. LSP Identifiers TLV is defined in [I-D.ietf-pce-stateful-pce], it MAY be included in the LSP object in PCLabelUpd message.
The LABEL object is defined in Section 7.3. The LABEL is the mandatory object and MUST be included in PCLabelUpd message. If the LABEL object is missing, the receiving PCC MUST send a PCErr message with Error-type=6 (Mandatory Object missing) and Error-value=[TBD] (LABEL object missing). More than one LABEL object MAY be included in the PCLabelUpd message for the transit LSR.
The FEC object is defined in Section 7.4. The FEC is an optional object and used in PCECC SR mode in PCLabelUpd message. The FEC object encodes the Node and Adjacency information of the Label Map.
To cleanup the SRP object must set the R (remove) bit.
Message described in [I-D.ietf-pce-pce-initiated-lsp] continue to apply.
The PCEP objects defined in this document are compliant with the PCEP object format defined in [RFC5440]. The P flag and the I flag of the PCEP objects defined in this document MUST always be set to 0 on transmission and MUST be ignored on receipt since these flags are exclusively related to path computation requests.
This document defines a new optional TLVs for use in the OPEN Object.
The PCECC-CAPABILITY TLV is an optional TLV for use in the OPEN Object for PCECC capability advertisement. Advertisement of the PCECC capability implies support of LSPs that are setup through PCECC as per PCEP extensions defined in this document.
Its format is shown in the following figure:
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 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Flags |S| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
The type of the TLV is [TBD] and it has a fixed length of 4 octets.
The value comprises a single field - Flags (32 bits):
Unassigned bits are considered reserved. They MUST be set to 0 on transmission and MUST be ignored on receipt.
The PATH-SETUP-TYPE TLV is defined in [I-D.ietf-pce-lsp-setup-type]; this document defines a new PST value:
PST = 1 (defined in [I-D.ietf-pce-segment-routing]) can be reused when Path is setup via PCECC SR-TE mode.
On a PCRpt/PCUpd/PCInitiate message, the PST=2 in PATH-SETUP-TYPE TLV in SRP object indicates that this LSP was setup via a basic PCECC based mechanism; the PST=1 indicates that this LSP was setup via a SR-TE based mechanism where either the labels are allocated by PCE via PCECC mechanism or advertised by IGP.
The LABEL Object is used to specify the Label information and MUST be carried within PCLabelUpd message.
LABEL Object-Class is TBD.
LABEL Object-Type is 1.
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 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Reserved | Flags |O| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Label | Reserved | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | // Optional TLV // | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
The fields in the LABEL object are as follows:
This document defines the following TLV for the LABEL object to associate the nexthop information incase of an outgoing label and local interface information incase of an incoming label.
IPV4-ADDRESS TLV: 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 = 8 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | IPv4 address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ IPV6-ADDRESS TLV: 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 = 20 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | // IPv6 address (16 bytes) // | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ UNNUMBERED-IPV4-ID-ADDRESS TLV: 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 = 12 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Node-ID | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Interface ID | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
The address TLVs are as follows:
The FEC Object is used to specify the FEC information and MAY be carried within PCLabelUpd message.
FEC Object-Class is TBD. 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 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
The FEC objects are as follows:
TBD
TBD.
TBD.
TBD.
TBD.
TBD.
TBD.
TBD
We would like to thank Robert Tao, Changjing Yan, Tieying Huang and Avantika for their useful comments and suggestions.
We would like to thank Adrian Farrel for presenting followup of PCECC proposal in IETF 94.
[RFC2119] | Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997. |
[RFC5440] | Vasseur, JP. and JL. Le Roux, "Path Computation Element (PCE) Communication Protocol (PCEP)", RFC 5440, DOI 10.17487/RFC5440, March 2009. |
[I-D.ietf-pce-stateful-pce] | Crabbe, E., Minei, I., Medved, J. and R. Varga, "PCEP Extensions for Stateful PCE", Internet-Draft draft-ietf-pce-stateful-pce-13, December 2015. |
[I-D.ietf-pce-pce-initiated-lsp] | Crabbe, E., Minei, I., Sivabalan, S. and R. Varga, "PCEP Extensions for PCE-initiated LSP Setup in a Stateful PCE Model", Internet-Draft draft-ietf-pce-pce-initiated-lsp-05, October 2015. |
[I-D.dhodylee-pce-pcep-ls] | Dhody, D., Lee, Y. and D. Ceccarelli, "PCEP Extension for Distribution of Link-State and TE Information.", Internet-Draft draft-dhodylee-pce-pcep-ls-03, March 2016. |
[I-D.ietf-idr-ls-distribution] | Gredler, H., Medved, J., Previdi, S., Farrel, A. and S. Ray, "North-Bound Distribution of Link-State and TE Information using BGP", Internet-Draft draft-ietf-idr-ls-distribution-13, October 2015. |
[RFC3630] | Katz, D., Kompella, K. and D. Yeung, "Traffic Engineering (TE) Extensions to OSPF Version 2", RFC 3630, DOI 10.17487/RFC3630, September 2003. |
[RFC4203] | Kompella, K. and Y. Rekhter, "OSPF Extensions in Support of Generalized Multi-Protocol Label Switching (GMPLS)", RFC 4203, DOI 10.17487/RFC4203, October 2005. |
[RFC5305] | Li, T. and H. Smit, "IS-IS Extensions for Traffic Engineering", RFC 5305, DOI 10.17487/RFC5305, October 2008. |
[RFC5307] | Kompella, K. and Y. Rekhter, "IS-IS Extensions in Support of Generalized Multi-Protocol Label Switching (GMPLS)", RFC 5307, DOI 10.17487/RFC5307, October 2008. |
[I-D.li-mpls-global-label-framework] | Li, Z., Zhao, Q., Chen, X., Yang, T. and R. Raszuk, "A Framework of MPLS Global Label", Internet-Draft draft-li-mpls-global-label-framework-02, July 2014. |
[I-D.zhao-pce-central-controller-user-cases] | Zhao, Q., Li, Z., Ke, Z., Fang, L., Zhou, C. and T. Communications, "The Use Cases for Using PCE as the Central Controller(PCECC) of LSPs", Internet-Draft draft-zhao-pce-central-controller-user-cases-02, July 2015. |
[I-D.ietf-pce-remote-initiated-gmpls-lsp] | Ali, Z., Sivabalan, S., Filsfils, C., Varga, R., Lopez, V., Dios, O. and X. Zhang, "Path Computation Element Communication Protocol (PCEP) Extensions for remote-initiated GMPLS LSP Setup", Internet-Draft draft-ietf-pce-remote-initiated-gmpls-lsp-01, July 2015. |
[I-D.ietf-spring-segment-routing] | Filsfils, C., Previdi, S., Decraene, B., Litkowski, S. and R. Shakir, "Segment Routing Architecture", Internet-Draft draft-ietf-spring-segment-routing-07, December 2015. |
[I-D.ietf-isis-segment-routing-extensions] | Previdi, S., Filsfils, C., Bashandy, A., Gredler, H., Litkowski, S., Decraene, B. and J. Tantsura, "IS-IS Extensions for Segment Routing", Internet-Draft draft-ietf-isis-segment-routing-extensions-06, December 2015. |
[I-D.ietf-ospf-segment-routing-extensions] | Psenak, P., Previdi, S., Filsfils, C., Gredler, H., Shakir, R., Henderickx, W. and J. Tantsura, "OSPF Extensions for Segment Routing", Internet-Draft draft-ietf-ospf-segment-routing-extensions-06, December 2015. |
[I-D.ietf-pce-segment-routing] | Sivabalan, S., Medved, J., Filsfils, C., Crabbe, E., Lopez, V., Tantsura, J., Henderickx, W. and J. Hardwick, "PCEP Extensions for Segment Routing", Internet-Draft draft-ietf-pce-segment-routing-06, August 2015. |
[I-D.ietf-pce-lsp-setup-type] | Sivabalan, S., Medved, J., Minei, I., Crabbe, E., Varga, R., Tantsura, J. and J. Hardwick, "Conveying path setup type in PCEP messages", Internet-Draft draft-ietf-pce-lsp-setup-type-03, June 2015. |
Udayasree Palle Huawei Technologies Divyashree Techno Park, Whitefield Bangalore, Karnataka 560066 India EMail: udayasree.palle@huawei.com Katherine Zhao Huawei Technologies 2330 Central Expressway Santa Clara, CA 95050 USA EMail: katherine.zhao@huawei.com Boris Zhang Telus Ltd. Toronto Canada EMail: boris.zhang@telus.com
This section is created to move the Label range handling text. It would be moved to a separate document in future.
New requirements for PCEP extension regarding Label Range:-
Two new flags are added in PCECC-CAPABILITY TLV (Section 7.1.1) to support PCECC:-
A new PCEP messages to support PCECC:-
After PCEP initial state synchronization, the label range is reserved.
If L flag is advertised in OPEN Object by PCEP speakers, a PCC reserves a local label range and is communicated using PCLRResv message to a PCE. The PCE maintains the local label range of each node and further during LSP setup, a label is assigned to each node from the corresponding local label range reserved.
If G flag is advertised in OPEN Object by PCEP speakers,a PCC reserves a global label range and is advertised in PCLRResv message to a PCE. The PCE MAY negotiate and reserves the global label range and also sends the negotiated global label range in PCLRResv message to the PCC. Please refer [I-D.li-mpls-global-label-framework] for MPLS global label allocation.
A PCC MUST send PCLRResv message immediately after the initial LSP synchronization completion. A PCE SHOULD NOT send PCLabelUpd message to a PCC before PCLRResv message is received. If the PCC has received PCLabelUpd message and has not initiated label range reservation, it SHOULD send a PCErr message with Error-type=[TBD] (label range not reserved) and Error-value=[TBD].
The label range reservation sequence is shown below.
+-+-+ +-+-+ |PCC| |PCE| +-+-+ +-+-+ | | |--- PCLRResv, label type=1 --->|local label range reserved | (100-500) |global label range negotiated | label type=2 | | (600-1000) | | | |<--- PCLRResv, label type=2 ---|global label range reserved | (700-1000) | | |
[Editor's Note: This section of the document would be updated with more details about Label Block Negotiation, Reservation, Adjustment etc in a future revision of the document.]
A Label Range Reservation message (also referred to as PCLRResv message) is a PCEP message sent by a PCC to a PCE for the reservation of label range or by PCE to PCC to send reserved label range for the network. The Message-Type field of the PCEP common header for the PCLRResv message is set to [TBD].
The format of a PCLRResv message is as follows:
PCLRResv Message>::= <Common Header> <label-range> Where: <label-range> ::= <SRP> <labelrange-list> Where <labelrange-list>::=<LABEL-RANGE>[<labelrange-list>]
There are two mandatory objects that MUST be included within each <label-range> in the PCLRResv message: the SRP Object and LABEL-RANGE object.
SRP object is defined in [I-D.ietf-pce-stateful-pce] and this document extends the use of SRP object in PCLRResv message. If the SRP object is missing, the receiving PCE MUST send a PCErr message with Error-type=6 (Mandatory Object missing) and Error-value=10 (SRP object missing).
PCC generates the value of SRP-ID-number in SRP object of PCLRResv message send to a PCE. The PCE MUST include the same SRP-ID-number in SRP object of PCLRResv message sent to the PCC in response to PCLRResv message.
LABEL-RANGE object is defined in Appendix B.3. If the LABEL-RANGE object is missing, the receiving PCE MUST send a PCErr message with Error-type=6 (Mandatory Object missing) and Error-value=[TBD] (Label object missing).
[Editor's Note: This section of the document would be updated with more details about Label Block Negotiation, Reservation, Adjustment etc in a future revision of the document.]
The LABEL-RANGE object MUST be carried within PCLRResv message. The LABEL-RANGE object is used to carry the label range information based on the label type.
LABEL-RANGE Object-Class is TBD.
LABEL-RANGE Object-Type is 1.
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 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | label type | range size | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | label base | Reserved | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | // Optional TLVs // | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+