<?xml version="1.0" encoding="UTF-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.17 (Ruby 2.6.10) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>


<rfc ipr="trust200902" docName="draft-ietf-teas-ns-ip-mpls-04" category="info" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="IP/MPLS Network Slicing">Realizing Network Slices in IP/MPLS Networks</title>

    <author initials="T." surname="Saad" fullname="Tarek Saad">
      <organization>Cisco Systems Inc.</organization>
      <address>
        <email>tsaad.net@gmail.com</email>
      </address>
    </author>
    <author initials="V." surname="Beeram" fullname="Vishnu Pavan Beeram">
      <organization>Juniper Networks</organization>
      <address>
        <email>vbeeram@juniper.net</email>
      </address>
    </author>
    <author initials="J." surname="Dong" fullname="Jie Dong">
      <organization>Huawei Technologies</organization>
      <address>
        <email>jie.dong@huawei.com</email>
      </address>
    </author>
    <author initials="B." surname="Wen" fullname="Bin Wen">
      <organization>Comcast</organization>
      <address>
        <email>Bin_Wen@cable.comcast.com</email>
      </address>
    </author>
    <author initials="D." surname="Ceccarelli" fullname="Daniele Ceccarelli">
      <organization>Cisco Systems Inc.</organization>
      <address>
        <email>daniele.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="J." surname="Halpern" fullname="Joel Halpern">
      <organization>Ericsson</organization>
      <address>
        <email>joel.halpern@ericsson.com</email>
      </address>
    </author>
    <author initials="S." surname="Peng" fullname="Shaofu Peng">
      <organization>ZTE Corporation</organization>
      <address>
        <email>peng.shaofu@zte.com.cn</email>
      </address>
    </author>
    <author initials="R." surname="Chen" fullname="Ran Chen">
      <organization>ZTE Corporation</organization>
      <address>
        <email>chen.ran@zte.com.cn</email>
      </address>
    </author>
    <author initials="X." surname="Liu" fullname="Xufeng Liu">
      <organization>IBM Corporation</organization>
      <address>
        <email>xufeng.liu.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="L." surname="Contreras" fullname="Luis M. Contreras">
      <organization>Telefonica</organization>
      <address>
        <email>luismiguel.contrerasmurillo@telefonica.com</email>
      </address>
    </author>
    <author initials="R." surname="Rokui" fullname="Reza Rokui">
      <organization>Ciena</organization>
      <address>
        <email>rrokui@ciena.com</email>
      </address>
    </author>
    <author initials="L." surname="Jalil" fullname="Luay Jalil">
      <organization>Verizon</organization>
      <address>
        <email>luay.jalil@verizon.com</email>
      </address>
    </author>

    <date year="2024" month="May" day="28"/>

    
    <workgroup>TEAS Working Group</workgroup>
    <keyword>Internet-Draft</keyword>

    <abstract>


<t>Realizing network slices may require the Service Provider to have the ability to
partition a physical network into multiple logical networks of varying sizes,
structures, and functions so that each slice can be dedicated to specific
services or customers. Multiple network slices can be realized on the same
network while ensuring slice elasticity in terms of network resource
allocation. This document describes a scalable solution to realize network
slicing in IP/MPLS networks by supporting multiple services on top of a single
physical network by relying on compliant domains and nodes to provide
forwarding treatment (scheduling, drop policy, resource usage) on to packets
that carry identifiers that indicate the slicing service that is to be applied
to the packets.</t>



    </abstract>



  </front>

  <middle>


<section anchor="introduction"><name>Introduction</name>

<t>Network slicing allows a Service Provider to create independent and logical
networks on top of a shared physical network infrastructure. Such network
slices can be offered to customers or used internally by the Service Provider
to enhance the delivery of their service offerings. A Service Provider can also
use network slicing to structure and organize the elements of its
infrastructure. The solution discussed in this document works with any path
control technology (such as RSVP-TE, or SR) that can be used by a Service Provider
to realize network slicing in IP/MPLS networks.</t>

<t><xref target="RFC9543"/> provides the definition of a network
slice for use within the IETF and discusses the general framework for
requesting and operating IETF Network Slices, their characteristics, and the
necessary system components and interfaces. It also  discusses the function of
an IETF Network Slice Controller and the requirements on its northbound and
southbound interfaces.</t>

<t>This document introduces the notion of a Slice-Flow Aggregate which comprises
of one or more IETF network slice traffic streams. It also describes the
Network Resource Partition (NRP) and the NRP Policy that can be used to
instantiate control and data plane behaviors on select topological elements
associated with the NRP that supports a Slice-Flow
Aggregate - refer <xref target="SliceDefinition"/> for further details.</t>

<t>The IETF Network Slice Controller is responsible for the aggregation of
multiple IETF network traffic streams into a Slice-Flow Aggregate, and for
maintaining the mapping required between them. The mechanisms used by the
controller to determine the mapping of one or more IETF network slice to a
Slice-Flow Aggregate are outside the scope of this document. The focus of this
document is on the mechanisms required at the device level to address the
requirements of network slicing in packet networks.</t>

<t>In a Diffserv (DS) domain <xref target="RFC2475"/>, packets requiring the same forwarding
treatment (scheduling and drop policy) are classified and marked with the
respective Class Selector (CS) Codepoint (or the Traffic Class (TC) field for
MPLS packets <xref target="RFC5462"/>) at the DS domain ingress nodes.  Such packets are
said to belong to a Behavior Aggregate (BA) that has a common set of behavioral
characteristics or a common set of delivery requirements.  At transit nodes,
the CS is inspected to determine the specific forwarding treatment to be
applied before the packet is forwarded.  A similar approach is adopted in this
document to realize network slicing. The solution proposed in this document
does not mandate Diffserv to be enabled in the network to provide a specific
forwarding treatment. If Diffserv is enabled within the network, the Slice-Flow
Aggregate traffic can further carry a Diffserv CS to enable differentiation of
forwarding treatments for packets within a Slice-Flow Aggregate.</t>

<t>When logical networks associated with an NRP are realized on top of a shared
physical network infrastructure, it is important to steer traffic on the
specific network resources partition that is allocated for a given Slice-Flow
Aggregate.  In packet networks, the packets of a specific Slice-Flow Aggregate
may be identified by one or more specific fields carried within the packet. An
NRP ingress boundary node (where Slice-Flow Aggregate traffic enters the NRP)
populates the respective field(s) in packets that are
mapped to a Slice-Flow Aggregate in order to allow interior NRP nodes to
identify and apply the specific Per NRP Hop Behavior (NRP-PHB) associated with the
Slice-Flow Aggregate. The NRP-PHB defines the scheduling treatment and, in some
cases, the packet drop probability.</t>

<t>This document covers different modes of NRPs and discusses how
each mode can ensure proper placement of Slice-Flow Aggregate paths
and respective treatment of Slice-Flow Aggregate traffic.</t>

<section anchor="terminology"><name>Terminology</name>

<t>The reader is expected to be familiar with the terminology specified in
<xref target="RFC9543"/>.</t>

<t>The following terminology is used in the document:</t>

<dl newline="true">
  <dt>IETF Network Slice:</dt>
  <dd>
    <t>refer to the definition of 'IETF network slice' in 
<xref target="RFC9543"/>.</t>
  </dd>
  <dt>IETF Network Slice Controller (NSC):</dt>
  <dd>
    <t>refer to the definition in <xref target="RFC9543"/>.</t>
  </dd>
  <dt>Network Resource Partition:</dt>
  <dd>
    <t>refer to the definition in <xref target="RFC9543"/>.</t>
  </dd>
  <dt>Slice-Flow Aggregate:</dt>
  <dd>
    <t>a collection of packets that are mapped to an NRP and are given the same
forwarding treatment; a Slice-Flow Aggregate comprises of one or more IETF
network slice traffic streams from one or more connectivity constructs
(belonging to one or more IETF network slices); the mapping of one or more IETF
network slice streams to a Slice-Flow Aggregate is maintained by the IETF Network
Slice Controller.  The boundary nodes MAY also maintain a mapping of specific
IETF network slice service(s) to a SFA.</t>
  </dd>
  <dt>Network Resource Partition Policy (NRP):</dt>
  <dd>
    <t>a policy construct that enables instantiation of mechanisms in support 
of IETF network slice specific control and data plane behaviors 
on select topological elements; the enforcement of an NRP Policy 
results in the creation of an NRP.</t>
  </dd>
  <dt>NRP Identifier (NRP-ID):</dt>
  <dd>
    <t>an identifier that is globally unique within an NRP domain and that can
be used in the control or management plane to identify the resources associated with the NRP.</t>
  </dd>
  <dt>NRP Capable Node:</dt>
  <dd>
    <t>a node that supports one of the NRP modes described in this document.</t>
  </dd>
  <dt>NRP Incapable Node:</dt>
  <dd>
    <t>a node that does not support any of the NRP modes described in this document.</t>
  </dd>
  <dt>Slice-Flow Aggregate Path:</dt>
  <dd>
    <t>a path that is setup over the NRP that is associated with a specific Slice-Flow Aggregate.</t>
  </dd>
  <dt>Slice-Flow Aggregate Packet:</dt>
  <dd>
    <t>a packet that traverses over the NRP that is associated with a specific Slice-Flow Aggregate.</t>
  </dd>
  <dt>NRP Filtered Topology:</dt>
  <dd>
    <t>a set of topological elements associated with a Network Resource Partition.</t>
  </dd>
  <dt>NRP state aware TE (NRP-TE):</dt>
  <dd>
    <t>a mechanism for TE path selection that takes into account the available network resources associated with a specific NRP.</t>
  </dd>
