<?xml version="1.0" encoding="US-ASCII"?>
<!-- This is built from a template for a generic Internet Draft. Suggestions for
     improvement welcome - write to Brian Carpenter, brian.e.carpenter @ gmail.com -->
<!-- This can be converted using the Web service at http://xml.resource.org/experimental.html
     (which supports the latest, sometimes undocumented and under-tested, features.) -->
<!DOCTYPE rfc SYSTEM "rfc2629.dtd">
<?rfc toc="yes"?>
<!-- You want a table of contents -->
<?rfc symrefs="yes"?>
<!-- Use symbolic labels for references -->
<?rfc sortrefs="yes"?>
<!-- This sorts the references -->
<?rfc iprnotified="no" ?>
<!-- Change to "yes" if someone has disclosed IPR for the draft -->
<?rfc compact="yes"?>
<!-- This defines the specific filename and version number of your draft (and inserts the appropriate IETF boilerplate -->
<rfc category="std"
     docName="draft-dong-spring-srv6-inter-layer-programming-08"
     ipr="trust200902">
  <front>
    <title abbrev="SRv6 Inter-Layer Network Programming">SRv6 for Inter-Layer
    Network Programming</title>

    <author fullname="Liuyan Han" initials="L." surname="Han">
      <organization>China Mobile</organization>

      <address>
        <postal>
          <street>No.32 XuanWuMen West Street</street>

          <city>Beijing, 100053</city>

          <country>China</country>
        </postal>

        <email>hanliuyan@chinamobile.com</email>
      </address>
    </author>

    <author fullname="Jie Dong" initials="J." surname="Dong">
      <organization>Huawei Technologies</organization>

      <address>
        <postal>
          <street>Huawei Campus, No.156 Beiqing Road</street>

          <city>Beijing, 100095</city>

          <country>China</country>
        </postal>

        <email>jie.dong@huawei.com</email>
      </address>
    </author>

    <author fullname="Minxue Wang" initials="M." surname="Wang">
      <organization>China Mobile</organization>

      <address>
        <postal>
          <street>No.32 XuanWuMen West Street</street>

          <city>Beijing, 100053</city>

          <country>China</country>
        </postal>

        <email>wangminxue@chinamobile.com</email>
      </address>
    </author>

    <author fullname="Ran Chen" initials="R." surname="Chen">
      <organization>ZTE Corporation</organization>

      <address>
        <postal>
          <street/>

          <!-- Reorder these if your country does things differently -->

          <city>Nanjing</city>

          <region/>

          <code/>

          <country>China</country>
        </postal>

        <email>chen.ran@zte.com.cn</email>

        <!-- uri and facsimile elements may also be added -->
      </address>
    </author>

    <author fullname="Zongpeng Du" initials="Z." surname="Du">
      <organization>China Mobile</organization>

      <address>
        <postal>
          <street>No.32 XuanWuMen West Street</street>

          <city>Beijing, 100053</city>

          <country>China</country>
        </postal>

        <email>duzongpeng@foxmail.com</email>
      </address>
    </author>

    <date day="25" month="June" year="2024"/>

    <area>Routing</area>

    <workgroup>SPRING Working Group</workgroup>

    <keyword>SRv6, Network Programming, Inter-Layer</keyword>

    <abstract>
      <t>The Segment Routing over IPv6 (SRv6) Network Programming framework
      enables a network operator or an application to specify a packet
      processing program by encoding a sequence of instructions in the IPv6
      packet header.</t>

      <t>Following the SRv6 Network Programming concept, this document defines
      SRv6 based mechanisms for inter-layer network programming, which can
      help to integrate the packet network layer with its underlying layers
      efficiently. New SRv6 behaviors used for steering packets to underlay
      links or connections are defined, and the applicability of these SRv6
      behaviors in typical inter-layer network programming scenarios is
      illustrated.</t>
    </abstract>
  </front>

  <middle>
    <section anchor="intro" title="Introduction">
      <t>In many network scenarios, operator owns a multi-layered network. In
      layer-3, the technology has converged to IP, while there can be
      different technologies in layer-2 and below. In such networks, the
      cross-layer planning and optimization is considered more efficient than
      independent planning and operation of the layer-3 and the underlying
      networks in terms of resource utilization and SLA assurance, but it is
      also considered more complicated. Thus a mechanism for flexible and
      efficient inter-layer network integration is desired.</t>

      <t>Segment Routing over IPv6 (SRv6) <xref target="RFC8986"/> enables a
      network operator or an application to specify a packet processing
      program by encoding a sequence of instructions in the IPv6 packet
      header. Currently SRv6 does not consider about the network layers under
      the IP layer. However, with the capability of SRv6 network programming,
      it is possible to achieve seamless integration between IP (layer-3) and
      the underlying (layer-2 and below) networks.</t>

      <t>Following the SRv6 network programming concept, this document defines
      new SRv6 behaviors, which can be used for steering packets to underlay
      links or connections, so that the packet network layer can be integrated
      with the underlying layers efficiently. The applicability of SRv6
      behaviors in typical inter-layer network programming scenarios is also
      illustrated.</t>

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

    <section title="Use Cases of Inter-Layer Network Programming">
      <section title="IP and Optical Inter-layer Programming">
        <t>In many network scenarios, the underlay of the IP network is an
        optical network. The IP network and optical network are usually
        managed separately, the optical network works as an underlay which is
        normally invisible to the IP network. In some cases, the optical path
        resources and the IP path resources may not be one-to-one mapping,
        which makes the redundant optical paths not fully used by the IP
        layer. In some other cases, there may be optical paths between
        non-adjacent IP nodes thus they are not visible in the L3 topology,
        thus they can not be used for carrying traffic based on IP routing.
        However, such optical paths may be used for inter-layer traffic
        engineering.</t>
      </section>

      <section title="IP and MTN Inter-layer Programming">
        <t>The architecture of Metro Transport Network (MTN) is defined in
        <xref target="ITU-T_G.8310"/>. In an MTN based network, network nodes
        can support two forwarding modes: per-hop IP packet forwarding and the
        MTN Path (MTNP) layer cross-connect. An MTN path is a multi-hop
        underlay transport path which may be established between any two nodes
        in the MTN network, and the intermediate nodes on the MTN path will
        forward the traffic based on the pre-established MTN cross-connect
        without IP table lookup. Thus an MTN path is considered as an underlay
        connection between two remote MTN nodes. Although in some cases it is
        possible to set up a layer-3 adjacency between the two endpoints of
        the MTN path, it will make the provisioning of MTN path complicated.
        Moreover, in some cases the two endpoints may reside in different IGP
        areas or ASes, which makes a layer-3 adjacency between them more
        challenging. Last but not the least, the MTN path may be provisioned
        unidirectionally, which cannot pass the bidirectional connectivity
        check required for a layer-3 link. Since the MTN paths are usually not
        visible in the L3 topology, it is difficult to compute and establish
        an end-to-end inter-layer path which consists of both the layer-3
        network segments and the MTN paths.</t>
      </section>
    </section>

    <section title="SRv6 Behavior for Inter-layer Programming">
      <t>In this section, two new SRv6 Endpoint Behaviors, SRv6 END.XU
      Behavior and SRv6 END.BXC Behavior are proposed, which can be seen as
      two options for SRv6 based inter-layer network programming. Network
      operators may choose either one of these options that best suits their
      use cases, network managment and operation model. The use of these SRv6
      Endpoint Behaviors enables inter-layer TE paths for network
      programming.</t>

      <section title="SRv6 END.XU Behavior">
        <t>The "Endpoint with Underlay cross-connect" behavior ("End.XU" for
        short) is a variant of the SRv6 End.X behavior as defined in <xref
        target="RFC8986"/>. Its main use is for SRv6 based inter-layer network
        programming and traffic engineering. Instead of pointing to an
        interface with layer-3 adjacency, the End.XU behavior points to an
        underlay interface which connects to a remote network node via
        underlying links or connections that may be invisible in the L3
        network topology. Thus the End.XU behavior can be used to steer
        packets through an underlay link or connection to a remote layer-3
        node.</t>

        <t>Unlike an L3 link, the underlying links or connections can be
        unidirectional and does not require bi-directional check. Thus the
        underlay links or connections are invisible in the L3 topology and can
        not be used for IP distributed route computation (e.g. SPF). However,
        this may just be the expected behavior in some inter-layer programming
        scenarios, where the underlay links or connections are provisioned for
        traffic engineering for specific types of services. Such underlying
        links or connections may be realized using either Metro Transport
        Network (MTN) paths <xref target="ITU-T_G.8310"/>, or ODUk or DWDM
        connections. The SRv6 End.XU SIDs can be used together with other
        types of SRv6 SIDs to build SRv6 SID lists for inter-layer network
        programming.</t>

        <t>Any SID instance of this behavior is associated with an underlay
        interface, which connects to one or more underlay links or
        connections.</t>

        <t>When node N receives a packet destined to S and S is a local End.XU
        SID, N does the following:</t>

        <figure>
          <artwork><![CDATA[   S01. When an SRH is processed {
   S02.   If (Segments Left == 0) {
   S03.      Stop processing the SRH, and proceed to process the next
                header in the packet, whose type is identified by
                the Next Header field in the routing header.
   S04.   }
   S05.   If (IPv6 Hop Limit <= 1) {
   S06.      Send an ICMP Time Exceeded message to the Source Address
                with Code 0 (Hop limit exceeded in transit),
                interrupt packet processing, and discard the packet.
   S07.   }
   S08.   max_LE = (Hdr Ext Len / 2) - 1
   S09.   If ((Last Entry > max_LE) or (Segments Left > Last Entry+1)) {
   S10.      Send an ICMP Parameter Problem to the Source Address
                with Code 0 (Erroneous header field encountered)
                and Pointer set to the Segments Left field,
                interrupt packet processing, and discard the packet.

   S11.   }
   S12.   Decrement IPv6 Hop Limit by 1
   S13.   Decrement Segments Left by 1
   S14.   Update IPv6 DA with Segment List[Segments Left]
   S15.   Send the packet through one of the underlay links associated
          with the underlay interface identified by S.
   S16.   }
]]></artwork>
        </figure>

        <t/>

        <t>Note that the underlay interface and the associated links in step
        15 SHOULD be established before the associated End.XU SID is announced
        into the network.</t>

        <t>When forwarding packets through the underlay interface towards the
        remote endpoint node, the information required for layer-2
        encapsulation may be provisioned via mechanisms such as static
        Neighbor Discovery (ND) Cache. The details are out of the scope of
        this document.</t>

        <t>End.XU SIDs MAY be announced using IGP or BGP-LS in a similar way
        to the announcement of the End.X SIDs, while the information about the
        underlay connections and the associated End.XU SIDs need to be
        distinguished from the layer-3 links and the End.X SIDs. The detailed
        protocol extensions is out of the scope of this document, and will be
        described in a separate document. With the collected information of
        End.XU SIDs, the network controller or headend nodes could use the
        End.XU SIDs together with other types of SRv6 SIDs to build SRv6 SID
        lists for inter-layer TE paths.</t>
      </section>

      <section title="SRv6 END.BXC Behavior">
        <t>The "Endpoint Bound to an underlay Channel" behavior ("End.BXC" for
        short) is a variant of the SRv6 End behavior. It is an SRv6
        instantiation of a Binding SID. Any SID instance of this behavior is
        associated with an underlay tunnel (e.g.L1 channel) X. Typical types
        of the L1 channel include MTN, and OTN.</t>

        <t>This End.BXC SID can support the Penultimate Segment Pop (PSP) of
        the SRH, Ultimate Segment Pop (USP) of the SRH, and Ultimate Segment
        Decapsulation (USD) flavors defined in <xref target="RFC8986"/> either
        individually or in combinations. The SRH processing of the End.BXC
        behavior with PSP, USP, and USD is the same as <xref
        target="RFC8986"/></t>

        <t>When N receives a packet destined to S and S is a local End.BXC
        SID, the line S15 from the End processing defined in <xref
        target="RFC8986"/> is replaced by the following:</t>

        <t><figure>
            <artwork><![CDATA[S15  Forward the packet to the new destination via underlay tunnel X.           ]]></artwork>
          </figure></t>

        <t>Another option is an SRv6 End.BXC behavior may require additional
        information for its processing. This information may be encoded in the
        ARG part of the SID as defined in <xref target="RFC8986"/>.For
        example, the high bit part of ARG may be used to encode Channel Type,
        and the low bit part of ARG may be used to encapsulate Channel ID. The
        Channel is uniquely identified by channel type and channel ID. With
        this option, N gets the channel type and channel ID directly from the
        ARG, and then find the corresponding underlying channel. Using this
        option, the number of SID forwarding entries can be reduced.</t>

        <t>The End.BXC SIDs can be allocated either by a centralized network
        controller or by the network nodes, and the END.BXC SIDs MAY be
        announced via Netconf/YANG, BGP, and PCEP in a similar way to the
        announcement of the Binding SIDs. However, the association between the
        underlying connections and the BXC SID needs to be announced. The
        detailed protocol extensions are out of the scope of this document and
        will be described in a separate document.</t>
      </section>
    </section>

    <section title="Application of SRv6 Inter-Layer Programming">
      <t/>

      <section anchor="uif" title="IP and Optical Integration">
        <t>Assuming that an operator owns both the IP and optical network, and
        the operator needs to deploy E2E service across IP and optical
        network, with traditional approaches the planning and service
        provisioning would be complex and time consuming due of the manual
        synergy needed between the operator's IP team and optical team. With
        the introduction of SRv6 and the new SRv6 behaviors defined in this
        document, one simplified approach for IP and optical integration is to
        build a SRv6 SID list that integrates the path in both the IP layer
        and the optical layer.</t>

        <t>As the optical layer is not packet based, source routing mechanism
        can not be directly used in the optical network. However, the
        abstracted optical paths (e.g., with ODUk or DWDM) could be exposed to
        the control system of the IP network using either the SRv6 End.XU or
        SRv6 End.BXC SIDs (depends on the management and operation model
        chosen by the operator), and some of the attributes of the optical
        paths may also be provided. Based on this information, IP-optical
        inter-layer paths can be computed and programmed using SRv6 SID lists
        to meet some specific service requirements, such as low latency.</t>

        <figure>
          <artwork><![CDATA[             -----          -----          -----
            |  P1 |--------|  P2 |--------|  P3 |
             -----          -----          -----
            /  |.             |.             |.  \
    -----  /   | .            | .            | .  \ -----
   |  P7 |     |  .           |  .           |  .  |  P8 |
    ----- \    |   .          |   .          |   ./ -----
           \   |    .         |    .         |  / .
             -----   .      -----   .      -----   .
            |  P4 |-------|  P5 |--------|  P6 |   .
             -----    .     -----     .    -----     .
               .      .       .       .      .       .
               .    =====      .     =====    .     =====
                .  |  O1 |----------|  O2 |--------|  O3 |
                 .  =====        .   =====      .   =====
                  .    |          .    |         .    |
                   .   |           .   |          .   |
                    .  |            .  |           .  |
                     . |             . |            . |
                      .|              .|             .|
                    =====            =====          =====
                   |  O4 |----------|  O5 |--------|  O6 |
                    =====            =====          =====
          Figure 1. IP and Optical Layered Network Topology
]]></artwork>
        </figure>

        <t/>

        <t>In Figure 1, P1 to P8 are IP nodes, and O1 to O6 are optical nodes.
        Assume the operator needs to deploy a low latency path between P7 and
        P8. With normal segment routing, an IP layer path with the segment
        list {P7, P1, P2, P3, P8} can be used. If an optical path from O1 to
        O3 exists, the End.XU SID or End.BXC SID as defined in this document
        can be used to announce this optical path as an underlay interface or
        connection with specific attributes into the IP network. The headend
        node or the controller in IP layer can program an inter-layer TE path
        along {P7, P1, (O1, O2, O3), P3, P8} or {P7, P1, (O1, O2, O3), P3, P8}
        which could provide lower latency.</t>

        <t>The underlay optical path between O1 and O3 may be created in
        advance or as a result of the request from the IP layer. The creation
        should be done by the optical network controller (not shown in the
        figure). The details of the process are out of scope of this document,
        and may refer to <xref
        target="I-D.ietf-teas-actn-poi-applicability"/>.</t>

        <t>There is also another case of IP and Optical integration. Assume
        there are two optical paths between P1 and P2. One is {P1, O1, O2, P2}
        , and the other is {P1, O1, O4, O5, O2, P2}. With SRv6 inter-layer
        programming, two separate SRv6 inter-layer SIDs can be allocated for
        these two underlay connections respectively. One is P1::C2 for the
        underlay path {P1, O1, O2, P2}, and the other is P1::C45 for the path
        {P1, O1, O4, O5, O2, P2}. The headend P7 or the IP network controller
        will be informed about these two SRv6 SIDs and the associated path
        attributes, so that the headend or the controller can program
        different end-to-end inter-layer paths using SRv6 SID lists with
        different SRv6 inter-layer SIDs for services with different SLA
        requirements.</t>
      </section>

      <section title="IP and MTN Integration">
        <t>Assuming that an operator owns both an MTN network domain and an IP
        network domain. In the MTN network, each MTN node has both the layer-3
        functionality and the MTN Path layer functionality. In layer-3, all
        the MTN nodes are in a layer-3 network topology, which connects to the
        IP network domain. In the MTN Path Layer, a set of MTN paths are
        provisioned between the selected pairs of MTN nodes for traffic
        engineering. In the MTN network, different types of services may be
        carried using either a layer-3 path, an end-to-end MTN path, or an
        inter-layer path comprising of both the layer-3 links and the MTN
        paths as segments. In addition, For some type of services, end-to-end
        paths across the IP domain and the MTN domain are needed, which is
        comprised of both the layer-3 paths and the MTN path as different
        segments.</t>

        <t><figure>
            <artwork><![CDATA[ .......................................... ...........................
 .                                        . .                         .
 .          +----+     +----+     +----+  . . +----+     +----+       .
 .          | M1 |-----| M2 |-----| M3 |------| P1 |-----| P2 |       .
 .          +----+     +----+     +----+  . . +----+     +----+       .
 .         /  |          |          |     . .   |          |  \       .
 . +----+ /   |          |          |     . .   |          |   \+----+.
 . | M7 |/    |          |          |     . .   |          |    | P5 |.
 . +----+\    |          |          |     . .   |          |   /+----+.
 .        \   |          |          |     . .   |          |  /       .
 .         \+----+     +----+     +----+  . . +----+     +----+       .
 .          | M4 |-----| M5 |-----| M6 |------| P3 |-----| P4 |       .
 .          +----+     +----+     +----+  . . +----+     +----+       .
 .                                        . .                         .
 . Layer-3 Topology    MTN Network        . .        IP Network       .
 .                                        . ...........................
 ----------------------------------------------------------------------
 . MTN Path Layer Topology                .
 .                                        .
 .          +----+     +----+     +----+  .
 .          | M1'|################| M3'|  .                          
 .          +----+ ##  +----+  ## +----+  .
 .                   ##      ##           .
 . +----+              ##  ##             .
 . | M7'|                ##               .                 
 . +----+              ##  ##             .
 .                   ##      ##           .
 .          +----+ ##  +----+  ## +----+  .
 .          | M4'|################| M6'|  .
 .          +----+     +----+     +----+  .
 .                                        .
 .                                        .
 .......................................... 
         .
      Figure 2. A network with MTN Domain and IP Domain 
]]></artwork>
          </figure></t>

        <t>Figure 2 gives an example of a network with a MTN domain and an IP
        domain. M1 to M7 are MTN nodes, and P1 to P4 are IP nodes. The same
        set of MTN nodes builds two separate network layers. The topology in
        the IP layer shows the layer-3 connectivity between the MTN nodes and
        the connectivity with the IP network domain, while the topology in the
        MTN Path layer shows the MTN paths between the selected pair of MTN
        nodes. An end-to-end path from M7 to P5 can be established in layer-3
        using an SRv6 SID list representing the layer-3 path {M7, M1, M2, M3,
        P1, P2, P5}. While for services which require low latency, with SRv6
        inter-layer programming, an end-to-end path consisting of both the
        layer-3 segments and MTN paths could be established using an SRv6 SID
        list representing the inter-layer path {M7, M1::C3, P1, P2, P5}, where
        the SRv6 SID M1::C3 represents the underlay MTN path M1'-M3'.</t>

        <t>This shows that it is convenient to use integrated SRv6 SID lists
        to program inter-layer TE paths both within the MTN domain, and across
        the IP and MTN domain using the combination of SRv6 L3 SIDs and the
        SRv6 inter-layer SID.</t>
      </section>
    </section>

    <section anchor="security" title="Security Considerations">
      <t>The security considerations of SRv6 in <xref target="RFC8754"/> <xref
      target="RFC8986"/> apply to this document.</t>
    </section>

    <!-- security -->

    <section anchor="iana" title="IANA Considerations">
      <section title="SRv6 END.XU behavior">
        <t>This document defines a new SRv6 Endpoint behavior called
        END.XU.</t>

        <t>IANA has allocated the following code points for different flavors
        of End.XU from the "SRv6 Endpoint Behaviors" sub-registry in the
        "Segment-routing with IPv6 data plane (SRv6) Parameters" registry:</t>

        <t><figure>
            <artwork align="center"><![CDATA[
+------+--------+------------------------------------------+-----------+
| Value|  Hex   |             Endpoint Behavior            | Reference |
+------+--------+------------------------------------------+-----------+
|  150 | 0x0096 | End.XU                                   | [This ID] |
|  151 | 0x0097 | End.XU with PSP                          | [This ID] |
|  152 | 0x0098 | End.XU with USP                          | [This ID] |
|  153 | 0x0099 | End.XU with USD                          | [This ID] |
|  154 | 0x009A | End.XU with PSP, USP & USD               | [This ID] |
|  155 | 0x009B | End.XU with REPPLACE-CSID                | [This ID] |
|  156 | 0x009C | End.XU with REPPLACE-CSID & PSP          | [This ID] |
|  157 | 0x009D | End.XU with REPPLACE-CSID, PSP, USP & USD| [This ID] |
+------+--------+------------------------------------------+-----------+
]]></artwork>
          </figure></t>
      </section>

      <section title="SRv6 END.BXC behavior">
        <t>This document defines a new SRv6 Endpoint behavior called
        END.BXC.</t>

        <t>IANA has allocated the following code points for different flavors
        of End.BXC from the "SRv6 Endpoint Behaviors" sub-registry in the
        "Segment-routing with IPv6 data plane (SRv6) Parameters" registry:</t>

        <t><figure>
            <artwork align="center"><![CDATA[
+------+--------+------------------------------------------+-----------+
| Value|  Hex   |             Endpoint Behavior            | Reference |
+------+--------+------------------------------------------+-----------+
|  79  | 0x004F | End.BXC                                  | [This ID] |
|  80  | 0x0050 | End.BXC with PSP                         | [This ID] |
|  81  | 0x0051 | End.BXC with USP                         | [This ID] |
|  82  | 0x0052 | End.BXC with USD                         | [This ID] |
|  83  | 0x0053 | End.BXC with PSP, USP & USD              | [This ID] |
+------+--------+------------------------------------------+-----------+
]]></artwork>
          </figure></t>
      </section>
    </section>

    <section anchor="ack" title="Acknowledgements">
      <t>The authors would like to thank Xiaodong Chang, Yongjian Hu,
      Alexander Vainshtein, Ketan Talaulikar and Zhibo Hu for their review and
      comments.</t>
    </section>
  </middle>

  <back>
    <references title="Normative References">
      <?rfc include='reference.RFC.2119'?>

      <?rfc include='reference.RFC.8174'?>

      <?rfc include='reference.RFC.8754'?>

      <?rfc include='reference.RFC.8986'?>
    </references>

    <references title="Informative References">
      <?rfc include='reference.I-D.ietf-teas-actn-poi-applicability'?>

      <reference anchor="ITU-T_G.8310">
        <!-- the following is the minimum to make xml2rfc happy -->

        <front>
          <title>ITU-T G.8310: Architecture of the metro transport
          network</title>

          <author>
            <organization>ITU-T</organization>
          </author>

          <date month="December" year="2020"/>
        </front>

        <seriesInfo name=""
                    value="https://www.itu.int/rec/T-REC-G.8310-202012-I/en"/>
      </reference>
    </references>
  </back>
</rfc>