<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE rfc [
<!ENTITY nbsp "&#160;">
<!ENTITY zwsp "&#8203;">
<!ENTITY nbhy "&#8209;">
<!ENTITY wj "&#8288;">
]>
<?rfc toc="yes"?>
<?rfc tocompact="yes"?>
<?rfc tocdepth="3"?>
<?rfc tocindent="yes"?>
<?rfc symrefs="yes"?>
<?rfc sortrefs="yes"?>
<?rfc comments="yes"?>
<?rfc inline="yes"?>
<?rfc compact="yes"?>
<?rfc subcompact="no"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" category="exp" ipr="trust200902" docName="draft-ietf-spring-bfd-10" obsoletes="" updates="" submissionType="IETF" xml:lang="en" tocInclude="true" tocDepth="3" symRefs="true" sortRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.6.0 -->
  <?xml-stylesheet type='text/xsl' href='rfc2629.xslt' ?>

<front>
    <title abbrev="BFD in SPRING MPLS">Bidirectional Forwarding Detection (BFD) in Segment Routing Networks Using MPLS Dataplane</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-spring-bfd-10"/>
    <author initials="G." surname="Mirsky" fullname="Greg Mirsky">
      <organization>Ericsson</organization>
      <address>
        <email>gregimirsky@gmail.com</email>
      </address>
    </author>
    <author initials="J." surname="Tantsura" fullname="Jeff  Tantsura">
      <organization>NVDIA</organization>
      <address>
        <email>jefftant.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="I." surname="Varlashkin" fullname="Ilya Varlashkin">
      <organization>Google</organization>
      <address>
        <email>imv@google.com</email>
      </address>
    </author>
    <author fullname="Mach(Guoyi) Chen" initials="M." surname="Chen">
      <organization>Huawei</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <code/>
          <country/>
        </postal>
        <email>mach.chen@huawei.com</email>
      </address>
    </author>
    <author fullname="Jiang Wenying" initials="J." surname="Wenying">
      <organization>CMCC</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <code/>
          <country/>
        </postal>
        <email>jiangwenying@chinamobile.com</email>
      </address>
    </author>
    
    <date year="2024"/>
    
    <area>Routing</area>
    <workgroup>SPRING Working Group</workgroup>
    
    <keyword>Internet-Draft</keyword>
    <keyword>LSP Ping</keyword>
    <keyword>BFD </keyword>
    <abstract>
      <t>
   Segment Routing (SR) architecture leverages the paradigm of source routing. It
   can be realized in the Multiprotocol Label Switching (MPLS) network without any change to the data plane. 
   A segment is encoded as an MPLS label, and  an ordered list of segments 
   is encoded as a stack of labels.
   Bidirectional Forwarding Detection (BFD) is expected 
   to monitor any existing path between systems. This document defines
   how to use Label Switched Path (LSP) Ping to bootstrap a BFD session, optional control of the selection
   of a segment list  as the reverse direction of the BFD session, applicability of
   BFD Demand mode, and Seamless BFD in the SR-MPLS domain.
   Also, the document describes the use of the BFD Echo function with the BFD Control packet payload.
      </t>
    </abstract>
  </front>
  <middle>
    <section anchor="intro" numbered="true" toc="default">
      <name>Introduction</name>
      <t>
 <xref target="RFC5880" format="default"/>, <xref target="RFC5881" format="default"/>, and <xref target="RFC5883" format="default"/> 
 defined the operation of Bidirectional Forwarding Detection (BFD) protocol
 between the two systems over IP networks.
 <xref target="RFC5884" format="default"/> and <xref target="RFC7726" format="default"/> set rules 
 for using BFD Asynchronous mode over point-to-point (p2p) Multiprotocol Label Switching (MPLS)
 Label Switched Path (LSP). These latter standards implicitly assume that the remote 
 BFD system, which is at the egress Label Edge Router (LER),
 will use the shortest path route regardless of the path the BFD system at the ingress LER
 uses to send BFD Control packets towards it. Throughout this document, references to
 ingress LER and egress LER are used, respectively, as a shortened version of the "BFD system at the ingress/egress
 LER".
      </t>
      <t>
 This document defines the use of LSP Ping for Segment Routing networks over the MPLS
 data plane <xref target="RFC8287" format="default"/> to bootstrap 
 and control path of a BFD session from the egress to ingress LER
 using Segment Routing tunnel with MPLS data plane (SR-MPLS).
      </t>
      <t>
      <xref target="RFC9256"/> defines the SR Policy architecture.  When analyzing the
   applicability of a BFD-based mechanism for detecting network failures
   in a Segment Routing domain, it is essential to identify the SR Policy elements monitored by the BFD.  Concluding from
   the definition of BFD in <xref target="RFC5880"/>, in an SR domain, BFD, in its modes
   and functions, monitors not the SR Policy, as defined in <xref target="RFC9256"/>,
  but a segment list that is a constituent of the candidate path of the
   particular SR Policy. That is the context used throughout the document.
      </t>
      <section numbered="true" toc="default">
        <name>Conventions</name>
        <section numbered="true" toc="default">
          <name>Terminology</name>
          <t>BFD:         Bidirectional Forwarding Detection</t>
          <t>BSID:       Binding Segment Identifier</t>
          <t>FEC:         Forwarding Equivalence Class</t>
          <t>MPLS:         Multiprotocol Label Switching</t>
          <t>SR-MPLS   Segment Routing with MPLS data plane</t>
          <t>LSP:         Label Switched Path</t>
          <t>LER          Label Edge Router</t>
          <t>p2p           Point-to-point</t>
          <t>p2mp         Point-to-multipoint</t>
          <t>SID           Segment Identifier</t>
          <t>SR            Segment Routing</t>
          <t>S-BFD      Seamless BFD</t>
        </section>
        <section numbered="true" toc="default">
          <name>Requirements Language</name>
          <t>
   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
   NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
   "MAY", and "OPTIONAL" in this document are to be interpreted as
   described in BCP 14 <xref target="RFC2119" format="default"/> <xref target="RFC8174" format="default"/> 
   when, and only when, they appear in all capitals, as shown here.
          </t>
        </section>
      </section>
    </section>
    <section anchor="seg-rout-oper" numbered="true" toc="default">
      <name>Bootstrapping BFD Session over Segment Routed Tunnel with MPLS Data Plane</name>
      <t>