</dl>

</section>
<section anchor="acronyms-and-abbreviations"><name>Acronyms and Abbreviations</name>

<ul empty="true"><li>
  <t>BA: Behavior Aggregate</t>
</li></ul>

<ul empty="true"><li>
  <t>CS: Class Selector</t>
</li></ul>

<ul empty="true"><li>
  <t>NRP-PHB: NRP Per Hop Behavior as described in <xref target="SlicePHB"/></t>
</li></ul>

<ul empty="true"><li>
  <t>SLA: Service Level Agreements</t>
</li></ul>

<ul empty="true"><li>
  <t>SLO: Service Level Objectives</t>
</li></ul>

<ul empty="true"><li>
  <t>SLE: Service Level Expectations</t>
</li></ul>

<ul empty="true"><li>
  <t>Diffserv: Differentiated Services</t>
</li></ul>

<ul empty="true"><li>
  <t>MPLS: Multiprotocol Label Switching</t>
</li></ul>

<ul empty="true"><li>
  <t>LSP: Label Switched Path</t>
</li></ul>

<ul empty="true"><li>
  <t>RSVP: Resource Reservation Protocol</t>
</li></ul>

<ul empty="true"><li>
  <t>TE: Traffic Engineering</t>
</li></ul>

<ul empty="true"><li>
  <t>SR: Segment Routing</t>
</li></ul>

<ul empty="true"><li>
  <t>VRF: VPN Routing and Forwarding</t>
</li></ul>

<ul empty="true"><li>
  <t>AC: Attachment Circuit</t>
</li></ul>

<ul empty="true"><li>
  <t>CE: Customer Edge</t>
</li></ul>

<ul empty="true"><li>
  <t>PE: Provider Edge</t>
</li></ul>

<ul empty="true"><li>
  <t>PCEP: Path Computation Element (PCE) Communication Protocol (PCEP)</t>
</li></ul>

</section>
</section>
<section anchor="network-resource-slicing-membership"><name>Network Resource Slicing Membership</name>

<t>An NRP that supports a Slice-Flow Aggregate can be
instantiated over parts of an IP/MPLS network (e.g., all or specific network
resources in the access, aggregation, or core network), and can stretch across
multiple domains administered by a provider.  The NRP topology may
be comprised of dedicated and/or shared network resources (e.g., in
terms of processing power, storage, and bandwidth).</t>

<t>The physical network resources may be fully dedicated to a specific Slice-Flow
Aggregate.  For example, traffic belonging to a Slice-Flow Aggregate can traverse
dedicated network resources without being subjected to contention from traffic of
other Slice-Flow Aggregates.  Dedicated physical network resource slicing allows for simple
partitioning of the physical network resources amongst Slice-Flow Aggregates without
the need to distinguish packets traversing the dedicated network resources
since only one Slice-Flow Aggregate traffic stream can traverse the dedicated
resource at any time.</t>

<t>To optimize network utilization, sharing of the physical network resources may
be desirable. In such case, the same physical network resource capacity is
divided among multiple NRPs that support multiple Slice-Flow
Aggregates. The shared physical network resources can be
partitioned in the data plane (for example by applying hardware policers and
shapers) and/or partitioned in the control plane by providing a logical
representation of the physical link that has a subset of the network resources
available to it.</t>

</section>
<section anchor="NSRealization"><name>IETF Network Slice Realization</name>

<t><xref target="ns-workflow"/> describes the steps required to realize an IETF network slice
service in a provider network  using the solution proposed in this document.
While Figure 4 of <xref target="RFC9543"/> provides an abstract
architecture of an IETF Network Slice, this section intends to offer a
realization of that architecture specific for IP/MPLS packet networks.</t>

<t>Each of the steps is further elaborated on in a subsequent section.</t>

<figure title="IETF network slice realization steps." anchor="ns-workflow"><artwork><![CDATA[
                        --      --      --
                       |CE|    |CE|    |CE|
                        --      --      --
                      AC :    AC :    AC :
                      ----------------------       -------
                     ( |PE|....|PE|....|PE| )     ( IETF  )
    IETF Network    (   --:     --     :--   )   ( Network )
    Slice Service   (     :............:     )   (  Slice  )
    Request          (  IETF Network Slice  )     (       )  Customer
      v               ----------------------       -------     View
      v        ............................\........./...............
      v                                     \       /        Provider
      v    >>>>>>>>>>>>>>>  Slice-Flow       \     /           View
      v   ^                 Aggregate Mapping v   v
      v   ^             -----------------------------------------
      v   ^            ( |PE|.......|PE|........|PE|.......|PE|  )
     ---------        (   --:        --         :--         --    )
    |         |       (     :...................:                 )
    |   NSC   |        (        Network Resource Partition       )
    |         |         -----------------------------------------
    |         |                             ^
    |         |>>>>>  Resource Partitioning |
     ---------          of Filtered Topology|
      v   v                                 |
      v   v            -----------------------------      --------
      v   v           (|PE|..-..|PE|... ..|PE|..|PE|)    (        )
      v   v          ( :--  |P|  --   :-:  --   :--  )  (  Filter  )
      v   v          ( :.-   -:.......|P|       :-   )  ( Topology )
      v   v          (  |P|...........:-:.......|P|  )   (        )
      v   v           (  -    Filtered Topology      )     --------
      v   v            -----------------------------       ^
      v    >>>>>>>>>>>>  Topology Filter ^                /
      v        ...........................\............../...........
      v                                    \            /  Underlay
     ----------                             \          /  (Physical)
    |          |                             \        /    Network
    | Network  |    ----------------------------------------------
    |Controller|   ( |PE|.....-.....|PE|......    |PE|.......|PE| )
    |          |  (   --     |P|     --      :-...:--     -..:--   )
     ----------  (    :       -:.............|P|.........|P|        )
         v       (    -......................:-:..-       -         )
          >>>>>>> (  |P|.........................|P|......:        )
      Program the  (  -                           -               )
        Network     ----------------------------------------------
                             (NRP Policies and Paths)*

 * : NRP Policy installation and path placement can be centralized
     or distributed.
]]></artwork></figure>

<section anchor="network-topology-filters"><name>Network Topology Filters</name>

<t>The Physical Network may be filtered into a number of Filter
Topologies.  Filter actions may include selection of specific nodes
and links according to their capabilities and are based on network-
wide policies.  The resulting topologies can be used to host IETF
Network Slices and provide a useful way for the network operator to
know that all of the resources they are using to plan a network
slice meet specific SLOs.  This step can be done offline during
planning activity, or could be performed dynamically
as new demands arise.</t>

<t><xref target="SlicePolicyTopology"/> describes how topology filters can be
associated with the NRP instantiated by the NRP Policy.</t>

</section>
<section anchor="NetworkSliceServiceRequest"><name>IETF Network Slice Service Request</name>

<t>The customer requests an IETF Network Slice Service specifying the
CE-AC-PE points of attachment, the connectivity matrix, and the
SLOs/SLEs as described in <xref target="RFC9543"/>.
These capabilities are always provided based on a Service Level Agreement (SLA)
between the network slice costumer and the provider.</t>

<t>This defines the traffic flows that need to be supported
when the slice is realized.  Depending on the mechanism and
encoding of the Attachment Circuit (AC), the IETF Network Slice Service may also include
information that will allow the operator's controllers to configure
the PEs to determine what customer traffic is intended
for this IETF Network Slice.</t>

<t>IETF Network Slice Service Requests are likely to arrive at various
times in the life of the network, and may also be modified.</t>

</section>
<section anchor="SliceAggregateMapping"><name>Slice-Flow Aggregation</name>

<t>A network may be called upon to support very many IETF Network
Slices, and this could present scaling challenges in the operation
of the network.  In order to overcome this, the IETF Network Slice
streams may be aggregated into groups according to similar characteristics.</t>

<t>A Slice-Flow Aggregate is a construct that comprises the traffic flows of one or
more IETF Network Slices. The mapping of IETF Network Slices into an Slice-Flow
Aggregate is a matter of local operator policy is a function executed by the
Controller.  The Slice-Flow Aggregate may be preconfigured, created on demand, or
modified dynamically.</t>

</section>
<section anchor="PathPlacement"><name>Path Placement over NRP Filtered Topology</name>

<t>Depending on the underlying network technology, the paths are selected in the
network in order to best deliver the SLOs for the different services carried by
the Slice-Flow Aggregate.  The path placement function (carried on ingress node
or by a controller) is performed on the Filtered Topology that is
selected to support the Slice-Flow Aggregate.</t>

<t>Note that this step may indicate the need to increase the capacity of the
underlying Filtered Topology or to create a new Filtered Topology.</t>

</section>
<section anchor="nrp-policy"><name>NRP Policy</name>

<t>An NRP policy is a policy construct that enables instantiation of mechanisms in support of service
specific control and data plane behaviors on select topological
elements associated with the NRP.</t>

<t>The NRP Policy is a construct that enables the instantiation of control and
data plane behaviors on select topological elements in support of the IETF
network slice service. The NRP Policy encompasses policy actions (see <xref target="SliceDefinition"/>) that
manage the specific resources in the network associated with the NRP.</t>

