<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.21 (Ruby 3.3.6) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-watal-spring-srv6-sfc-sr-aware-functions-02" category="info" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.25.0 -->
  <front>
    <title abbrev="SRv6 SFC with SR-aware Functions">SRv6 SFC Architecture with SR-aware Functions</title>
    <seriesInfo name="Internet-Draft" value="draft-watal-spring-srv6-sfc-sr-aware-functions-02"/>
    <author initials="W." surname="Mishima" fullname="Wataru Mishima">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>w.mishima@ntt.com</email>
      </address>
    </author>
    <author initials="Y." surname="Fukagawa" fullname="Yuta Fukagawa">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>y.fukagawa@ntt.com</email>
      </address>
    </author>
    <date year="2025" month="January" day="31"/>
    <area>Routing</area>
    <workgroup>SPRING</workgroup>
    <keyword>SRv6</keyword>
    <keyword>SFC</keyword>
    <abstract>
      <?line 35?>

<t>This document describes the architecture of Segment Routing over IPv6 (SRv6) Service Function Chaining (SFC) with SR-aware functions.
This architecture provides the following benefits:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive Management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, so that reduces nodes and address resource consumption.</t>
        </li>
      </ul>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Source Packet Routing in Networking Working Group mailing list (spring@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/spring/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://https/github.com/watal"/>.</t>
    </note>
  </front>
  <middle>
    <?line 43?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>Segment Routing over IPv6 (SRv6) <xref target="RFC8986"/> enables packet steering through a set of instructions called a segment list.
Each SR segment endpoint node provides SRv6 Endpoint Behaviors, including Prefix/Adjacency Segments, VPNs, and Binding Segments.</t>
      <t>Service Function Chaining (SFC) <xref target="RFC7665"/> can be used in various scenarios (e.g. FW, IPS, IDS, NAT, and DPI).
SFC based on Segment Routing (SR) is defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>, which describes some SRv6 Endpoint Behaviors, such as End.AS/AD/AM, are necessary for using SR-unaware functions.</t>
      <t>This document describes an architecture for SRv6 SFC with SR-aware functions, which provides comprehensive management of SRv6 network resources and services.</t>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <section anchor="terminology-defined-in-related-rfcs-and-internet-drafts">
        <name>Terminology Defined in Related RFCs and Internet-Drafts</name>
        <t>The following terms are used in this document as defined in the related RFCs and Internet-Drafts:</t>
        <ul spacing="normal">
          <li>
            <t>SR, SR Domain, Segment ID (SID), SRv6, SR Policy, Prefix Segment, Adjacency Segment, Anycast Segment, Active Segment, and Distributed/Centralized/Hybrid Control Plane defined in <xref target="RFC8402"/>.</t>
          </li>
          <li>
            <t>SR Source Node, Transit Node, and SR Segment Endpoint Node defined in <xref target="RFC8754"/>.</t>
          </li>
          <li>
            <t>SRv6 Endpoint Behavior defined in <xref target="RFC8986"/>.</t>
          </li>
          <li>
            <t>SFC, SFC Proxy, and Service Classification Function defined in <xref target="RFC7665"/>.</t>
          </li>
          <li>
            <t>Service Segment, SR-Aware Service, SR-Unaware Service, End.AS, End.AD and End.AM defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>.</t>
          </li>
          <li>
            <t>Headend, Color, and Endpoint defined in <xref target="RFC9256"/>.</t>
          </li>
          <li>
            <t>Quality of Service (QoS), Service Level Agreement (SLA), and Service Level Objective (SLO) defined in <xref target="RFC9522"/>.</t>
          </li>
          <li>
            <t>Forwarding Plane, Control Plane, Management Plane, Application Plane defined in <xref target="RFC7426"/>.</t>
          </li>
          <li>
            <t>Path Computation Client (PCC), Path Computation Element (PCE), and Traffic Engineering Database (TED) defined in <xref target="RFC5440"/>.</t>
          </li>
          <li>
            <t>BGP Flow Specification defined in <xref target="RFC8955"/></t>
          </li>
        </ul>
      </section>
      <section anchor="newly-defined-terminology">
        <name>Newly Defined Terminology</name>
        <t>The following terms are used in this document as defined below:</t>
        <ul spacing="normal">
          <li>
            <t>Service Function Node: an SR segment endpoint node that provides SR-aware functions as service segments.</t>
          </li>
          <li>
            <t>SRv6 Controller: controls SRv6 Forwarding Plane, consisting of a PCE and a Classification Rule Controller.</t>
          </li>
          <li>
            <t>Classification Rule Controller: applies sets of SR Policy and flows to SR source nodes.</t>
          </li>
          <li>
            <t>Service Function Manager: configures network function instances, enables SR-aware functions as service segments, and collects network metrics.</t>
          </li>
        </ul>
      </section>
      <section anchor="requirements-language">
        <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"/> <xref target="RFC8174"/> when, and only when, they appear in all capitals, as shown here.</t>
      </section>
    </section>
    <section anchor="design-objectives-and-assumptions">
      <name>Design Objectives and Assumptions</name>
      <t>## Goals/Objectives
SRv6 SFC Architecture is designed with two main objectives:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive Management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.
When providing SRv6 services, meeting SLAs for each customer is required.
These SLAs consist of one or more SLOs such as availability, latency, and bandwidth.
In an SRv6 SFC network, service segment provisioning, link-state collection, and SR Policy calculation are required to meet SLOs, respectively.  </t>
          <t><xref target="RFC8402"/> outlines a hybrid control plane that merges a distributed control plane and a centralized control plane.
In this hybrid control plane, forwarding information like Node/Adjacency SIDs are advertised mutually by distributed SR nodes via IGPs such as ISIS and OSPF, while other information like SR Policies, classification rules, and service segments are provided by a centralized controller and manager.  </t>
          <t>
Software-Defined Networking (SDN) <xref target="RFC7426"/> provides centralized management of a network by a controller and a manager.
Centralized management reduces operational costs through abstraction and automation.
The SDN framework allows users to manage an SR domain without considering the details of a forwarding plane like a topology and node state.
Operators can use an SRv6 controller to build SR Policies for SFC and QoS, manage the state of network functions, issue service segments automatically, and specify disaster recovery with protection.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, so that reduces nodes and address resource consumption.
Network complexity increases operating costs.
Generally, using a variety of protocols in a network raises operational costs, including designing, building, monitoring, and troubleshooting.  </t>
          <t>
Using an SFC proxy may increase forwarding overhead due to additional header manipulations.</t>
        </li>
      </ul>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <t>To achieve these objectives, this architecture is based on two main assumptions:</t>
        <ul spacing="normal">
          <li>
            <t>Straightforward extension of the SRv6 network programming model  </t>
            <t>
The protocol used in this architecture is compatible with SRv6.
This streamlines the operation of services like traffic steering, including SFC, redundancy, and local protection.
Standardized protocols such as BGP, PCEP, IS-IS, OSPF, TI-LFA, and Anycast SID are used in this architecture.  </t>
            <t>
This architecture is SRv6 compliant, enabling support for SR-unaware functions, although SR-aware functions are expected to meet the objective.</t>
          </li>
          <li>
            <t>SDN framework compliance and comprehensive management of SRv6 SFC by controllers  </t>
            <t>
A controller is used to provide comprehensive management.
To simplify building and operating, the controller uses standardized protocols and abstracted service interfaces.
This also provides programmability by controlling policies that meet a user's intent including SFC and quality of service (QoS).</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="overview-of-architecture">
      <name>Overview of Architecture</name>
      <t>Figure 1 illustrates an overview of this architecture.</t>
      <figure anchor="overview">
        <name>Overview of SRv6 SFC Architecture with SR-aware Functions</name>
        <sourcecode type="drawing"><![CDATA[
 +----------------------- Application Plane ----------------------+
 |                        User Application                        |
 +-----------------------------------|----------------------------+
                                     |
 +- Control Plane (SRv6 Controller) -v-----+ +- Management Plane -+
 | +--------------+ +--------------------+ | | +----------------+ |
 | |Classification| |        Path        | | | |    Service     | |
 | |     Rule     | |     Computation    | | | |    Function    | |
 | |  Controller  | |    Element (PCE)   | | | |    Manager     | |
 | +------|-------+ +-^-------|--------^-+ | | +----------------+ |
 +--------|-----------|-------|--------|---+ +---------|----------+
          |           |       |        |               |
 +--------|-----------|-------|--------|---------------|---+
 | +------v-----------|-------v-+    +-|---------------v-+ |
 | |                            |    |      Service      | |
 | |       SR Source Node       |----|      Function     | |
 | |                            |    |        Node       | |
 | +----------------------------+    +-------------------+ |
 +------------------- Forwarding Plane --------------------+
]]></sourcecode>
      </figure>
      <t>This architecture is based on <xref target="RFC7426"/> and consists of forwarding plane, control plane, management plane, and application plane.</t>
      <ul spacing="normal">
        <li>
          <t>Forwarding Plane: classifies packets and encapsulates SRH, forwards them, and applies SRv6 Endpoint Behavior.
          </t>
          <ul spacing="normal">
            <li>
              <t>Provides SR-aware function using End.AN.</t>
            </li>
            <li>
              <t>Classify flow and apply them to TE application with PBR.</t>
            </li>
            <li>
              <t>Ensures redundancy with anycast.</t>
            </li>
            <li>
              <t>Ensure local protection with Fast Reroute (FRR).</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Control Plane: makes decisions about packet forwarding and provides rules for a forwarding plane.
          </t>
          <ul spacing="normal">
            <li>
              <t>Collects link-state including SRv6 locator, prefix, behavior, and delay.</t>
            </li>
            <li>
              <t>Calculates and provisioning SR Policies.</t>
            </li>
            <li>
              <t>Applies SR Policies to each flow by provisioning flow classification rules.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Management Plane: deploys and monitors network functions and devices.
          </t>
          <ul spacing="normal">
            <li>
              <t>Setups network functions.</t>
            </li>
            <li>
              <t>Collects metrics of devices, network functions, and SFC services.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Application Plane: provides APIs for users to use a control and management plane.
          </t>
          <ul spacing="normal">
            <li>
              <t>Provide an interface to operators or customers.</t>
            </li>
            <li>
              <t>Applying intents defined in <xref target="RFC9315"/>, including Operational, Rule, Service, and Flow intents.</t>
            </li>
          </ul>
        </li>
      </ul>
      <t>Each component communicates using standardized protocols.
These are designed to be loosely coupled and cooperate by using an abstraction layer.</t>
      <t>This document suggests handling a control plane by application plane, but a detailed design of an application plane is out of the scope of this document.
This is because application plane components and abstraction layers should be designed based on individual network utilization and operator intent.
In the following sections, details of a forwarding plane, control plane, and management plane are explained.</t>
    </section>
    <section anchor="forwarding-plane">
      <name>Forwarding Plane</name>
      <t>A forwarding plane provides SFC through packet classification, SRv6 encapsulation, and forwarding.
In this architecture, all forwarding plane components are located within the SR domain.</t>
      <figure anchor="fp">
        <name>Forwarding Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +-----------------------------------------------------------------+
 | +-----------+             +----------+             +----------+ |
 | |           | SRv6 Packet | Service  | SRv6 Packet | Service  | |
 | | SR Source |(S2,S1; SL:1)| Function |(S2,S1; SL:1)| Function | |
-->|    Node   |------------>|   Node   |------------>|   Node   |-->
 | |           |             |   (S1)   |             |   (S2)   | |
 | +-----------+             +----------+             +----------+ |
 +--------------------------- SR domain ---------------------------+
]]></sourcecode>
      </figure>
      <t>Figure 2 shows an example of SFC with two network functions.
