Network Working Group                                            J. Dong
Internet-Draft                                                     Z. Li
Intended status: Standards Track                     Huawei Technologies
Expires: 8 January 2024                                           C. Xie
                                                                   C. Ma
                                                           China Telecom
                                                               G. Mishra
                                                            Verizon Inc.
                                                             7 July 2023
 Carrying Virtual Transport Network (VTN) Information in IPv6 Extension
                                 Header
                 draft-ietf-6man-enhanced-vpn-vtn-id-05
Abstract
   Virtual Private Networks (VPNs) provide different customers with
   logically separated connectivity over a common network
   infrastructure.  With the introduction and evolvement of 5G and also
   in some existing network scenarios, some customers may require
   network connectivity services with advanced features comparing to
   conventional VPN services.  Such kind of network service is called
   enhanced VPNs (VPN+).  VPN+ can be used, for example, to deliver IETF
   network slice services.
   A VTN is a virtual underlay network that is associated with a network
   topology, and is allocated with a set of dedicated or shared
   resources from the underlay physical network.  VPN+ services can be
   delivered by mapping one or a group of overlay VPNs to the
   appropriate VTNs as the virtual underlay.  For packet forwarding in a
   specific VTN, some fields in the data packet are used to identify the
   VTN the packet belongs to, so that VTN-specific processing can be
   performed on each node along a VTN-specific path.
   This document specifies a new IPv6 Hop-by-Hop option to carry the VTN
   related information in data packets, which could be used to identify
   the VTN-specific processing to be performed on the packets by each
   network node along a VTN-specific path.
Status of This Memo
   This Internet-Draft is submitted in full conformance with the
   provisions of BCP 78 and BCP 79.
Dong, et al.             Expires 8 January 2024                 [Page 1]
Internet-Draft               IPv6 VTN Option                   July 2023
   Internet-Drafts are working documents of the Internet Engineering
   Task Force (IETF).  Note that other groups may also distribute
   working documents as Internet-Drafts.  The list of current Internet-
   Drafts is at https://datatracker.ietf.org/drafts/current/.
   Internet-Drafts are draft documents valid for a maximum of six months
   and may be updated, replaced, or obsoleted by other documents at any
   time.  It is inappropriate to use Internet-Drafts as reference
   material or to cite them other than as "work in progress."
   This Internet-Draft will expire on 8 January 2024.
Copyright Notice
   Copyright (c) 2023 IETF Trust and the persons identified as the
   document authors.  All rights reserved.
   This document is subject to BCP 78 and the IETF Trust's Legal
   Provisions Relating to IETF Documents (https://trustee.ietf.org/
   license-info) in effect on the date of publication of this document.
   Please review these documents carefully, as they describe your rights
   and restrictions with respect to this document.  Code Components
   extracted from this document must include Revised BSD License text as
   described in Section 4.e of the Trust Legal Provisions and are
   provided without warranty as described in the Revised BSD License.
Table of Contents
   1.  Introduction  . . . . . . . . . . . . . . . . . . . . . . . .   3
     1.1.  Requirements Language . . . . . . . . . . . . . . . . . .   4
   2.  New IPv6 Extension Header Option for VTN  . . . . . . . . . .   4
   3.  Procedures  . . . . . . . . . . . . . . . . . . . . . . . . .   6
     3.1.  Adding VTN Option to Packets  . . . . . . . . . . . . . .   6
     3.2.  VTN based Packet Forwarding . . . . . . . . . . . . . . .   6
   4.  Operational Considerations  . . . . . . . . . . . . . . . . .   7
   5.  Considerations about Generalization . . . . . . . . . . . . .   7
   6.  IANA Considerations . . . . . . . . . . . . . . . . . . . . .   8
   7.  Security Considerations . . . . . . . . . . . . . . . . . . .   9
   8.  Contributors  . . . . . . . . . . . . . . . . . . . . . . . .   9
   9.  Acknowledgements  . . . . . . . . . . . . . . . . . . . . . .   9
   10. References  . . . . . . . . . . . . . . . . . . . . . . . . .   9
     10.1.  Normative References . . . . . . . . . . . . . . . . . .   9
     10.2.  Informative References . . . . . . . . . . . . . . . . .  10
   Authors' Addresses  . . . . . . . . . . . . . . . . . . . . . . .  11