</section>
<section anchor="nrp-policy-installation"><name>NRP Policy Installation</name>

<t>A Controller function programs the physical network with the NRP policies to define specific handling
for traffic flows belonging to the Slice-Flow Aggregate.  These NRP policies may
be consumed on select topological elements in the network and as a result
define how routers handle traffic for the Slice-Flow Aggregate associated with
the NRP.</t>

<t>For example, the routers that instantiate the NRP Policy can correlate markers
that are present in packets that belong to the Slice-Flow Aggregate and apply
specific treatments to them.</t>

<t>The way in which the NRP Policy is installed in the routers and the way that
the traffic is marked is implementation specific.  The NRP Policy instantiation
in the network is further described in <xref target="SlicePolicyInstantiation"/>.</t>

</section>
<section anchor="path-instantiation"><name>Path Instantiation</name>

<t>Depending on the underlying network technology, a Controller function may
install the forwarding state specific to the Slice-Flow Aggregate so that traffic is
routed along paths derived in the Path Placement step described in
<xref target="PathPlacement"/>.  The way in which the paths are instantiated is
implementation specific.</t>

</section>
<section anchor="service-mapping"><name>Service Mapping</name>

<t>The edge points can be configured to support the network slice service by
mapping the customer traffic to Slice-Flow Aggregates, possibly using
information supplied when the IETF network slice service was requested.  The
edge points may also be instructed to mark the packets so that the network
routers will know which policies and routing instructions to apply.
The steering of traffic onto Slice-Flow Aggregate paths is further described in <xref target="TrafficToSFAPath"/>.</t>

</section>
</section>
<section anchor="SliceModes"><name>Network Resource Partition Modes</name>

<t>An NRP Policy can be used to dictate if the network resource partitioning
of the shared network resources among multiple Slice-Flow Aggregates can be achieved:</t>

<t><list style="format %c)" counter="bar">
  <t>in data plane only,</t>
  <t>in control plane only, or</t>
  <t>in both control and data planes.</t>
</list></t>

<section anchor="DataplaneSlicing"><name>Data plane Network Resource Partition Mode</name>

<t>The physical network resources can be partitioned on network devices
by applying a Per Hop forwarding Behavior (PHB) onto packets that traverse the
network devices.</t>

<t>When data plane NRP mode is applied, packets need to be forwarded on the
specific NRP that supports the Slice-Flow Aggregate to ensure the proper
forwarding treatment dictated in the NRP Policy is applied (refer to
<xref target="SliceDefinition"/> below).  In this case, an NRP Selector
must be carried in each packet to identify the Slice-Flow Aggregate that
it belongs to.</t>

<t>The ingress node of an NRP domain adds an NRP Selector field (if not already
present) in each Slice-Flow Aggregate packet. In the data plane NRP mode, the
transit nodes within an NRP domain use the NRP Selector to associate packets with a
Slice-Flow Aggregate and to determine the Network Resource Partition Per Hop
Behavior (NRP-PHB) that is applied to the packet (refer to <xref target="SlicePHB"/> for
further details). The CS MAY be used to apply a Diffserv PHB on to the packet to
allow differentiation of traffic treatment within the same Slice-Flow
Aggregate.</t>

<t>When data plane only NRP mode is used, routers may rely on a
network state independent view of the topology to determine the best paths.
In this case, the best path selection dictates the
forwarding path of packets to the destination. The NRP Selector field carried in each
packet determines the specific NRP-PHB treatment along the
selected path.</t>

</section>
<section anchor="control-plane-network-resource-partition-mode"><name>Control Plane Network Resource Partition Mode</name>

<t>Multiple NRPs can be realized over the same set of physical resources.  Each
NRP is identified by an identifier (NRP-ID) that is globally unique within the
NRP domain. The NRP state reservations for each NRP can be maintained on the
network element or on a controller.</t>

<t>The network reservation states for a specific partition can be represented
in a topology that contains all or a subset of the physical network
elements (nodes and links) and reflect the network state reservations in
that NRP. The logical network resources that appear in the NRP topology can
reflect a part, whole, or in-excess of the physical network resource capacity
(e.g., when oversubscription is desirable).</t>

<t>For example, the physical link bandwidth can be
divided into fractions, each dedicated to an NRP that supports a Slice-Flow Aggregate.
The topology associated with the NRP supporting a Slice-Flow Aggregate
can be used by routing protocols, or by the ingress/PCE when computing NRP state
aware TE paths.</t>

<t>To perform NRP state aware Traffic Engineering (NRP-TE), the resource reservation
on each link needs to be NRP aware. The NRP reservations state can be managed
locally on the device or off device (e.g. on a controller).</t>

<t>The same physical link may be member of multiple slice policies that
instantiate different NRPs. The NRP
reservable or utilized bandwidth on such a link is updated (and may be
advertised) whenever new paths are placed in the network. The NRP
reservation state, in this case, is maintained on each device or off the
device on a resource reservation manager that holds reservation states for
those links in the network.</t>

<t>Multiple NRPs that support Slice-Flow Aggregates can form a group and share the available network
resources allocated to each. In this case, a node can update
the reservable bandwidth for each NRP to take into consideration
the available bandwidth from other NRPs in the same group.</t>

<t>For illustration purposes, <xref target="resource-sharing"/> describes bandwidth partitioning
or sharing amongst a group of NRPs. In Figure 2a, the NRPs identified by the following NRP-IDs:
NRP1, NRP2, NRP3 and NRP4 are not sharing any bandwidths between each
other. In Figure 2b, the NRPs: NRP1 and NRP2 can share the
available bandwidth portion allocated to each amongst them.
Similarly, NRP3 and NRP4 can share amongst themselves any available bandwidth
allocated to them, but they cannot share available bandwidth allocated to
NRP1 or NRP2.  In both cases, the Max Reservable Bandwidth may exceed the
actual physical link resource capacity to allow for over subscription.</t>

<figure title="Bandwidth isolation/sharing among NRPs." anchor="resource-sharing"><artwork><![CDATA[
  I-----------------------------I     I-----------------------------I 
  <--NRP1->                     I     I-----------------I           I
  I---------I                   I     I <-NRP1->        I           I
  I         I                   I     I I-------I       I           I
  I---------I                   I     I I       I       I           I
  I                             I     I I-------I       I           I
  <-----NRP2------>             I     I                 I           I
  I-----------------I           I     I <-NRP2->        I           I
  I                 I           I     I I---------I     I           I
  I-----------------I           I     I I         I     I           I
  I                             I     I I---------I     I           I
  <---NRP3---->                 I     I                 I           I
  I-------------I               I     I NRP1 + NRP2     I           I
  I             I               I     I-----------------I           I
  I-------------I               I     I                             I
  I                             I     I                             I
  <---NRP4---->                 I     I-----------------I           I
  I-------------I               I     I <-NRP3->        I           I
  I             I               I     I I-------I       I           I
  I-------------I               I     I I       I       I           I
  I                             I     I I-------I       I           I
  I NRP1+NRP2+NRP3+NRP4         I     I                 I           I
  I                             I     I <-NRP4->        I           I
  I-----------------------------I     I I---------I     I           I
  <--Max Reservable Bandwidth-->      I I         I     I           I
                                      I I---------I     I           I
                                      I                 I           I
                                      I NRP3 + NRP4     I           I
                                      I-----------------I           I
                                      I NRP1+NRP2+NRP3+NRP4         I
                                      I                             I
                                      I-----------------------------I
                                      <--Max Reservable Bandwidth-->

  (a) No bandwidth sharing            (b) Sharing bandwidth between
      between NRPs.                       NRPs of the same group.

]]></artwork></figure>

</section>
<section anchor="data-and-control-plane-network-resource-partition-mode"><name>Data and Control Plane Network Resource Partition Mode</name>

<t>In order to support strict guarantees for Slice-Flow
Aggregates, the network resources can be partitioned in both the control plane
and data plane.</t>

<t>The control plane partitioning allows the creation of customized topologies per
NRP that each supports a Slice-Flow Aggregate. The ingress routers or a Path
Computation Engine (PCE) may use the customized topologies and the NRP state
to determine optimal path placement for specific demand flows using NRP-TE.</t>

<t>The data plane partitioning provides isolation for Slice-Flow Aggregate traffic, and
protection when resource contention occurs due to bursts of traffic from other Slice-Flow
Aggregate traffic that traverses the same shared network resource.</t>

</section>
</section>
<section anchor="SlicePolicyInstantiation"><name>Network Resource Partition Instantiation</name>

<t>A network slice can span multiple technologies and multiple administrative
domains.  Depending on the network slice customer requirements, a network
slice can be differentiated from other network slices in terms of data, control,
and management planes.</t>

<t>The customer of a network slice service expresses their intent
by specifying requirements rather than mechanisms to realize the slice as described
in <xref target="NetworkSliceServiceRequest"/>.</t>

<t>The network slice controller is fed with the network slice service
intent and realizes it with an appropriate Network Resource Partition Policy (NRP Policy).
Multiple IETF network slices are mapped to the same Slice-Flow Aggregate as described in <xref target="SliceAggregateMapping"/>.</t>