Firstly, the SR source node classifies the flow and encapsulates it with an SRH containing the segment list &lt;S1, S2&gt;.
Next, the service function node (S1) receives the packet and applies a network function associated with an End.AN S1.
Finally, the service function node (S2) receives the packet and also applies a network function associated End.AN S2, thus achieving SFC.</t>
      <section anchor="endan-based-service-segment-provisioning">
        <name>End.AN-based Service Segment Provisioning</name>
        <t>End.AN provides an SR-aware function.</t>
        <t>Functions with the same role MAY be assigned as the same service segment within the SR domain.
By using Anycast SIDs, multiple nodes can be grouped as part of the same service segment.</t>
        <t>End.AN MAY have optional arguments.
This can provide additional programmability by embedding network function instructions in the segment list.</t>
        <t>By using virtualized spaces within routers or on generic servers, network functions can be provided at any node in an SR domain.
This allows for scaling and flexible redundancy of network functions.</t>
        <section anchor="when-a-network-function-goes-down">
          <name>When a Network Function Goes Down</name>
          <t>If a network function fails, the associated route MUST be removed immediately.
In the case of anycast configuration, the packet MUST be gracefully rerouted to other nodes.
If no alternative nodes are available, consider either dropping the packet and sending an ICMP Destination Unreachable message, or forwarding it as a pass-through.</t>
        </section>
        <section anchor="anycast-segment">
          <name>Anycast Segment</name>
          <t>The concept of the Anycast Segment is introduced in <xref target="RFC8402"/>.