Dong, et al.             Expires 8 January 2024                 [Page 2]
Internet-Draft               IPv6 VTN Option                   July 2023
1.  Introduction
   Virtual Private Networks (VPNs) [RFC4026] provide different customers
   with logically isolated connectivity over a common network
   infrastructure.  With the introduction and evolvement of 5G and also
   in some existing network scenarios, some customers may require
   network connectivity services with advanced features comparing to
   conventional VPNs, such as resource isolation from other services or
   guaranteed performance.  Such kind of network service is called
   enhanced VPN (VPN+).  VPN+ service requires the coordination and
   integration between the overlay VPNs and the capability and resources
   of the underlay network.  VPN+ can be used, for example, to deliver
   IETF network slice services [I-D.ietf-teas-ietf-network-slices].
   [I-D.ietf-teas-enhanced-vpn] describes a framework and the candidate
   component technologies for providing VPN+ services.  It also
   introduces the concept of Virtual Transport Network (VTN).  A VTN is
   a virtual underlay network that is associated with a network
   topology, and is allocated with a set of dedicated or shared
   resources from the underlay physical network.  A VPN+ service is
   realized by integrating a VPN in the overlay and a VTN in the
   underlay, so as to provide the network features required by the
   customers.  In packet forwarding, traffic of different VPN+ services
   needs to be processed separately based on the network resources and
   the logical topology associated with the corresponding VTN.  In the
   context of network slicing [I-D.ietf-teas-ietf-network-slices], a
   network construct called Network Resource Partition (NRP) is
   introduced, which can be seen as an instantiation of VTN.
   [I-D.ietf-teas-nrp-scalability] describes the scalability
   considerations and the possible optimizations for providing a
   relatively large number of VTNs for VPN+ services.  One approach to
   improve the data plane scalability of VTN is to introduce a dedicated
   VTN Resource Identifier (VTN Resource ID) in the data packet to
   identify the set of network resources allocated to a VTN, so that
   packets in a VTN can be processed and forwarded using the VTN-
   specific set of resources, which could avoid possible resource
   competition with services in other VTNs.  A VTN Resource ID is a VTN
   ID with network resource semantics, which represents a subset of the
   resources (e.g. bandwidth, buffer and queuing resources) allocated on
   a given set of links and nodes which constitute a logical network
   topology.  The logical topology of a VTN could be defined and
   identified using mechanisms such as Multi-Topology [RFC4915],
   [RFC5120] or Flex-Algo [RFC9350].
   This document specifies a mechanism to carry the VTN related
   information in a new IPv6 Hop-by-Hop option (Section 4.3 of
   [RFC8200]) called "VTN option".  The VTN option is parsed by every
Dong, et al.             Expires 8 January 2024                 [Page 3]
Internet-Draft               IPv6 VTN Option                   July 2023
   intermediate node along the forwarding path, and the obtained VTN
   Resource ID is used to invoke VTN-specific packet processing and
   forwarding using the set of VTN-specific resources.  This provides a
   scalable solution to support a relatively large number of VTNs in an
   IPv6 network [I-D.ietf-teas-nrp-scalability].
   Although in this document the application of the VTN option is to
   carry the VTN Resource ID information, the VTN option is considered
   as a generic mechanism to convey network wide VTN ID and information
   with different semantics to meet the possible use cases in the
   future.  Some considerations about generalization are described in
   Section 5.
1.1.  Requirements Language
   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
   BCP14 [RFC2119] [RFC8174] when, and only when, they appear in all
   capitals, as shown here.
