Label Switched Path (LSP) Ping for Segment Routing (SR)
Path Segment Identifiers (SIDs) with MPLS Data Planes
ZTE Corp.NanjingChina+86 25 88013062xiao.min2@zte.com.cnZTE Corp.NanjingChinapeng.shaofu@zte.com.cnChina MobileBeijingChinagongliyan@chinamobile.com
Routing
MPLS Working GroupRequest for CommentsRFCInternet DraftI-D Path Segment is a type of SR segment, which is used to identify an SR path. This document provides Target Forwarding
Equivalence Class (FEC) stack TLV definitions for Path Segment Identifiers. Path Segment is a type of SR segment, which is used to identify an SR path. Path Segment in MPLS based segment routing
network is defined in . When Path Segment is used, it's inserted by the ingress node of the SR path, and then processed by the egress node of
the SR path. The position of Path Segment Label within the MPLS label stack is immediately following the segment list of
the SR path. Note that the Path Segment would not be popped up until it reaches the egress node. This document provides Target Forwarding Equivalence Class (FEC) stack TLV definitions for Path-SIDs. Procedures for
LSP Ping as defined in and are applicable to Path-SIDs as well. 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
when, and only when, they appear in all capitals, as shown here. This document uses the terminology defined in and , readers are expected
to be familiar with those terms. Analogous to what's defined in Section 5 of and Section 4 of ,
three new sub-TLVs are defined for the Target FEC Stack TLV (Type 1), the Reverse-Path Target FEC Stack TLV (Type 16), and the Reply
Path TLV (Type 21).
Sub-Type Sub-TLV Name
-------- -----------------------------
TBD1 SR Policy's Path SID
TBD2 SR Candidate Path's Path SID
TBD3 SR Segment List's Path SID
As specified in Section 2 of , the Path Segment may be used to identify an SR
Policy, its Candidate Path, or a Segment List, so three different Target FEC sub-TLVs need to be defined for Path Segment ID. When a
Path Segment is used to identify an SR Policy, the Target FEC sub-TLV of SR Policy's Path SID would be used to validate the control
plane to forwarding plane synchronization for this Path-SID; When a Path Segment is used to identify an SR Candidate Path, the Target
FEC sub-TLV of SR Candidate Path's Path SID would be used to validate the control plane to forwarding plane synchronization for this
Path-SID; When a Path Segment is used to identify a Segment List, the Target FEC sub-TLV of SR Segment List's Path SID would be used
to validate the control plane to forwarding plane synchronization for this Path-SID. Note that the three new Target FEC sub-TLVs are
mutual exclusive and they wouldn't be present in one message simultaneously. The format of SR Policy's Path SID sub-TLV is as specified below: Type
This field is set to the value (TBD1) which indicates that it's an
SR Policy's Path SID sub-TLV.
Length
This field is set to the length of the sub-TLV's Value field in
octets. If Headend and Endpoint fields are in IPv4 address format which
is 4 octets long, it MUST be set to 12; If Headend and Endpoint fields
are in IPv6 address format which is 16 octets long, it MUST be set to 36.
Headend
This field identifies the headend of an SR Policy, the same as defined
in Section 2.1 of .
The headend is a 4-octet IPv4 address or a 16-octet IPv6 address.
Color
This field associates the SR Policy with an intent, the same as defined
in Section 2.1 of .
The color is a 4-octet numerical value.
Endpoint
This field identifies the endpoint of an SR Policy, the same as defined
in Section 2.1 of .
The endpoint is a 4-octet IPv4 address or a 16-octet IPv6 address.
The format of SR Candidate Path's Path SID sub-TLV is as specified below: Type
This field is set to the value (TBD2) which indicates that it's an
SR Candidate Path's Path SID sub-TLV.
Length
This field is set to the length of the sub-TLV's Value field in
octets. If Headend and Endpoint fields are in IPv4 address format which
is 4 octets long, it MUST be set to 40; If Headend and Endpoint fields
are in IPv6 address format which is 16 octets long, it MUST be set to 64.
Headend
This field identifies the headend of an SR Policy, the same as defined
in Section 2.1 of .
The headend is a 4-octet IPv4 address or a 16-octet IPv6 address.
Color
This field associates the SR Policy with an intent, the same as defined
in Section 2.1 of .
The color is a 4-octet numerical value.
Endpoint
This field identifies the endpoint of an SR Policy, the same as defined
in Section 2.1 of .
The endpoint is a 4-octet IPv4 address or a 16-octet IPv6 address.
Protocol-Origin
This field identifies the component or protocol that originates or signals
the candidate path for an SR Policy, the same as defined in Section 2.3 of
. The protocol-origin
is a 1-octet value that follows the recommendation from Table 1 of Section 2.3
of , which specifies
value 10 for "PCEP", value 20 for "BGP SR Policy" and value 30 for "Via Configuration".
Originator
This field identifies the node which provisioned or signaled the candidate
path for an SR Policy, the same as defined in Section 2.4 of
. The originator is a
20-octet numerical value formed by the concatenation of the fields of the tuple
<ASN, node-address>, among which ASN is a 4-octet number and node address is a
16-octet value (an IPv6 address or an IPv4 address encoded in the lowest 4 octets).
When Procotol-Origin is respectively "Via Configuration", or "PCEP", or "BGP SR Policy",
the values of ASN and node address follow the specification in Section 2.4 of
.
Discriminator
This field uniquely identifies a candidate path within the context of an SR policy,
the same as defined in Section 2.5 of .
The discriminator is a 4-octet value. When Protocol-Origin is respectively "Via Configuration",
or "PCEP", or "BGP SR Policy", the value of discriminator follows the specification in Section
2.5 of .
The format of SR Segment List's Path SID sub-TLV is as specified below: Type
This field is set to the value (TBD3) which indicates that it's an
SR Segment List's Path SID sub-TLV.
Length
This field is set to the length of the sub-TLV's Value field in
octets. If Headend and Endpoint fields are in IPv4 address format which
is 4 octets long, it MUST be set to 44; If Headend and Endpoint fields
are in IPv6 address format which is 16 octets long, it MUST be set to 68.
Headend
This field identifies the headend of an SR Policy, the same as defined
in Section 2.1 of .
The headend is a 4-octet IPv4 address or a 16-octet IPv6 address.
Color
This field associates the SR Policy with an intent, the same as defined
in Section 2.1 of .
The color is a 4-octet numerical value.
Endpoint
This field identifies the endpoint of an SR Policy, the same as defined
in Section 2.1 of .
The endpoint is a 4-octet IPv4 address or a 16-octet IPv6 address.
Protocol-Origin
This field identifies the component or protocol that originates or signals
the candidate path for an SR Policy, the same as defined in Section 2.3 of
. The protocol-origin
is a 1-octet value that follows the recommendation from Table 1 of Section 2.3
of , which specifies
value 10 for "PCEP", value 20 for "BGP SR Policy" and value 30 for "Via Configuration".
Originator
This field identifies the node which provisioned or signaled the candidate
path for an SR Policy, the same as defined in Section 2.4 of
. The originator is a
20-octet numerical value formed by the concatenation of the fields of the tuple
<ASN, node-address>, among which ASN is a 4-octet number and node address is a
16-octet value (an IPv6 address or an IPv4 address encoded in the lowest 4 octets).
When Procotol-Origin is respectively "Via Configuration", or "PCEP", or "BGP SR Policy",
the values of ASN and node address follow the specification in Section 2.4 of
.
Discriminator
This field uniquely identifies a candidate path within the context of an SR policy,
the same as defined in Section 2.5 of .
The discriminator is a 4-octet value. When Protocol-Origin is respectively "Via Configuration",
or "PCEP", or "BGP SR Policy", the value of discriminator follows the specification in Section
2.5 of .
Segment-List-ID
This field identifies an SR path within the context of a candidate path of an SR Policy, the
same as "Path ID" defined in Section 4.2 of , or "List Identifier"
defined in Section 2.2 of .
The segment-list-ID is a 4-octet identifier of the corresponding segment list.
The MPLS LSP Ping procedures MAY be initiated by the headend of the Segment Routing path or a
centralized topology-aware data plane monitoring system as described in . For the
Path-SID, the responder nodes that receive echo request and send echo reply MUST be the endpoint of the
Segment Routing path. When an endpoint receives the LSP echo request packet with top FEC being the Path-SID, it SHOULD perform
validity checks on the content of the Path-SID FEC sub-TLV. The basic length check should be performed on the
received FEC.
SR Policy's Path SID
------------------
Length = 12 or 36
SR Candidate Path's Path SID
------------------
Length = 40 or 64
SR Segment List's Path SID
------------------
Length = 44 or 68
If a malformed FEC sub-TLV is received, then a return code of 1, "Malformed echo request received" as defined
in SHOULD be sent. The below section augments the section 7.4 of . 4a. Segment Routing Path-SID Validation: If the Label-stack-depth is 0 and the Target FEC Stack sub-TLV
at FEC-stack-depth is TBD1 (SR Policy's Path SID sub-TLV), {
Set the Best-return-code to 10, "Mapping for this FEC is not
the given label at stack-depth <RSC>" if any below
conditions fail:
Validate that the Path Segment ID is signaled or provisioned for the SR Policy {
Validate that the signaled or provisioned headend, color and end-point for the Path SID, matches with the
corresponding fields in the received SR Policy's Path SID sub-TLV.
}
} If all the above validations have passed, set the return code to 3
"Replying router is an egress for the FEC at stack-depth <RSC>". Set FEC-Status to 1 and return.
} Else, if the Label-stack-depth is 0 and the Target FEC Stack sub-TLV
at FEC-stack-depth is TBD2 (SR Candidate Path's Path SID sub-TLV), {
Set the Best-return-code to 10, "Mapping for this FEC is not
the given label at stack-depth <RSC>" if any below
conditions fail:
Validate that the Path Segment ID is signaled or provisioned for the SR Candidate Path {
When the Protocol-Origin field in the received SR Candidate Path's Path SID sub-TLV is 10, "PCEP"
is used as the signaling protocol. And then validate that the Path Segment ID matches with the tuple
identifying the SR Candidate Path within PCEP {
Validate that the signaled headend, color, end-point, originator ASN, originator address and discriminator
defined in and ,
for the Path SID, matches with the corresponding fields in the received SR Candidate Path's Path SID sub-TLV.
} When the Protocol-Origin field in the received SR Candidate Path's Path SID sub-TLV is 20, "BGP SR Policy"
is used as the signaling protocol. And then validate that the Path Segment ID matches with the tuple identifying
the SR Candidate Path within BGP SR Policy {
Validate that the signaled headend, policy color, endpoint, ASN, BGP Router-ID and distinguisher defined in
and ,
for the Path SID, matches with the corresponding fields in the received SR Candidate Path's Path SID sub-TLV.
} When the Protocol-Origin field in the received SR Candidate Path's Path SID sub-TLV is 30, "Via Configuration"
is used. And then validate that the Path Segment ID matches with the tuple identifying the SR Candidate Path within
Configuration {
Validate that the provisioned headend, color, endpoint, originator and discriminator defined in
, for the Path SID, matches with the corresponding fields in the
received SR Candidate Path's Path SID sub-TLV.
}
} If all the above validations have passed, set the return code to 3
"Replying router is an egress for the FEC at stack-depth <RSC>". Set FEC-Status to 1 and return.
} Else, if the Label-stack-depth is 0 and the Target FEC Stack sub-TLV
at FEC-stack-depth is TBD3 (SR Segment List's Path SID sub-TLV), {
Set the Best-return-code to 10, "Mapping for this FEC is not
the given label at stack-depth <RSC>" if any below
conditions fail:
Validate that the Path Segment ID is signaled or provisioned for the SR Segment List {
When the Protocol-Origin field in the received SR Segment List's Path SID sub-TLV is 10, "PCEP"
is used as the signaling protocol. And then validate that the Path Segment ID matches with the tuple
identifying the SR Segment List within PCEP {
Validate that the signaled headend, color, end-point, originator ASN, originator address and discriminator
defined in and ,
and the signaled Path ID defined in , for the Path SID, matches with the
corresponding fields in the received SR Segment List's Path SID sub-TLV.
} When the Protocol-Origin field in the received SR Segment List's Path SID sub-TLV is 20, "BGP SR Policy"
is used as the signaling protocol. And then validate that the Path Segment ID matches with the tuple identifying
the SR Segment List within BGP SR Policy {
Validate that the signaled headend, policy color, endpoint, ASN, BGP Router-ID and distinguisher defined in
and ,
and the signaled List Identifier defined in , for the Path SID, matches
with the corresponding fields in the received SR Segment List's Path SID sub-TLV.
} When the Protocol-Origin field in the received SR Segment List's Path SID sub-TLV is 30, "Via Configuration"
is used. And then validate that the Path Segment ID matches with the tuple identifying the SR Segment List within
Configuration {
Validate that the provisioned headend, color, endpoint, originator, discriminator and Segment-List-ID defined in
, for the Path SID, matches with the corresponding fields in the received
SR Segment List's Path SID sub-TLV.
}
} If all the above validations have passed, set the return code to 3
"Replying router is an egress for the FEC at stack-depth <RSC>". Set FEC-Status to 1 and return.
} This document defines additional MPLS LSP Ping sub-TLVs and follows the mechanisms defined in .
All the security considerations defined in will be applicable for this document and, in addition,
they do not impose any additional security challenges to be considered. IANA is requested to assign three new sub-TLVs from the "sub-TLVs for TLV Types 1, 16, and 21" subregistry of the
"Multi-Protocol Label Switching (MPLS) Label Switched Paths (LSPs) Ping Parameters" registry .
Sub-Type Sub-TLV Name Reference
-------- ----------------------------- ------------
TBD1 SR Policy's Path SID Section 3.1
TBD2 SR Candidate Path's Path SID Section 3.2
TBD3 SR Segment List's Path SID Section 3.3
The authors would like to acknowledge Detao Zhao for his thorough review and very helpful comments. The authors would like to acknowledge Yao Liu for the very helpful f2f discussion.Multi-Protocol Label Switching (MPLS) Label Switched Paths (LSPs) Ping ParametersInternet Assigned Numbers Authority (IANA)