<t>The network wide consistent NRP Policy definition is distributed to the
devices in the network as shown in <xref target="ns-workflow"/>. The specification of
the network slice intent on the northbound interface of the controller and the
mechanism used to map the network slice to a Slice-Flow Aggregate are outside the scope
of this document and will be addressed in separate documents.</t>

<section anchor="SliceDefinition"><name>NRP Policy Definition</name>

<t>The NRP Policy is network-wide construct that is supplied to network devices,
and may include rules that control the following:</t>

<t><list style="symbols">
  <t>Data plane specific policies: This includes the NRP Selector, any firewall rules or
flow-spec filters, and QoS profiles associated with the NRP Policy and any
classes within it.</t>
  <t>Control plane specific policies: This includes bandwidth reservations, any
network resource sharing amongst slice policies, and reservation preference to
prioritize reservations of a specific NRP over others.</t>
  <t>Topology membership policies: This defines the topology filter policies that dictate
node/link/function membership to a specific NRP.</t>
</list></t>

<t>There is a desire for flexibility in realizing network slices to support the
services across networks consisting of implementations from multiple vendors.  These
networks may also be grouped into disparate domains and deploy various path
control technologies and tunnel techniques to carry traffic across the network.
It is expected that a standardized data model for NRP
Policy will facilitate the instantiation and management of the NRP
on the topological elements selected by the NRP
Policy topology filter.</t>

<t>It is also possible to distribute the NRP Policy to
network devices using several mechanisms, including protocols such as NETCONF
or RESTCONF, or exchanging it using a suitable routing protocol that network
devices participate in (such as IGP(s) or BGP). The extensions to enable
specific protocols to carry an NRP Policy definition will
be described in separate documents.</t>

<section anchor="SliceSelector"><name>Network Resource Partition Selector</name>

<t>A router should be able to identify a packet belonging to a Slice-Flow Aggregate
before it can apply the associated dataplane forwarding treatment or NRP-PHB.
One or more fields within the packet are used as an NRP Selector to do this.</t>

<t>Overloaded forwarding identifier as NRP Selector:</t>

<ul empty="true"><li>
  <t>It is possible to assign a different forwarding address (or MPLS forwarding
 label in case of MPLS network) for each Slice-Flow Aggregate on a specific node
 in the network. <xref target="RFC3031"/> states in Section 2.1 that: 'Some routers
 analyze a packet's network layer header not merely to choose the packet's
 next hop, but also to determine a packet's "precedence" or "class of
 service"'. Assigning a unique forwarding address (or MPLS forwarding label)
 to each Slice-Flow Aggregate allows Slice-Flow Aggregate packets destined to a node
 to be distinguished by the destination address (or
 MPLS forwarding label) that is carried in the packet.</t>
</li></ul>

<ul empty="true"><li>
  <t>This approach requires maintaining per Slice-Flow Aggregate state
for each destination in the network in both the control and data plane and on
each router in the network. For example, consider a network slicing provider
with a network composed of 'N' nodes, each with 'K' adjacencies to its
neighbors.  Assuming a node can be reached over 'M' different Slice-Flow Aggregates,
the node assigns and advertises reachability to 'N' unique
forwarding addresses, or MPLS forwarding labels.
Similarly, each node assigns a unique forwarding address
(or MPLS forwarding label) for each of its 'K' adjacencies to enable strict
steering over the adjacency for each slice.  The total number of control and data plane states that
need to be stored and programmed in a router's forwarding is (N+K)*M states.
Hence, as 'N', 'K', and 'M' parameters increase, this approach suffers from scalability challenges
in both the control and data planes.</t>
</li></ul>

<t>Overloaded service identifier as NRP Selector:</t>

<ul empty="true"><li>
  <t>The VPN service label can be overloaded to act as an NRP Selector to allow VPN packets
to be mapped to the Slice-Flow Aggregate. In this case, a single VPN service label
acting as an NRP Selector needs to be allocated by all Egress PEs of a VPN.</t>
</li></ul>

<t>In other cases, a range of VPN service labels can act as an NRP Selector to map VPN traffic to
a Slice-Flow Aggregate. An example of such deployment is shown in <xref target="bottom-stack"/>.</t>

<figure title="NRP Selector as VPN label at bottom of label stack." anchor="bottom-stack"><artwork><![CDATA[
  SR Adj-SID:          NRP Selector (VPN service label) on PE2: 1001
     9012: P1-P2
     9023: P2-PE2

         /-----\        /-----\        /-----\       /-----\
         | PE1 | -----  | P1  | ------ | P2  |------ | PE2 |
         \-----/        \-----/        \-----/       \-----/

In 
packet: 
+------+       +------+         +------+        +------+
| IP   |       | 9012 |         | 9023 |        | 1001 |
+------+       +------+         +------+        +------+
| Pay- |       | 9023 |         | 1001 |        | IP   | 
| Load |       +------+         +------+        +------+
+----- +       | 1001 |         | IP   |        | Pay- |
               +------+         +------+        | Load |
               | IP   |         | Pay- |        +------+
               +------+         | Load |
               | Pay- |         +------+
               | Load |
               +------+
]]></artwork></figure>

<t>Dedicated identifier as NRP Selector:</t>

<ul empty="true"><li>
  <t>An NRP Policy may define a dedicated identifier as NRP Selector that is carried
in packets associated with the Slice-Flow Aggregate,
independent of the forwarding address or MPLS forwarding label bound to
the destination. Routers within the NRP domain can use the forwarding
address (or MPLS forwarding label) to determine the forwarding next-hop(s),
and use the NRP Selector field in the packet to infer the specific forwarding treatment that needs to be applied on
the packet.</t>
</li></ul>

<ul empty="true"><li>
  <t>The NRP Selector, in this case, can be carried in one of multiple fields in the packet, depending on
the dataplane used. For example, in MPLS networks, the NRP Selector can be
encoded within an MPLS label that is carried in the packet's MPLS label stack.
All packets that belong to the same Slice-Flow Aggregate may carry the same NRP Selector in the
MPLS label stack. It is also possible to have multiple NRP Selector's map
to the same Slice-Flow Aggregate.</t>
</li></ul>

<ul empty="true"><li>
  <t>In some cases, the position of the NRP Selector may not be at a fixed position
in the MPLS label header. In this case, the NRP Selector label can show up in any
position in the MPLS label stack. To enable a transit router to identify
the position of the NRP Selector label, a Network Action Indicator (NAI) special purpose label
can be used to indicate the presence of a NRP Selector in the MPLS label stack as shown in <xref target="sli-sl"/>.</t>
</li></ul>

<figure title="NAI and NRP Selector label in the label stack." anchor="sli-sl"><artwork><![CDATA[
     SR Adj-SID:          NRP Selector: 1001
        9012: P1-P2
        9023: P2-PE2

            /-----\        /-----\        /-----\       /-----\
            | PE1 | -----  | P1  | ------ | P2  |------ | PE2 |
            \-----/        \-----/        \-----/       \-----/

   In
   packet:
   +------+       +------+         +------+        +------+
   | IP   |       | 9012 |         | 9023 |        | NAI  |
   +------+       +------+         +------+        +------+
   | Pay- |       | 9023 |         | NAI  |        | 1001 |
   | Load |       +------+         +------+        +------+
   +------+       | NAI  |         | 1001 |        | IP   |
                  +------+         +------+        +------+
                  | 1001 |         | IP   |        | Pay- |
                  +------+         +------+        | Load |
                  | IP   |         | Pay- |        +------+
                  +------+         | Load |
                  | Pay- |         +------+
                  | Load |
                  +------+
]]></artwork></figure>

<ul empty="true"><li>
  <t>When the slice is realized over an IP dataplane, the NRP Selector can be encoded in
the IP header (e.g. as an  IPv6 option header).</t>
</li></ul>

</section>
<section anchor="network-resource-partition-resource-reservation"><name>Network Resource Partition Resource Reservation</name>

<t>Bandwidth and network resource allocation strategies for slice policies are
essential to achieve optimal placement of paths within the
network while still meeting the target SLOs.</t>

<t>Resource reservation allows for the management of available bandwidth and the
prioritization of existing allocations to enable preference-based preemption
when contention on a specific network resource arises. Sharing of a network
resource's available bandwidth amongst a group of NRPs
may also be desirable.  For example, a Slice-Flow Aggregate may not be using all of
the NRP reservable bandwidth; this allows other NRPs in
the same group to use the available bandwidth resources for other Slice-Flow
Aggregates.</t>

<t>Congestion on shared network resources may result from sub-optimal placement
of paths in different slice policies. When this occurs, preemption
of some Slice-Flow Aggregate paths may be desirable to alleviate congestion.
A preference-based allocation scheme enables prioritization of Slice-Flow Aggregate paths
that can be preempted.</t>

<t>Since network characteristics and its state can change over time, the NRP
topology and its network state need to be propagated in the network to enable
ingress TE routers or Path Computation Engine (PCEs) to perform accurate path placement
based on the current state of the NRP network resources.</t>

</section>
<section anchor="SlicePHB"><name>Network Resource Partition Per Hop Behavior</name>

<t>The NRP Per Hop Behavior (NRP-PHB) is the externally
observable forwarding behavior applied to a specific packet belonging to a
Slice-Flow Aggregate. The goal of an NRP-PHB is to provide a specified amount
of network resources for traffic belonging to a specific Slice-Flow Aggregate.
A single NRP may also support multiple forwarding
treatments or services that can be carried over the same logical network.</t>