2.  New IPv6 Extension Header Option for VTN
   A new Hop-by-Hop option (Section 4.3 of [RFC8200]) type "VTN" is
   defined to carry the VTN related information.  Its format is shown in
   Figure 1.
        0                   1                   2                   3
        0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
                                       +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                                       |  Option Type  |  Opt Data Len |
       +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
       |     Flags     | Context Type  |            Reserved           |
       +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
       ~                            VTN ID                             ~
       +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
                   Figure 1. The format of VTN Option
   Option Type: 8-bit identifier of the type of option.  The type of VTN
   option is to be assigned by IANA.  The bits of the type field are
   defined as below:
   *  BB 00 The highest-order 2 bits are set to 00 to indicate that a
      node which does not recognize this type will skip over it and
      continue processing the header.
Dong, et al.             Expires 8 January 2024                 [Page 4]
Internet-Draft               IPv6 VTN Option                   July 2023
   *  C 0 The third highest-order bit is set to 0 to indicate this
      option does not change en route.
   *  TTTTT To be assigned by IANA.
   Opt Data Len: 8-bit unsigned integer indicates the length of the
   option Data field of this option, in octets.
   Flags: 8-bit flags field.  The most significant bit is defined in
   this document.
                                   0 1 2 3 4 5 6 7
                                  +-+-+-+-+-+-+-+-+
                                  |S|U U U U U U U|
                                  +-+-+-+-+-+-+-+-+
   *  S (Strict Match): The S flag is used to indicate whether the VTN
      ID MUST be strictly matched for the processing of the packet.
      When S flag is set to 1, if the VTN ID in the VTN option does not
      match with any of the VTN ID provisioned on the network node, the
      packet MUST be dropped.  When S flag is set to 0, if the VTN ID
      does not match with any of the VTN ID provisioned on the network
      node, the packet MUST be forwarded using the default behavior as
      if the VTN option does not exist.
   *  U (Unused): These flags are reserved for future use.  They MUST be
      set to 0 on transmission and MUST be ignored on receipt.
   Context Type (CT): One-octet field used to indicate the semantics and
   length of the VTN ID carried in the option.  The context value
   defined in this document is as follows:
   *  CT=0: The VTN ID is a network-wide 4-octet resource ID, which is
      used to identify the subset of network resources allocated to the
      VTN on the involved network nodes and links.
   Reserved: 2-octet field reserved for future use.  They MUST be set to
   0 on transmission and MUST be ignored on receipt.
   VTN ID: The identifier of a Virtual Transport Network, the semantics
   and length of the ID is determined by the Context Type.
   Note that, in the context of 5G network slicing, if a deployment
   found it useful, the four-octet VTN ID field may be derived from the
   four-octet Single Network Slice Selection Assistance Information
   (S-NSSAI) defined in 3GPP [TS23501].
Dong, et al.             Expires 8 January 2024                 [Page 5]
Internet-Draft               IPv6 VTN Option                   July 2023
3.  Procedures
   This section describes the procedures for VTN option processing when
   the Context Type in the VTN option is set to 0.  The processing
   procedures for VTN option with other Context Types are out of the
   scope of this document and will be specified in separate documents
   which introduce those Context Types.
3.1.  Adding VTN Option to Packets
   When an ingress node of an IPv6 domain receives a packet, according
   to the traffic classification and mapping policy, the packet needs to
   be steered into one of the VTNs in the network, then the packet MUST
   be encapsulated in an outer IPv6 header with the source and
   destination addresses set according to the policy, and the Resource
   ID of the VTN which the packet is mapped to according to the policy
   MUST be carried in the VTN option of the Hop-by-Hop Options header,
   which is associated with the outer IPv6 header.