Use of an LSP Ping to bootstrap BFD over MPLS LSP is required, as documented in <xref target="RFC5884" format="default"/>,
to establish an association between a fault detection message, i.e., BFD Control message,
and the Forwarding Equivalency Class (FEC) of a single label stack LSP in case
of Penultimate Hop Popping or when the egress LER distributes the Explicit NULL label
to the penultimate hop router. The Explicit NULL label is not advertised as a Segment Identifier (SID) by an SR node
but, as demonstrated in section 3.1 <xref target="RFC8660" format="default"/>
if the operation at the penultimate hop is NEXT; then
the egress SR node will receive an IP encapsulated packet. Thus the conclusion is that LSP Ping MUST be used to bootstrap
a BFD session in an SR-MPLS domain if there are no other means to bootstrap the BFD session,
e.g., using an extension to a dynamic routing protocol as described in <xref target="RFC9026" format="default"/>
and <xref target="RFC9186" format="default"/>.
</t>
      <t>
As demonstrated in <xref target="RFC8287" format="default"/>, the introduction of Segment Routing network domains
with an MPLS data plane requires three new sub-TLVs that 
MAY be used with Target FEC TLV <xref target="RFC8029"/>. Section 6.1 addresses the use of
the new sub-TLVs in Target FEC TLV in LSP ping and LSP traceroute. 
For the case of LSP ping, the <xref target="RFC8287" format="default"/> states that:
</t>
      <ul empty="true" spacing="normal">
        <li>
The initiator, i.e., ingress LER, MUST include FEC(s) corresponding to the destination segment.
</li>
        <li>
The initiator MAY include FECs corresponding to some or all of
segments imposed in the label stack by the ingress LER to
communicate the segments traversed.
</li>
      </ul>
      <t>