<t>The Slice-Flow Aggregate traffic may be identified at NRP ingress boundary
nodes by carrying a NRP Selector to allow routers to apply a specific forwarding
treatment that guarantee the SLA(s).</t>

<t>To support multiple forwarding treatments over the same Slice-Flow Aggregate, a
Slice-Flow Aggregate packet may also carry a Diffserv CS to identify the
specific Diffserv forwarding treatment to be applied on the traffic belonging
to the same NRP.</t>

<t>At transit nodes, the CS field carried inside the packets are used to determine the
specific PHB that determines the forwarding and scheduling
treatment before packets are forwarded, and in some cases, drop probability for
each packet.</t>

</section>
<section anchor="SlicePolicyTopology"><name>Network Resource Partition Topology</name>

<t>A key element of the NRP Policy is a customized topology that may include the
full or subset of the physical network topology. The NRP topology
could also span multiple administrative domains and/or multiple dataplane
technologies.</t>

<t>An NRP topology can overlap or share a subset of links
with another NRP topology. A number of topology
filtering policies can be defined as part of the NRP
Policy to limit the specific topology elements that belong to the NRP.
For example, a topology filtering policy can leverage Resource
Affinities as defined in <xref target="RFC2702"/> to include or exclude certain links that
the NRP is instantiated on in supports of the Slice-Flow
Aggregate.</t>