3.2.  VTN based Packet Forwarding
   On receipt of a packet with the VTN option, each network node which
   can process the Hop-by-Hop Options header and the VTN option in fast
   path [I-D.ietf-6man-hbh-processing] MUST use the VTN Resource ID to
   determine the set of local network resources which are allocated to
   the VTN.  The packet forwarding behavior is based on both the
   destination IP address and the VTN Resource ID.  More specifically,
   the destination IP address is used to determine the next-hop and the
   outgoing interface, and VTN Resource ID is used to determine the set
   of network resources on the outgoing interface which are allocated to
   the VTN for processing and sending the packet.  If the VTN Resource
   ID does not match with any of the VTN Resource ID provisioned on the
   outgoing interface, the S flag in the VTN option is used to determine
   whether the packet is dropped or forwarded using the default set of
   network resources of the outgoing interface.  The Traffic Class field
   of the outer IPv6 header can be used to provide differentiated
   treatment for packets which belong to the same VTN.  The egress node
   of the IPv6 domain MUST decapsulate the outer IPv6 header and the
   Hop-by-Hop Options header which includes the VTN option.
   In the forwarding plane, there can be different approaches of
   partitioning the local network resources and allocating them to
   different VTNs.  For example, on one physical interface, a subset of
   the forwarding plane resources (e.g. bandwidth and the associated
   buffer and queuing resources) can be allocated to a particular VTN
   and represented as a virtual sub-interface or a data channel with
   reserved bandwidth resource.  In packet forwarding, the IPv6
   destination address of the received packet is used to identify the
Dong, et al.             Expires 8 January 2024                 [Page 6]
Internet-Draft               IPv6 VTN Option                   July 2023
   next-hop and the outgoing layer-3 interface, and the VTN Resource ID
   is used to further identify the virtual sub-interface or the data
   channel on the outgoing interface which is associated with the VTN.
   Network nodes which do not support the processing of Hop-by-Hop
   Options header SHOULD ignore the Hop-by-Hop options header and
   forward the packet only based on the destination IP address.  Network
   nodes which support Hop-by-Hop Options header, but do not support the
   VTN option SHOULD ignore the VTN option and forward the packet only
   based on the destination IP address.  The network node MAY process
   the rest of the Hop-by-Hop options in the Hop-by-Hop Options header.
4.  Operational Considerations
   As described in [RFC8200], network nodes may be configured to ignore
   the Hop-by-Hop Options header, drop packets containing a Hop-by-Hop
   Options header, or assign packets containing a Hop-by-Hop Options
   header to a slow processing path.  In networks with such network
   nodes, it is important that packets of a VTN are not dropped due to
   the existence of the Hop-by-Hop Options header.  Operators need to
   make sure that all the network nodes involved in a VTN can either
   process the Hop-by-Hop Options header in the fast path, or ignore the
   Hop-by-Hop Options header.  Since a VTN is associated with a logical
   network topology, one practical approach is to ensure that all the
   network nodes involved in that logical topology support the
   processing of the Hop-by-Hop Options header and the VTN option in the
   fast path, and constrain the packet forwarding path to the logical
   topology of the VTN.
   [I-D.ietf-6man-hbh-processing] specifies the modified procedures for
   the processing of IPv6 Hop-by-Hop Options header, with the purpose of
   making the Hop-by-Hop Options header useful.  Network nodes complying
   with [I-D.ietf-6man-hbh-processing] will not drop packets with Hop-
   by-Hop Options header and the VTN option.
5.  Considerations about Generalization
   During the discussion of this document in the 6MAN WG, one of the
   suggestions received is to make the VTN option more generic in terms
   of semantics and encoding.  This section gives some analysis about to
   what extent the semantics of VTN could be generalized, and how the
   generalization could be achieved with the proposed encoding.