In the SRv6 SFC, it realizes to provide the same network function segment as the same Anycast Segment.
In such cases, the state between network functions MUST be shared mutually.</t>
        </section>
        <section anchor="fast-reroute">
          <name>Fast Reroute</name>
          <t>The ordering of network functions in an SRv6 SFC is guaranteed by the segment list, even if an FRR occurs,
When an FRR occurs, if the Active segment is an Anycast SID, it MAY be forwarded to another service function node.
In such a case, since state synchronization may not have been completed, the network function MUST have a mechanism to handle rerouted packets, such as buffering to wait for synchronization.</t>
        </section>
      </section>
      <section anchor="service-function-chains">
        <name>Service Function Chains</name>
        <t>In this architecture, each SFC is represented as an SR Policy.
The purpose or intent of each SR Policy can be identified using attributes such as color or name.</t>
        <t>In general, SFC is achieved by using loose source routing.
If both SFC and QoS are desired, they can be achieved by using strict source routing or loose source routing with Flex-Algo SIDs.</t>
      </section>
      <section anchor="per-flow-encapsulation">
        <name>Per-Flow Encapsulation</name>
        <t>In an SR source node, which serves as the Service Classification Function, packets are classified on a per-flow basis using PBR and encapsulated with SR Policy.
Therefore, the SR source node MUST be capable of identifying packets using at least a 5-tuple or even more detailed information.</t>
        <t>In this architecture, aiming for comprehensive management, the Service Classification Function has an API to communicate with the controller.</t>
      </section>
    </section>
    <section anchor="control-plane">
      <name>Control Plane</name>
      <t>A control plane sets up a forwarding plane by creating SR policies, including SFCs, and applying them to each flow.</t>
      <figure anchor="cp">
        <name>Control Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +- Control Plane (SRv6 Controller) -------+
 | +--------------+ +--------------------+ |
 | |Classification| |        Path        | |
 | |     Rule     | |     Computation    | |
 | |  Controller  | |    Element (PCE)   | |
 | +------|-------+ +-^-------|--------^-+ |
 +--------|-----------|-------|--------|---+
  Classification link-state SR Policy link-state(Service Segment)
        Rule      (BGP-LS) (PCEP/BGP) (BGP-LS)
  (BGP Flowspec)      |       |        |
 +--------|-----------|-------|--------|-------------------+
 | +------v-----------|-------v-+    +-|-----------------+ |
 | |                            |    |      Service      | |
 | |       SR Source Node       |----|      Function     | |
 | |                            |    |        Node       | |
 | +----------------------------+    +-------------------+ |
 +------------------- Forwarding Plane --------------------+
]]></sourcecode>
      </figure>
      <t>The SRv6 Controller consists of the following two components:</t>
      <ul spacing="normal">
        <li>
          <t>PCE: provides SR Policies that fulfill SFC/QoS requirements from the headend to the tailend and sends them to the SR source node.</t>
        </li>
        <li>
          <t>Classification Rule Controller: provides an Encapsulation Policy that corresponds to a specific flow and SR Policy, and sends them to the SR source node.</t>
        </li>
      </ul>
      <section anchor="path-computation-element-pce">
        <name>Path Computation Element (PCE)</name>
        <t>PCE is a controller that provides SR Policy.
