Internet-Draft | draft-ietf-ccamp-flexe-yang-cm-03 | September 2023 |
Wang, et al. | Expires 15 March 2024 | [Page] |
This document defines a service provider targeted YANG data model for the configuration and management of a Flex Ethernet (FlexE) network, including FlexE group and FlexE client. The YANG module in this document conforms to the Network Management Datastore Architecture (NMDA).¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
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 15 March 2024.¶
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.¶
From a service provider's point of view, a transport network with Flex Ethernet (FlexE) support is usually deployed with all FlexE Groups configured at first, and then FlexE clients are added one by one at a later stage. This document defines a service provider targeted YANG data model for the configuration and management of FlexE, including FlexE groups and FlexE clients. It supports the configuration of FlexE client as an interface as the data model of FlexE client is augmented based on the generic interfaces data model as defined in [RFC8343]. Furthermore, when a FlexE transport network is used to backhaul 5G mobile services, synchronization channel can also be imbedded in a FlexE PHY. The specific PHY used for synchronization channel can be retrieved for management. Other FlexE attributes are based on the FlexE 2.1 Implementation Agreement as specified in [FLEXE].¶
Note that this document would only focus on the configuration and maintenance of the FlexE interfaces. Cross connection of FlexE timeslots in a network node is out of the scope of this document.¶
The YANG modules in this document conform to the Network Management Datastore Architecture (NMDA) [RFC8342].¶
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
A simplified graphical representation of the data model can be used in this document. The meaning of the symbols in the YANG data tree presented later in this document is defined in [RFC8340]. They are provided below for reference.¶
o Brackets "[" and "]" enclose list keys.¶
o Abbreviations before data node names: "rw" means configuration (read-write) and "ro" state data (read-only).¶
o Symbols after data node names: "?" means an optional node, "!" means a presence container, and "*" denotes a list and leaf-list¶
o Parentheses enclose choice and case nodes, and case nodes are also marked with a colon (":").¶
o Ellipsis ("...") stands for contents of subtrees that are not shown.¶
o Some of the key terms used in this document are listed as follow.¶
The terminology for describing YANG data models can be found in [RFC6020].¶
The following terminologies used in this document are defined in [IEEE802.3] and [FLEXE]. The following terminologies are listed in alphabetical order.¶
In this section, the requirements are summarized according to the descriptions in OIF FlexE Implementation Agreement and ITU-T FlexE related standards e.g. [ITU-T_G.8023]. FlexE YANG data model aims to provide the configurations of functions, report real states, and verify the consistency between the configuration and the real states. The requirements of FlexE groups and FlexE clients are summarized and illustrated as follows.¶
This section describes the hierarchy and tree diagram of YANG modules for the FlexE management.¶
Configuration management of FlexE group includes:¶
Configuration management of a FlexE client includes:¶
YANG tree diagram [RFC8340] representing the data model is typically used by YANG modules. A simplified FlexE tree diagram defined in this document follows the syntax and notation defined in [RFC8340].¶
A tree diagram of IETF FlexE is depicted as the following:¶
module: ietf-flexe +--rw flexe +--rw flexe-groups | +--rw flexe-group* [index] | +--rw index uint32 | +--rw group-num uint32 | +--rw negotiation-mode negotiation-mode-type | +--ro total-bandwidth? string | +--ro free-bandwidth? string | +--ro sync-phy-number? uint32 | +--rw flexe-phys | +--rw flexe-phy* [port-name] | +--rw port-name if:interface-ref | +--rw phy-number uint32 | +--ro free-timeslot-list? string | +--ro used-timeslot-list? string +--rw flexe-clients +--rw flexe-client* [client-index] +--rw client-index uint32 +--rw group-index -> /flexe/flexe-groups/flexe-group/index +--rw client-num uint32 +--rw timeslot-lists +--rw timeslot-list* [port-name] +--rw port-name if:interface-ref +--rw time-slot string¶
The following YANG data module augments the interface container defined in [RFC8343] for a FlexE group interface. It imports ietf-interfaces [RFC8343].¶
module ietf-flexe { yang-version 1.1; namespace "urn:ietf:params:xml:ns:yang:ietf-flexe"; prefix "flexe"; import ietf-interfaces { prefix if; reference "RFC 8343: A YANG Data Model For Interface Management"; } organization "IETF CCAMP Working Group"; contact "WG Web: http://datatracker.ietf.org/wg/ccamp/ WG List: <mailto:ccamp@ietf.org> Author: Minxue Wang <mailto: wangminxue@chinamobile.com> Author: Liuyan Han <mailto: hanliuyan@chinamobile.com> Author: Xuesong Geng <mailto:gengxuesong@huawei.com> Author: Xiaobing Niu <mailto: niu.xiaobing@zte.com.cn> Author: Luis M. Contreras <mailto:luismiguel.contrerasmurillo@telefonica.com> Author: Xufeng Liu <mailto:xufeng.liu.ietf@gmail.com>"; description "This YANG module defines a data model for the configuration of FlexE, which includes the configuration of FlexE group and FlexE client. Copyright (c) 2022 IETF Trust and the persons identified as authors of the code. All rights reserved. Redistribution and use in source and binary forms, with or without modification, is permitted pursuant to, and subject to the license terms contained in, the Revised BSD License set forth in Section 4.c of the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info). This version of this YANG module is part of RFC XXXX; see the RFC itself for full legal notices."; revision "2023-09-12" { description "the sixth version"; reference "RFC XXXX: YANG Data Model for FlexE Management"; } typedef negotiation-mode-type { type enumeration { enum "dynamic" { value 1; description "Dynamic mode."; } enum "static" { value 2; description "Static mode."; } } description "Negotiation mode of a FlexE group."; } container flexe { description "Specify FlexE group configuration information."; reference "Flex Ethernet 2.1 Implementation Agreement"; container flexe-groups { description "List of FlexE groups."; list flexe-group { key "index"; description "Configure FlexE group."; leaf index { type uint32 { range "1..65535"; } description "FlexE group index."; } leaf group-num { type uint32 { range "1..1048574"; } mandatory true; description "FlexE group number, as specified in OIF FlexE 2.1."; } leaf negotiation-mode { type negotiation-mode-type; mandatory true; description "FlexE group calendar negotiation mode, the default value is 'dynamic'."; } leaf total-bandwidth { type string { length "1..9"; } config false; description "FlexE group total bandwidth in Gbit/s, such as 10."; } leaf free-bandwidth { type string { length "1..9"; } config false; description "FlexE group free bandwidth in Gbit/s, such as 100."; } leaf sync-phy-number { type uint32 { range "1..254"; } config false; description "The FlexE PHY number used for synchronization management channel in a FlexE group, which is one of the PHY number value in a FlexE group."; } container flexe-phys { description "List of physical port information in a FlexE Group."; list flexe-phy { key "port-name"; description "FlexE PHY port name."; leaf port-name { type if:interface-ref; description "Physical port name. "; } leaf phy-number { type uint32 { range "1..254"; } mandatory true; description "Number of a FlexE physical port. The PHY number of a 100G port is an integer ranging from 1 to 254. The PHY number of a 50G port is an integer ranging from 1 to 126."; } leaf free-timeslot-list { type string { length "1..199"; } config false; description "Free timeslots of a FlexE PHY. The string consists of one or more numbers separated by commas (,) or hyphens (-), e.g.'1-5' indicates 1,2,3,4,5 timeslots, '0,5,7-10' indicates 0,5,7,8,9,10 timeslots."; } leaf used-timeslot-list { type string { length "1..199"; } config false; description "Used timeslots of a FlexE PHY. The string consists of one or more numbers separated by commas (,) or hyphens (-), e.g.'1-5' indicates 1,2,3,4,5 timeslots, '0,5,7-10' indicates 0,5,7,8,9,10 timeslots."; } } } } } container flexe-clients { description "All the clients configured in the same FlexE group."; list flexe-client{ key "client-index"; description "Specify FlexE client configuration information."; reference "Flex Ethernet 2.1 Implementation Agreement"; leaf client-index { type uint32 { range "1..65535"; } mandatory true; description "FlexE client index."; } leaf group-index { type leafref { path "/flexe:flexe/flexe:flexe-groups" + "/flexe:flexe-group/flexe:index"; } mandatory true; description "A local FlexE group index configured for a client on one equipment for the sake of simplicity on configuration and management."; } leaf client-num { type uint32 { range "1..65534"; } mandatory true; description "FlexE Client number."; } container timeslot-lists { description "List of binding timeslots."; list timeslot-list { key "port-name"; description "Configure binding timeslots."; leaf port-name { type if:interface-ref; description "FlexE physical port name."; } leaf time-slot { type string { length "1..199"; } mandatory true; description "Timeslot allocated for a FlexE client. The string consists of one or more numbers separated by commas (,) or hyphens (-), e.g.'1-5' indicates 1,2,3,4,5 timeslots, '0,5,7-10' indicates 0,5,7,8,9,10 timeslots."; } } } } } } }¶
The YANG module specified in this document defines a schema for data that is designed to be accessed via network management protocols such as NETCONF [RFC6241] or RESTCONF [RFC8040]. The lowest NETCONF layer is the secure transport layer, and the mandatory-to-implement secure transport is Secure Shell (SSH) [RFC6242]. The lowest RESTCONF layer is HTTPS, and the mandatory-to-implement secure transport is TLS [RFC8446].¶
The NETCONF access control model [RFC8341] provides the means to restrict access for particular NETCONF or RESTCONF users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content.¶
There are a number of data nodes defined in the YANG data modules in this document are writable, and the involved subtrees that are sensitive include:¶
Write operations (e.g., edit-config) to these data nodes without proper protection can have a negative effect on network operations. Specifically, an inappropriate configuration may interrupt a FlexE client flow, drop all Ethernet frames of a FlexE client, or even break down a whole FlexE group interface.¶
IANA is asked to assign new URIs from the "IETF XML Registry" [RFC3688] as follows:¶
URI: urn:ietf:params:xml:ns:yang:ietf-flexe Registrant Contact: The IESG XML: N/A; the requested URI is an XML namespace¶
The following YANG modules are requested to be registered in the IANA "YANG Module Names" [RFC6020] registry:¶
Name: ietf-flexe Namespace: urn:ietf:params:xml:ns:yang:ietf-flexe Prefix: flexe Reference: this document¶
The authors would like to thank Weiqiang Cheng and Yuanlong Jiang for their valuable suggestions.¶
A FlexE group must be configured first before any client signals are carried over it. The initial configuration commands could be from external management system, SDN controller etc.¶
Currently, t he FlexE configuration model shows the necessary parameters about the FlexE group and the FlexE client. That is the base model for further augments or extensions.¶
In this section, more details about parameters in the model are elaborated, and some examples are illustrated based on following figure.¶
The FlexE group YANG tree is shown in section 4. More explanations for the flexe-group data node include,¶
While in the FlexE demux, part of the configuration for FlexE group is shown as follows,¶
Based on the configuration above, the running states in the FlexE device can be gotten by using NETCONF Get command. To FlexE group, the running states include total-bandwidth and free-bandwidth of the FlexE group, and free-timeslot-list and used-timeslot-list of each PHY in the FlexE group.¶
The FlexE client YANG tree is shown in section 4. More explanations for the flexe-client data node include,¶
For example, two FlexE clients are configured to be transported by the FlexE group in section 4.1.¶
The bandwidth of the first FlexE client is 10Gb/s, and the assigned calendar slots include two 5G slots.¶
The bandwidth of the second FlexE client is 200Gb/s, and the assigned calendar slots include 40 5G slots, exactly located in two 100G PHYs. This configuration shows the capability of FlexE bonding.¶
Part of the configuration for the first and second FlexE client in FlexE mux is shown as follows,¶
Part of the configuration for the first and second FlexE client in FlexE demux is shown as follows,¶