It has been noted in <xref target="RFC5884" format="default"/> that a BFD session monitors for 
defects particular &lt;MPLS LSP, FEC&gt; tuple. <xref target="RFC7726" format="default"/> clarified
how to establish and operate multiple BFD sessions for the same &lt;MPLS LSP, FEC&gt; tuple.
Because only the ingress LER is aware of the SR-based explicit route, the egress LER
can associate the LSP ping with BFD Discriminator TLV with only one of the FECs it advertised for
the particular segment. Thus this document clarifies that:
</t>
      <ul empty="true" spacing="normal">
        <li>
When LSP Ping is used to bootstrapping a BFD session for SR-MPLS tunnel
the FEC corresponding to the segment to be associated with the BFD session
MUST be as the very last sub-TLV in the Target FEC TLV.
</li>
      </ul>
      <!--
      <t>
If the target segment is an anycast prefix segment (<xref target="I-D.ietf-spring-mpls-anycast-segments" format="default"/>) the corresponding Anycast SID
MUST be included in the Target FEC TLV as the very last sub-TLV. Also, for
BFD Control packet the ingress SR node MUST use precisely the same label stack encapsulation,
especially Entropy Label (<xref target="RFC6790" format="default"/>), as for the LSP ping with the BFD Discriminator TLV that bootstrapped the BFD session.
Other operational aspects of using BFD
to monitor the continuity of the path to the particular Anycast SID, advertised by a group of SR-MPLS capable
nodes, will be considered in the future versions of the document.
</t>
-->
      <t>
Encapsulation of a BFD Control packet in Segment Routing network with MPLS data plane
MUST follow Section 7 <xref target="RFC5884" format="default"/> when the IP/UDP header used and
MUST follow Section 3.4 <xref target="RFC6428" format="default"/> without IP/UDP header being used. 
</t>
    </section>
    <section anchor="seg-rout-return" numbered="true" toc="default">
      <name>Use BFD Reverse Path TLV over Segment Routed MPLS Tunnel</name>
      <t>
For BFD over MPLS LSP case, per <xref target="RFC5884" format="default"/>, egress LER MAY 
send BFD Control packet to the ingress LER either over IP network or an MPLS LSP. 
Similarly, for the case of BFD over p2p SR-MPLS tunnel, the egress LER
MAY route BFD Control packet over the IP network, as described in <xref target="RFC5883" format="default"/>, or
transmit over a segment tunnel, as described in Section 7 <xref target="RFC5884" format="default"/>.
   In some cases, there may be a need to direct egress LER to use a specific path
   for the reverse direction of the BFD session by using the BFD Reverse Path TLV and following all
   procedures as defined in <xref target="I-D.ietf-mpls-bfd-directed" format="default"/>. 
</t>
    </section>
    <section anchor="non-fec-tlv" numbered="true" toc="default">
      <name>Use Non-FEC Path TLV</name>
      <t>
 For the case of MPLS data plane, 
Segment Routing Architecture <xref target="RFC8402" format="default"/> 
explains that "a segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels." 
<!--
YANG Data Model for MPLS Static LSPs <xref target="I-D.ietf-mpls-static-yang"/>
models outgoing MPLS labels to be imposed as leaf-list <xref target="RFC6020"/>,
i.e., as array of rt-types:mpls-label <xref target="RFC8294"/>.
-->
</t>
      <t>