As an Active Stateful PCE, it establishes sessions with all PEs in an SR domain and manages SFCs.
SR Policies MUST support both explicit and dynamic paths.
For dynamic path, Constrained Shortest Path First (CSPF) considers not only SFC but also QoS.</t>
        <t>It acquires the Traffic Engineering Database (TED) of the SR domain using BGP-LS and deploys SR Policies via PCEP <xref target="RFC5440"/> or BGP SR Policy <xref target="I-D.draft-ietf-idr-segment-routing-te-policy"/>.
The BGP-LS service segment is required to calculate dynamic paths based on the state of service segments and network functions.</t>
      </section>
      <section anchor="classification-rule-controller">
        <name>Classification Rule Controller</name>
        <t>A Classification Rule Controller determines flows to apply specific SFC.</t>
        <t>The classification results are advertised to each SR source node as a set of flow, endpoints, and color with an extended protocol based on BGP Flowspec defined in <xref target="I-D.draft-ietf-idr-ts-flowspec-srv6-policy"/>.</t>
      </section>
    </section>
    <section anchor="management-plane">
      <name>Management Plane</name>
      <t>A management plane configures network function instances, enables SR-aware functions as service segments, monitors resources, and collects network metrics.
The details of each manager are outside the scope of this document, as the southbound interface of the management plane may be different for each service and hardware architecture.</t>
      <figure anchor="mp">
        <name>Management Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +-------------------- Function Managers ---------------------+
 | +-----------+ +--------------+ +-----------+ +-----------+ |
 | |  Service  | | Virtualized  | |    VNF    | |  Network  | |
 | |  Function | |Infrastructure| |  Manager  | |  Metric   | |
 | |  Manager  | |   Manager    | |           | |  Manager  | |
 | +-----|-----+ +------^-------+ +-----|-----+ +-----^-----+ |
 +-------|--------------|---------------|-------------|-------+
         |              |               |             |
             Management Plane Southbound Interfaces
         |              |               |             |
 +-------|--------------|---------------|-------------|--------+
 | +-----v--------------v---------------v-------------|------+ |
 | |                  Service Function Node                  | |
 | +---------------------------------------------------------+ |
 +------------------------- SR domain -------------------------+
]]></sourcecode>
      </figure>
      <t>Figure 4 shows examples of managers that MAY be added to a management plane:</t>
      <ul spacing="normal">
        <li>
          <t>Service Function Manager: provides an SID for a network service and manages this state.</t>
        </li>
        <li>
          <t>VNF Manager: handles deployment and scaling of network functions.
          </t>
          <ul spacing="normal">
            <li>
              <t>VNF Manager keeps links redundant and optimize link utilization.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>VIM: monitors hypervisor resources on service function nodes.
          </t>
          <ul spacing="normal">
            <li>
              <t>In SRv6 SFC, a hypervisor managed by a VIM MAY be located in virtualized spaces within routers or on generic servers.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Network Metrics Manager: collects metrics for SR Policy calculation and evaluation.
          </t>
          <ul spacing="normal">
            <li>
              <t>Metrics are collected from multiple data sources, including IPFIX, TCP statistics, and SRv6 path tracing <xref target="I-D.draft-filsfils-spring-path-tracing"/>.</t>
            </li>
            <li>
              <t>Metrics can be used for PCE calculation parameters.</t>
            </li>
          </ul>
        </li>
      </ul>
      <section anchor="service-function-manager">
        <name>Service Function Manager</name>
        <t>Service Function Manager enables and disables service segments of service function nodes.