<t>The NRP Policy may also include a reference to a
predefined topology (e.g., derived from a Flexible Algorithm Definition (FAD)
as defined in <xref target="I-D.ietf-lsr-flex-algo"/>, or Multi-Topology ID as defined
<xref target="RFC4915"/>.</t>

</section>
</section>
<section anchor="NRPBoundary"><name>Network Resource Partition Boundary</name>

<t>A network slice originates at the edge nodes of a network slice provider.
Traffic that is steered over the corresponding NRP supporting a Slice-Flow
Aggregate may traverse NRP capable as well as NRP incapable interior nodes.</t>

<t>The network slice may encompass one or more domains administered by a provider.
For example, an organization's intranet or an ISP.  The network provider
is responsible for ensuring that adequate network resources are
provisioned and/or reserved to support the SLAs offered by the network
end-to-end.</t>

<section anchor="network-resource-partition-edge-nodes"><name>Network Resource Partition Edge Nodes</name>

<t>NRP edge nodes sit at the boundary of a network slice provider network
and receive traffic that requires steering over network resources specific to a
NRP that supports a Slice-Flow Aggregate. These edge nodes are responsible for identifying Slice-Flow
Aggregate specific traffic flows by possibly inspecting multiple fields from
inbound packets (e.g., implementations may inspect IP traffic's network 5-tuple
in the IP and transport protocol headers) to decide on which NRP it
can be steered.</t>

<t>Network slice ingress nodes may condition the inbound traffic at network boundaries in
accordance with the requirements or rules of each service's SLAs.  The
requirements and rules for network slice services are set using
mechanisms which are outside the scope of this document.</t>

<t>When data plane NRP mode is employed, the NRP ingress nodes are responsible for
setting a suitable NRP Selector on packets that belong to the Slice-Flow
Aggregate, and optionally the desired Diffserv CS.</t>

</section>
<section anchor="network-resource-partition-interior-nodes"><name>Network Resource Partition Interior Nodes</name>

<t>An NRP interior node receives slice traffic and may be able to identify the
packets belonging to a specific Slice-Flow Aggregate by inspecting the NRP Selector
field carried inside each packet, or by inspecting other fields
within the packet that may identify the traffic streams that belong to a specific
Slice-Flow Aggregate. For example, when data plane NRP mode is applied, interior
nodes can use the NRP Selector carried within the packet to apply the corresponding NRP-PHB
forwarding behavior.</t>

</section>
<section anchor="NRPIncapbale"><name>Network Resource Partition Incapable Nodes</name>

<t>Packets that belong to a Slice-Flow Aggregate may need to traverse nodes that
are NRP incapable. In this case, several options are possible to allow the
slice traffic to continue to be forwarded over such devices and be able to
resume the NRP forwarding treatment once the traffic reaches devices that are
NRP-capable.</t>

<t>When data plane NRP mode is employed, packets carry a NRP Selector to allow
slice interior nodes to identify them. To support end-to-end network slicing,
the NRP Selector is maintained in the packets as they traverse devices within
the network -- including NRP capable and incapable devices.</t>

<t>For example, when the NRP Selector is an MPLS label at the bottom of the MPLS
label stack, packets can traverse over devices that are NRP incapable without
any further considerations. On the other hand when the NRP Selector label is at
the top of the MPLS label stack, packets can be bypassed (or tunneled) over the
NRP incapable devices towards the next device that supports NRP as shown in
<xref target="sl-interworking"/>.</t>

<figure title="Extending network slice over NRP incapable device(s)." anchor="sl-interworking"><artwork><![CDATA[
  SR Node-SID:           NRP Selector: 1001     @@@: NRP Policy
     1601: P1            Label                       enforced
     1602: P2                                   ...: NRP Policy
     1603: P3                                        not enforced
     1604: P4
     1605: P5

            @@@@@@@@@@@@@@ ........................
                                                  .
           /-----\        /-----\        /-----\  .
           | P1  | -----  | P2  | ----- | P3  |   .
           \-----/        \-----/        \-----/  .
                                            |     @@@@@@@@@@
                                            |
                                         /-----\        /-----\ 
                                         | P4  | ------ | P5  |
                                         \-----/        \-----/


            +------+       +------+        +------+
            | 1001 |       | 1604 |        | 1001 |
            +------+       +------+        +------+
            | 1605 |       | 1001 |        | IP   |
            +------+       +------+        +------+
            | IP   |       | 1605 |        | Pay- |
            +------+       +------+        | Load |
            | Pay- |       | IP   |        +------+
            | Load |       +------+
            +----- +       | Pay- |
                           | Load |
                           +------+
]]></artwork></figure>

</section>
<section anchor="combining-network-resource-partition-modes"><name>Combining Network Resource Partition Modes</name>

<t>It is possible to employ a combination of the NRP modes that were
discussed in <xref target="SliceModes"/> to realize a network slice. For example, data and
control plane NRP modes can be employed in parts of a network, while
control plane NRP mode can be employed in the other parts of the
network. The path selection, in such case, can take into
account the NRP available network resources.  The NRP Selector carried within
packets allow transit nodes to enforce the corresponding NRP-PHB on the parts of the
network that apply the data plane NRP mode. The NRP Selector can be
maintained while traffic traverses nodes that do not enforce data plane NRP
mode, and so slice PHB enforcement can resume once traffic traverses
capable nodes.</t>

</section>
</section>
</section>
<section anchor="TrafficToSFAPath"><name>Mapping Traffic on Slice-Flow Aggregates</name>

<t>The usual techniques to steer traffic onto paths can be applicable when
steering traffic over paths established for a specific Slice-Flow Aggregate.</t>

<t>For example, one or more (layer-2 or layer-3) VPN services can be directly
mapped to paths established for a Slice-Flow Aggregate. In this case, the per
Virtual Routing and Forwarding (VRF) instance traffic that arrives on the
Provider Edge (PE) router over external interfaces can be directly mapped to a
specific Slice-Flow Aggregate path. External interfaces can be further
partitioned (e.g., using VLANs) to allow mapping one or more VLANs to specific
Slice-Flow Aggregate paths.</t>

<t>Another option is steer traffic to specific destinations directly over multiple
slice policies. This allows traffic arriving on any external interface and
targeted to such destinations to be directly steered over the slice paths.</t>

<t>A third option that can also be used is to utilize a data plane firewall filter
or classifier to enable matching of several fields in the incoming packets to
decide whether the packet belongs to a specific Slice-Flow Aggregate. This option
allows for applying a rich set of rules to identify specific packets to be
mapped to a Slice-Flow Aggregate. However, it requires data plane network resources to
be able to perform the additional checks in hardware.</t>

<section anchor="network-slice-flow-aggregate-relationships"><name>Network Slice-Flow Aggregate Relationships</name>

<t>The following describes the generalization relationships between
the IETF network slice and different parts of the solution
as described in <xref target="ns-workflow"/>.</t>

<t>o A customer may request one or more IETF Network Slices.</t>

<t>o Any given Attachment Circuit (AC) may support the traffic for one or more IETF Network
  Slices. If there is more than one IETF Network Slice using a
  single AC, the IETF Network Slice Service request must include
  enough information to allow the edge nodes to demultiplex the
  traffic for the different IETF Network Slices.</t>

<t>o By definition, multiple IETF Network Slices may be mapped to a
  single Slice-Flow Aggregate.  However, it is possible for an
  Slice-Flow Aggregate to contain just a single IETF Network Slice.</t>

<t>o The physical network may be filtered to multiple Filter
  Topologies.  Each such Filtered Topology facilitates
  planning the placement of paths for the Slice-Flow Aggregate by
  presenting only the subset of links and nodes that meet specific
  criteria.  Note, however, in absence of 
  any Filtered Topology, Slice-Flow Aggregate are free to
  operate over the full physical network.</t>

<t>o It is anticipated that there may be very many IETF Network Slices supported
  by a network operator over a single physical network.  A network may support a
  limited number of Slice-Flow Aggregates, with each of the Slice-Flow Aggregates
  grouping any number of the IETF Network Slices streams.</t>

</section>
</section>
<section anchor="path-selection-and-instantiation"><name>Path Selection and Instantiation</name>

<section anchor="applicability-of-path-selection-to-slice-flow-aggregates"><name>Applicability of Path Selection to Slice-Flow Aggregates</name>

<t>In State-dependent TE <xref target="I-D.ietf-teas-rfc3272bis"/>, the path selection adapts
based on the current state of the network. The state of the network can be
based on parameters flooded by the routers as described in <xref target="RFC2702"/>.  The
link state is advertised with current reservations, thereby reflecting the
available bandwidth on each link.  Such link reservations may be maintained
centrally on a network wide network resource manager, or distributed on devices
(as usually done with RSVP-TE). TE extensions exist today to allow IGPs (e.g.,
<xref target="RFC3630"/> and <xref target="RFC5305"/>), and BGP-LS <xref target="RFC7752"/> to advertise such link
state reservations.</t>

<t>When the network resource reservations are maintained for NRPs,
the link state can carry per NRP state (e.g.,
reservable bandwidth).  This allows path computation to take into account the
specific network resources available for an NRP.  In this
case, we refer to the process of path placement and path provisioning as NRP
aware TE (NRP-TE).</t>

</section>
<section anchor="applicability-of-path-control-technologies-to-slice-flow-aggregates"><name>Applicability of Path Control Technologies to Slice-Flow Aggregates</name>

<t>The NRP modes described in this document are agnostic to the
technology used to setup paths that carry Slice-Flow Aggregate traffic.
One or more paths connecting the endpoints of the mapped IETF network
slices may be selected to steer the corresponding traffic streams
over the resources allocated for the NRP that
supports a Slice-Flow Aggregate.</t>

<t>The feasible paths can be computed using the NRP topology and network state
subject the optimization metrics and constraints.</t>

<section anchor="rsvp-te-based-slice-flow-aggregate-paths"><name>RSVP-TE Based Slice-Flow Aggregate Paths</name>

<t>RSVP-TE <xref target="RFC3209"/> can be used to signal LSPs over the computed feasible paths
in order to carry the Slice-Flow Aggregate traffic. The specific extensions to the RSVP-TE
protocol required to enable signaling of NRP aware RSVP-TE LSPs are
outside the scope of this document.</t>

</section>
<section anchor="sr-based-slice-flow-aggregate-paths"><name>SR Based Slice-Flow Aggregate Paths</name>

<t>Segment Routing (SR) <xref target="RFC8402"/> can be used to setup and steer traffic over
the computed Slice-Flow Aggregate feasible paths.</t>

<t>The SR architecture defines a number of building blocks that can be leveraged to support
the realization of NRPs that support Slice-Flow Aggregates in an SR network.</t>

<t>Such building blocks include:</t>

<t><list style="symbols">
  <t>SR Policy with or without Flexible Algorithm.</t>
  <t>Steering of services (e.g. VPN) traffic over SR paths</t>
  <t>SR Operation, Administration and Management (OAM) and Performance Management (PM)</t>
</list></t>

<t>SR allows a headend node to steer packets onto specific SR paths using
a Segment Routing Policy (SR Policy). The SR policy supports various
optimization objectives and constraints and can be used to steer Slice-Flow Aggregate
traffic in the SR network.</t>

<t>The SR policy can be instantiated with or without the IGP Flexible Algorithm
(Flex-Algorithm) feature.  It may be possible to dedicate a single SR
Flex-Algorithm to compute and instantiate SR paths for one Slice-Flow Aggregate
traffic. In this case, the SR Flex-Algorithm computed paths and Flex-Algorithm
SR SIDs are not shared by other Slice-Flow Aggregates traffic. However, to allow for better
scale, it may be desirable for multiple Slice-Flow Aggregates traffic to share the
same SR Flex-Algorithm computed paths and SIDs.</t>

</section>
</section>
</section>
<section anchor="network-resource-partition-protocol-extensions"><name>Network Resource Partition Protocol Extensions</name>

<t>Routing protocols may need to be extended to carry additional per NRP link
state. For example, <xref target="RFC5305"/>, <xref target="RFC3630"/>, and <xref target="RFC7752"/> are ISIS, OSPF, and BGP
protocol extensions to exchange network link state information to allow
ingress TE routers and PCE(s) to do proper path placement in the network.  The
extensions required to support network slicing may be defined in other
documents, and are outside the scope of this document.</t>

<t>The instantiation of an NRP Policy may need to be automated. Multiple options
are possible to facilitate automation of distribution of an NRP Policy to
capable devices.</t>

<t>For example, a YANG data model for the NRP Policy may be
supported on network devices and controllers. A suitable transport (e.g.,
NETCONF <xref target="RFC6241"/>, RESTCONF <xref target="RFC8040"/>, or gRPC) may be used to enable
configuration and retrieval of state information for slice policies on network
devices. The NRP Policy YANG data model is outside the scope of this
document.</t>

</section>
<section anchor="outstanding-issues"><name>Outstanding Issues</name>

<t>Note to RFC Editor: Please remove this section prior to publication.</t>

<t>This section records non-blocking issues that were raised during the Working
Group Adoption Poll for the document. The below list of issues needs to be fully
addressed before progressing the document to publication in IESG.</t>

<t><list style="numbers">
  <t>Add new Appendix section with examples for the NRP modes described in
<xref target="SliceModes"/>.</t>
  <t>Elaborate on the SFA packet treatment when no rules to associate the packet
to an NRP are defined in the NRP Policy.</t>
  <t>Clarify how the solution caters to the different IETF Network Slice Service
Demarcation Point locations described in Section 4.2 of
<xref target="RFC9543"/>.</t>
  <t>Clarify the relationship the underlay physical network, the filter topology
and the NRP resources.</t>
  <t>Expand on how isolation between NRPs can be realized depending on the
deployed NRP mode.</t>
  <t>Revise <xref target="NRPIncapbale"/> to describe how nodes can discover NRP incapable
downstream neighbors.</t>
  <t>Expand <xref target="SecurityConsiderations"/> on additional security threats introduced
with the solution.</t>
  <t>Expand <xref target="NRPBoundary"/> on NRP domain boundary and multi-domain aspects.</t>
</list></t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>This document has no IANA actions.</t>

</section>
<section anchor="SecurityConsiderations"><name>Security Considerations</name>

<t>The main goal of network slicing is to allow for varying treatment of
traffic from multiple different network slices that are utilizing a common
network infrastructure and to allow for different levels of services to be
provided for traffic traversing a given network resource.</t>

<t>A variety of techniques may be used to achieve this, but the end result will be
that some packets may be mapped to specific resources and may receive
different (e.g., better) service treatment than others.  The mapping of network
traffic to a specific NRP is indicated primarily by the NRP Selector, and hence an
adversary may be able to utilize resources allocated to a specific 
NRP by injecting packets carrying the same NRP Selector field in their packets.</t>

<t>Such theft-of-service may become a denial-of-service attack when the modified
or injected traffic depletes the resources available to forward legitimate
traffic belonging to a specific NRP.</t>

<t>The defense against this type of theft and denial-of-service attacks consists
of a combination of traffic conditioning at NRP domain boundaries
with security and integrity of the network infrastructure within an NRP
domain.</t>

</section>
<section anchor="acknowledgement"><name>Acknowledgement</name>

<t>The authors would like to thank Krzysztof Szarkowicz, Swamy SRK, Navaneetha
Krishnan, Prabhu Raj Villadathu Karunakaran, and Mohamed Boucadair
for their review of this document and for providing valuable feedback on it.
The authors would also like to thank Adrian Farrel for detailed discussions
that resulted in <xref target="NSRealization"/>.</t>

</section>
<section anchor="contributors"><name>Contributors</name>

<t>The following individuals contributed to this document:</t>

<figure><artwork><![CDATA[
   Colby Barth
   Juniper Networks
   Email: cbarth@juniper.net

   Srihari R.  Sangli
   Juniper Networks
   Email: ssangli@juniper.net

   Chandra Ramachandran
   Juniper Networks
   Email: csekar@juniper.net

   Adrian Farrel
   Old Dog Consulting
   United Kingdom
   Email: adrian@olddog.co.uk
]]></artwork></figure>

</section>


  </middle>

  <back>


    <references title='Normative References'>



<reference anchor='RFC3630' target='https://www.rfc-editor.org/info/rfc3630'>
  <front>
    <title>Traffic Engineering (TE) Extensions to OSPF Version 2</title>
    <author fullname='D. Katz' initials='D.' surname='Katz'/>
    <author fullname='K. Kompella' initials='K.' surname='Kompella'/>
    <author fullname='D. Yeung' initials='D.' surname='Yeung'/>
    <date month='September' year='2003'/>
    <abstract>
      <t>This document describes extensions to the OSPF protocol version 2 to support intra-area Traffic Engineering (TE), using Opaque Link State Advertisements.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3630'/>
  <seriesInfo name='DOI' value='10.17487/RFC3630'/>
</reference>

<reference anchor='RFC5305' target='https://www.rfc-editor.org/info/rfc5305'>
  <front>
    <title>IS-IS Extensions for Traffic Engineering</title>
    <author fullname='T. Li' initials='T.' surname='Li'/>
    <author fullname='H. Smit' initials='H.' surname='Smit'/>
    <date month='October' year='2008'/>
    <abstract>
      <t>This document describes extensions to the Intermediate System to Intermediate System (IS-IS) protocol to support Traffic Engineering (TE). This document extends the IS-IS protocol by specifying new information that an Intermediate System (router) can place in Link State Protocol Data Units (LSP). This information describes additional details regarding the state of the network that are useful for traffic engineering computations. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='5305'/>
  <seriesInfo name='DOI' value='10.17487/RFC5305'/>
</reference>

<reference anchor='RFC7752' target='https://www.rfc-editor.org/info/rfc7752'>
  <front>
    <title>North-Bound Distribution of Link-State and Traffic Engineering (TE) Information Using BGP</title>
    <author fullname='H. Gredler' initials='H.' role='editor' surname='Gredler'/>
    <author fullname='J. Medved' initials='J.' surname='Medved'/>
    <author fullname='S. Previdi' initials='S.' surname='Previdi'/>
    <author fullname='A. Farrel' initials='A.' surname='Farrel'/>
    <author fullname='S. Ray' initials='S.' surname='Ray'/>
    <date month='March' year='2016'/>
    <abstract>
      <t>In a number of environments, a component external to a network is called upon to perform computations based on the network topology and current state of the connections within the network, including Traffic Engineering (TE) information. This is information typically distributed by IGP routing protocols within the network.</t>
      <t>This document describes a mechanism by which link-state and TE information can be collected from networks and shared with external components using the BGP routing protocol. This is achieved using a new BGP Network Layer Reachability Information (NLRI) encoding format. The mechanism is applicable to physical and virtual IGP links. The mechanism described is subject to policy control.</t>
      <t>Applications of this technique include Application-Layer Traffic Optimization (ALTO) servers and Path Computation Elements (PCEs).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7752'/>
  <seriesInfo name='DOI' value='10.17487/RFC7752'/>
</reference>

<reference anchor='RFC3209' target='https://www.rfc-editor.org/info/rfc3209'>
  <front>
    <title>RSVP-TE: Extensions to RSVP for LSP Tunnels</title>
    <author fullname='D. Awduche' initials='D.' surname='Awduche'/>
    <author fullname='L. Berger' initials='L.' surname='Berger'/>
    <author fullname='D. Gan' initials='D.' surname='Gan'/>
    <author fullname='T. Li' initials='T.' surname='Li'/>
    <author fullname='V. Srinivasan' initials='V.' surname='Srinivasan'/>
    <author fullname='G. Swallow' initials='G.' surname='Swallow'/>
    <date month='December' year='2001'/>
    <abstract>
      <t>This document describes the use of RSVP (Resource Reservation Protocol), including all the necessary extensions, to establish label-switched paths (LSPs) in MPLS (Multi-Protocol Label Switching). Since the flow along an LSP is completely identified by the label applied at the ingress node of the path, these paths may be treated as tunnels. A key application of LSP tunnels is traffic engineering with MPLS as specified in RFC 2702. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3209'/>
  <seriesInfo name='DOI' value='10.17487/RFC3209'/>
</reference>




    </references>

    <references title='Informative References'>



<reference anchor='RFC9543' target='https://www.rfc-editor.org/info/rfc9543'>
  <front>
    <title>A Framework for Network Slices in Networks Built from IETF Technologies</title>
    <author fullname='A. Farrel' initials='A.' role='editor' surname='Farrel'/>
    <author fullname='J. Drake' initials='J.' role='editor' surname='Drake'/>
    <author fullname='R. Rokui' initials='R.' surname='Rokui'/>
    <author fullname='S. Homma' initials='S.' surname='Homma'/>
    <author fullname='K. Makhijani' initials='K.' surname='Makhijani'/>
    <author fullname='L. Contreras' initials='L.' surname='Contreras'/>
    <author fullname='J. Tantsura' initials='J.' surname='Tantsura'/>
    <date month='March' year='2024'/>
    <abstract>
      <t>This document describes network slicing in the context of networks built from IETF technologies. It defines the term "IETF Network Slice" to describe this type of network slice and establishes the general principles of network slicing in the IETF context.</t>
      <t>The document discusses the general framework for requesting and operating IETF Network Slices, the characteristics of an IETF Network Slice, the necessary system components and interfaces, and the mapping of abstract requests to more specific technologies. The document also discusses related considerations with monitoring and security.</t>
      <t>This document also provides definitions of related terms to enable consistent usage in other IETF documents that describe or use aspects of IETF Network Slices.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='9543'/>
  <seriesInfo name='DOI' value='10.17487/RFC9543'/>
</reference>

<reference anchor='RFC2475' target='https://www.rfc-editor.org/info/rfc2475'>
  <front>
    <title>An Architecture for Differentiated Services</title>
    <author fullname='S. Blake' initials='S.' surname='Blake'/>
    <author fullname='D. Black' initials='D.' surname='Black'/>
    <author fullname='M. Carlson' initials='M.' surname='Carlson'/>
    <author fullname='E. Davies' initials='E.' surname='Davies'/>
    <author fullname='Z. Wang' initials='Z.' surname='Wang'/>
    <author fullname='W. Weiss' initials='W.' surname='Weiss'/>
    <date month='December' year='1998'/>
    <abstract>
      <t>This document defines an architecture for implementing scalable service differentiation in the Internet. This memo provides information for the Internet community.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='2475'/>
  <seriesInfo name='DOI' value='10.17487/RFC2475'/>
</reference>

<reference anchor='RFC5462' target='https://www.rfc-editor.org/info/rfc5462'>
  <front>
    <title>Multiprotocol Label Switching (MPLS) Label Stack Entry: "EXP" Field Renamed to "Traffic Class" Field</title>
    <author fullname='L. Andersson' initials='L.' surname='Andersson'/>
    <author fullname='R. Asati' initials='R.' surname='Asati'/>
    <date month='February' year='2009'/>
    <abstract>
      <t>The early Multiprotocol Label Switching (MPLS) documents defined the form of the MPLS label stack entry. This includes a three-bit field called the "EXP field". The exact use of this field was not defined by these documents, except to state that it was to be "reserved for experimental use".</t>
      <t>Although the intended use of the EXP field was as a "Class of Service" (CoS) field, it was not named a CoS field by these early documents because the use of such a CoS field was not considered to be sufficiently defined. Today a number of standards documents define its usage as a CoS field.</t>
      <t>To avoid misunderstanding about how this field may be used, it has become increasingly necessary to rename this field. This document changes the name of the field to the "Traffic Class field" ("TC field"). In doing so, it also updates documents that define the current use of the EXP field. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='5462'/>
  <seriesInfo name='DOI' value='10.17487/RFC5462'/>
</reference>

<reference anchor='RFC3031' target='https://www.rfc-editor.org/info/rfc3031'>
  <front>
    <title>Multiprotocol Label Switching Architecture</title>
    <author fullname='E. Rosen' initials='E.' surname='Rosen'/>
    <author fullname='A. Viswanathan' initials='A.' surname='Viswanathan'/>
    <author fullname='R. Callon' initials='R.' surname='Callon'/>
    <date month='January' year='2001'/>
    <abstract>
      <t>This document specifies the architecture for Multiprotocol Label Switching (MPLS). [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3031'/>
  <seriesInfo name='DOI' value='10.17487/RFC3031'/>
</reference>

<reference anchor='RFC2702' target='https://www.rfc-editor.org/info/rfc2702'>
  <front>
    <title>Requirements for Traffic Engineering Over MPLS</title>
    <author fullname='D. Awduche' initials='D.' surname='Awduche'/>
    <author fullname='J. Malcolm' initials='J.' surname='Malcolm'/>
    <author fullname='J. Agogbua' initials='J.' surname='Agogbua'/>
    <author fullname='M. O&apos;Dell' initials='M.' surname='O&apos;Dell'/>
    <author fullname='J. McManus' initials='J.' surname='McManus'/>
    <date month='September' year='1999'/>
    <abstract>
      <t>This document presents a set of requirements for Traffic Engineering over Multiprotocol Label Switching (MPLS). It identifies the functional capabilities required to implement policies that facilitate efficient and reliable network operations in an MPLS domain. This memo provides information for the Internet community.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='2702'/>
  <seriesInfo name='DOI' value='10.17487/RFC2702'/>
</reference>


<reference anchor='I-D.ietf-lsr-flex-algo' target='https://datatracker.ietf.org/doc/html/draft-ietf-lsr-flex-algo-26'>
   <front>
      <title>IGP Flexible Algorithm</title>
      <author fullname='Peter Psenak' initials='P.' surname='Psenak'>
         <organization>Cisco Systems, Inc.</organization>
      </author>
      <author fullname='Shraddha Hegde' initials='S.' surname='Hegde'>
         <organization>Juniper Networks, Inc.</organization>
      </author>
      <author fullname='Clarence Filsfils' initials='C.' surname='Filsfils'>
         <organization>Cisco Systems, Inc.</organization>
      </author>
      <author fullname='Ketan Talaulikar' initials='K.' surname='Talaulikar'>
         <organization>Cisco Systems, Inc</organization>
      </author>
      <author fullname='Arkadiy Gulko' initials='A.' surname='Gulko'>
         <organization>Edward Jones</organization>
      </author>
      <date day='17' month='October' year='2022'/>
      <abstract>
	 <t>IGP protocols historically compute the best paths over the network based on the IGP metric assigned to the links.  Many network deployments use RSVP-TE or Segment Routing - Traffic Engineering (SR-TE) to steer traffic over a path that is computed using different metrics or constraints than the shortest IGP path.  This document specifies a solution that allows IGPs themselves to compute constraint-based paths over the network.  This document also specifies a way of using Segment Routing (SR) Prefix-SIDs and SRv6 locators to steer packets along the constraint-based paths.
	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-lsr-flex-algo-26'/>
   
</reference>

<reference anchor='RFC4915' target='https://www.rfc-editor.org/info/rfc4915'>
  <front>
    <title>Multi-Topology (MT) Routing in OSPF</title>
    <author fullname='P. Psenak' initials='P.' surname='Psenak'/>
    <author fullname='S. Mirtorabi' initials='S.' surname='Mirtorabi'/>
    <author fullname='A. Roy' initials='A.' surname='Roy'/>
    <author fullname='L. Nguyen' initials='L.' surname='Nguyen'/>
    <author fullname='P. Pillay-Esnault' initials='P.' surname='Pillay-Esnault'/>
    <date month='June' year='2007'/>
    <abstract>
      <t>This document describes an extension to Open Shortest Path First (OSPF) in order to define independent IP topologies called Multi- Topologies (MTs). The Multi-Topologies extension can be used for computing different paths for unicast traffic, multicast traffic, different classes of service based on flexible criteria, or an in- band network management topology.</t>
      <t>An optional extension to exclude selected links from the default topology is also described. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='4915'/>
  <seriesInfo name='DOI' value='10.17487/RFC4915'/>
</reference>


<reference anchor='I-D.ietf-teas-rfc3272bis' target='https://datatracker.ietf.org/doc/html/draft-ietf-teas-rfc3272bis-27'>
   <front>
      <title>Overview and Principles of Internet Traffic Engineering</title>
      <author fullname='Adrian Farrel' initials='A.' surname='Farrel'>
         <organization>Old Dog Consulting</organization>
      </author>
      <date day='12' month='August' year='2023'/>
      <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.

   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='Internet-Draft' value='draft-ietf-teas-rfc3272bis-27'/>
   
</reference>

<reference anchor='RFC8402' target='https://www.rfc-editor.org/info/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='RFC6241' target='https://www.rfc-editor.org/info/rfc6241'>
  <front>
    <title>Network Configuration Protocol (NETCONF)</title>
    <author fullname='R. Enns' initials='R.' role='editor' surname='Enns'/>
    <author fullname='M. Bjorklund' initials='M.' role='editor' surname='Bjorklund'/>
    <author fullname='J. Schoenwaelder' initials='J.' role='editor' surname='Schoenwaelder'/>
    <author fullname='A. Bierman' initials='A.' role='editor' surname='Bierman'/>
    <date month='June' year='2011'/>
    <abstract>
      <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6241'/>
  <seriesInfo name='DOI' value='10.17487/RFC6241'/>
</reference>

<reference anchor='RFC8040' target='https://www.rfc-editor.org/info/rfc8040'>
  <front>
    <title>RESTCONF Protocol</title>
    <author fullname='A. Bierman' initials='A.' surname='Bierman'/>
    <author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'/>
    <author fullname='K. Watsen' initials='K.' surname='Watsen'/>
    <date month='January' year='2017'/>
    <abstract>
      <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8040'/>
  <seriesInfo name='DOI' value='10.17487/RFC8040'/>
</reference>




    </references>



  </back>

<!-- ##markdown-source:
H4sIAE4FVmYAA71963fbRpbn9/orsPHZY6lDMn6lM1H39FqW5UQd29FKGmdm
NztzIBIUYZMAGwAlK7b2b9/7rBcKFJ30WX1ITBKox61bt+7jd2+Nx2PTld2y
OMjOinxZ/lZWV9nborupmw/Z+bKcFm1WVtnJ6TdvTl+f6y+tyS8vm+L6IP6B
XoEmzKyeVvkKWp01+bwbl0U3H3dF3o6rdlyux6v1sh0/emameVdc1c3tAXQy
r025bg6yrtm03ZNHj75/9MRgm1dNvVkfZBfHh+fZL/AZR/gDfmc+FLfwwAxG
UXVFUxXd+CX2ZtrN5aps27Kuuts1jOHk+OKVMW2XV7P/ypd1BV/dFq1ZlwfZ
/+7q6Shr66ZrinkL/7pd4T/+jzH5plvUzYEx2dhk8FdWLQxikp3n+Yy+4Pld
5E3xwX1ZN1d5Vf6Wd9D5QXZUttM6O79tu2LVwiinE3qoWOXlEibawlsTGPbz
K/xiMq1XYW/vJtmLomjyldffu7JdVJvsNL/OK//XsOO/b6pyXTRuvbxury/p
refv+RkcQNjt3yfZyxrW0HX697JwX4U9/bjJb4oyuyimi6pe1ldlEXT2viwm
M3jz+YKe68/xxST7pai8vl4Au+k3ETXr1TRvO795ePi/4OHn0/xyWWDj+IDf
CfXxcpIdFdMprNRyWRrb00tou1gW0W+7rKD0PuMGJsjd/TVUWv6YL4HMlev3
73Wx9L8Nezxuymnb1pXXz3t4YbLgF54X8nuvq/NJdlrwGnE/54u8nm/sl2E3
/+viGAjarOuGvvB6W8Pzk5beff5bR1SdTKugqzMg6KLwpnQGzKjf7NrPFJ6f
NHk11Mm/T7LX5cb18e+bOYxMvwt7OXnxZqCXj/TWZFluti3Ta5gQSIsGNkbr
eny9KdvsTfRT2PEFrP+8rspp7vW5hPdW5dWmwI7k1dWmKZfL+nlnX+gNAqh6
Vn/YeBx6VvyWu+9iziwqv9OmweeeT/Hr1Pz+DtJ96c8tv3XfhU2/Ax77LaDi
Ep6evMenn1/zj9xFVTcreOm6ADmJEtx9Go/HWX7Zdk0+BfHizpZKDoqWz5YV
jKIp/rEpmyLrFkV2XjTX8EN22tTX5QwkWFdni/yaf8wvy2XZ3cJ3Zp03cGzB
aLM8Wy9uW6Dn0rZdVvDWarPsyjVsbxRK3q9tVs+z67y5xdG05W9FO4KjodlM
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
sO0/fdJpjSUtI0AAuH5Cy7WxSRyaw6JUlMIJRBHByz/JRyqq4gObXUpaZoDP
6/YAT+PHI/z4hP77lNYG/vGMWJdyX7X76tYNsrV1oUjZIaoEA7l0AyEsz2Nt
+AkndunqmxSlScQiH8erb2nAPsdzjiqiwRyO3XXhvwB61TWdt7ep9TVBb/j8
KLvc0Jt0RCot0szhv0xEzbioxxM239iMdzUz3uQfNXER23lh20GxgsdtwdAH
ONw2IANDYdjPuLH1RJDHSb3zT1zJJqB8gpOtkK0Twk3d9ww089fxGCc5/lsS
2zXUzIn/TDCYk+FWoK+wq14rWeqXuJWTqKffN5b47eGxpP52Hctf6VfkHn7u
b8lW0q2nZpSkv/z3r9zPDtRNPhHNyLLQ7xpLvJJ/jLpDY/kr0/Zpn7LpnrPe
N/0Zxc9rKyQJvma5d/+MBlr5gn20bSzb/nan7n2tCHWfbaXuP2lGf+V13JF3
h1rZXTJsG8v/H8nAHPU18hP+5+nXdNzFraRb/9Kx/JXXcZi6vVXs02mn3Th0
GFoGul8y7PJ3/1h2a2XbN7u3QgrL15ldv9/Vyr37aOexDPPU76ZL8OvvnlEw
ux1b2c5TBlrZy/ezt7Wnv6mW6/3tXe7jzQX0tXtQ9F4ZiWrBrIin/0gZ1wiU
byyIUoaI9Ng0UFi6UwzLtmb4xTeBPcA9f+WHgFAL/kJ/oY8BVFsOgfPTLrva
5A3Y0oU4ypJp2qNkCC4ZMtKQVreI0qdNGNwSV0AYGwuS/qUmADXk1T7iGC/Z
8h5UHeM01hXEJfTv8QdlfvRD/dbk3qM6JEHlDvK2SOEOVOA19JAei1/nmF08
gUebMvpR549QbH59Dcb/CSqGEfDs5RGyeZ74gGY2e9pyU7So/eoEBDY16L4S
3zk5qpwJ4so/1NPpBuv7bShOdgn/Zqy3hcQ4+3lrMc+oIpFzVKejt/eFlgOw
hoaYUwgPH53rLlho1/Af623qvNtlGBysv2gpkobunTBSoSSF3I768LH1Wnd2
1Etk0EyFsLKOR9LoPgf/LgbkhpFupZFh71VYm0urU9vR+IXZI0hD8RH94bI0
ZcOA7Q4jvx7uP6iUDDRZsN+p8rGBXmGBzsLefYi/ITTBlvSEu8i7r+h8v572
3PfhJmdkeAbifacBtVhkVYu2UtHddUPuxN1qzcm/9yfOWZYo0hcVJEzE2ALM
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
zmb11WRaTzYfiFz/Dy0/c1hn1gAA

-->

</rfc>