Dong, et al.             Expires 8 January 2024                 [Page 7]
Internet-Draft               IPv6 VTN Option                   July 2023
   Based on the VTN definition in [I-D.ietf-teas-enhanced-vpn], the
   concept of VTN could be extended as: a virtual transport network
   which is associated with a set of network-wide attributes and states
   maintained on each participating network node.  The attributes
   associated with an VTN may include but not limited to: network
   resource attributes, network topology attributes, and network
   function attributes etc.
   *  The network resource can refer to various type of data plane
      resources, including link bandwidth, bufferage and queueing
      resources.
   *  The network topology can be multipoint-to-multipoint, point-to-
      point, point-to-multipoint or multipoint-to-point.
   *  The network functions may include both data forwarding actions and
      other types network functions which can be executed on data
      packets mapped to a VTN.
   This shows the semantics of VTN can be quite generic.  Although
   generalization is something good to have, it would be important to
   understand and identify the boundary of generalization.  In this
   document, It is anticipated that for one network attribute to be
   included in VTN, it needs to be a network-wide attribute rather than
   a node-specific attribute.  Thus whether a network-wide view can be
   provided or not could be considered as one prerequisite of making one
   attribute part of the VTN option.
   The format of the VTN option contains the Flags field, the Context
   Type field and the Reserved field, which provide the capability for
   future extensions.  That said, since the VTN option needs to be
   processed by network nodes in the fast path, the capability of
   network devices need to be considered when new semantics and encoding
   are introduced.
6.  IANA Considerations
   This document requests IANA to assign a new option type from
   "Destination Options and Hop-by-Hop Options" registry [IANA-HBH].
      Hex Value      Binary Value      Description      Reference
                     act chg rest
      -----------------------------------------------------------
         TBA         00   0  tba       VTN Option      [this document]
Dong, et al.             Expires 8 January 2024                 [Page 8]
Internet-Draft               IPv6 VTN Option                   July 2023
   This document requests IANA to create a new registry for the "VTN
   Option Context Type" under the "Internet Protocol Version 6 (IPv6)
   Parameters" registry.  The allocation policy of this registry is
   "Standards Action".  The initial codepoints are assigned by this
   document as follows:
      Value          Description       Reference
      -----------------------------------------------
        0            Resource ID      [this document]
      1-254          Unassigned
       255           Reserved         [this document]
7.  Security Considerations
   The security considerations with IPv6 Hop-by-Hop Options header are
   described in [RFC8200], [RFC7045], [RFC9098] [RFC9099] and
   [I-D.ietf-6man-hbh-processing].  This document introduces a new IPv6
   Hop-by-Hop option which is either processed in the fast path or
   ignored by network nodes, thus it does not introduce additional
   security issues.
8.  Contributors
      Zhibo Hu
      Email: huzhibo@huawei.com
      Lei Bao
      Email: baolei7@huawei.com
9.  Acknowledgements
   The authors would like to thank Juhua Xu, James Guichard, Joel
   Halpern, Tom Petch, Aijun Wang, Zhenqiang Li, Tom Herbert, Adrian
   Farrel, Eric Vyncke, Erik Kline and Mohamed Boucadair for their
   review and valuable comments.
10.  References
10.1.  Normative References
   [I-D.ietf-teas-enhanced-vpn]
              Dong, J., Bryant, S., Li, Z., Miyasaka, T., and Y. Lee, "A
              Framework for Enhanced Virtual Private Network (VPN+)",
              Work in Progress, Internet-Draft, draft-ietf-teas-
              enhanced-vpn-13, 7 July 2023,
              .
Dong, et al.             Expires 8 January 2024                 [Page 9]
Internet-Draft               IPv6 VTN Option                   July 2023
   [IANA-HBH] "IANA, "Destination Options and Hop-by-Hop Options"",
              2016, .
   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119,
              DOI 10.17487/RFC2119, March 1997,
              .
   [RFC8174]  Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
              2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
              May 2017, .
   [RFC8200]  Deering, S. and R. Hinden, "Internet Protocol, Version 6
              (IPv6) Specification", STD 86, RFC 8200,
              DOI 10.17487/RFC8200, July 2017,
              .