This document defines a new optional Non-FEC Path TLV.
The format of the Non-FEC Path TLV is presented in <xref target="non-fec-tlv-fig" format="default"/>
      </t>
      <figure anchor="non-fec-tlv-fig">
        <name>Non-FEC Path TLV Format</name>
        <artwork name="" type="" align="left" alt=""><![CDATA[    
    0                   1                   2                   3
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |    Non-FEC Path TLV Type      |           Length              |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |                                                               |
   ~                          Non-FEC Path                         ~
   |                                                               |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork>
      </figure>
      <t>
Non-FEC Path TLV Type is two octets in length and has a value of
   TBD1 (to be assigned by IANA as requested in <xref target="iana-non-fec-tlv" format="default"/>).
      </t>
      <t>
   Length field is two octets long and defines the length in octets of the
   Non-FEC Path field.
      </t>
      <t>
  Non-FEC Path field contains a sub-TLV. Any Non-FEC Path sub-TLV
   (defined in this document or to be defined in the future) for Non-FEC 
   Path TLV type MAY be used in this
   field.  None or one sub-TLV MAY be included in the Non-FEC
   Path TLV. If no sub-TLV has been found in the Non-FEC Path TLV, the
   egress LER MUST revert to using the reverse path selected
   based on its local policy. If there is more than one sub-TLV, then
   the Return Code in echo reply MUST be set to value TBD3 "Too Many TLVs Detected"
 (to be assigned by IANA as requested in <xref target="return-code-iana" format="default"/>).
      </t>
      <t>
Non-FEC Path TLV MAY be used to specify the reverse path of the BFD session identified in the BFD Discriminator TLV.
If the Non-FEC Path TLV is present in the echo request message the  BFD Discriminator TLV MUST
be present as well. If the BFD Discriminator TLV is absent when the Non-FEC Path TLV is
   included, then it MUST be treated as malformed Echo Request, as
   described in <xref target="RFC8029" format="default"/>.
      </t>
      <t>
This document defines the Segment Routing MPLS Tunnel sub-TLV that MAY be used with the Non-FEC Path TLV.
The format of the sub-TLV is presented in <xref target="spring-mpls-sub-tlv" format="default"/>.
</t>
      <figure anchor="spring-mpls-sub-tlv">
        <name>Segment Routing MPLS Tunnel sub-TLV</name>
        <artwork name="" type="" align="left" alt=""><![CDATA[    
  0                   1                   2                   3
  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
 |  SR MPLS Tunnel sub-TLV Type  |           Length              |
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
 |                   SID Entry 1 (Top of Stack)                  |
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
 |                           SID Entry 2                         |
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
 ~                                                               ~
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
 |                   SID Entry N (Bottom of Stack)               |
 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

]]></artwork>
      </figure>
      <t>
The Segment Routing MPLS Tunnel sub-TLV Type is two octets in length, and has a value of TBD2 
(to be assigned by IANA as requested in <xref target="iana-non-fec-tlv" format="default"/>).
</t>
      <t>
The egress LER MUST use the Value field as label stack for BFD Control packets
for the BFD session identified by the source IP address of the MPLS LSP Ping packet
and the value in the BFD Discriminator TLV. Label Entries MUST be in network order.
</t>
    </section>
    <section anchor="dynamic-protocol" numbered="true" toc="default">
      <name>BFD Reverse Path TLV over Segment Routed MPLS Tunnel with Dynamic Control Plane</name>
      <t>
When Segment Routed domain with MPLS data plane uses distributed tunnel computation BFD Reverse Path TLV MAY
use Target FEC sub-TLVs defined in <xref target="RFC8287" format="default"/>.
</t>
    </section>
    <section anchor="demand-bfd" numbered="true" toc="default">
      <name>Applicability of BFD Demand Mode in SR-MPLS Domain</name>
      <t>
Sections 6.6 and 6.18.4 of <xref target="RFC5880" format="default"/> define how Demand mode of BFD
can be used to monitor uni-directional MPLS LSP. Similar procedures can be following in SR-MPLS to monitor uni-directional SR tunnels:
</t>
      <ul spacing="normal">
        <li>an ingress SR node bootstraps BFD session over SR-MPLS in Async BFD mode;</li>
        <li>once BFD session is Up, the ingress SR node switches the egress LER into the Demand mode by setting D field in BFD Control packet it transmits;</li>
        <li>if the egress LER detects the failure of the BFD session, it sends its BFD Control packet to the ingress SR node over the IP network with a Poll sequence;</li>
        <li>if the ingress SR node receives a BFD Control packet from the remote node in a Demand mode 
with Poll sequence and Diag field indicating the failure, the ingress SR node transmits BFD Control packet with Final over IP and switches the BFD over SR-MPLS
back into Async mode, sending BFD Control packets one per second.</li>
      </ul>
    </section>
    <section anchor="sr-p2mp-bfd-sec" numbered="true" toc="default">
      <name>Using BFD to Monitor Point-to-Multipoint SR Policy</name>
      <t>
<xref target="I-D.ietf-spring-sr-replication-segment" format="default"/> defined variants of SR Policy to deliver point-to-multipoint (p2mp) services.
For the given p2mp segment <xref target="RFC8562" format="default"/> can be used if, for example, leaves have an
alternative source of the multicast service flow to select. In such a scenario, a leaf may switch to using the alternative flow
after p2mp BFD detects the failure in the working multicast path. For scenarios where it is required for the root to
monitor the state of the multicast tree <xref target="RFC8563" format="default"/> can be used. The root may use the detection of the failure
of the multicast tree to the particular leaf to restore the path for that leaf or re-instantiate the whole multicast tree.
</t>
      <t>
An essential part of using p2mp BFD is the bootstrapping the BFD session at all the leaves. The root, acting as the MultipointHead,
MAY use LSP Ping with the BFD Discriminator TLV. Alternatively, extensions
to routing protocols, e.g., BGP, or management plane, e.g., Path Computation Element Protocol,
MAY be used to associate the particular p2mp segment with MultipointHead's Discriminator. Extensions for routing protocols and
management plane are for further study.
</t>
    </section>
    <section anchor="echo-bfd-sec" numbered="true" toc="default">
      <name>Use of Echo BFD in SR-MPLS</name>
      <t>
Echo-BFD <xref target="RFC5880" format="default"/> can be used to monitor a segment list of the particular SR Policy between the local and the remote BFD peers.
As defined in <xref target="RFC5880" format="default"/>, the remote BFD system does not process the payload of an Echo BFD. Thus
it is the local system that demultiplexes the Echo BFD packet matching it to the appropriate BFD session and detects
missing Echo BFD packets. A BFD Control packet MAY be used as the payload of Echo BFD. This specification defines the use of Echo BFD in SR-MPLS
network with BFD Control packet as the payload. The use of other types of Echo BFD payload is outside the scope of this document.
Because the remote BFD system
does not process Echo BFD, the value of the Your Discriminator field MUST be set to the discriminator the local BFD system
assigned to the given BFD session. My Discriminator field MUST be zeroed. Authentication MUST be set according to the configuration
of the BFD session. To ensure that the Echo BFD packet is returned to the sender without being processed, the sender MAY use
a Binding SID (BSID) <xref target="RFC8402" format="default"/> that has been bound with the SR Policy that ensures the return of a packet to that particular node.
A BSID MAY be associated with the SR Policy that is the reverse to the SR Policy programmed onto the BFD Echo packet by the sender.
</t>
    </section>
        <section anchor="s-bfd-sec" numbered="true" toc="default">
      <name>Use of S-BFD in SR-MPLS</name>
      <t>
      Seamless BFD (S-BFD), defined in <xref target="RFC7880"/>, maintains essential characteristics
      and elements of the base BFD mechanism described in <xref target="RFC5880"/> with a lighter approach
      to instantiating a BFD session between BFD peers. Similar to the BFD Asynchronous mode, S-BFD
      is capable of monitoring a segment list of a p2p SR Policy.
      </t>
      <t>
         Considering that a particular SR Policy can include multiple
   candidate paths, which, in turn, have one or more segment lists, it could be beneficial to monitor each segment list
   independently.  To achieve that, S-BFD Reflector advertises My
   Discriminator value.  Then, the S-BFD Initiator uses the advertised My
   Discriminator value as Your Discriminator value in the BFD Control
   messages transmitted over the segment list of the SR Policy.
   Furthermore, the S-BFD Initiator assigns a unique My Discriminator for
   each S-BFD session monitoring a segment list.  S-BFD Reflector
   transmits BFD Control messages as IP/UDP packets, taking
   advantage of the available resilience mechanisms of the IP network.
   From that point, to minimize the detection of failures in the IP network that
   do not affect the monitored segment list, it is reasonable
   not to use defect detection intervals that are close to the IP network
   repair time.  Instead, having an S-BFD detection
   interval three times longer than the IP network repair time is practical.



      </t>
      </section>
  
    <section anchor="iana-consider" numbered="true" toc="default">
      <name>IANA Considerations</name>
      <section anchor="iana-non-fec-tlv" numbered="true" toc="default">
        <name>Non-FEC Path TLV</name>
        <t>
IANA is requested to assign new TLV type from the from Standards Action range
of the registry "Multiprotocol Label Switching Architecture (MPLS)
Label Switched Paths (LSPs) Ping Parameters - TLVs" as defined in <xref target="spring-non-fec-tlv-table" format="default"/>.
</t>
        <table anchor="spring-non-fec-tlv-table" align="center">
          <name>New Non-FEC Path TLV</name>
          <thead>
            <tr>
              <th align="left">Value</th>
              <th align="left">TLV Name</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">&nbsp;TBD1</td>
              <td align="left">Non-FEC Path TLV</td>
              <td align="left">This&nbsp;document</td>
            </tr>
          </tbody>
        </table>
        <t>
IANA is requested to create new Non-FEC Path sub-TLV registry for the Non-FEC Path TLV, as described in <xref target="iana-non-fec-sub-tlv-reg-tbl" format="default"/>.
</t>
        <table anchor="iana-non-fec-sub-tlv-reg-tbl" align="center">
          <name>Non-FEC Path sub-TLV registry</name>
          <thead>
            <tr>
              <th align="left">Range</th>
              <th align="center">Registration Procedures</th>
              <th align="left">Note</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">0-16383</td>
              <td align="center">Standards Action</td>
              <td align="left">This range is for mandatory TLVs or for optional TLVs that require an error message if not recognized.</td>
            </tr>
            <tr>
              <td align="left">16384-31743</td>
              <td align="center">Specification Required</td>
              <td align="left">Experimental RFC needed</td>
            </tr>
            <tr>
              <td align="left">32768-49161</td>
              <td align="center">Standards Action</td>
              <td align="left">This range is for optional TLVs that can be silently dropped if not recognized.</td>
            </tr>
            <tr>
              <td align="left">49162-64511</td>
              <td align="center">Specification Required</td>
              <td align="left">Experimental RFC needed</td>
            </tr>
            <tr>
              <td align="left">64512-65535</td>
              <td align="center">Private Use</td>
              <td align="left"/>
            </tr>
          </tbody>
        </table>
        <t>IANA is requested to allocate the following values from the Non-FEC Path sub-TLV registry as defined in <xref target="spring-sub-tlv-table" format="default"/>.</t>
        <table anchor="spring-sub-tlv-table" align="center">
          <name>New Segment Routing Tunnel sub-TLV</name>
          <thead>
            <tr>
              <th align="left">Value</th>
              <th align="left">Description</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">0</td>
              <td align="left">Reserved</td>
              <td align="left">This document</td>
            </tr>
            <tr>
              <td align="left">&nbsp;TBD2</td>
              <td align="left">Segment Routing MPLS Tunnel sub-TLV</td>
              <td align="left">This&nbsp;document</td>
            </tr>
            <tr>
              <td align="left">65535</td>
              <td align="left">Reserved</td>
              <td align="left">This document</td>
            </tr>
          </tbody>
        </table>
      </section>
      <section anchor="iana-return-code" numbered="true" toc="default">
        <name>Return Code</name>
        <t>
IANA is requested to create Non-FEC Path sub-TLV sub-registry for
the new Non-FEC Path TLV and assign a new Return Code value from the "Multi-Protocol Label Switching (MPLS)
Label Switched Paths (LSPs) Ping Parameters" registry, "Return Codes" sub-registry, as follows using a
Standards Action value.
</t>
        <table anchor="return-code-iana" align="center">
          <name>New Return Code</name>
          <thead>
            <tr>
              <th align="left">Value</th>
              <th align="left">Description</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">X&nbsp;TBD3</td>
              <td align="left">Too Many TLVs Detected.</td>
              <td align="left">This&nbsp;document</td>
            </tr>
          </tbody>
        </table>
      </section>
    </section>
    <section numbered="true" toc="default">
      <name>Implementation Status</name>
           <t>Note to RFC Editor: This section MUST be removed before publication of the document.</t>
      <t>
    This section records the status of known implementations of the
     protocol defined by this specification at the time of posting of
     this Internet-Draft, and is based on a proposal described in
     <xref target="RFC7942"/>.  The description of implementations in this section is
     intended to assist the IETF in its decision processes in
     progressing drafts to RFCs.  Please note that the listing of any
     individual implementation here does not imply endorsement by the
     IETF.  Furthermore, no effort has been spent to verify the
     information presented here that was supplied by IETF contributors.
     This is not intended as, and must not be construed to be, a
     catalog of available implementations or their features.  Readers
     are advised to note that other implementations may exist.
      </t>
            <t>
      According to <xref target="RFC7942"/>, "this will allow reviewers and working
     groups to assign due consideration to documents that have the
     benefit of running code, which may serve as evidence of valuable
     experimentation and feedback that have made the implemented
     protocols more mature.  It is up to the individual working groups
     to use this information as they see fit".
      </t>
      <t>-  The organization responsible for the implementation: ZTE Corporation.</t>
      <t>-  The implementation's name ROSng SW empowers traditional routers, e.g., ZXCTN 6000.</t>
      <t>-  A brief general description: A list of SIDs can be specified as the Return Path for an SR-MPLS tunnel.</t>
      <t> -  The implementation's level of maturity: production.</t>
      <t>-  Coverage: complete</t>
      <t>-  Version compatibility: draft-mirsky-spring-bfd-06.</t>
      <t>-  Licensing: proprietary.</t>
      <t>-  Implementation experience: Appreciate Early Allocation of values for Non-FEC TLV and Segment Routing MPLS Tunnel sub-TLV (using Private Use code points).</t>
      <t>-  Contact information: Qian Xin qian.xin2@zte.com.cn</t>
      <t>-  The date when information about this particular implementation was last updated: 12/16/2019</t>
    </section>
    
    <section anchor="security" numbered="true" toc="default">
      <name>Security Considerations</name>
      <t>
 Security considerations discussed in <xref target="RFC5880" format="default"/>, 
 <xref target="RFC5884" format="default"/>, <xref target="RFC7726" format="default"/>, and <xref target="RFC8029" format="default"/> 
 apply to this document. 
      </t>
    </section>
    <section anchor="contr-sec" numbered="true" toc="default">
      <name>Contributors</name>
      <artwork name="" type="" align="left" alt=""><![CDATA[    
   Xiao Min
   ZTE Corp.
   Email: xiao.min2@zte.com.cn
       ]]></artwork>
    </section>
    <section numbered="true" toc="default">
      <name>Acknowledgments</name>
      <t>
      Authors express their sincere gratitude to Alexander "Sasha" Vainshtein for his helpful comments
      and thought-inspiring discussion of SR Policies and BFD-based mechanisms.
         Authors greatly appreciate the help of Qian Xin, who provided the information about the implementation of this specification.
      </t>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.5880.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.5881.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.5883.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.5884.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8029.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.7726.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.6428.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8287.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8402.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8562.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8563.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8660.xml"/>
        <!--   <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.6790.xml"/> -->
        <xi:include href="https://datatracker.ietf.org/doc/bibxml3/draft-ietf-spring-sr-replication-segment.xml"/>
        <xi:include href="https://datatracker.ietf.org/doc/bibxml3/draft-ietf-mpls-bfd-directed.xml"/>
        <!-- <xi:include href="https://datatracker.ietf.org/doc/bibxml3/draft-mirsky-bfd-mpls-demand.xml"/> -->
      </references>
      <references>
        <name>Informative References</name>
<!-- <?rfc include="reference.RFC.6020"?>  -->
  <!-- <?rfc include='reference.RFC.8294'?>  -->

      <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.7942.xml"/>
        <!-- <?rfc include="reference.RFC.7110"?> -->
    <!-- <?rfc include='reference.I-D.ietf-mpls-static-yang'?> -->
<!--  <xi:include href="https://datatracker.ietf.org/doc/bibxml3/draft-ietf-spring-mpls-anycast-segments.xml"/> -->
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.9026.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.9186.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.9256.xml"/>
        <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.7880.xml"/>
      </references>
    </references>
  </back>
</rfc>