To manage service segments, it utilizes the extensions provided in a BGP-LS service segment, as outlined in <xref target="I-D.draft-ietf-idr-bgp-ls-sr-service-segments"/> and TODO: draft-watal-idr-bgp-ls-sr-service-segments-enabler, and defines the following parameters:</t>
        <ul spacing="normal">
          <li>
            <t>Behavior: End.AN</t>
          </li>
          <li>
            <t>SID: the SID of End.AN (in IPv6 Address format). Service segments that support slicing are specified here as Flex-Algo SIDs.</t>
          </li>
          <li>
            <t>Function Name: type of network function</t>
          </li>
          <li>
            <t>Action: enable</t>
          </li>
          <li>
            <t>TLV:
            </t>
            <ul spacing="normal">
              <li>
                <t>Specification of the Anycast Group: when deploying multiple Network Functions within the same context, it MUST use the Anycast Group TLV to specify the same anycast group SID.</t>
              </li>
              <li>
                <t>Allows for the specification of unique parameters and context associated with a particular network function.</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-normative-references">
      <name>Normative References</name>
      <reference anchor="RFC8986">
        <front>
          <title>Segment Routing over IPv6 (SRv6) Network Programming</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="P. Camarillo" initials="P." role="editor" surname="Camarillo"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="Z. Li" initials="Z." surname="Li"/>
          <date month="February" year="2021"/>
          <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>Each instruction is implemented on one or several nodes in the network and identified by an SRv6 Segment Identifier in the packet.</t>
            <t>This document defines the SRv6 Network Programming concept and specifies the base set of SRv6 behaviors that enables the creation of interoperable overlays with underlay optimization.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8986"/>
        <seriesInfo name="DOI" value="10.17487/RFC8986"/>
      </reference>
      <reference anchor="RFC7665">
        <front>
          <title>Service Function Chaining (SFC) Architecture</title>
          <author fullname="J. Halpern" initials="J." role="editor" surname="Halpern"/>
          <author fullname="C. Pignataro" initials="C." role="editor" surname="Pignataro"/>
          <date month="October" year="2015"/>
          <abstract>
            <t>This document describes an architecture for the specification, creation, and ongoing maintenance of Service Function Chains (SFCs) in a network. It includes architectural concepts, principles, and components used in the construction of composite services through deployment of SFCs, with a focus on those to be standardized in the IETF. This document does not propose solutions, protocols, or extensions to existing protocols.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7665"/>
        <seriesInfo name="DOI" value="10.17487/RFC7665"/>
      </reference>
      <reference anchor="I-D.draft-ietf-spring-sr-service-programming">
        <front>
          <title>Service Programming with Segment Routing</title>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Shaowen Ma" initials="S." surname="Ma">
            <organization>Mellanox</organization>
          </author>
          <author fullname="Chaitanya Yadlapalli" initials="C." surname="Yadlapalli">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Wim Henderickx" initials="W." surname="Henderickx">
            <organization>Nokia</organization>
          </author>
          <author fullname="Stefano Salsano" initials="S." surname="Salsano">
            <organization>Universita di Roma "Tor Vergata"</organization>
          </author>
          <date day="23" month="August" year="2024"/>
          <abstract>
            <t>   This document defines data plane functionality required to implement
   service segments and achieve service programming in SR-enabled MPLS
   and IPv6 networks, as described in the Segment Routing architecture.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-spring-sr-service-programming-10"/>
      </reference>
      <reference anchor="RFC8402">
        <front>
          <title>Segment Routing Architecture</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
          <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
          <author fullname="B. Decraene" initials="B." surname="Decraene"/>
          <author fullname="S. Litkowski" initials="S." surname="Litkowski"/>
          <author fullname="R. Shakir" initials="R." surname="Shakir"/>
          <date month="July" year="2018"/>
          <abstract>
            <t>Segment Routing (SR) leverages the source routing paradigm. A node steers a packet through an ordered list of instructions, called "segments". A segment can represent any instruction, topological or service based. A segment can have a semantic local to an SR node or global within an SR domain. SR provides a mechanism that allows a flow to be restricted to a specific topological path, while maintaining per-flow state only at the ingress node(s) to the SR domain.</t>
            <t>SR can be directly applied to the MPLS architecture with no change to the forwarding plane. A segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels. The segment to process is on the top of the stack. Upon completion of a segment, the related label is popped from the stack.</t>
            <t>SR can be applied to the IPv6 architecture, with a new type of routing header. A segment is encoded as an IPv6 address. An ordered list of segments is encoded as an ordered list of IPv6 addresses in the routing header. The active segment is indicated by the Destination Address (DA) of the packet. The next active segment is indicated by a pointer in the new routing header.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8402"/>
        <seriesInfo name="DOI" value="10.17487/RFC8402"/>
      </reference>
      <reference anchor="RFC8754">
        <front>
          <title>IPv6 Segment Routing Header (SRH)</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="D. Dukes" initials="D." role="editor" surname="Dukes"/>
          <author fullname="S. Previdi" initials="S." surname="Previdi"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <date month="March" year="2020"/>
          <abstract>
            <t>Segment Routing can be applied to the IPv6 data plane using a new type of Routing Extension Header called the Segment Routing Header (SRH). This document describes the SRH and how it is used by nodes that are Segment Routing (SR) capable.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8754"/>
        <seriesInfo name="DOI" value="10.17487/RFC8754"/>
      </reference>
      <reference anchor="RFC9256">
        <front>
          <title>Segment Routing Policy Architecture</title>
          <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
          <author fullname="K. Talaulikar" initials="K." role="editor" surname="Talaulikar"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="A. Bogdanov" initials="A." surname="Bogdanov"/>
          <author fullname="P. Mattes" initials="P." surname="Mattes"/>
          <date month="July" year="2022"/>
          <abstract>
            <t>Segment Routing (SR) allows a node to steer a packet flow along any path. Intermediate per-path states are eliminated thanks to source routing. SR Policy is an ordered list of segments (i.e., instructions) that represent a source-routed policy. Packet flows are steered into an SR Policy on a node where it is instantiated called a headend node. The packets steered into an SR Policy carry an ordered list of segments associated with that SR Policy.</t>
            <t>This document updates RFC 8402 as it details the concepts of SR Policy and steering into an SR Policy.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9256"/>
        <seriesInfo name="DOI" value="10.17487/RFC9256"/>
      </reference>
      <reference anchor="RFC9522">
        <front>
          <title>Overview and Principles of Internet Traffic Engineering</title>
          <author fullname="A. Farrel" initials="A." role="editor" surname="Farrel"/>
          <date month="January" year="2024"/>
          <abstract>
            <t>This document describes the principles of traffic engineering (TE) in the Internet. The document is intended to promote better understanding of the issues surrounding traffic engineering in IP networks and the networks that support IP networking and to provide a common basis for the development of traffic-engineering capabilities for the Internet. The principles, architectures, and methodologies for performance evaluation and performance optimization of operational networks are also discussed.</t>
            <t>This work was first published as RFC 3272 in May 2002. This document obsoletes RFC 3272 by making a complete update to bring the text in line with best current practices for Internet traffic engineering and to include references to the latest relevant work in the IETF.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9522"/>
        <seriesInfo name="DOI" value="10.17487/RFC9522"/>
      </reference>
      <reference anchor="RFC7426">
        <front>
          <title>Software-Defined Networking (SDN): Layers and Architecture Terminology</title>
          <author fullname="E. Haleplidis" initials="E." role="editor" surname="Haleplidis"/>
          <author fullname="K. Pentikousis" initials="K." role="editor" surname="Pentikousis"/>
          <author fullname="S. Denazis" initials="S." surname="Denazis"/>
          <author fullname="J. Hadi Salim" initials="J." surname="Hadi Salim"/>
          <author fullname="D. Meyer" initials="D." surname="Meyer"/>
          <author fullname="O. Koufopavlou" initials="O." surname="Koufopavlou"/>
          <date month="January" year="2015"/>
          <abstract>
            <t>Software-Defined Networking (SDN) refers to a new approach for network programmability, that is, the capacity to initialize, control, change, and manage network behavior dynamically via open interfaces. SDN emphasizes the role of software in running networks through the introduction of an abstraction for the data forwarding plane and, by doing so, separates it from the control plane. This separation allows faster innovation cycles at both planes as experience has already shown. However, there is increasing confusion as to what exactly SDN is, what the layer structure is in an SDN architecture, and how layers interface with each other. This document, a product of the IRTF Software-Defined Networking Research Group (SDNRG), addresses these questions and provides a concise reference for the SDN research community based on relevant peer-reviewed literature, the RFC series, and relevant documents by other standards organizations.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7426"/>
        <seriesInfo name="DOI" value="10.17487/RFC7426"/>
      </reference>
      <reference anchor="RFC5440">
        <front>
          <title>Path Computation Element (PCE) Communication Protocol (PCEP)</title>
          <author fullname="JP. Vasseur" initials="JP." role="editor" surname="Vasseur"/>
          <author fullname="JL. Le Roux" initials="JL." role="editor" surname="Le Roux"/>
          <date month="March" year="2009"/>
          <abstract>
            <t>This document specifies the Path Computation Element (PCE) Communication Protocol (PCEP) for communications between a Path Computation Client (PCC) and a PCE, or between two PCEs. Such interactions include path computation requests and path computation replies as well as notifications of specific states related to the use of a PCE in the context of Multiprotocol Label Switching (MPLS) and Generalized MPLS (GMPLS) Traffic Engineering. PCEP is designed to be flexible and extensible so as to easily allow for the addition of further messages and objects, should further requirements be expressed in the future. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5440"/>
        <seriesInfo name="DOI" value="10.17487/RFC5440"/>
      </reference>
      <reference anchor="RFC8955">
        <front>
          <title>Dissemination of Flow Specification Rules</title>
          <author fullname="C. Loibl" initials="C." surname="Loibl"/>
          <author fullname="S. Hares" initials="S." surname="Hares"/>
          <author fullname="R. Raszuk" initials="R." surname="Raszuk"/>
          <author fullname="D. McPherson" initials="D." surname="McPherson"/>
          <author fullname="M. Bacher" initials="M." surname="Bacher"/>
          <date month="December" year="2020"/>
          <abstract>
            <t>This document defines a Border Gateway Protocol Network Layer Reachability Information (BGP NLRI) encoding format that can be used to distribute (intra-domain and inter-domain) traffic Flow Specifications for IPv4 unicast and IPv4 BGP/MPLS VPN services. This allows the routing system to propagate information regarding more specific components of the traffic aggregate defined by an IP destination prefix.</t>
            <t>It also specifies BGP Extended Community encoding formats, which can be used to propagate Traffic Filtering Actions along with the Flow Specification NLRI. Those Traffic Filtering Actions encode actions a routing system can take if the packet matches the Flow Specification.</t>
            <t>This document obsoletes both RFC 5575 and RFC 7674.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8955"/>
        <seriesInfo name="DOI" value="10.17487/RFC8955"/>
      </reference>
      <reference anchor="RFC2119">
        <front>
          <title>Key words for use in RFCs to Indicate Requirement Levels</title>
          <author fullname="S. Bradner" initials="S." surname="Bradner"/>
          <date month="March" year="1997"/>
          <abstract>
            <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="2119"/>
        <seriesInfo name="DOI" value="10.17487/RFC2119"/>
      </reference>
      <reference anchor="RFC8174">
        <front>
          <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
          <author fullname="B. Leiba" initials="B." surname="Leiba"/>
          <date month="May" year="2017"/>
          <abstract>
            <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="8174"/>
        <seriesInfo name="DOI" value="10.17487/RFC8174"/>
      </reference>
      <reference anchor="RFC9315">
        <front>
          <title>Intent-Based Networking - Concepts and Definitions</title>
          <author fullname="A. Clemm" initials="A." surname="Clemm"/>
          <author fullname="L. Ciavaglia" initials="L." surname="Ciavaglia"/>
          <author fullname="L. Z. Granville" initials="L. Z." surname="Granville"/>
          <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
          <date month="October" year="2022"/>
          <abstract>
            <t>Intent and Intent-Based Networking are taking the industry by storm. At the same time, terms related to Intent-Based Networking are often used loosely and inconsistently, in many cases overlapping and confused with other concepts such as "policy." This document clarifies the concept of "intent" and provides an overview of the functionality that is associated with it. The goal is to contribute towards a common and shared understanding of terms, concepts, and functionality that can be used as the foundation to guide further definition of associated research and engineering problems and their solutions.</t>
            <t>This document is a product of the IRTF Network Management Research Group (NMRG). It reflects the consensus of the research group, having received many detailed and positive reviews by research group participants. It is published for informational purposes.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9315"/>
        <seriesInfo name="DOI" value="10.17487/RFC9315"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-segment-routing-te-policy">
        <front>
          <title>Advertising Segment Routing Policies in BGP</title>
          <author fullname="Stefano Previdi" initials="S." surname="Previdi">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Paul Mattes" initials="P." surname="Mattes">
            <organization>Microsoft</organization>
          </author>
          <author fullname="Dhanendra Jain" initials="D." surname="Jain">
            <organization>Google</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   This document introduces a BGP SAFI with two NLRIs to advertise a
   candidate path of a Segment Routing (SR) Policy.  An SR Policy is an
   ordered list of segments (i.e., instructions) that represent a
   source-routed policy.  An SR Policy consists of one or more candidate
   paths, each consisting of one or more segment lists.  A headend may
   be provisioned with candidate paths for an SR Policy via several
   different mechanisms, e.g., CLI, NETCONF, PCEP, or BGP.  This
   document specifies how BGP may be used to distribute SR Policy
   candidate paths.  It defines sub-TLVs for the Tunnel Encapsulation
   Attribute for signaling information about these candidate paths.

   This documents updates RFC9012 with extensions to the Color Extended
   Community to support additional steering modes over SR Policy.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-segment-routing-te-policy-26"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-ts-flowspec-srv6-policy">
        <front>
          <title>Traffic Steering using BGP FlowSpec with SR Policy</title>
          <author fullname="Jiang Wenying" initials="J." surname="Wenying">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Yisong Liu" initials="Y." surname="Liu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Shunwan Zhuang" initials="S." surname="Zhuang">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Gyan Mishra" initials="G. S." surname="Mishra">
            <organization>Verizon Communications Inc.</organization>
          </author>
          <author fullname="Shuanglong Chen" initials="S." surname="Chen">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="6" month="January" year="2025"/>
          <abstract>
            <t>   BGP Flow Specification (FlowSpec) [RFC8955] and [RFC8956] has been
   proposed to distribute BGP [RFC4271] FlowSpec NLRI to FlowSpec
   clients to mitigate (distributed) denial-of-service attacks, and to
   provide traffic filtering in the context of a BGP/MPLS VPN service.
   Recently, traffic steering applications in the context of SR-MPLS and
   SRv6 using FlowSpec also attract attention.  This document introduces
   the usage of BGP FlowSpec to steer packets into an SR Policy.


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-ts-flowspec-srv6-policy-05"/>
      </reference>
      <reference anchor="I-D.draft-filsfils-spring-path-tracing">
        <front>
          <title>Path Tracing in SRv6 networks</title>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Ahmed Abdelsalam" initials="A." surname="Abdelsalam">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Pablo Camarillo" initials="P." surname="Camarillo">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Mark Yufit" initials="M." surname="Yufit">
            <organization>Broadcom</organization>
          </author>
          <author fullname="Thomas Graf" initials="T." surname="Graf">
            <organization>Swisscom</organization>
          </author>
          <author fullname="Yuanchao Su" initials="Y." surname="Su">
            <organization>Alibaba, Inc</organization>
          </author>
          <author fullname="Satoru Matsushima" initials="S." surname="Matsushima">
            <organization>SoftBank</organization>
          </author>
          <author fullname="Mike Valentine" initials="M." surname="Valentine">
            <organization>Goldman Sachs</organization>
          </author>
          <author fullname="Amit Dhamija" initials="" surname="Dhamija">
            <organization>Arrcus</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   Path Tracing provides a record of the packet path as a sequence of
   interface ids.  In addition, it provides a record of end-to-end
   delay, per-hop delay, and load on each egress interface along the
   packet delivery path.

   Path Tracing allows to trace 14 hops with only a 40-bytes IPv6 Hop-
   by-Hop extension header.

   Path Tracing supports fine grained timestamp.  It has been designed
   for linerate hardware implementation in the base pipeline.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-filsfils-spring-path-tracing-05"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-bgp-ls-sr-service-segments">
        <front>
          <title>BGP-LS Advertisement of Segment Routing Service Segments</title>
          <author fullname="Gaurav Dawra" initials="G." surname="Dawra">
            <organization>LinkedIn</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Jim Uttaro" initials="J." surname="Uttaro">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Hani Elmalky" initials="H." surname="Elmalky">
            <organization>Ericsson</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>Capitalonline</organization>
          </author>
          <author fullname="Jim Guichard" initials="J." surname="Guichard">
            <organization>Futurewei Technologies</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="5" month="November" year="2022"/>
          <abstract>
            <t>   Service functions are deployed as, physical or virtualized elements
   along with network nodes or on servers in data centers.  Segment
   Routing (SR) brings in the concept of segments which can be
   topological or service instructions.  Service segments are SR
   segments that are associated with service functions.  SR Policies are
   used for the setup of paths for steering of traffic through service
   functions using their service segments.

   BGP Link-State (BGP-LS) enables distribution of topology information
   from the network to a controller or an application in general so it
   can learn the network topology.  This document specifies the
   extensions to BGP-LS for the advertisement of service functions along
   their associated service segments.  The BGP-LS advertisement of
   service function information along with the network nodes that they
   are attached to, or associated with, enables controllers compute and
   setup service paths in the network.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-bgp-ls-sr-service-segments-02"/>
      </reference>
    </references>
    <?line 322?>

<section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors would like to acknowledge the review and inputs from Mitsuru Maruyama, Katsuhiro Sebayashi, Yuma Ito, and Taisei Tanabe.
We partially obtained the research results from NICT's commissioned research No.JPJ012368C03101 and JST's CRONOS No.JPMJCS24N9.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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

-->

</rfc>