10.2.  Informative References
   [I-D.ietf-6man-hbh-processing]
              Hinden, R. M. and G. Fairhurst, "IPv6 Hop-by-Hop Options
              Processing Procedures", Work in Progress, Internet-Draft,
              draft-ietf-6man-hbh-processing-09, 4 July 2023,
              .
   [I-D.ietf-teas-ietf-network-slices]
              Farrel, A., Drake, J., Rokui, R., Homma, S., Makhijani,
              K., Contreras, L. M., and J. Tantsura, "A Framework for
              IETF Network Slices", Work in Progress, Internet-Draft,
              draft-ietf-teas-ietf-network-slices-21, 15 June 2023,
              .
   [I-D.ietf-teas-nrp-scalability]
              Dong, J., Li, Z., Gong, L., Yang, G., Guichard, J.,
              Mishra, G. S., Qin, F., Saad, T., and V. P. Beeram,
              "Scalability Considerations for Network Resource
              Partition", Work in Progress, Internet-Draft, draft-ietf-
              teas-nrp-scalability-02, 2 June 2023,
              .
   [RFC4026]  Andersson, L. and T. Madsen, "Provider Provisioned Virtual
              Private Network (VPN) Terminology", RFC 4026,
              DOI 10.17487/RFC4026, March 2005,
              .
Dong, et al.             Expires 8 January 2024                [Page 10]
Internet-Draft               IPv6 VTN Option                   July 2023
   [RFC4915]  Psenak, P., Mirtorabi, S., Roy, A., Nguyen, L., and P.
              Pillay-Esnault, "Multi-Topology (MT) Routing in OSPF",
              RFC 4915, DOI 10.17487/RFC4915, June 2007,
              .
   [RFC5120]  Przygienda, T., Shen, N., and N. Sheth, "M-ISIS: Multi
              Topology (MT) Routing in Intermediate System to
              Intermediate Systems (IS-ISs)", RFC 5120,
              DOI 10.17487/RFC5120, February 2008,
              .
   [RFC7045]  Carpenter, B. and S. Jiang, "Transmission and Processing
              of IPv6 Extension Headers", RFC 7045,
              DOI 10.17487/RFC7045, December 2013,
              .
   [RFC9098]  Gont, F., Hilliard, N., Doering, G., Kumari, W., Huston,
              G., and W. Liu, "Operational Implications of IPv6 Packets
              with Extension Headers", RFC 9098, DOI 10.17487/RFC9098,
              September 2021, .
   [RFC9099]  Vyncke, É., Chittimaneni, K., Kaeo, M., and E. Rey,
              "Operational Security Considerations for IPv6 Networks",
              RFC 9099, DOI 10.17487/RFC9099, August 2021,
              .
   [RFC9350]  Psenak, P., Ed., Hegde, S., Filsfils, C., Talaulikar, K.,
              and A. Gulko, "IGP Flexible Algorithm", RFC 9350,
              DOI 10.17487/RFC9350, February 2023,
              .
   [TS23501]  "3GPP TS23.501", 2016,
              .
Authors' Addresses
   Jie Dong
   Huawei Technologies
   Huawei Campus, No. 156 Beiqing Road
   Beijing
   100095
   China
   Email: jie.dong@huawei.com
Dong, et al.             Expires 8 January 2024                [Page 11]
Internet-Draft               IPv6 VTN Option                   July 2023
   Zhenbin Li
   Huawei Technologies
   Huawei Campus, No. 156 Beiqing Road
   Beijing
   100095
   China
   Email: lizhenbin@huawei.com
   Chongfeng Xie
   China Telecom
   China Telecom Beijing Information Science & Technology, Beiqijia
   Beijing
   102209
   China
   Email: xiechf@chinatelecom.cn
   Chenhao Ma
   China Telecom
   China Telecom Beijing Information Science & Technology, Beiqijia
   Beijing
   102209
   China
   Email: machh@chinatelecom.cn
   Gyan Mishra
   Verizon Inc.
   Email: gyan.s.mishra@verizon.com
Dong, et al.             Expires 8 January 2024                [Page 12]