netconfcentral logo

ietf-interfaces-common@2017-07-03



  module ietf-interfaces-common {

    yang-version 1.1;

    namespace
      "urn:ietf:params:xml:ns:yang:ietf-interfaces-common";

    prefix if-cmn;

    import ietf-interfaces {
      prefix if;
    }
    import iana-if-type {
      prefix ianaift;
    }

    organization
      "IETF NETMOD (NETCONF Data Modeling Language) Working Group";

    contact
      "WG Web:   <http://tools.ietf.org/wg/netmod/>
     WG List:  <mailto:netmod@ietf.org>

     WG Chair: Lou Berger
               <mailto:lberger@labn.net>
     WG Chair: Kent Watsen
               <mailto:kwatsen@juniper.net>

     Editor:   Robert Wilton
               <mailto:rwilton@cisco.com>";

    description
      "This module contains common definitions for extending the IETF
     interface YANG model (RFC 7223) with common configurable layer 2
     properties.

     Copyright (c) 2016, 2017 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 Simplified BSD License
     set forth in Section 4.c of the IETF Trust's Legal Provisions
     Relating to IETF Documents
      (http://trustee.ietf.org/license-info).

     This version of this YANG module is part of XXX; see the RFC
     itself for full legal notices.";

    revision "2017-07-03" {
      description "Initial version";
      reference
        "Internet draft: draft-ietf-netmod-intf-ext-yang-05";

    }


    feature reservable-bandwidth {
      description
        "This feature indicates that the device supports configuring
       'reservable-bandwidth' on interfaces.";
      reference
        "RFC XXX, Section 3.1 Reservable Bandwidth";

    }

    feature carrier-delay {
      description
        "This feature indicates that configurable interface
       carrier delay is supported, which is a feature is used to
       limit the propagation of very short interface link state
       flaps.";
      reference
        "RFC XXX, Section 3.2 Carrier Delay";

    }

    feature dampening {
      description
        "This feature indicates that the device supports interface
       dampening, which is a feature that is used to limit the
       propagation of interface link state flaps over longer
       periods";
      reference
        "RFC XXX, Section 3.3 Dampening";

    }

    feature loopback {
      description
        "This feature indicates that configurable interface loopback
       is supported.";
      reference
        "RFC XXX, Section 3.5 Loopback";

    }

    feature configurable-l2-mtu {
      description
        "This feature indicates that the device supports configuring
       layer 2 MTUs on interfaces.  Such MTU configurations include
       the layer 2 header overheads (but exclude any FCS overhead).
       The payload MTU available to higher layer protocols is either
       derived from the layer 2 MTU, taking into account the size of
       the layer 2 header, or is further restricted by explicit layer
       3 or protocol specific MTU configuration.";
      reference
        "RFC XXX, Section 3.6 Layer 2 MTU";

    }

    feature sub-interfaces {
      description
        "This feature indicates that the device supports the
       instantiation of sub-interfaces.  Sub-interfaces are defined
       as logical child interfaces that allow features and forwarding
       decisions to be applied to a subset of the traffic processed
       on the specified parent interface.";
      reference
        "RFC XXX, Section 3.7 Sub-interface";

    }

    feature forwarding-mode {
      description
        "This feature indicates that the device supports the
       configurable forwarding mode leaf";
      reference
        "RFC XXX, Section 3.8 Forwarding Mode";

    }

    identity sub-interface {
      base 
      description
        "Base type for generic sub-interfaces.

       New or custom interface types can derive from this type to
       inherit generic sub-interface configuration";
      reference
        "RFC XXX, Section 3.7 Sub-interface";

    }

    identity ethSubInterface {
      base ianaift:l2vlan;sub-interface;
      description
        "This identity represents the child sub-interface of any
       interface types that uses Ethernet framing (with or without
       802.1Q tagging)";
    }

    identity loopback {
      base 
      description
        "Base identity for interface loopback options";
      reference
        "RFC XXX, section 3.5";

    }

    identity loopback-internal {
      base loopback;
      description
        "All egress traffic on the interface is internally looped back
       within the interface to be received on the ingress path.";
      reference
        "RFC XXX, section 3.5";

    }

    identity loopback-line {
      base loopback;
      description
        "All ingress traffic received on the interface is internally
       looped back within the interface to the egress path.";
      reference
        "RFC XXX, section 3.5";

    }

    identity loopback-connector {
      base loopback;
      description
        "The interface has a physical loopback connector attached
       that loops all egress traffic back into the interface's
       ingress path, with equivalent semantics to loopback-internal";
      reference
        "RFC XXX, section 3.5";

    }

    identity forwarding-mode {
      base 
      description
        "Base identity for forwarding-mode options.";
      reference
        "RFC XXX, section 3.8";

    }

    identity optical-layer {
      base forwarding-mode;
      description
        "Traffic is being forwarded at the optical layer.  This
       includes DWDM or OTN based switching.";
      reference
        "RFC XXX, section 3.8";

    }

    identity layer-2-forwarding {
      base forwarding-mode;
      description
        "Layer 2 based forwarding, such as Ethernet/VLAN based
       switching, or L2VPN services.";
      reference
        "RFC XXX, section 3.8";

    }

    identity network-layer {
      base forwarding-mode;
      description
        "Network layer based forwarding, such as IP, MPLS, or L3VPNs.";
      reference
        "RFC XXX, section 3.8";

    }

    augment /if:interfaces/if:interface {
      description
        "Augments the IETF interface model with optional common
       interface level commands that are not formally covered by any
       specific standard.";
      leaf reservable-bandwidth {
        if-feature reservable-bandwidth;
        type uint64;
        units "kbps";
        description
          "The reservable-bandwidth configuration leaf allows the
         bandwidth of an interface reported to upper layer protocols
         to be changed (either higher or lower) from the inherent
         interface bandwidth. The reservable-bandwidth leaf can
         affect the routing metric cost associated with the
         interface, but it does not directly limit the amount of
         traffic that can be sent/received over the interface.  If
         required, interface traffic can be limited to the required
         bandwidth by configuring an explicit QoS policy.";
        reference
          "RFC XXX, section 3.1";

      }

      container carrier-delay {
        if-feature carrier-delay;
        description
          "Holds carrier delay related feature configuration";
        reference
          "RFC XXX, Section 3.2 Carrier Delay";

        leaf down {
          type uint32;
          units "milliseconds";
          description
            "Delays the propagation of a 'loss of carrier signal' event
           that would cause the interface state to go down, i.e. the
           command allows short link flaps to be suppressed. The
           configured value indicates the minimum time interval (in
           milliseconds) that the carrier signal must be continuously
           down before the interface state is brought down. If not
           configured, the behaviour on loss of carrier signal is
           vendor/interface specific, but with the general
           expectation that there should be little or no delay.";
        }

        leaf up {
          type uint32;
          units "milliseconds";
          description
            "Defines the minimum time interval (in milliseconds) that
           the carrier signal must be continuously present and error
           free before the interface state is allowed to transition
           from down to up.  If not configured, the behaviour is
           vendor/interface specific, but with the general
           expectation that sufficient default delay should be used
           to ensure that the interface is stable when enabled before
           being reported as being up.  Configured values that are
           too low for the hardware capabilties may be rejected.";
        }
      }  // container carrier-delay

      container dampening {
        if-feature dampening;
        presence
          "Enable interface link flap dampening with default settings
         (that are vendor/device specific)";
        description
          "Interface dampening limits the propagation of interface link
         state flaps over longer periods";
        reference
          "RFC XXX, Section 3.3 Dampening";

        leaf half-life {
          type uint32;
          units "seconds";
          description
            "The Time (in seconds) after which a penalty reaches half
           its original value. Once the interface has been assigned
           a penalty, the penalty is decreased by half after the
           half-life period. For some devices, the allowed values may
           be restricted to particular multiples of seconds. The
           default value is vendor/device specific.";
          reference
            "RFC XXX, Section 3.3.2 Half-Life Period";

        }

        leaf reuse {
          type uint32;
          description
            "Penalty value below which a stable interface is
           unsuppressed (i.e. brought up) (no units).  The default
           value is vendor/device specific.  The penalty value for a
           link up->down state change is nominally 1000 units.";
          reference
            "RFC XXX, Section 3.3.3 Reuse Threshold";

        }

        leaf suppress {
          type uint32;
          description
            "Limit at which an interface is suppressed (i.e. held down)
           when its penalty exceeds that limit (no units). The value
           must be greater than the reuse threshold.  The default
           value is vendor/device specific.  The penalty value for a
           link up->down state change is nominally 1000 units.";
          reference
            "RFC XXX, Section 3.3.1 Suppress Threshold";

        }

        leaf max-suppress-time {
          type uint32;
          units "seconds";
          description
            "Maximum time (in seconds) that an interface can be
           suppressed. This value effectively acts as a ceiling that
           the penalty value cannot exceed.  The default value is
           vendor/device specific.";
          reference
            "RFC XXX, Section 3.3.4 Maximum Suppress Time";

        }
      }  // container dampening

      container encapsulation {
        when
          "derived-from-or-self(../if:type,
                              'ianaift:ethernetCsmacd') or
         derived-from-or-self(../if:type,
                              'ianaift:ieee8023adLag') or
         derived-from-or-self(../if:type, 'ianaift:pos') or
         derived-from-or-self(../if:type,
                              'ianaift:atmSubInterface') or
         derived-from-or-self(../if:type, 'ethSubInterface')" {
          description
            "All interface types that can have a configurable L2
           encapsulation";
        }
        description
          "Holds the OSI layer 2 encapsulation associated with an
         interface";
        choice encaps-type {
          description
            "Extensible choice of layer 2 encapsulations";
          reference
            "RFC XXX, Section 3.4 Encapsulation";

        }  // choice encaps-type
      }  // container encapsulation

      leaf loopback {
        when
          "derived-from-or-self(../if:type,
                                 'ianaift:ethernetCsmacd') or
            derived-from-or-self(../if:type, 'ianaift:sonet') or
            derived-from-or-self(../if:type, 'ianaift:atm') or
            derived-from-or-self(../if:type, 'ianaift:otnOtu')" {
          description
            "All interface types that support loopback configuration.";
        }
        if-feature loopback;
        type identityref {
          base loopback;
        }
        description
          "Enables traffic loopback.";
        reference
          "RFC XXX, Section 3.5 Loopback";

      }

      leaf l2-mtu {
        if-feature configurable-l2-mtu;
        type uint16 {
          range "64 .. 65535";
        }
        description
          "The maximum size of layer 2 frames that may be transmitted
         or received on the interface (excluding any FCS overhead).
         In the case of Ethernet interfaces it also excludes the
         4-8 byte overhead of any known (i.e. explicitly matched by
         a child sub-interface) 801.1Q VLAN tags.";
        reference
          "RFC XXX, Section 3.6 Layer 2 MTU";

      }

      leaf forwarding-mode {
        if-feature forwarding-mode;
        type identityref {
          base forwarding-mode;
        }
        description
          "The forwarding mode that the interface is operating in.";
        reference
          "RFC XXX, Section 3.8 Forwarding Mode";

      }
    }

    augment /if:interfaces/if:interface {
      when
        "derived-from(if:type, 'sub-interface') or
          derived-from-or-self(if:type, 'ianaift:atmSubInterface') or
          derived-from-or-self(if:type, 'ianaift:frameRelay')" {
        description
          "Any ianaift:types that explicitly represent sub-interfaces
         or any types that derive from the sub-interface identity";
      }
      if-feature sub-interfaces;
      description
        "Add a parent interface field to interfaces that model
       sub-interfaces";
      leaf parent-interface {
        type if:interface-ref;
        mandatory true;
        description
          "This is the reference to the parent interface of this
         sub-interface.";
        reference
          "RFC XXX, Section 3.7 Sub-interface";

      }
    }
  }  // module ietf-interfaces-common