<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.39 (Ruby 3.4.9) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-opsawg-discardmodel-14" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.0 -->
  <front>
    <title abbrev="IM and DM for Packet Discard Reporting">Information and Data Models for Packet Discard Reporting</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-opsawg-discardmodel-14"/>
    <author initials="J." surname="Evans" fullname="John Evans" role="editor">
      <organization>Amazon</organization>
      <address>
        <postal>
          <street>1 Principal Place, Worship Street</street>
          <city>London</city>
          <code>EC2A 2FA</code>
          <country>UK</country>
        </postal>
        <email>jevanamz@amazon.co.uk</email>
      </address>
    </author>
    <author initials="O." surname="Pylypenko" fullname="Oleksandr Pylypenko" role="editor">
      <organization>Nvidia</organization>
      <address>
        <postal>
          <street>2788 San Tomas Expy</street>
          <city>Santa Clara</city>
          <region>CA</region>
          <code>95051</code>
          <country>US</country>
        </postal>
        <email>opylypenko@nvidia.com</email>
      </address>
    </author>
    <author initials="J." surname="Haas" fullname="Jeffrey Haas">
      <organization>Juniper Networks</organization>
      <address>
        <postal>
          <street>1133 Innovation Way</street>
          <city>Sunnyvale</city>
          <region>CA</region>
          <code>94089</code>
          <country>US</country>
        </postal>
        <email>jhaas@juniper.net</email>
      </address>
    </author>
    <author initials="A." surname="Kadosh" fullname="Aviran Kadosh">
      <organization>Cisco Systems, Inc.</organization>
      <address>
        <postal>
          <street>170 West Tasman Dr.</street>
          <city>San Jose</city>
          <region>CA</region>
          <code>95134</code>
          <country>US</country>
        </postal>
        <email>akadosh@cisco.com</email>
      </address>
    </author>
    <author initials="M." surname="Boucadair" fullname="Mohamed Boucadair" role="editor">
      <organization>Orange</organization>
      <address>
        <postal>
          <country>France</country>
        </postal>
        <email>mohamed.boucadair@orange.com</email>
      </address>
    </author>
    <date year="2026" month="June" day="24"/>
    <area>Operations and Management Area</area>
    <workgroup>Operations and Management Area Working Group</workgroup>
    <keyword>Troubleshooting</keyword>
    <keyword>Diagnostic</keyword>
    <keyword>Network Automation</keyword>
    <keyword>Network Service</keyword>
    <keyword>Resilience</keyword>
    <keyword>Robustness</keyword>
    <keyword>Root cause</keyword>
    <keyword>Anomaly</keyword>
    <keyword>Incident</keyword>
    <keyword>Customer experience</keyword>
    <abstract>
      <?line 105?>

<t>This document defines an Information Model and specifies a corresponding YANG data model for packet discard reporting. The Information Model provides an implementation-independent framework for classifying packet loss - both intended (e.g., due to policy) and unintended (e.g., due to congestion or errors) - to enable automated network mitigation of unintended packet loss. The YANG data model specifies an implementation of this Information Model for network elements with a focus on the interface, device, and control-plane discards.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://o-pylypenko.github.io/draft-ietf-opsawg-discardmodel/draft-ietf-opsawg-discardmodel.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-opsawg-discardmodel/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Operations and Management Area Working Group  mailing list (<eref target="mailto:opsawg@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/opsawg/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/opsawg/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/o-pylypenko/draft-ietf-opsawg-discardmodel"/>.</t>
    </note>
  </front>
  <middle>
    <?line 109?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>The primary function of a network is to transport and deliver packets according to service level objectives. For network operators, understanding both where and why packet loss occurs within a network is essential for effective operation. Device-reported packet loss provides the most direct signal for identifying service impact. While certain types of packet loss, such as policy-based discards, are intentional and part of normal network operation, unintended packet loss can impact customer services.  To automate network operations, operators must be able to detect customer-impacting packet loss, determine its root cause, and apply appropriate mitigation actions. Precise classification of packet loss is thus crucial to ensure that anomalous packet loss is easily detected and that the right action is taken to mitigate the impact. Taking the wrong action can make problems worse; for example, removing a congested device from service can exacerbate congestion by redirecting traffic to other already congested links or devices.</t>
      <t>Existing metrics for reporting packet loss, such as ifInDiscards, ifOutDiscards, ifInErrors, and ifOutErrors defined in "The Interfaces Group MIB" <xref target="RFC2863"/> and "A YANG Data Model for Interface Management" <xref target="RFC8343"/>, are insufficient for automating network operations. First, they lack precision; for instance, ifInDiscards aggregates all discarded inbound packets without specifying the cause, making it challenging to distinguish between intended and unintended discards. Second, these definitions are ambiguous, leading to inconsistent vendor implementations. For example, in some implementations ifInErrors accounts only for errored packets that are dropped, while in others, it includes all errored packets, whether they are dropped or not. Many implementations support more discard metrics than these, however, they have been inconsistently implemented due to the lack of a standardised classification scheme and clear semantics for packet loss reporting. For example, <xref target="RFC7270"/> provides support for reporting discards per flow in IP Flow Information Export (IPFIX) <xref target="RFC7011"/> using the forwardingStatus IPFIX Information Element, however, the defined drop reason codes also lack sufficient clarity to facilitate automated root cause analysis and impact mitigation (e.g., the "For us" reason code).</t>
      <t>This document defines an Information Model (IM) and specifies a corresponding YANG Data Model (DM) for packet loss reporting to address the above issues. The IM provides precise classification of packet loss to enable accurate automated mitigation. The DM specifies a YANG implementation of this IM for network elements, while maintaining consistency through clear semantics.</t>
      <t>The scope of this document is limited to reporting packet loss at Layer 3 and frames discarded at Layer 2. This document considers only the signals that may trigger automated mitigation actions and not how the actions are defined or executed. Such considerations are deployment-specific.</t>
      <t><xref target="problem"/> describes the problem space and requirements. <xref target="infomodel"/> defines the IM and its classification scheme. <xref target="datamodel"/> specifies the corresponding YANG data model and implementation requirements together with a set of usage examples, and the complete YANG module definition. Appendices <xref format="counter" target="wheredropped"/> and <xref format="counter" target="mapping"/> provide additional context and implementation guidance.</t>
      <section anchor="editorial-note-to-be-removed-by-the-rfc-editor">
        <name>Editorial Note (To be removed by the RFC Editor)</name>
        <t>Note to the RFC Editor: This section is to be removed prior to
   publication.</t>
        <t>This document contains placeholder values that need to be replaced
   with finalized values at the time of publication.  This note
   summarizes all of the substitutions that are needed.</t>
        <t>Please apply the following replacements:</t>
        <ul spacing="normal">
          <li>
            <t>XXXX --&gt; the assigned RFC number for this I-D</t>
          </li>
          <li>
            <t>2026-03-03 --&gt; the actual date of the publication of this document</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
      <?line -18?>

<t>Tree diagrams used in this document follow the notation defined in <xref target="RFC8340"/>.</t>
      <t>This document makes use of the following terms:</t>
      <dl>
        <dt>Packet discard:</dt>
        <dd>
          <t>It accounts for any instance where a packet is dropped by a device, regardless of whether the discard was intentional or unintentional.</t>
        </dd>
        <dt>Intended packet discards (Intended discards, for short):</dt>
        <dd>
          <t>Are packets dropped due to deliberate network policies or configurations designed to enforce security or Quality of Service (QoS). For example, packets dropped because they match an Access Control List (ACL) denying certain traffic types.</t>
        </dd>
        <dt>Unintended packet discards (Unintended discards, for short):</dt>
        <dd>
          <t>Are packets that were dropped, which the network operator otherwise intended to deliver, i.e., which indicates an error state.  There are many possible reasons for unintended packet loss, including: erroring links may corrupt packets in transit; incorrect routing tables may result in packets being dropped because they do not match a valid route; configuration errors may result in a valid packet incorrectly matching an ACL and being dropped.</t>
        </dd>
      </dl>
    </section>
    <section anchor="problem">
      <name>Problem Statement</name>
      <t>The fundamental problem for network operators is how to automatically detect when and where unintended packet loss is occurring and determine the appropriate action to mitigate it. For any network, there are a small set of potential actions that can be taken to mitigate customer impact when unintended packet loss is detected, for example:</t>
      <ol spacing="normal" type="1"><li>
          <t>Take a problematic device, link, or set of devices and/or links out of service.</t>
        </li>
        <li>
          <t>Return a device, link, or set of devices and/or links back into service.</t>
        </li>
        <li>
          <t>Move traffic to other links or devices to alleviate congestion or avoid problematic paths.</t>
        </li>
        <li>
          <t>Roll back a recent change to a device that might have caused the problem.</t>
        </li>
        <li>
          <t>Escalate to a network operator as a last resort when automated mitigation is not possible.</t>
        </li>
      </ol>
      <t>The ability to select the appropriate mitigation action depends on four key features of packet loss:</t>
      <dl>
        <dt>FEATURE-DISCARD-SCOPE:</dt>
        <dd>
          <t>Determines which devices, interfaces, and/or flows are impacted. This also needs to cover control plane discards.</t>
        </dd>
        <dt>FEATURE-DISCARD-RATE:</dt>
        <dd>
          <t>The rate and/or magnitude of the discards, indicating the severity and urgency of the problem.  Rate may be expressed using absolute (e.g., packets per second (pps)) or relative (e.g., percent) values.</t>
        </dd>
        <dt>FEATURE-DISCARD-DURATION:</dt>
        <dd>
          <t>The duration of the discards which helps to distinguish transient from persistent issues.</t>
        </dd>
        <dt>FEATURE-DISCARD-CLASS:</dt>
        <dd>
          <t>The type or class of discards, which is crucial for selecting the appropriate type of mitigation. Examples may be:  error discards may require taking faulty components out of service, no-buffer discards may require traffic redistribution, or intended policy discards typically require no action. Refer to <xref target="ex-table"/> for more examples.</t>
        </dd>
      </dl>
      <t>While most of FEATURE-DISCARD-SCOPE, FEATURE-DISCARD-RATE, and FEATURE-DISCARD-DURATION are implicitly supported by the Interfaces Group MIB <xref target="RFC2863"/> and the YANG Data Model for Interface Management <xref target="RFC8343"/>, FEATURE-DISCARD-CLASS requires a more detailed classification scheme than they define. The IM provided in <xref target="infomodel"/> defines such a classification scheme to enable automated mapping from discard signals to appropriate mitigation actions (refer to <xref target="mapping"/> for examples).</t>
    </section>
    <section anchor="infomodel">
      <name>Information Model (IM)</name>
      <t>The IM is defined using YANG <xref target="RFC7950"/>, with Data Structure Extensions <xref target="RFC8791"/>, allowing the model to remain abstract and decoupled from specific implementations in accordance with <xref target="RFC3444"/>. This abstraction supports different DM implementations, such as YANG or IPFIX <xref target="RFC7011"/>, while ensuring consistency across implementations. Using YANG for the IM enables this abstraction, leverages the community's familiarity with its syntax, and ensures lossless translation to the corresponding YANG data model, which is defined in <xref target="datamodel"/>.</t>
      <ul empty="true">
        <li>
          <t>Design note: In order to ease reuse of the IM structure by DMs but without requiring that these DMs to parse the "sx" structure defined in <xref target="RFC8791"/>, main reusable nodes are defined in a common module (<xref target="common-module"/>) while the main IM structure is defined in <xref target="infomodel-module"/>.</t>
        </li>
      </ul>
      <section anchor="infomodel-structure">
        <name>Structure</name>
        <t>The IM defines a hierarchical classification scheme for packet discards, which captures where in a device the discards are accounted (component), in which direction of traffic they were flowing (direction), whether they were successfully processed or discarded (type), what protocol layer they belong to (layer), and the specific reason for any discards (subtypes). This structure enables both high-level monitoring of total discards (i.e., aggregates) and more detailed triage to map to mitigation actions.</t>
        <t>The abstract structure of the IM is depicted in <xref target="tree-im-abstract"/>. The full YANG tree diagram of the IM is provided in <xref target="sec-im-full-tree"/>.</t>
        <figure anchor="tree-im-abstract">
          <name>Abstract IM Tree Structure</name>
          <artwork><![CDATA[
module: ietf-packet-discard-reporting-sx

  structure packet-discard-reporting:
    +-- control-plane {pdr-common:control-plane-stats}?
    |  +-- traffic* [direction]
    |  |  ...
    |  +-- discards* [direction]
    |     ...
    +-- interface* [name] {pdr-common:interface-stats}?
    |  +-- name        string
    |  +-- traffic* [direction]
    |  |  +-- direction    identityref
    |  |  +-- l2
    |  |  |  ...
    |  |  +-- l3
    |  |  |  ...
    |  |  +-- qos
    |  |     ...
    |  +-- discards* [direction]
    |     +-- direction    identityref
    |     +-- l2
    |     |  ...
    |     +-- l3
    |     |  ...
    |     +-- errors
    |     |  +-- l2
    |     |  |  ...
    |     |  +-- l3
    |     |  |  ...
    |     |  +-- internal
    |     |     ...
    |     +-- policy
    |     |  +-- l2
    |     |  |  ...
    |     |  +-- l3
    |     |     ...
    |     +-- no-buffer
    |           ...
    +-- flow* [direction] {pdr-common:flow-reporting}?
    |  +-- direction    identityref
    |  +-- traffic
    |  |  +-- l2
    |  |  |  ...
    |  |  +-- l3
    |  |  |  ...
    |  |  +-- qos
    |  |     ...
    |  +-- discards
    |     +-- l2
    |     |  ...
    |     +-- l3
    |     |  ...
    |     +-- errors
    |     |  +-- l2
    |     |  |  ...
    |     |  +-- l3
    |     |  |  ...
    |     |  +-- internal
    |     |     ...
    |     +-- policy
    |     |  +-- l2
    |     |  |  ...
    |     |  +-- l3
    |     |     ...
    |     +-- no-buffer
    |           ...
    +-- device {pdr-common:device-stats}?
       +-- traffic
       |  +-- l2
       |  |  ...
       |  +-- l3
       |  |  ...
       |  +-- qos
       |     ...
       +-- discards
          +-- l2
          |  ...
          +-- l3
          |  ...
          +-- errors
          |  +-- l2
          |  |  ...
          |  +-- l3
          |  |  ...
          |  +-- internal
          |     ...
          +-- policy
          |  +-- l2
          |  |  ...
          |  +-- l3
          |     ...
          +-- no-buffer
                ...
]]></artwork>
        </figure>
        <t>The discard reporting can be organized into several types: control plane, interface, flow, and device. In order to allow for better mapping to underlying DMs, the IM supports a set of "features" to control the supported type.</t>
        <t>A complete classification path follows the pattern: component/direction/type/layer/subtype/sub-subtype/.../metric. <xref target="wheredropped"/> illustrates where these discards typically occur in a network device.  The elements of the tree are defined as follows:</t>
        <ul spacing="normal">
          <li>
            <t>Component:
            </t>
            <ul spacing="normal">
              <li>
                <t>control-plane: discards of traffic to or from a device's control plane.</t>
              </li>
              <li>
                <t>interface: discards of traffic to or from a specific network interface.</t>
              </li>
              <li>
                <t>flow: discards of traffic associated with a specific traffic flow.</t>
              </li>
              <li>
                <t>device: discards of traffic transiting the device.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Direction:
            </t>
            <ul spacing="normal">
              <li>
                <t>ingress: counters for incoming packets or frames.</t>
              </li>
              <li>
                <t>egress: counters for outgoing packets or frames.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Type:
            </t>
            <ul spacing="normal">
              <li>
                <t>traffic: counters for successfully received or transmitted packets or frames.</t>
              </li>
              <li>
                <t>discards: counters for packets or frames that were dropped.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Layer:
            </t>
            <ul spacing="normal">
              <li>
                <t>l2: Layer 2 traffic and discards. This covers both frame and byte counts.</t>
              </li>
              <li>
                <t>l3: Layer 3 traffic and discards. This covers both packet and byte counts.</t>
              </li>
            </ul>
          </li>
        </ul>
        <t>The hierarchical structure allows for future extensions while maintaining backward compatibility. New discard types can be added as new branches without affecting existing implementations.</t>
        <t>The corresponding YANG module is defined in <xref target="infomodel-module"/>.</t>
      </section>
      <section anchor="subtype-definitions">
        <name>Subtype Definitions</name>
        <dl>
          <dt>discards/policy/:</dt>
          <dd>
            <t>These are intended discards, meaning packets dropped due to a configured policy, including: ACLs, traffic policers, unicast Reverse Path Forwarding (uRPF) checks, Distributed Denial-of-Service (DDoS) protection rules, and explicit null routes.  In practice, ingress DDoS protection policies are often realized using mechanisms such as ingress filtering and uRPF (<xref target="RFC2827"/>, <xref target="RFC3704"/>, and <xref target="RFC8704"/>), remotely triggered blackholing (<xref target="RFC3882"/>, <xref target="RFC5635"/>), or BGP Flow Specification–based filters (<xref target="RFC8955"/>, <xref target="RFC8956"/>, and <xref target="RFC9117"/>); all such policy-driven discards are reported under this class.</t>
          </dd>
          <dt>discards/errors/:</dt>
          <dd>
            <t>These are unintended discards due to errors in processing packets or frames.  There are multiple sub-classes:
</t>
            <ul spacing="normal">
              <li>
                <dl>
                  <dt>discards/errors/l2/rx/:</dt>
                  <dd>
                    <t>These are frames discarded due to errors in the received Layer 2 frame, including: Cyclic Redundancy Check (CRC) errors, invalid Media Access Control (MAC) addresses, invalid VLAN tags, frame size violations and other malformed frame conditions.</t>
                  </dd>
                </dl>
              </li>
              <li>
                <dl>
                  <dt>discards/errors/l3/rx/:</dt>
                  <dd>
                    <t>These discards occur due to errors in the received packet, indicating an upstream problem rather than an issue with the device dropping the errored packets, including: header checksum errors,  MTU exceeded, invalid packet errors (i.e., incorrect version, incorrect header length, invalid options, and other malformed packet conditions).</t>
                  </dd>
                </dl>
              </li>
              <li>
                <dl>
                  <dt>discards/errors/l3/ttl-expired:</dt>
                  <dd>
                    <t>These discards occur due to TTL (or Hop limit) expiry. These can occur, e.g., for the following reasons: normal trace-route operations, end-system TTL/Hop limit set too low, or routing loops in the network.</t>
                  </dd>
                </dl>
              </li>
              <li>
                <dl>
                  <dt>discards/errors/l3/no-route/:</dt>
                  <dd>
                    <t>These discards occur due to a packet not matching any route in the routing table, e.g., which may be due to routing configuration errors or may be transient discards during convergence.</t>
                  </dd>
                </dl>
              </li>
              <li>
                <dl>
                  <dt>discards/errors/internal/:</dt>
                  <dd>
                    <t>These discards occur due to internal device issues, including: parity errors in device memory or other internal hardware errors.  Any errored discards not explicitly assigned to other classes are also accounted for here.</t>
                  </dd>
                </dl>
              </li>
            </ul>
          </dd>
          <dt>discards/no-buffer/:</dt>
          <dd>
            <t>These are discards due to buffer exhaustion (that is congestion related discards). These can be tail-drop discards or due to an active queue management algorithm, such as Random Early Detection (RED) <xref target="RED93"/> or Controlled Delay (CoDel) <xref target="RFC8289"/>.</t>
          </dd>
        </dl>
        <t>An example of possible signal-to-mitigation action mapping is provided in <xref target="mapping"/>.</t>
      </section>
      <section anchor="common-module">
        <name>"ietf-packet-discard-reporting-common" YANG Module</name>
        <t>The "ietf-packet-discard-reporting-common" module imports "ietf-yang-types" defined in <xref target="RFC9911"/>.</t>
        <sourcecode markers="true" name="ietf-packet-discard-reporting-common@2026-03-03.yang"><![CDATA[
module ietf-packet-discard-reporting-common {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:"
          + "ietf-packet-discard-reporting-common";
  prefix pdr-common;

  import ietf-yang-types {
    prefix yang;
    reference
      "RFC 9911: Common YANG Data Types";
  }

  organization
    "IETF OPSAWG (Operations and Management Area Working Group)";
  contact
    "WG Web:   https://datatracker.ietf.org/wg/opsawg/
     WG List:  OPSAWG <mailto:opsawg@ietf.org>

     Editor:   John Evans
               <mailto:jevanamz@amazon.co.uk>

     Editor:   Oleksandr Pylypenko
               <mailto:opylypenko@nvidia.com>

     Author:   Jeffrey Haas
               <mailto:jhaas@juniper.net>

     Author:   Aviran Kadosh
               <mailto:akadosh@cisco.com>

     Editor:   Mohamed Boucadair
               <mailto:mohamed.boucadair@orange.com>";
  description
    "This module defines a common YANG module for packet discard
     reporting.

     Copyright (c) 2026 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).

     All revisions of IETF and IANA published modules can be found
     at the YANG Parameters registry group
     (https://www.iana.org/assignments/yang-parameters).

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

  revision 2026-03-03 {
    description
      "Initial revision.";
    reference
      "RFC XXXX: Information and Data Models for Packet Discard
                 Reporting";
  }

  /*
   * Features
   */

  feature control-plane-stats {
    description
      "Indicates support of control plane discard statistics.";
  }

  feature interface-stats {
    description
      "Indicates support of interface discard statistics.";
  }

  feature flow-reporting {
    description
      "Indicates support of flow discard reporting.";
  }

  feature device-stats {
    description
      "Indicates support of global device discard statistics.";
  }

  /*
   * Identities
   */

  identity direction {
    description
      "Defines a direction for the reported statistics.";
  }

  identity ingress {
    base direction;
    description
      "Reports statistics for the received packets from
       the network.";
  }

  identity egress {
    base direction;
    description
      "Reports statistics for the sent packets to
       to the network.";
  }

  identity address-family {
    description
      "Defines a type for the address family.

       This identity is defined here rather than importing
       it from other YANG modules to simplify implementations
       and avoid inheriting dependencies of those modules.

       Additional address families can be added by defining
       identities derived from this base identity, without
       affecting existing implementations.";
  }

  identity ip {
    base address-family;
    description
      "Identity for IP address family.";
  }

  identity ipv4 {
    base ip;
    description
      "Identity for IPv4 address family.";
  }

  identity ipv6 {
    base ip;
    description
      "Identity for IPv6 address family.";
  }

  /*
   * Groupings
   */

  grouping basic-packets {
    description
      "Grouping for packet counters.";
    leaf packets {
      type yang:counter64;
      description
        "Number of packets.";
    }
  }

  grouping basic-packets-bytes {
    description
      "Grouping for packet and byte counters.";
    uses basic-packets;
    leaf bytes {
      type yang:counter64;
      description
        "Number of bytes.";
    }
  }

  grouping basic-frames {
    description
      "Grouping for Layer 2 frame counters.";
    leaf frames {
      type yang:counter64;
      description
        "Number of Layer 2 frames.";
    }
  }

  grouping l2-traffic {
    description
      "Grouping for Layer 2 frame and byte counters.";
    uses basic-frames;
    leaf bytes {
      type yang:counter64;
      description
        "Number of Layer 2 bytes.";
    }
  }

  grouping l3-traffic {
    description
      "Layer 3 traffic counters per address family.";
    list address-family-stat {
      key "address-family";
      description
        "Reports per address family traffic counters.";
      leaf address-family {
        type identityref {
          base address-family;
        }
        description
          "Specifies an address family.";
      }
      uses basic-packets-bytes;
      container unicast {
        description
          "Unicast traffic counters.";
        uses basic-packets-bytes;
      }
      container multicast {
        description
          "Multicast traffic counters.";
        uses basic-packets-bytes;
      }
      container broadcast {
        when "derived-from-or-self(../address-family, "
           + "'pdr-common:ipv4')" {
          description
            "Only applicable for IPv4.";
        }
        description
          "Broadcast traffic counters.";
        uses basic-packets-bytes;
      }
    }
  }

  grouping class-list {
    description
      "Class-based traffic counters.";
    list class {
      key "id";
      min-elements 1;
      description
        "Class traffic counters.";
      leaf id {
        type string;
        description
          "Indicates a Quality of Service (QoS) class
           identifier.";
      }
      uses basic-packets-bytes;
    }
  }

  grouping qos {
    description
      "QoS traffic counters.";
    container qos {
      presence "QoS statistics are available.";
      description
        "Per-class QoS traffic counters.";
      uses class-list;
    }
  }

  grouping traffic {
    description
      "All traffic counters.";
    container l2 {
      description
        "Layer 2 traffic counters.";
      uses l2-traffic;
    }
    container l3 {
      description
        "Layer 3 traffic counters.";
      uses l3-traffic;
    }
    uses qos;
  }

  grouping errors-l2-rx {
    description
      "Layer 2 ingress frame error discard counters.";
    container rx {
      description
        "Layer 2 ingress frame receive error discard
         counters.";
      leaf frames {
        type yang:counter64;
        description
          "The number of frames discarded due to errors
           with the received frame.";
      }
      leaf crc-error {
        type yang:counter64;
        description
          "The number of received frames discarded due to
            Cyclic Redundancy Check (CRC) error.";
      }
      leaf invalid-mac {
        type yang:counter64;
        description
          "The number of received frames discarded due to
           an invalid Media Access Control (MAC) address.";
      }
      leaf invalid-vlan {
        type yang:counter64;
        description
          "The number of received frames discarded due to
           an invalid VLAN tag.";
      }
      leaf invalid-frame {
        type yang:counter64;
        description
          "The number of invalid received frames discarded due to
           other reasons, not limited to: malformed frames,
           frame-size violations.";
      }
    }
  }

  grouping errors-l3-rx {
    description
      "Layer 3 ingress packet error discard counters.";
    container rx {
      description
        "Layer 3 ingress packet receive error discard
         counters.";
      leaf packets {
        type yang:counter64;
        description
          "The number of Layer 3 packets discarded due to
           errors in the received packet.";
      }
      leaf checksum-error {
        type yang:counter64;
        description
          "The number of received packets discarded due
           to a checksum error.";
      }
      leaf mtu-exceeded {
        type yang:counter64;
        description
          "The number of received packets discarded due to
           MTU exceeded.";
      }
      leaf invalid-packet {
        type yang:counter64;
        description
          "The number of received invalid packets discarded due
           to other reasons, not limited to: invalid packet length,
           invalid header fields, invalid options, invalid protocol
           version, invalid flags or control bits, malformed
           packets.";
      }
    }
    leaf ttl-expired {
      type yang:counter64;
      description
        "The number of received packets discarded due to
         expired TTL or Hop Limit exceeded.";
    }
    leaf no-route {
      type yang:counter64;
      description
        "The number of received packets discarded due to not
         matching a valid route.";
    }
    leaf invalid-sid {
      type yang:counter64;
      description
        "The number of received packets discarded due to an
         invalid Segment Routing over IPv6 (SRv6) segment 
         identifier (SID).
         For SR-MPLS, invalid SIDs have to be accounted
         under invalid-label.";
    }
    leaf invalid-label {
      type yang:counter64;
      description
        "The number of received packets discarded due to an
         invalid MPLS label.";
    }
  }

  grouping errors-l3-int {
    description
      "Internal error discard counters.";
    leaf packets {
      type yang:counter64;
      description
        "The number of packets discarded due to internal
         errors.";
    }
    leaf parity-error {
      type yang:counter64;
      description
        "The number of packets discarded due to parity
         errors.";
    }
  }

  grouping errors-l2-tx {
    description
      "Layer 2 transmit error discard counters.";
    container tx {
      description
        "Layer 2 transmit frame error discard counters.";
      leaf frames {
        type yang:counter64;
        description
          "The number of Layer 2 frames discarded due to
           errors when transmitting.";
      }
    }
  }

  grouping errors-l3-tx {
    description
      "Layer 3 transmit error discard counters.";
    container tx {
      description
        "Layer 3 transmit packet error discard counters.";
      leaf packets {
        type yang:counter64;
        description
          "The number of Layer 3 packets discarded due to
           errors when transmitting.";
      }
    }
  }

  grouping errors {
    description
      "Error discard counters.";
    container l2 {
      description
        "Layer 2 frame error discard counters.";
      uses errors-l2-rx;
      uses errors-l2-tx;
    }
    container l3 {
      description
        "Layer 3 packet error discard counters.";
      uses errors-l3-rx;
      uses errors-l3-tx;
    }
    container internal {
      description
        "Internal error discard counters.";
      uses errors-l3-int;
    }
  }

  grouping policy-l2 {
    description
      "Layer 2 policy frame discard counters.";
    leaf frames {
      type yang:counter64;
      description
        "The number of Layer 2 frames discarded due
         to policy.";
    }
    leaf acl {
      type yang:counter64;
      description
        "The number of frames discarded due to Layer 2 
         Access Control Lists (ACLs).";
    }
  }

  grouping policy-l3 {
    description
      "Layer 3 policy packet discard counters.";
    leaf packets {
      type yang:counter64;
      description
        "The number of Layer 3 packets discarded due to policy.";
    }
    leaf acl {
      type yang:counter64;
      description
        "The number of packets discarded due to Layer 3 ACLs.";
    }
    container policer {
      description
        "The number of packets discarded due to policer
         violations.";
      uses basic-packets-bytes;
      container classes {
        presence "Per-class policer statistics are available.";
        description
          "Per-class policer discard counters.";
        uses class-list;
      }
    }
    leaf null-route {
      type yang:counter64;
      description
        "The number of packets discarded due to matching
         a null route.";
    }
    leaf rpf {
      type yang:counter64;
      description
        "The number of packets discarded due to failing
         Reverse Path Forwarding (RPF) check.";
    }
    leaf ddos {
      type yang:counter64;
      description
        "The number of packets discarded due to Distributed
         Denial-of-Service (DDoS) protection policies.";
    }
  }

  grouping discards {
    description
      "Discard counters.";
    container l2 {
      description
        "Layer 2 frame discard counters.";
      uses l2-traffic;
    }
    container l3 {
      description
        "Layer 3 packet discard counters.";
      uses l3-traffic;
    }
    container errors {
      description
        "Error discard counters.";
      uses errors;
    }
    container policy {
      description
        "Policy-related discard counters.";
      uses policy;
    }
    container no-buffer {
      description
        "Discard counters due to buffer unavailability.";
      uses qos;
    }
  }

  grouping policy {
    description
      "Policy-related discard counters.";
    container l2 {
      description
        "Layer 2 policy frame discard counters.";
      uses policy-l2;
    }
    container l3 {
      description
        "Layer 3 policy packet discard counters.";
      uses policy-l3;
    }
  }

  grouping traffic-and-discards {
    description
      "Specifies overall traffic and discard counters.";
    container traffic {
      description
        "Traffic counters.";
      uses traffic;
    }
    container discards {
      description
        "Discard counters.";
      uses discards;
    }
  }

  grouping interface {
    description
      "Interface-level traffic and discard counters.";
    list traffic {
      key "direction";
      description
        "Traffic counters.";
      leaf direction {
        type identityref {
          base direction;
        }
        description
          "Specifies a direction.";
      }
      uses traffic;
    }
    list discards {
      key "direction";
      description
        "Discard counters.";
      leaf direction {
        type identityref {
          base direction;
        }
        description
          "Specifies a direction.";
      }
      uses discards;
    }
  }

  grouping control-plane {
    description
      "Control plane packet counters.";
    list traffic {
      key "direction";
      description
        "Total control plane packets.";
      leaf direction {
        type identityref {
          base direction;
        }
        description
          "Specifies a direction.";
      }
      uses basic-packets-bytes;
    }
    list discards {
      key "direction";
      description
        "Control plane packet discard counters.";
      leaf direction {
        type identityref {
          base direction;
        }
        description
          "Specifies a direction.";
      }
      uses basic-packets-bytes;
      container policy {
        description
          "Number of control plane packets discarded due to policy.";
        uses basic-packets;
      }
    }
  }
}
]]></sourcecode>
      </section>
      <section anchor="infomodel-module">
        <name>"ietf-packet-discard-reporting-sx" YANG Module</name>
        <t>The "ietf-packet-discard-reporting-sx" module uses the "sx" structure defined in <xref target="RFC8791"/> and also imports the "ietf-packet-discard-reporting-common" module (<xref target="common-module"/>).</t>
        <sourcecode markers="true" name="ietf-packet-discard-reporting-sx@2026-03-03.yang"><![CDATA[
module ietf-packet-discard-reporting-sx {
  yang-version 1.1;
  namespace
    "urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting-sx";
  prefix pdr-sx;

  import ietf-packet-discard-reporting-common {
    prefix pdr-common;
    reference
      "RFC XXXX: Information and Data Models for Packet Discard
                 Reporting";
  }
  import ietf-yang-structure-ext {
    prefix sx;
    reference
      "RFC 8791: YANG Data Structure Extensions";
  }

  organization
    "IETF OPSAWG (Operations and Management Area Working Group)";
  contact
    "WG Web:   https://datatracker.ietf.org/wg/opsawg/
     WG List:  OPSAWG <mailto:opsawg@ietf.org>

     Editor:   John Evans
               <mailto:jevanamz@amazon.co.uk>

     Editor:   Oleksandr Pylypenko
               <mailto:opylypenko@nvidia.com>

     Author:   Jeffrey Haas
               <mailto:jhaas@juniper.net>

     Author:   Aviran Kadosh
               <mailto:akadosh@cisco.com>

     Editor:   Mohamed Boucadair
               <mailto:mohamed.boucadair@orange.com>";
  description
    "This module defines an information model for packet discard
     reporting.

     Copyright (c) 2026 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).

     All revisions of IETF and IANA published modules can be found
     at the YANG Parameters registry group
     (https://www.iana.org/assignments/yang-parameters).

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

  revision 2026-03-03 {
    description
      "Initial revision.";
    reference
      "RFC XXXX: Information and Data Models for Packet Discard
                 Reporting";
  }

  /*
   * Main structure definition
   */

  sx:structure packet-discard-reporting {
    description
      "Specifies the abstract structure of packet discard
       reporting data.";
    container control-plane {
      if-feature "pdr-common:control-plane-stats";
      description
        "Control plane packet counters.";
      uses pdr-common:control-plane;
    }
    list interface {
      if-feature "pdr-common:interface-stats";
      key "name";
      description
        "Indicates a list of interfaces for which packet
         discard reporting data is provided.";
      leaf name {
        type string;
        description
          "Indicates the name of the interface.";
      }
      uses pdr-common:interface;
    }
    list flow {
      if-feature "pdr-common:flow-reporting";
      key "direction";
      leaf direction {
        type identityref {
          base pdr-common:direction;
        }
        description
          "Specifies a direction.";
      }
      description
        "Flow packet counters.";
      uses pdr-common:traffic-and-discards;
    }
    container device {
      if-feature "pdr-common:device-stats";
      description
        "Device level packet counters.";
      uses pdr-common:traffic-and-discards;
    }
  }
}
]]></sourcecode>
      </section>
    </section>
    <section anchor="datamodel">
      <name>Data Model (DM)</name>
      <t>This DM implements the IM defined in <xref target="infomodel"/> for the interface, device, and control-plane components. It is a device model per <xref section="2.1" sectionFormat="of" target="RFC8969"/>. Specifically, it is a device-local (network element) operational state model: counters are scoped to a single device (interfaces and control plane).</t>
      <t>The IM defines the abstract classification tree using YANG data structure extensions <xref target="RFC8791"/>. This DM imports that module and reuses the same groupings and hierarchy of components, directions, layers, and discard classes, attaching them via augment statements to existing YANG modules for routing, interfaces, and logical network elements. The flow component is defined only in the IM for use by flow-oriented data models and are not instantiated in this DM.</t>
      <section anchor="datamodel-structure">
        <name>Structure</name>
        <t>There is a direct mapping between the IM components and their DM implementations, with each component in the hierarchy represented by corresponding YANG containers and leaf data nodes. The abstract tree is shown in <xref target="tree-dm-abstract"/>.</t>
        <figure anchor="tree-dm-abstract">
          <name>Abstract DM Tree Structure</name>
          <artwork><![CDATA[
module: ietf-packet-discard-reporting

  augment /rt:routing/rt:control-plane-protocols
            /rt:control-plane-protocol:
    +--ro traffic-discard-stats {control-plane-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic* [direction]
       |  ...
       +--ro discards* [direction]
          ...
  augment /if:interfaces/if:interface/if:statistics:
    +--ro traffic-discard-stats {interface-stats}?
       +--ro discard-order-capability*   identityref?
       +--ro traffic* [direction] {interface-stats}?
       |  +--ro direction    identityref
       |  +--ro l2
       |  |  ...
       |  +--ro l3
       |  |  ...
       |  +--ro qos!
       |     +--ro class* [id]
       |        ...
       +--ro discards* [direction]?
          +--ro direction    identityref
          +--ro l2
          |  ...
          +--ro l3
          |  ...
          +--ro errors
          |  +--ro l2
          |  |  ...
          |  +--ro l3
          |  |  ...
          |  +--ro internal
          |     ...
          +--ro policy
          |  +--ro l2
          |  |  ...
          |  +--ro l3
          |     ...
          +--ro no-buffer
             +--ro qos!
                +--ro class* [id]
                   ...
  augment /lne:logical-network-elements/lne:logical-network-element:
    +--ro traffic-discard-stats {device-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic
       |  +--ro l2
       |  |  ...
       |  +--ro l3
       |  |  ...
       |  +--ro qos!
       |     +--ro class* [id]
       |        ...
       +--ro discards
          +--ro l2
          |  ...
          +--ro l3
          |  ...
          +--ro errors
          |  +--ro l2
          |  |  ...
          |  +--ro l3
          |  |  ...
          |  +--ro internal
          |     ...
          +--ro policy
          |  +--ro l2
          |  |  ...
          |  +--ro l3
          |     ...
          +--ro no-buffer
             +--ro qos!
                +--ro class* [id]
                   ...
]]></artwork>
        </figure>
        <t>The full tree structure is provided in <xref target="sec-dm-full-tree"/>.</t>
      </section>
      <section anchor="requirements">
        <name>Implementation Requirements</name>
        <t>The following requirements apply to the implementation of the DM and are intended to ensure consistent implementation across different vendors and platforms while allowing for platform-specific optimisations where needed. While the DM defines a comprehensive set of counters and statistics, implementations <bcp14>MAY</bcp14> support a subset of the defined features based on device capabilities and operational requirements. However, implementations <bcp14>MUST</bcp14> clearly document which features are supported and how they map to the DM.</t>
        <t>Requirements 1-13 relate to packets forwarded or discarded by the device, while requirement 14 relates to packets destined for or originating from the device:</t>
        <ol spacing="normal" type="1"><li>
            <t>All instances of Layer 2 frame or Layer 3 packet receipt, transmission, and discards <bcp14>MUST</bcp14> be accounted for.</t>
          </li>
          <li>
            <t>All instances of Layer 2 frame or Layer 3 packet receipt, transmission, and discards <bcp14>SHOULD</bcp14> be attributed to the physical or logical interface of the device where they occur.  Where they cannot be attributed to the interface, they <bcp14>MUST</bcp14> be attributed to the device.</t>
          </li>
          <li>
            <t>An individual frame <bcp14>MUST</bcp14> only be accounted for by either the Layer 2 traffic class or the Layer 2 discard classes within a single direction or context, i.e., ingress or egress or device.  This is to avoid double counting.</t>
          </li>
          <li>
            <t>An individual packet <bcp14>MUST</bcp14> only be accounted for by either the Layer 3 traffic class or the Layer 3 discard classes within a single direction or context, i.e., ingress or egress or device.  This is to avoid double counting.</t>
          </li>
          <li>
            <t>A frame accounted for at Layer 2 <bcp14>MUST NOT</bcp14> be accounted for at Layer 3 and vice versa. This is to avoid double counting.</t>
          </li>
          <li>
            <t>The aggregate Layer 2 and Layer 3 traffic and discard classes <bcp14>SHOULD</bcp14> account for all underlying frames or packets received, transmitted, and discarded across all other classes. There might be exceptions when distinct discontinuity times are observed for more granular discards.</t>
          </li>
          <li>
            <t>The aggregate QoS traffic and no-buffer discard classes <bcp14>MUST</bcp14> account for all underlying packets received, transmitted, and discarded across all other classes.</t>
          </li>
          <li>
            <t>In addition to the Layer 2 and Layer 3 aggregate classes, an individual discarded packet <bcp14>MUST</bcp14> only account against a single error, policy, or no-buffer discard subclass.</t>
          </li>
          <li>
            <t>When there are multiple reasons for discarding a packet, the ordering of discard class reporting <bcp14>MUST</bcp14> be defined. Typically, this can be exposed by an implementation by means of <tt>discard-order-capability</tt>.</t>
          </li>
          <li>
            <t>If Diffserv <xref target="RFC2475"/> is not used, no-buffer discards <bcp14>MUST</bcp14> be reported as <tt>class[id="0"]</tt>, which represents the default class.</t>
          </li>
          <li>
            <t>When traffic is mirrored, the discard metrics <bcp14>MUST</bcp14> account for the original traffic rather than the reflected traffic.</t>
          </li>
          <li>
            <t>No-buffer discards can be realized differently with different memory architectures. Whether a no-buffer discard is attributed to ingress or egress can differ accordingly. For successful auto-mitigation, discards due to an egress interface congestion <bcp14>MUST</bcp14> be reportable on <tt>egress</tt>, while discards due to device-level congestion (e.g., due to exceeding the device forwarding rate) <bcp14>MUST</bcp14> be reportable on <tt>ingress</tt>.</t>
          </li>
          <li>
            <t>When the ingress and egress headers differ (for example, at a tunnel endpoint), the discard class attribution <bcp14>MUST</bcp14> relate to the outer header at the point of discard.</t>
          </li>
          <li>
            <t>Traffic to the device control plane (to-CPU) has its own class. Traffic from the device control plane (from-CPU) is accounted for by origin, independent of the forwarding mechanism (e.g., any egress policer it traverses), and <bcp14>MUST</bcp14> also be accounted for in the same way as other egress traffic.</t>
          </li>
        </ol>
      </section>
      <section anchor="examples">
        <name>Usage Examples</name>
        <t>This section assumes that no class of service is implemented.</t>
        <t>If all of the requirements listed in <xref target="requirements"/> are met, a "good" unicast IPv4 packet received would increment:</t>
        <ul spacing="normal">
          <li>
            <t><tt>interface/traffic[direction="ingress"]/l3/address-family-stat[address-family="ipv4"]/unicast/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/l3/address-family-stat[address-family="ipv4"]/unicast/bytes</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/qos/class[id="0"]/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/qos/class[id="0"]/bytes</tt></t>
          </li>
        </ul>
        <t>A received unicast IPv6 packet discarded due to Hop Limit expiry would increment:</t>
        <ul spacing="normal">
          <li>
            <t><tt>interface/discards[direction="ingress"]/errors/l3/ttl-expired</tt></t>
          </li>
        </ul>
        <t>An IPv4 packet discarded on egress due to no buffers would increment:</t>
        <ul spacing="normal">
          <li>
            <t><tt>interface/discards[direction="egress"]/l3/address-family-stat[address-family="ipv4"]/unicast/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/discards[direction="egress"]/l3/address-family-stat[address-family="ipv4"]/unicast/bytes</tt></t>
          </li>
          <li>
            <t><tt>interface/discards[direction="egress"]/no-buffer/class[id="0"]/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/discards[direction="egress"]/no-buffer/class[id="0"]/bytes</tt></t>
          </li>
        </ul>
        <t>A multicast IPv6 packet dropped due to RPF check failure would increment:</t>
        <ul spacing="normal">
          <li>
            <t><tt>interface/discards[direction="ingress"]/l3/address-family-stat[address-family="ipv6"]/multicast/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/discards[direction="ingress"]/l3/address-family-stat[address-family="ipv6"]/multicast/bytes</tt></t>
          </li>
          <li>
            <t><tt>interface/discards[direction="ingress"]/policy/l3/rpf</tt></t>
          </li>
        </ul>
        <t>A "good" Layer-2 frame received would increment:</t>
        <ul spacing="normal">
          <li>
            <t><tt>interface/traffic[direction="ingress"]/l2/frames</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/l2/bytes</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/qos/class[id="0"]/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/qos/class[id="0"]/bytes</tt></t>
          </li>
        </ul>
      </section>
      <section anchor="datamodel-module">
        <name>"ietf-packet-discard-reporting" YANG Module</name>
        <t>The "ietf-packet-discard-reporting" module imports "ietf-packet-discard-reporting-common" (<xref target="common-module"/>), "ietf-netconf-acm" <xref target="RFC8341"/>, "ietf-interfaces" <xref target="RFC8343"/>, "ietf-routing" <xref target="RFC8349"/>, and "ietf-logical-network-element" <xref target="RFC8530"/>.</t>
        <sourcecode markers="true" name="ietf-packet-discard-reporting@2026-03-03.yang"><![CDATA[
module ietf-packet-discard-reporting {
  yang-version 1.1;
  namespace
    "urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting";
  prefix pdr;

  import ietf-packet-discard-reporting-common {
    prefix pdr-common;
    reference
      "RFC XXXX: Information and Data Models for Packet Discard
                 Reporting";
  }
  import ietf-netconf-acm {
    prefix nacm;
    reference
      "RFC 8341: Network Configuration Access Control Model";
  }
  import ietf-interfaces {
    prefix if;
    reference
      "RFC 8343: A YANG Data Model for Interface Management";
  }
  import ietf-routing {
    prefix rt;
    reference
      "RFC 8349: A YANG Data Model for Routing Management
                 (NMDA Version)";
  }
  import ietf-logical-network-element {
    prefix lne;
    reference
      "RFC 8530: YANG Model for Logical Network Elements";
  }

  organization
    "IETF OPSAWG (Operations and Management Area Working Group)";
  contact
    "WG Web:   https://datatracker.ietf.org/wg/opsawg/
     WG List:  OPSAWG <mailto:opsawg@ietf.org>

     Editor:   John Evans
               <mailto:jevanamz@amazon.co.uk>

     Editor:   Oleksandr Pylypenko
               <mailto:opylypenko@nvidia.com>

     Author:   Jeffrey Haas
               <mailto:jhaas@juniper.net>

     Author:   Aviran Kadosh
               <mailto:akadosh@cisco.com>

     Editor:   Mohamed Boucadair
               <mailto:mohamed.boucadair@orange.com>";
  description
    "This module defines a data model for packet discard reporting.

     Copyright (c) 2026 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).

     All revisions of IETF and IANA published modules can be found
     at the YANG Parameters registry
     (https://www.iana.org/assignments/yang-parameters).

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

  revision 2026-03-03 {
    description
      "Initial revision.";
    reference
      "RFC XXXX: Information and Data Models for Packet Discard
                 Reporting";
  }

  /*
   * Identities
   */

  identity discard-class {
    description
      "Base identity to identify the discard class.";
  }

  identity layer2 {
    base discard-class;
    description
      "Indicates a Layer 2 discard.";
  }

  identity layer3 {
    base discard-class;
    description
      "Indicates a Layer 3 discard.";
  }

  identity internal {
    base discard-class;
    description
      "Indicates an internal discard.";
  }

  identity policy {
    base discard-class;
    description
      "Indicates a discard due to a policy.";
  }

  identity no-buffer {
    base discard-class;
    description
      "Indicates a discard due to buffer unavailability.";
  }

  /*
   * Groupings
   */

  grouping discard-order-policy {
    description
      "Defines the implementation-specific precedence of discard
       classes when multiple discard reasons apply to a single
       packet.

       The list is ordered from highest to lowest precedence.";

    leaf-list discard-order-capability {
      type identityref {
        base discard-class;
      }
      config false;
      description
        "The discard class identity that has this precedence.";
    }
  }

  /*
   * Main structure definition
   */

  augment "/rt:routing/rt:control-plane-protocols"
        + "/rt:control-plane-protocol" {
    if-feature "pdr-common:control-plane-stats";
    description
      "Adds control plane discard counters.";
    container traffic-discard-stats {
      nacm:default-deny-all;
      config false;
      description
        "List of traffic and control plane discard counters.";
      uses discard-order-policy;
      uses pdr-common:control-plane;
    }
  }
  augment "/if:interfaces/if:interface/if:statistics" {
    if-feature "pdr-common:interface-stats";
    description
      "Adds traffic and discard reporting to the interface
       statistics.";

    container traffic-discard-stats {
      nacm:default-deny-all;
      config false;
      description
        "List of traffic and interface discard counters.";
      uses discard-order-policy;
      uses pdr-common:interface;
    }
  }
  augment "/lne:logical-network-elements"
        + "/lne:logical-network-element" {
    if-feature "pdr-common:device-stats";
    description
      "Adds device level traffic and discard counters.";

    container traffic-discard-stats {
      nacm:default-deny-all;
      config false;
      description
        "List of traffic and device level discard counters.";
      uses discard-order-policy;
      uses pdr-common:traffic-and-discards;
    }
  }
}
]]></sourcecode>
      </section>
    </section>
    <section anchor="operational-considerations">
      <name>Operational Considerations</name>
      <section anchor="determining-intent-for-policy">
        <name>Determining Intent for Policy</name>
        <t>Device discard counters do not by themselves establish operator intent. Discards reported under policy (e.g., ACL/policer) indicate only that traffic matched a configured rule; such discards may still be unintended if the configuration is in error. Determining intent for policy discards requires external context (e.g., configuration validation and change history). Such contexts are local to each operator.</t>
      </section>
      <section anchor="experience">
        <name>Deployment Experience</name>
        <t>This section captures practical insights gained from implementing the model across multiple vendors' platforms, as guidance for future implementers and operators:</t>
        <ol spacing="normal" type="1"><li>
            <t>The number and granularity of discard classes defined in the IM represent a compromise. It aims to provide sufficient detail to enable appropriate automated actions while avoiding excessive detail, which may hinder quick problem identification.  Additionally, it helps to limit the quantity of data produced per interface, constraining the data volume and device CPU impacts.  While further granularity is possible, the defined schema has generally proven to be sufficient for the task of mitigating unintended packet loss.</t>
          </li>
          <li>
            <t>There are many possible ways to define the discard classification tree.  For example, an approach is to use a multi-rooted tree, rooted in each protocol. Instead, a better approach is to define a tree where protocol discards and causal discard classes are accounted for orthogonally.  This decision reduces the number of combinations of classes and has proven sufficient for determining mitigation actions.</t>
          </li>
          <li>
            <t>Platforms often account for the number of packets discarded where the TTL has expired (or IPv6 Hop Limit exceeded), and the device CPU has returned an ICMP Time Exceeded message <xref target="RFC4884"/>. There is typically a policer applied to limit the number of packets sent to the device CPU, however, which implicitly limits the rate of TTL discards that are processed.  One method to account for all packet discards due to TTL expired, even those that are dropped by a policer when being forwarded to the CPU, is to use accounting of all ingress packets received with TTL=1 as a proxy measure.</t>
          </li>
          <li>
            <t>Where no route discards are implemented with a default null route, separate discard accounting is required for any explicit null routes configured in order to differentiate between interface/ingress/discards/policy/null-route/packets and interface/ingress/discards/errors/no-route/packets.</t>
          </li>
          <li>
            <t>It is useful to account separately for transit packets discarded by ACLs or policers, and packets discarded by ACLs or policers which limit the number of packets to the device control plane.</t>
          </li>
          <li>
            <t>It is not possible to identify a configuration error (e.g., when intended discards are unintended) with device discard metrics alone. For example, additional context is needed to determine if ACL discards are intended or due to a misconfigured ACL (i.e., with configuration validation before deployment or by detecting a significant change in ACL discards after a configuration change compared to before).</t>
          </li>
          <li>
            <t>Aggregate counters need to be able to deal with the possibility of discontinuities in the underlying counters.</t>
          </li>
          <li>
            <t>While the classification tree is seven levels deep, a minimal implementation may only implement the top six.</t>
          </li>
        </ol>
      </section>
      <section anchor="anchoring-flow-structure">
        <name>Anchoring Flow Structure</name>
        <t>The characterization of a flow depends on the underlying data model that adheres to the IM. From that standpoint, the IM does not make an assumption about flow characterization and identification. Future flow-oriented data models <bcp14>MUST</bcp14> ensure that the flow structure is anchored so that the discards are unambiguously associated with a flow.</t>
      </section>
    </section>
    <section anchor="implementation-status">
      <name>Implementation Status</name>
      <t>Note to RFC Editor: This section is to be removed before publication as an RFC.</t>
      <t>This section records the status of known implementations of the protocol defined by this specification at the time of posting of this Internet-Draft, and is based on a proposal described in RFC 7942.  The description of implementations in this section is intended to assist the IETF in its decision processes in progressing drafts to RFCs.  Please note that the listing of any individual implementation here does not imply endorsement by the IETF.  Furthermore, no effort has been spent to verify the information presented here that was supplied by IETF contributors.  This is not intended as, and must not be construed to be, a catalog of available implementations or their features.  Readers are advised to note that other implementations may exist.</t>
      <section anchor="information-model-implementations">
        <name>Information Model Implementations</name>
        <t>The IM defined in <xref target="infomodel"/> has been implemented or mapped on at least nine hardware platforms across four vendors, including:</t>
        <ul spacing="normal">
          <li>
            <t>Broadcom: Trident, Tomahawk 1, Tomahawk 3, Tomahawk 5</t>
          </li>
          <li>
            <t>Cisco: Q200L</t>
          </li>
          <li>
            <t>Juniper: MX, PTX, QFX</t>
          </li>
          <li>
            <t>Marvell: TL7</t>
          </li>
        </ul>
      </section>
      <section anchor="data-model-implementations">
        <name>Data Model Implementations</name>
        <t>A YANG-compliant open-source SLAX script implements a subset of the DM defined in <xref target="datamodel"/> for Juniper MX routers.  This implementation is available at:</t>
        <ul spacing="normal">
          <li>
            <t><eref target="https://github.com/o-pylypenko-aws/draft-ietf-opsawg-discardmodel-sample/">https://github.com/o-pylypenko-aws/draft-ietf-opsawg-discardmodel-sample/</eref></t>
          </li>
        </ul>
        <t>Practical observations from these implementations are reflected in <xref target="experience"/>.</t>
      </section>
    </section>
    <section anchor="security">
      <name>Security Considerations</name>
      <section anchor="security-infomodel">
        <name>Information Model</name>
        <t>The IM defined in <xref target="infomodel-module"/> specifies a YANG module using <xref target="RFC8791"/> data extensions. As such, there are no additional security issues related to the YANG module that need to be considered.</t>
        <t>The "ietf-packet-discard-reporting-common" YANG module defines a set of identities, types, and
   groupings. These nodes are intended to be reused by other YANG
   modules. The module by itself does not expose any data nodes that
   are writable, data nodes that contain read-only state, or RPCs.
   As such, there are no additional security issues related to
   the YANG module that need to be considered.</t>
        <t>Modules that use the groupings that are defined in the "ietf-packet-discard-reporting-common" module
   should identify the corresponding security considerations.</t>
      </section>
      <section anchor="security-datamodel">
        <name>Data Model</name>
        <t>This section is modeled after the template described in <xref section="3.7.1" sectionFormat="of" target="RFC9907"/>.</t>
        <t>The YANG module specified in <xref target="datamodel-module"/> defines a data model that is designed to be accessed via YANG-based management protocols, such as Network Configuration Protocol (NETCONF) <xref target="RFC6241"/> and RESTCONF <xref target="RFC8040"/>. These YANG-based management protocols (1) have to use a secure transport layer (e.g., Secure Shell (SSH) <xref target="RFC4252"/>, TLS <xref target="RFC8446"/>, and QUIC <xref target="RFC9000"/>) and (2) have to use mutual authentication.</t>
        <t>The Network Configuration Access Control Model (NACM) <xref target="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.</t>
        <t>There are no particularly sensitive writable data nodes.</t>
        <t>Some of the readable data nodes in this YANG module may be considered sensitive or vulnerable in some network environments.  It is thus important to control read access (e.g., via get, get-config, or notification) to these data nodes. Specifically, the following subtrees and data nodes have particular sensitivities/vulnerabilities:</t>
        <dl>
          <dt>rt:control-plane-protocol/pdr:traffic-discard-stats, if:statistics/pdr:traffic, if:statistics/pdr:traffic-discard-stats, and lne:logical-network-element/pdr:traffic-discard-stats:</dt>
          <dd>
            <t>Access to these data nodes would reveal information about the attacks to which an element is subject, misconfigurations, etc.</t>
          </dd>
          <dt/>
          <dd>
            <t>Also, an attacker who can inject packets can infer the efficiency of its attack by monitoring (the increase of) some discard counters (e.g., policy) and adjust its attack strategy accordingly.</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="iana">
      <name>IANA Considerations</name>
      <t>IANA is requested to register the following URI in the "ns" subregistry within the "IETF XML Registry" <xref target="RFC3688"/>:</t>
      <artwork><![CDATA[
   URI:  urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting-common
   Registrant Contact:  The IESG.
   XML:  N/A; the requested URI is an XML namespace.

   URI:  urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting-sx
   Registrant Contact:  The IESG.
   XML:  N/A; the requested URI is an XML namespace.
   URI:  urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting
   Registrant Contact:  The IESG.
   XML:  N/A; the requested URI is an XML namespace.
]]></artwork>
      <t>IANA is requested to register the following YANG module in the "YANG Module
   Names" subregistry <xref target="RFC6020"/> within the "YANG Parameters" registry:</t>
      <artwork><![CDATA[
   Name:  ietf-packet-discard-reporting-common
   Namespace:
     urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting-common
   Prefix:  pdr-common
   Maintained by IANA?  N
   Reference:  RFC XXXX

   Name:  ietf-packet-discard-reporting-sx
   Namespace:  urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting-sx
   Prefix:  pdr-sx
   Maintained by IANA?  N
   Reference:  RFC XXXX

   Name:  ietf-packet-discard-reporting
   Namespace:  urn:ietf:params:xml:ns:yang:ietf-packet-discard-reporting
   Prefix:  pdr
   Maintained by IANA?  N
   Reference:  RFC XXXX
]]></artwork>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC8343">
          <front>
            <title>A YANG Data Model for Interface Management</title>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document defines a YANG data model for the management of network interfaces. It is expected that interface-type-specific data models augment the generic interfaces data model defined in this document. The data model includes definitions for configuration and system state (status information and counters for the collection of statistics).</t>
              <t>The YANG data model in this document conforms to the Network Management Datastore Architecture (NMDA) defined in RFC 8342.</t>
              <t>This document obsoletes RFC 7223.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8343"/>
          <seriesInfo name="DOI" value="10.17487/RFC8343"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC7950">
          <front>
            <title>The YANG 1.1 Data Modeling Language</title>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <date month="August" year="2016"/>
            <abstract>
              <t>YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols. This document describes the syntax and semantics of version 1.1 of the YANG language. YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification. There are a small number of backward incompatibilities from YANG version 1. This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7950"/>
          <seriesInfo name="DOI" value="10.17487/RFC7950"/>
        </reference>
        <reference anchor="RFC8791">
          <front>
            <title>YANG Data Structure Extensions</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Björklund" initials="M." surname="Björklund"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <date month="June" year="2020"/>
            <abstract>
              <t>This document describes YANG mechanisms for defining abstract data structures with YANG.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8791"/>
          <seriesInfo name="DOI" value="10.17487/RFC8791"/>
        </reference>
        <reference anchor="RFC9911">
          <front>
            <title>Common YANG Data Types</title>
            <author fullname="J. Schönwälder" initials="J." role="editor" surname="Schönwälder"/>
            <date month="December" year="2025"/>
            <abstract>
              <t>This document defines a collection of common data types to be used with the YANG data modeling language. It includes several new type definitions and obsoletes RFC 6991.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9911"/>
          <seriesInfo name="DOI" value="10.17487/RFC9911"/>
        </reference>
        <reference anchor="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="RFC8341">
          <front>
            <title>Network Configuration Access Control Model</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>The standardization of network configuration interfaces for use with the Network Configuration Protocol (NETCONF) or the RESTCONF protocol requires a structured and secure operating environment that promotes human usability and multi-vendor interoperability. There is a need for standard mechanisms to restrict NETCONF or RESTCONF protocol access for particular users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content. This document defines such an access control model.</t>
              <t>This document obsoletes RFC 6536.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="91"/>
          <seriesInfo name="RFC" value="8341"/>
          <seriesInfo name="DOI" value="10.17487/RFC8341"/>
        </reference>
        <reference anchor="RFC8349">
          <front>
            <title>A YANG Data Model for Routing Management (NMDA Version)</title>
            <author fullname="L. Lhotka" initials="L." surname="Lhotka"/>
            <author fullname="A. Lindem" initials="A." surname="Lindem"/>
            <author fullname="Y. Qu" initials="Y." surname="Qu"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document specifies three YANG modules and one submodule. Together, they form the core routing data model that serves as a framework for configuring and managing a routing subsystem. It is expected that these modules will be augmented by additional YANG modules defining data models for control-plane protocols, route filters, and other functions. The core routing data model provides common building blocks for such extensions -- routes, Routing Information Bases (RIBs), and control-plane protocols.</t>
              <t>The YANG modules in this document conform to the Network Management Datastore Architecture (NMDA). This document obsoletes RFC 8022.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8349"/>
          <seriesInfo name="DOI" value="10.17487/RFC8349"/>
        </reference>
        <reference anchor="RFC8530">
          <front>
            <title>YANG Model for Logical Network Elements</title>
            <author fullname="L. Berger" initials="L." surname="Berger"/>
            <author fullname="C. Hopps" initials="C." surname="Hopps"/>
            <author fullname="A. Lindem" initials="A." surname="Lindem"/>
            <author fullname="D. Bogdanovic" initials="D." surname="Bogdanovic"/>
            <author fullname="X. Liu" initials="X." surname="Liu"/>
            <date month="March" year="2019"/>
            <abstract>
              <t>This document defines a logical network element (LNE) YANG module that is compliant with the Network Management Datastore Architecture (NMDA). This module can be used to manage the logical resource partitioning that may be present on a network device. Examples of common industry terms for logical resource partitioning are logical systems or logical routers. The YANG model in this document conforms with NMDA as defined in RFC 8342.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8530"/>
          <seriesInfo name="DOI" value="10.17487/RFC8530"/>
        </reference>
        <reference anchor="RFC3688">
          <front>
            <title>The IETF XML Registry</title>
            <author fullname="M. Mealling" initials="M." surname="Mealling"/>
            <date month="January" year="2004"/>
            <abstract>
              <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="81"/>
          <seriesInfo name="RFC" value="3688"/>
          <seriesInfo name="DOI" value="10.17487/RFC3688"/>
        </reference>
        <reference anchor="RFC6020">
          <front>
            <title>YANG - A Data Modeling Language for the Network Configuration Protocol (NETCONF)</title>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <date month="October" year="2010"/>
            <abstract>
              <t>YANG is a data modeling language used to model configuration and state data manipulated by the Network Configuration Protocol (NETCONF), NETCONF remote procedure calls, and NETCONF notifications. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6020"/>
          <seriesInfo name="DOI" value="10.17487/RFC6020"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RED93" target="https://ieeexplore.ieee.org/document/251892">
          <front>
            <title>Random early detection gateways for congestion avoidance</title>
            <author initials="S." surname="Floyd">
              <organization/>
            </author>
            <author initials="V." surname="Jacobson">
              <organization/>
            </author>
            <date year="1993" month="August"/>
          </front>
        </reference>
        <reference anchor="RFC2863">
          <front>
            <title>The Interfaces Group MIB</title>
            <author fullname="K. McCloghrie" initials="K." surname="McCloghrie"/>
            <author fullname="F. Kastenholz" initials="F." surname="Kastenholz"/>
            <date month="June" year="2000"/>
            <abstract>
              <t>This memo discusses the 'interfaces' group of MIB-II, especially the experience gained from the definition of numerous media-specific MIB modules for use in conjunction with the 'interfaces' group for managing various sub-layers beneath the internetwork-layer. It specifies clarifications to, and extensions of, the architectural issues within the MIB-II model of the 'interfaces' group. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2863"/>
          <seriesInfo name="DOI" value="10.17487/RFC2863"/>
        </reference>
        <reference anchor="RFC7270">
          <front>
            <title>Cisco-Specific Information Elements Reused in IP Flow Information Export (IPFIX)</title>
            <author fullname="A. Yourtchenko" initials="A." surname="Yourtchenko"/>
            <author fullname="P. Aitken" initials="P." surname="Aitken"/>
            <author fullname="B. Claise" initials="B." surname="Claise"/>
            <date month="June" year="2014"/>
            <abstract>
              <t>This document describes some additional IP Flow Information Export (IPFIX) Information Elements in the range of 1-127, which is the range compatible with field types used by NetFlow version 9 in RFC 3954, as specified in the IPFIX Information Model in RFC 7012.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7270"/>
          <seriesInfo name="DOI" value="10.17487/RFC7270"/>
        </reference>
        <reference anchor="RFC7011">
          <front>
            <title>Specification of the IP Flow Information Export (IPFIX) Protocol for the Exchange of Flow Information</title>
            <author fullname="B. Claise" initials="B." role="editor" surname="Claise"/>
            <author fullname="B. Trammell" initials="B." role="editor" surname="Trammell"/>
            <author fullname="P. Aitken" initials="P." surname="Aitken"/>
            <date month="September" year="2013"/>
            <abstract>
              <t>This document specifies the IP Flow Information Export (IPFIX) protocol, which serves as a means for transmitting Traffic Flow information over the network. In order to transmit Traffic Flow information from an Exporting Process to a Collecting Process, a common representation of flow data and a standard means of communicating them are required. This document describes how the IPFIX Data and Template Records are carried over a number of transport protocols from an IPFIX Exporting Process to an IPFIX Collecting Process. This document obsoletes RFC 5101.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="77"/>
          <seriesInfo name="RFC" value="7011"/>
          <seriesInfo name="DOI" value="10.17487/RFC7011"/>
        </reference>
        <reference anchor="RFC8340">
          <front>
            <title>YANG Tree Diagrams</title>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="L. Berger" initials="L." role="editor" surname="Berger"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document captures the current syntax used in YANG module tree diagrams. The purpose of this document is to provide a single location for this definition. This syntax may be updated from time to time based on the evolution of the YANG language.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="215"/>
          <seriesInfo name="RFC" value="8340"/>
          <seriesInfo name="DOI" value="10.17487/RFC8340"/>
        </reference>
        <reference anchor="RFC3444">
          <front>
            <title>On the Difference between Information Models and Data Models</title>
            <author fullname="A. Pras" initials="A." surname="Pras"/>
            <author fullname="J. Schoenwaelder" initials="J." surname="Schoenwaelder"/>
            <date month="January" year="2003"/>
            <abstract>
              <t>There has been ongoing confusion about the differences between Information Models and Data Models for defining managed objects in network management. This document explains the differences between these terms by analyzing how existing network management model specifications (from the IETF and other bodies such as the International Telecommunication Union (ITU) or the Distributed Management Task Force (DMTF)) fit into the universe of Information Models and Data Models. This memo documents the main results of the 8th workshop of the Network Management Research Group (NMRG) of the Internet Research Task Force (IRTF) hosted by the University of Texas at Austin. This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3444"/>
          <seriesInfo name="DOI" value="10.17487/RFC3444"/>
        </reference>
        <reference anchor="RFC2827">
          <front>
            <title>Network Ingress Filtering: Defeating Denial of Service Attacks which employ IP Source Address Spoofing</title>
            <author fullname="P. Ferguson" initials="P." surname="Ferguson"/>
            <author fullname="D. Senie" initials="D." surname="Senie"/>
            <date month="May" year="2000"/>
            <abstract>
              <t>This paper discusses a simple, effective, and straightforward method for using ingress traffic filtering to prohibit DoS (Denial of Service) attacks which use forged IP addresses to be propagated from 'behind' an Internet Service Provider's (ISP) aggregation point. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="38"/>
          <seriesInfo name="RFC" value="2827"/>
          <seriesInfo name="DOI" value="10.17487/RFC2827"/>
        </reference>
        <reference anchor="RFC3704">
          <front>
            <title>Ingress Filtering for Multihomed Networks</title>
            <author fullname="F. Baker" initials="F." surname="Baker"/>
            <author fullname="P. Savola" initials="P." surname="Savola"/>
            <date month="March" year="2004"/>
            <abstract>
              <t>BCP 38, RFC 2827, is designed to limit the impact of distributed denial of service attacks, by denying traffic with spoofed addresses access to the network, and to help ensure that traffic is traceable to its correct source network. As a side effect of protecting the Internet against such attacks, the network implementing the solution also protects itself from this and other attacks, such as spoofed management access to networking equipment. There are cases when this may create problems, e.g., with multihoming. This document describes the current ingress filtering operational mechanisms, examines generic issues related to ingress filtering, and delves into the effects on multihoming in particular. This memo updates RFC 2827. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="84"/>
          <seriesInfo name="RFC" value="3704"/>
          <seriesInfo name="DOI" value="10.17487/RFC3704"/>
        </reference>
        <reference anchor="RFC8704">
          <front>
            <title>Enhanced Feasible-Path Unicast Reverse Path Forwarding</title>
            <author fullname="K. Sriram" initials="K." surname="Sriram"/>
            <author fullname="D. Montgomery" initials="D." surname="Montgomery"/>
            <author fullname="J. Haas" initials="J." surname="Haas"/>
            <date month="February" year="2020"/>
            <abstract>
              <t>This document identifies a need for and proposes improvement of the unicast Reverse Path Forwarding (uRPF) techniques (see RFC 3704) for detection and mitigation of source address spoofing (see BCP 38). Strict uRPF is inflexible about directionality, the loose uRPF is oblivious to directionality, and the current feasible-path uRPF attempts to strike a balance between the two (see RFC 3704). However, as shown in this document, the existing feasible-path uRPF still has shortcomings. This document describes enhanced feasible-path uRPF (EFP-uRPF) techniques that are more flexible (in a meaningful way) about directionality than the feasible-path uRPF (RFC 3704). The proposed EFP-uRPF methods aim to significantly reduce false positives regarding invalid detection in source address validation (SAV). Hence, they can potentially alleviate ISPs' concerns about the possibility of disrupting service for their customers and encourage greater deployment of uRPF techniques. This document updates RFC 3704.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="84"/>
          <seriesInfo name="RFC" value="8704"/>
          <seriesInfo name="DOI" value="10.17487/RFC8704"/>
        </reference>
        <reference anchor="RFC3882">
          <front>
            <title>Configuring BGP to Block Denial-of-Service Attacks</title>
            <author fullname="D. Turk" initials="D." surname="Turk"/>
            <date month="October" year="2004"/>
            <abstract>
              <t>This document describes an operational technique that uses BGP communities to remotely trigger black-holing of a particular destination network to block denial-of-service attacks. Black-holing can be applied on a selection of routers rather than all BGP-speaking routers in the network. The document also describes a sinkhole tunnel technique using BGP communities and tunnels to pull traffic into a sinkhole router for analysis. This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3882"/>
          <seriesInfo name="DOI" value="10.17487/RFC3882"/>
        </reference>
        <reference anchor="RFC5635">
          <front>
            <title>Remote Triggered Black Hole Filtering with Unicast Reverse Path Forwarding (uRPF)</title>
            <author fullname="W. Kumari" initials="W." surname="Kumari"/>
            <author fullname="D. McPherson" initials="D." surname="McPherson"/>
            <date month="August" year="2009"/>
            <abstract>
              <t>Remote Triggered Black Hole (RTBH) filtering is a popular and effective technique for the mitigation of denial-of-service attacks. This document expands upon destination-based RTBH filtering by outlining a method to enable filtering by source address as well. This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5635"/>
          <seriesInfo name="DOI" value="10.17487/RFC5635"/>
        </reference>
        <reference anchor="RFC8955">
          <front>
            <title>Dissemination of Flow Specification Rules</title>
            <author fullname="C. Loibl" initials="C." surname="Loibl"/>
            <author fullname="S. Hares" initials="S." surname="Hares"/>
            <author fullname="R. Raszuk" initials="R." surname="Raszuk"/>
            <author fullname="D. McPherson" initials="D." surname="McPherson"/>
            <author fullname="M. Bacher" initials="M." surname="Bacher"/>
            <date month="December" year="2020"/>
            <abstract>
              <t>This document defines a Border Gateway Protocol Network Layer Reachability Information (BGP NLRI) encoding format that can be used to distribute (intra-domain and inter-domain) traffic Flow Specifications for IPv4 unicast and IPv4 BGP/MPLS VPN services. This allows the routing system to propagate information regarding more specific components of the traffic aggregate defined by an IP destination prefix.</t>
              <t>It also specifies BGP Extended Community encoding formats, which can be used to propagate Traffic Filtering Actions along with the Flow Specification NLRI. Those Traffic Filtering Actions encode actions a routing system can take if the packet matches the Flow Specification.</t>
              <t>This document obsoletes both RFC 5575 and RFC 7674.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8955"/>
          <seriesInfo name="DOI" value="10.17487/RFC8955"/>
        </reference>
        <reference anchor="RFC8956">
          <front>
            <title>Dissemination of Flow Specification Rules for IPv6</title>
            <author fullname="C. Loibl" initials="C." role="editor" surname="Loibl"/>
            <author fullname="R. Raszuk" initials="R." role="editor" surname="Raszuk"/>
            <author fullname="S. Hares" initials="S." role="editor" surname="Hares"/>
            <date month="December" year="2020"/>
            <abstract>
              <t>"Dissemination of Flow Specification Rules" (RFC 8955) provides a Border Gateway Protocol (BGP) extension for the propagation of traffic flow information for the purpose of rate limiting or filtering IPv4 protocol data packets.</t>
              <t>This document extends RFC 8955 with IPv6 functionality. It also updates RFC 8955 by changing the IANA Flow Spec Component Types registry.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8956"/>
          <seriesInfo name="DOI" value="10.17487/RFC8956"/>
        </reference>
        <reference anchor="RFC9117">
          <front>
            <title>Revised Validation Procedure for BGP Flow Specifications</title>
            <author fullname="J. Uttaro" initials="J." surname="Uttaro"/>
            <author fullname="J. Alcaide" initials="J." surname="Alcaide"/>
            <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
            <author fullname="D. Smith" initials="D." surname="Smith"/>
            <author fullname="P. Mohapatra" initials="P." surname="Mohapatra"/>
            <date month="August" year="2021"/>
            <abstract>
              <t>This document describes a modification to the validation procedure defined for the dissemination of BGP Flow Specifications. The dissemination of BGP Flow Specifications as specified in RFC 8955 requires that the originator of the Flow Specification match the originator of the best-match unicast route for the destination prefix embedded in the Flow Specification. For an Internal Border Gateway Protocol (iBGP) received route, the originator is typically a border router within the same autonomous system (AS). The objective is to allow only BGP speakers within the data forwarding path to originate BGP Flow Specifications. Sometimes it is desirable to originate the BGP Flow Specification from any place within the autonomous system itself, for example, from a centralized BGP route controller. However, the validation procedure described in RFC 8955 will fail in this scenario. The modification proposed herein relaxes the validation rule to enable Flow Specifications to be originated within the same autonomous system as the BGP speaker performing the validation. Additionally, this document revises the AS_PATH validation rules so Flow Specifications received from an External Border Gateway Protocol (eBGP) peer can be validated when such a peer is a BGP route server.</t>
              <t>This document updates the validation procedure in RFC 8955.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9117"/>
          <seriesInfo name="DOI" value="10.17487/RFC9117"/>
        </reference>
        <reference anchor="RFC8289">
          <front>
            <title>Controlled Delay Active Queue Management</title>
            <author fullname="K. Nichols" initials="K." surname="Nichols"/>
            <author fullname="V. Jacobson" initials="V." surname="Jacobson"/>
            <author fullname="A. McGregor" initials="A." role="editor" surname="McGregor"/>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <date month="January" year="2018"/>
            <abstract>
              <t>This document describes CoDel (Controlled Delay) -- a general framework that controls bufferbloat-generated excess delay in modern networking environments. CoDel consists of an estimator, a setpoint, and a control loop. It requires no configuration in normal Internet deployments.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8289"/>
          <seriesInfo name="DOI" value="10.17487/RFC8289"/>
        </reference>
        <reference anchor="RFC8969">
          <front>
            <title>A Framework for Automating Service and Network Management with YANG</title>
            <author fullname="Q. Wu" initials="Q." role="editor" surname="Wu"/>
            <author fullname="M. Boucadair" initials="M." role="editor" surname="Boucadair"/>
            <author fullname="D. Lopez" initials="D." surname="Lopez"/>
            <author fullname="C. Xie" initials="C." surname="Xie"/>
            <author fullname="L. Geng" initials="L." surname="Geng"/>
            <date month="January" year="2021"/>
            <abstract>
              <t>Data models provide a programmatic approach to represent services and networks. Concretely, they can be used to derive configuration information for network and service components, and state information that will be monitored and tracked. Data models can be used during the service and network management life cycle (e.g., service instantiation, service provisioning, service optimization, service monitoring, service diagnosing, and service assurance). Data models are also instrumental in the automation of network management, and they can provide closed-loop control for adaptive and deterministic service creation, delivery, and maintenance.</t>
              <t>This document describes a framework for service and network management automation that takes advantage of YANG modeling technologies. This framework is drawn from a network operator perspective irrespective of the origin of a data model; thus, it can accommodate YANG modules that are developed outside the IETF.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8969"/>
          <seriesInfo name="DOI" value="10.17487/RFC8969"/>
        </reference>
        <reference anchor="RFC4884">
          <front>
            <title>Extended ICMP to Support Multi-Part Messages</title>
            <author fullname="R. Bonica" initials="R." surname="Bonica"/>
            <author fullname="D. Gan" initials="D." surname="Gan"/>
            <author fullname="D. Tappan" initials="D." surname="Tappan"/>
            <author fullname="C. Pignataro" initials="C." surname="Pignataro"/>
            <date month="April" year="2007"/>
            <abstract>
              <t>This document redefines selected ICMP messages to support multi-part operation. A multi-part ICMP message carries all of the information that ICMP messages carried previously, as well as additional information that applications may require.</t>
              <t>Multi-part messages are supported by an ICMP extension structure. The extension structure is situated at the end of the ICMP message. It includes an extension header followed by one or more extension objects. Each extension object contains an object header and object payload. All object headers share a common format.</t>
              <t>This document further redefines the above mentioned ICMP messages by specifying a length attribute. All of the currently defined ICMP messages to which an extension structure can be appended include an "original datagram" field. The "original datagram" field contains the initial octets of the datagram that elicited the ICMP error message. Although the original datagram field is of variable length, the ICMP message does not include a field that specifies its length. Therefore, in order to facilitate message parsing, this document allocates eight previously reserved bits to reflect the length of the "original datagram" field.</t>
              <t>The proposed modifications change the requirements for ICMP compliance. The impact of these changes on compliant implementations is discussed, and new requirements for future implementations are presented.</t>
              <t>This memo updates RFC 792 and RFC 4443. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4884"/>
          <seriesInfo name="DOI" value="10.17487/RFC4884"/>
        </reference>
        <reference anchor="RFC9907">
          <front>
            <title>Guidelines for Authors and Reviewers of Documents Containing YANG Data Models</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Boucadair" initials="M." role="editor" surname="Boucadair"/>
            <author fullname="Q. Wu" initials="Q." surname="Wu"/>
            <date month="March" year="2026"/>
            <abstract>
              <t>This document provides guidelines for authors and reviewers of specifications containing YANG data models, including IANA-maintained YANG modules. Recommendations and procedures are defined, which are intended to increase interoperability and usability of Network Configuration Protocol (NETCONF) and RESTCONF protocol implementations that utilize YANG modules.</t>
              <t>This document obsoletes RFC 8407; it also updates RFC 8126 by providing additional guidelines for writing the IANA considerations for RFCs that specify IANA-maintained YANG modules.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="216"/>
          <seriesInfo name="RFC" value="9907"/>
          <seriesInfo name="DOI" value="10.17487/RFC9907"/>
        </reference>
        <reference anchor="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">
          <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>
        <reference anchor="RFC4252">
          <front>
            <title>The Secure Shell (SSH) Authentication Protocol</title>
            <author fullname="T. Ylonen" initials="T." surname="Ylonen"/>
            <author fullname="C. Lonvick" initials="C." role="editor" surname="Lonvick"/>
            <date month="January" year="2006"/>
            <abstract>
              <t>The Secure Shell Protocol (SSH) is a protocol for secure remote login and other secure network services over an insecure network. This document describes the SSH authentication protocol framework and public key, password, and host-based client authentication methods. Additional authentication methods are described in separate documents. The SSH authentication protocol runs on top of the SSH transport layer protocol and provides a single authenticated tunnel for the SSH connection protocol. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4252"/>
          <seriesInfo name="DOI" value="10.17487/RFC4252"/>
        </reference>
        <reference anchor="RFC8446">
          <front>
            <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2018"/>
            <abstract>
              <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8446"/>
          <seriesInfo name="DOI" value="10.17487/RFC8446"/>
        </reference>
        <reference anchor="RFC9000">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document defines the core of the QUIC transport protocol. QUIC provides applications with flow-controlled streams for structured communication, low-latency connection establishment, and network path migration. QUIC includes security measures that ensure confidentiality, integrity, and availability in a range of deployment circumstances. Accompanying documents describe the integration of TLS for key negotiation, loss detection, and an exemplary congestion control algorithm.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9000"/>
          <seriesInfo name="DOI" value="10.17487/RFC9000"/>
        </reference>
      </references>
    </references>
    <?line 1595?>

<section anchor="wheredropped">
      <name>Where Do Packets Get Dropped?</name>
      <t>Understanding where packets are discarded in a network device is essential for interpreting discard signals and determining appropriate mitigation actions.  <xref target="ex-drop"/> depicts an example of where and why packets may be discarded in a typical single-ASIC, shared-buffered type device. While actual device architectures vary between vendors and platforms, with some using multiple ASICs, distributed forwarding, or different buffering architectures, this example illustrates the common processing stages where packets may be dropped. The logical model for classifying and reporting discards remains consistent regardless of the underlying hardware architecture.</t>
      <t>Packets ingress on the left and egress on the right:</t>
      <figure anchor="ex-drop">
        <name>Example of Where Packets Get Dropped</name>
        <artset>
          <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="448" width="568" viewBox="0 0 568 448" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 40,176 L 40,192" fill="none" stroke="black"/>
              <path d="M 40,224 L 40,240" fill="none" stroke="black"/>
              <path d="M 72,144 L 72,176" fill="none" stroke="black"/>
              <path d="M 104,176 L 104,240" fill="none" stroke="black"/>
              <path d="M 128,176 L 128,192" fill="none" stroke="black"/>
              <path d="M 128,224 L 128,240" fill="none" stroke="black"/>
              <path d="M 216,176 L 216,240" fill="none" stroke="black"/>
              <path d="M 232,32 L 232,96" fill="none" stroke="black"/>
              <path d="M 240,176 L 240,192" fill="none" stroke="black"/>
              <path d="M 240,224 L 240,240" fill="none" stroke="black"/>
              <path d="M 264,96 L 264,144" fill="none" stroke="black"/>
              <path d="M 296,96 L 296,144" fill="none" stroke="black"/>
              <path d="M 320,176 L 320,240" fill="none" stroke="black"/>
              <path d="M 328,32 L 328,96" fill="none" stroke="black"/>
              <path d="M 344,176 L 344,192" fill="none" stroke="black"/>
              <path d="M 344,224 L 344,240" fill="none" stroke="black"/>
              <path d="M 432,176 L 432,240" fill="none" stroke="black"/>
              <path d="M 456,176 L 456,192" fill="none" stroke="black"/>
              <path d="M 456,224 L 456,240" fill="none" stroke="black"/>
              <path d="M 488,144 L 488,176" fill="none" stroke="black"/>
              <path d="M 520,176 L 520,240" fill="none" stroke="black"/>
              <path d="M 232,32 L 328,32" fill="none" stroke="black"/>
              <path d="M 232,96 L 288,96" fill="none" stroke="black"/>
              <path d="M 304,96 L 328,96" fill="none" stroke="black"/>
              <path d="M 72,144 L 256,144" fill="none" stroke="black"/>
              <path d="M 272,144 L 488,144" fill="none" stroke="black"/>
              <path d="M 40,176 L 104,176" fill="none" stroke="black"/>
              <path d="M 128,176 L 216,176" fill="none" stroke="black"/>
              <path d="M 240,176 L 320,176" fill="none" stroke="black"/>
              <path d="M 344,176 L 432,176" fill="none" stroke="black"/>
              <path d="M 456,176 L 520,176" fill="none" stroke="black"/>
              <path d="M 24,208 L 40,208" fill="none" stroke="black"/>
              <path d="M 104,208 L 128,208" fill="none" stroke="black"/>
              <path d="M 216,208 L 240,208" fill="none" stroke="black"/>
              <path d="M 320,208 L 344,208" fill="none" stroke="black"/>
              <path d="M 432,208 L 456,208" fill="none" stroke="black"/>
              <path d="M 520,208 L 536,208" fill="none" stroke="black"/>
              <path d="M 40,240 L 104,240" fill="none" stroke="black"/>
              <path d="M 128,240 L 216,240" fill="none" stroke="black"/>
              <path d="M 240,240 L 320,240" fill="none" stroke="black"/>
              <path d="M 344,240 L 432,240" fill="none" stroke="black"/>
              <path d="M 456,240 L 520,240" fill="none" stroke="black"/>
              <polygon class="arrowhead" points="544,208 532,202.4 532,213.6" fill="black" transform="rotate(0,536,208)"/>
              <polygon class="arrowhead" points="464,208 452,202.4 452,213.6" fill="black" transform="rotate(0,456,208)"/>
              <polygon class="arrowhead" points="352,208 340,202.4 340,213.6" fill="black" transform="rotate(0,344,208)"/>
              <polygon class="arrowhead" points="304,96 292,90.4 292,101.6" fill="black" transform="rotate(270,296,96)"/>
              <polygon class="arrowhead" points="272,144 260,138.4 260,149.6" fill="black" transform="rotate(90,264,144)"/>
              <polygon class="arrowhead" points="248,208 236,202.4 236,213.6" fill="black" transform="rotate(0,240,208)"/>
              <polygon class="arrowhead" points="136,208 124,202.4 124,213.6" fill="black" transform="rotate(0,128,208)"/>
              <polygon class="arrowhead" points="48,208 36,202.4 36,213.6" fill="black" transform="rotate(0,40,208)"/>
              <g class="text">
                <text x="280" y="52">Control</text>
                <text x="280" y="68">Plane</text>
                <text x="220" y="116">from_cpu</text>
                <text x="332" y="116">to_cpu</text>
                <text x="12" y="212">Rx</text>
                <text x="72" y="212">PHY/MAC</text>
                <text x="168" y="212">Ingress</text>
                <text x="280" y="212">Buffers</text>
                <text x="380" y="212">Egress</text>
                <text x="488" y="212">PHY/MAC</text>
                <text x="556" y="212">Tx</text>
                <text x="172" y="228">Pipeline</text>
                <text x="388" y="228">Pipeline</text>
                <text x="48" y="276">Unintended:</text>
                <text x="76" y="292">errors/l2/rx</text>
                <text x="188" y="292">errors/l3/rx</text>
                <text x="288" y="292">no-buffer</text>
                <text x="404" y="292">errors/l3/tx</text>
                <text x="212" y="308">errors/l3/no-route</text>
                <text x="224" y="324">errors/l3/ttl-expired</text>
                <text x="200" y="340">errors/internal</text>
                <text x="40" y="356">Intended:</text>
                <text x="180" y="372">policy/acl</text>
                <text x="396" y="372">policy/acl</text>
                <text x="196" y="388">policy/policer</text>
                <text x="412" y="388">policy/policer</text>
                <text x="180" y="404">policy/rpf</text>
                <text x="208" y="420">policy/null-route</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art"><![CDATA[
                            .-----------.
                            |  Control  |
                            |   Plane   |
                            |           |
                            '---+---^---'
                       from_cpu |   | to_cpu
                                |   |
        .-----------------------v---+-----------------------.
        |                                                   |
    .---+---.  .----------.  .---------.  .----------.  .---+---.
    |       |  |          |  |         |  |          |  |       |
Rx-->PHY/MAC+--> Ingress  +--> Buffers +--> Egress   +-->PHY/MAC+-> Tx
    |       |  | Pipeline |  |         |  | Pipeline |  |       |
    '-------'  '----------'  '---------'  '----------'  '-------'

Unintended:
   errors/l2/rx  errors/l3/rx  no-buffer    errors/l3/tx
                 errors/l3/no-route
                 errors/l3/ttl-expired
                 errors/internal
Intended:
                 policy/acl                 policy/acl
                 policy/policer             policy/policer
                 policy/rpf
                 policy/null-route

]]></artwork>
        </artset>
      </figure>
      <t>See <xref target="mapping"/> for examples of how these discard signals map to root causes and mitigation actions.</t>
    </section>
    <section anchor="mapping">
      <name>Example Signal-to-mitigation Action Mapping</name>
      <t>The effectiveness of automated mitigation depends on correctly mapping discard signals to root causes and appropriate actions.  Tables <xref format="counter" target="ex-table"/> and <xref format="counter" target="ex-table2"/> give example discard signal-to-mitigation action mappings based on the features described in <xref target="problem"/>.</t>
      <table anchor="ex-table">
        <name>Example Signal-Cause-Mitigation Mapping (1)</name>
        <thead>
          <tr>
            <th align="left">DISCARD-CLASS</th>
            <th align="left">Discard cause</th>
            <th align="left">DISCARD-RATE</th>
            <th align="center">DISCARD-DURATION</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="left">ingress/discards/errors/l2/rx</td>
            <td align="left">Upstream device or link error</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1min)</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="left">Tracert</td>
            <td align="left">&lt;=Baseline</td>
            <td align="center"> </td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="left">Convergence</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1s)</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="left">Routing loop</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1min)</td>
          </tr>
          <tr>
            <td align="left">.*/policy/.*</td>
            <td align="left">Policy</td>
            <td align="left"> </td>
            <td align="center"> </td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="left">Convergence</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1s)</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="left">Config error</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1min)</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="left">Invalid destination</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(10min)</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/internal</td>
            <td align="left">Device errors</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1min)</td>
          </tr>
          <tr>
            <td align="left">egress/discards/no-buffer</td>
            <td align="left">Congestion</td>
            <td align="left">&lt;=Baseline</td>
            <td align="center"> </td>
          </tr>
          <tr>
            <td align="left">egress/discards/no-buffer</td>
            <td align="left">Congestion</td>
            <td align="left">&gt;Baseline</td>
            <td align="center">O(1min)</td>
          </tr>
        </tbody>
      </table>
      <table anchor="ex-table2">
        <name>Example Signal-Cause-Mitigation Mapping (2)</name>
        <thead>
          <tr>
            <th align="left">DISCARD-CLASS</th>
            <th align="center">Unintended?</th>
            <th align="left">Possible actions</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="left">ingress/discards/errors/l2/rx</td>
            <td align="center">Y</td>
            <td align="left">Take upstream link or device out-of-service</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="center">N</td>
            <td align="left">no action</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="center">Y</td>
            <td align="left">No action</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/ttl-expired</td>
            <td align="center">Y</td>
            <td align="left">Roll-back change</td>
          </tr>
          <tr>
            <td align="left">.*/policy/.*</td>
            <td align="center">N</td>
            <td align="left">No action</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="center">Y</td>
            <td align="left">No action</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="center">Y</td>
            <td align="left">Roll-back change</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/l3/no-route</td>
            <td align="center">N</td>
            <td align="left">Escalate to operator</td>
          </tr>
          <tr>
            <td align="left">ingress/discards/errors/internal</td>
            <td align="center">Y</td>
            <td align="left">Take device out-of-service</td>
          </tr>
          <tr>
            <td align="left">egress/discards/no-buffer</td>
            <td align="center">N</td>
            <td align="left">No action</td>
          </tr>
          <tr>
            <td align="left">egress/discards/no-buffer</td>
            <td align="center">Y</td>
            <td align="left">Bring capacity back into service or move traffic</td>
          </tr>
        </tbody>
      </table>
      <t>The 'Baseline' in the 'DISCARD-RATE' column is both DISCARD-CLASS and network dependent.</t>
    </section>
    <section anchor="sec-im-full-tree">
      <name>Full Information Model Tree</name>
      <t>The following YANG tree diagram shows the complete IM structure:</t>
      <artwork><![CDATA[
module: ietf-packet-discard-reporting-sx

  structure packet-discard-reporting:
    +-- control-plane {pdr-common:control-plane-stats}?
    |  +-- traffic* [direction]
    |  |  +-- direction    identityref
    |  |  +-- packets?     yang:counter64
    |  |  +-- bytes?       yang:counter64
    |  +-- discards* [direction]
    |     +-- direction    identityref
    |     +-- packets?     yang:counter64
    |     +-- bytes?       yang:counter64
    |     +-- policy
    |        +-- packets?   yang:counter64
    +-- interface* [name] {pdr-common:interface-stats}?
    |  +-- name        string
    |  +-- traffic* [direction]
    |  |  +-- direction    identityref
    |  |  +-- l2
    |  |  |  +-- frames?   yang:counter64
    |  |  |  +-- bytes?    yang:counter64
    |  |  +-- l3
    |  |  |  +-- address-family-stat* [address-family]
    |  |  |     +-- address-family    identityref
    |  |  |     +-- packets?          yang:counter64
    |  |  |     +-- bytes?            yang:counter64
    |  |  |     +-- unicast
    |  |  |     |  +-- packets?   yang:counter64
    |  |  |     |  +-- bytes?     yang:counter64
    |  |  |     +-- multicast
    |  |  |     |  +-- packets?   yang:counter64
    |  |  |     |  +-- bytes?     yang:counter64
    |  |  |     +-- broadcast
    |  |  |        +-- packets?   yang:counter64
    |  |  |        +-- bytes?     yang:counter64
    |  |  +-- qos!
    |  |     +-- class* [id]
    |  |        +-- id         string
    |  |        +-- packets?   yang:counter64
    |  |        +-- bytes?     yang:counter64
    |  +-- discards* [direction]
    |     +-- direction    identityref
    |     +-- l2
    |     |  +-- frames?   yang:counter64
    |     |  +-- bytes?    yang:counter64
    |     +-- l3
    |     |  +-- address-family-stat* [address-family]
    |     |     +-- address-family    identityref
    |     |     +-- packets?          yang:counter64
    |     |     +-- bytes?            yang:counter64
    |     |     +-- unicast
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     +-- multicast
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     +-- broadcast
    |     |        +-- packets?   yang:counter64
    |     |        +-- bytes?     yang:counter64
    |     +-- errors
    |     |  +-- l2
    |     |  |  +-- rx
    |     |  |  |  +-- frames?          yang:counter64
    |     |  |  |  +-- crc-error?       yang:counter64
    |     |  |  |  +-- invalid-mac?     yang:counter64
    |     |  |  |  +-- invalid-vlan?    yang:counter64
    |     |  |  |  +-- invalid-frame?   yang:counter64
    |     |  |  +-- tx
    |     |  |     +-- frames?   yang:counter64
    |     |  +-- l3
    |     |  |  +-- rx
    |     |  |  |  +-- packets?          yang:counter64
    |     |  |  |  +-- checksum-error?   yang:counter64
    |     |  |  |  +-- mtu-exceeded?     yang:counter64
    |     |  |  |  +-- invalid-packet?   yang:counter64
    |     |  |  +-- ttl-expired?     yang:counter64
    |     |  |  +-- no-route?        yang:counter64
    |     |  |  +-- invalid-sid?     yang:counter64
    |     |  |  +-- invalid-label?   yang:counter64
    |     |  |  +-- tx
    |     |  |     +-- packets?   yang:counter64
    |     |  +-- internal
    |     |     +-- packets?        yang:counter64
    |     |     +-- parity-error?   yang:counter64
    |     +-- policy
    |     |  +-- l2
    |     |  |  +-- frames?   yang:counter64
    |     |  |  +-- acl?      yang:counter64
    |     |  +-- l3
    |     |     +-- packets?      yang:counter64
    |     |     +-- acl?          yang:counter64
    |     |     +-- policer
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     |  +-- classes!
    |     |     |     +-- class* [id]
    |     |     |        +-- id         string
    |     |     |        +-- packets?   yang:counter64
    |     |     |        +-- bytes?     yang:counter64
    |     |     +-- null-route?   yang:counter64
    |     |     +-- rpf?          yang:counter64
    |     |     +-- ddos?         yang:counter64
    |     +-- no-buffer
    |        +-- qos!
    |           +-- class* [id]
    |              +-- id         string
    |              +-- packets?   yang:counter64
    |              +-- bytes?     yang:counter64
    +-- flow* [direction] {pdr-common:flow-reporting}?
    |  +-- direction    identityref
    |  +-- traffic
    |  |  +-- l2
    |  |  |  +-- frames?   yang:counter64
    |  |  |  +-- bytes?    yang:counter64
    |  |  +-- l3
    |  |  |  +-- address-family-stat* [address-family]
    |  |  |     +-- address-family    identityref
    |  |  |     +-- packets?          yang:counter64
    |  |  |     +-- bytes?            yang:counter64
    |  |  |     +-- unicast
    |  |  |     |  +-- packets?   yang:counter64
    |  |  |     |  +-- bytes?     yang:counter64
    |  |  |     +-- multicast
    |  |  |     |  +-- packets?   yang:counter64
    |  |  |     |  +-- bytes?     yang:counter64
    |  |  |     +-- broadcast
    |  |  |        +-- packets?   yang:counter64
    |  |  |        +-- bytes?     yang:counter64
    |  |  +-- qos!
    |  |     +-- class* [id]
    |  |        +-- id         string
    |  |        +-- packets?   yang:counter64
    |  |        +-- bytes?     yang:counter64
    |  +-- discards
    |     +-- l2
    |     |  +-- frames?   yang:counter64
    |     |  +-- bytes?    yang:counter64
    |     +-- l3
    |     |  +-- address-family-stat* [address-family]
    |     |     +-- address-family    identityref
    |     |     +-- packets?          yang:counter64
    |     |     +-- bytes?            yang:counter64
    |     |     +-- unicast
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     +-- multicast
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     +-- broadcast
    |     |        +-- packets?   yang:counter64
    |     |        +-- bytes?     yang:counter64
    |     +-- errors
    |     |  +-- l2
    |     |  |  +-- rx
    |     |  |  |  +-- frames?          yang:counter64
    |     |  |  |  +-- crc-error?       yang:counter64
    |     |  |  |  +-- invalid-mac?     yang:counter64
    |     |  |  |  +-- invalid-vlan?    yang:counter64
    |     |  |  |  +-- invalid-frame?   yang:counter64
    |     |  |  +-- tx
    |     |  |     +-- frames?   yang:counter64
    |     |  +-- l3
    |     |  |  +-- rx
    |     |  |  |  +-- packets?          yang:counter64
    |     |  |  |  +-- checksum-error?   yang:counter64
    |     |  |  |  +-- mtu-exceeded?     yang:counter64
    |     |  |  |  +-- invalid-packet?   yang:counter64
    |     |  |  +-- ttl-expired?     yang:counter64
    |     |  |  +-- no-route?        yang:counter64
    |     |  |  +-- invalid-sid?     yang:counter64
    |     |  |  +-- invalid-label?   yang:counter64
    |     |  |  +-- tx
    |     |  |     +-- packets?   yang:counter64
    |     |  +-- internal
    |     |     +-- packets?        yang:counter64
    |     |     +-- parity-error?   yang:counter64
    |     +-- policy
    |     |  +-- l2
    |     |  |  +-- frames?   yang:counter64
    |     |  |  +-- acl?      yang:counter64
    |     |  +-- l3
    |     |     +-- packets?      yang:counter64
    |     |     +-- acl?          yang:counter64
    |     |     +-- policer
    |     |     |  +-- packets?   yang:counter64
    |     |     |  +-- bytes?     yang:counter64
    |     |     |  +-- classes!
    |     |     |     +-- class* [id]
    |     |     |        +-- id         string
    |     |     |        +-- packets?   yang:counter64
    |     |     |        +-- bytes?     yang:counter64
    |     |     +-- null-route?   yang:counter64
    |     |     +-- rpf?          yang:counter64
    |     |     +-- ddos?         yang:counter64
    |     +-- no-buffer
    |        +-- qos!
    |           +-- class* [id]
    |              +-- id         string
    |              +-- packets?   yang:counter64
    |              +-- bytes?     yang:counter64
    +-- device {pdr-common:device-stats}?
       +-- traffic
       |  +-- l2
       |  |  +-- frames?   yang:counter64
       |  |  +-- bytes?    yang:counter64
       |  +-- l3
       |  |  +-- address-family-stat* [address-family]
       |  |     +-- address-family    identityref
       |  |     +-- packets?          yang:counter64
       |  |     +-- bytes?            yang:counter64
       |  |     +-- unicast
       |  |     |  +-- packets?   yang:counter64
       |  |     |  +-- bytes?     yang:counter64
       |  |     +-- multicast
       |  |     |  +-- packets?   yang:counter64
       |  |     |  +-- bytes?     yang:counter64
       |  |     +-- broadcast
       |  |        +-- packets?   yang:counter64
       |  |        +-- bytes?     yang:counter64
       |  +-- qos!
       |     +-- class* [id]
       |        +-- id         string
       |        +-- packets?   yang:counter64
       |        +-- bytes?     yang:counter64
       +-- discards
          +-- l2
          |  +-- frames?   yang:counter64
          |  +-- bytes?    yang:counter64
          +-- l3
          |  +-- address-family-stat* [address-family]
          |     +-- address-family    identityref
          |     +-- packets?          yang:counter64
          |     +-- bytes?            yang:counter64
          |     +-- unicast
          |     |  +-- packets?   yang:counter64
          |     |  +-- bytes?     yang:counter64
          |     +-- multicast
          |     |  +-- packets?   yang:counter64
          |     |  +-- bytes?     yang:counter64
          |     +-- broadcast
          |        +-- packets?   yang:counter64
          |        +-- bytes?     yang:counter64
          +-- errors
          |  +-- l2
          |  |  +-- rx
          |  |  |  +-- frames?          yang:counter64
          |  |  |  +-- crc-error?       yang:counter64
          |  |  |  +-- invalid-mac?     yang:counter64
          |  |  |  +-- invalid-vlan?    yang:counter64
          |  |  |  +-- invalid-frame?   yang:counter64
          |  |  +-- tx
          |  |     +-- frames?   yang:counter64
          |  +-- l3
          |  |  +-- rx
          |  |  |  +-- packets?          yang:counter64
          |  |  |  +-- checksum-error?   yang:counter64
          |  |  |  +-- mtu-exceeded?     yang:counter64
          |  |  |  +-- invalid-packet?   yang:counter64
          |  |  +-- ttl-expired?     yang:counter64
          |  |  +-- no-route?        yang:counter64
          |  |  +-- invalid-sid?     yang:counter64
          |  |  +-- invalid-label?   yang:counter64
          |  |  +-- tx
          |  |     +-- packets?   yang:counter64
          |  +-- internal
          |     +-- packets?        yang:counter64
          |     +-- parity-error?   yang:counter64
          +-- policy
          |  +-- l2
          |  |  +-- frames?   yang:counter64
          |  |  +-- acl?      yang:counter64
          |  +-- l3
          |     +-- packets?      yang:counter64
          |     +-- acl?          yang:counter64
          |     +-- policer
          |     |  +-- packets?   yang:counter64
          |     |  +-- bytes?     yang:counter64
          |     |  +-- classes!
          |     |     +-- class* [id]
          |     |        +-- id         string
          |     |        +-- packets?   yang:counter64
          |     |        +-- bytes?     yang:counter64
          |     +-- null-route?   yang:counter64
          |     +-- rpf?          yang:counter64
          |     +-- ddos?         yang:counter64
          +-- no-buffer
             +-- qos!
                +-- class* [id]
                   +-- id         string
                   +-- packets?   yang:counter64
                   +-- bytes?     yang:counter64
]]></artwork>
    </section>
    <section anchor="sec-dm-full-tree">
      <name>Full Data Model Tree</name>
      <t>The following YANG tree diagram shows the complete DM structure:</t>
      <artwork><![CDATA[
module: ietf-packet-discard-reporting

  augment /rt:routing/rt:control-plane-protocols
            /rt:control-plane-protocol:
    +--ro traffic-discard-stats {pdr-common:control-plane-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic* [direction]
       |  +--ro direction    identityref
       |  +--ro packets?     yang:counter64
       |  +--ro bytes?       yang:counter64
       +--ro discards* [direction]
          +--ro direction    identityref
          +--ro packets?     yang:counter64
          +--ro bytes?       yang:counter64
          +--ro policy
             +--ro packets?   yang:counter64
  augment /if:interfaces/if:interface/if:statistics:
    +--ro traffic-discard-stats {pdr-common:interface-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic* [direction]
       |  +--ro direction    identityref
       |  +--ro l2
       |  |  +--ro frames?   yang:counter64
       |  |  +--ro bytes?    yang:counter64
       |  +--ro l3
       |  |  +--ro address-family-stat* [address-family]
       |  |     +--ro address-family    identityref
       |  |     +--ro packets?          yang:counter64
       |  |     +--ro bytes?            yang:counter64
       |  |     +--ro unicast
       |  |     |  +--ro packets?   yang:counter64
       |  |     |  +--ro bytes?     yang:counter64
       |  |     +--ro multicast
       |  |     |  +--ro packets?   yang:counter64
       |  |     |  +--ro bytes?     yang:counter64
       |  |     +--ro broadcast
       |  |        +--ro packets?   yang:counter64
       |  |        +--ro bytes?     yang:counter64
       |  +--ro qos!
       |     +--ro class* [id]
       |        +--ro id         string
       |        +--ro packets?   yang:counter64
       |        +--ro bytes?     yang:counter64
       +--ro discards* [direction]
          +--ro direction    identityref
          +--ro l2
          |  +--ro frames?   yang:counter64
          |  +--ro bytes?    yang:counter64
          +--ro l3
          |  +--ro address-family-stat* [address-family]
          |     +--ro address-family    identityref
          |     +--ro packets?          yang:counter64
          |     +--ro bytes?            yang:counter64
          |     +--ro unicast
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     +--ro multicast
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     +--ro broadcast
          |        +--ro packets?   yang:counter64
          |        +--ro bytes?     yang:counter64
          +--ro errors
          |  +--ro l2
          |  |  +--ro rx
          |  |  |  +--ro frames?          yang:counter64
          |  |  |  +--ro crc-error?       yang:counter64
          |  |  |  +--ro invalid-mac?     yang:counter64
          |  |  |  +--ro invalid-vlan?    yang:counter64
          |  |  |  +--ro invalid-frame?   yang:counter64
          |  |  +--ro tx
          |  |     +--ro frames?   yang:counter64
          |  +--ro l3
          |  |  +--ro rx
          |  |  |  +--ro packets?          yang:counter64
          |  |  |  +--ro checksum-error?   yang:counter64
          |  |  |  +--ro mtu-exceeded?     yang:counter64
          |  |  |  +--ro invalid-packet?   yang:counter64
          |  |  +--ro ttl-expired?     yang:counter64
          |  |  +--ro no-route?        yang:counter64
          |  |  +--ro invalid-sid?     yang:counter64
          |  |  +--ro invalid-label?   yang:counter64
          |  |  +--ro tx
          |  |     +--ro packets?   yang:counter64
          |  +--ro internal
          |     +--ro packets?        yang:counter64
          |     +--ro parity-error?   yang:counter64
          +--ro policy
          |  +--ro l2
          |  |  +--ro frames?   yang:counter64
          |  |  +--ro acl?      yang:counter64
          |  +--ro l3
          |     +--ro packets?      yang:counter64
          |     +--ro acl?          yang:counter64
          |     +--ro policer
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     |  +--ro classes!
          |     |     +--ro class* [id]
          |     |        +--ro id         string
          |     |        +--ro packets?   yang:counter64
          |     |        +--ro bytes?     yang:counter64
          |     +--ro null-route?   yang:counter64
          |     +--ro rpf?          yang:counter64
          |     +--ro ddos?         yang:counter64
          +--ro no-buffer
             +--ro qos!
                +--ro class* [id]
                   +--ro id         string
                   +--ro packets?   yang:counter64
                   +--ro bytes?     yang:counter64
  augment /lne:logical-network-elements/lne:logical-network-element:
    +--ro traffic-discard-stats {pdr-common:device-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic
       |  +--ro l2
       |  |  +--ro frames?   yang:counter64
       |  |  +--ro bytes?    yang:counter64
       |  +--ro l3
       |  |  +--ro address-family-stat* [address-family]
       |  |     +--ro address-family    identityref
       |  |     +--ro packets?          yang:counter64
       |  |     +--ro bytes?            yang:counter64
       |  |     +--ro unicast
       |  |     |  +--ro packets?   yang:counter64
       |  |     |  +--ro bytes?     yang:counter64
       |  |     +--ro multicast
       |  |     |  +--ro packets?   yang:counter64
       |  |     |  +--ro bytes?     yang:counter64
       |  |     +--ro broadcast
       |  |        +--ro packets?   yang:counter64
       |  |        +--ro bytes?     yang:counter64
       |  +--ro qos!
       |     +--ro class* [id]
       |        +--ro id         string
       |        +--ro packets?   yang:counter64
       |        +--ro bytes?     yang:counter64
       +--ro discards
          +--ro l2
          |  +--ro frames?   yang:counter64
          |  +--ro bytes?    yang:counter64
          +--ro l3
          |  +--ro address-family-stat* [address-family]
          |     +--ro address-family    identityref
          |     +--ro packets?          yang:counter64
          |     +--ro bytes?            yang:counter64
          |     +--ro unicast
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     +--ro multicast
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     +--ro broadcast
          |        +--ro packets?   yang:counter64
          |        +--ro bytes?     yang:counter64
          +--ro errors
          |  +--ro l2
          |  |  +--ro rx
          |  |  |  +--ro frames?          yang:counter64
          |  |  |  +--ro crc-error?       yang:counter64
          |  |  |  +--ro invalid-mac?     yang:counter64
          |  |  |  +--ro invalid-vlan?    yang:counter64
          |  |  |  +--ro invalid-frame?   yang:counter64
          |  |  +--ro tx
          |  |     +--ro frames?   yang:counter64
          |  +--ro l3
          |  |  +--ro rx
          |  |  |  +--ro packets?          yang:counter64
          |  |  |  +--ro checksum-error?   yang:counter64
          |  |  |  +--ro mtu-exceeded?     yang:counter64
          |  |  |  +--ro invalid-packet?   yang:counter64
          |  |  +--ro ttl-expired?     yang:counter64
          |  |  +--ro no-route?        yang:counter64
          |  |  +--ro invalid-sid?     yang:counter64
          |  |  +--ro invalid-label?   yang:counter64
          |  |  +--ro tx
          |  |     +--ro packets?   yang:counter64
          |  +--ro internal
          |     +--ro packets?        yang:counter64
          |     +--ro parity-error?   yang:counter64
          +--ro policy
          |  +--ro l2
          |  |  +--ro frames?   yang:counter64
          |  |  +--ro acl?      yang:counter64
          |  +--ro l3
          |     +--ro packets?      yang:counter64
          |     +--ro acl?          yang:counter64
          |     +--ro policer
          |     |  +--ro packets?   yang:counter64
          |     |  +--ro bytes?     yang:counter64
          |     |  +--ro classes!
          |     |     +--ro class* [id]
          |     |        +--ro id         string
          |     |        +--ro packets?   yang:counter64
          |     |        +--ro bytes?     yang:counter64
          |     +--ro null-route?   yang:counter64
          |     +--ro rpf?          yang:counter64
          |     +--ro ddos?         yang:counter64
          +--ro no-buffer
             +--ro qos!
                +--ro class* [id]
                   +--ro id         string
                   +--ro packets?   yang:counter64
                   +--ro bytes?     yang:counter64
]]></artwork>
    </section>
    <section numbered="false" anchor="acknowledgements">
      <name>Acknowledgements</name>
      <t>The content of this document has benefitted from feedback from JR Rivers, Ronan Waide, Chris DeBruin, and Marcos Sanz.</t>
      <t>Thanks to Benoît Claise, Joe Clarke, Tom Petch, Mahesh Jethanandani, Paul Aitken, and Randy Bush for the review and comments.</t>
      <t>Thanks to Ladislav Lhotka for the YANGDOCTORS reviews, Sergio Belotti for the OPSDIR review, Satoru Matsushima for the INTDIR review,
Derrell Piper for the SECDIR review, Roni Even for the GENART review, and Michael Tüxen for the TSVART review.</t>
      <t>Thanks to Diego Lopez for shepherding the document and Mahesh Jethanandani for the AD review.</t>
    </section>
    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
      <name>Contributors</name>
      <contact fullname="Nadav Chachmon">
        <organization>Cisco Systems, Inc.</organization>
        <address>
          <postal>
            <street>170 West Tasman Dr.</street>
            <city>San Jose</city>
            <region>CA</region>
            <code>95134</code>
            <country>US</country>
          </postal>
          <email>nchachmo@cisco.com</email>
        </address>
      </contact>
    </section>
  </back>
  <!-- ##markdown-source:
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
hAa6TqHJW+nIWWazm/e2jTWq2GprjZN9R0YkpoWO8CaRVg3wpKaOH9WxvQpN
qozPXDsrc9fOhi5z/6Vm3S+1Z+1L95z8EtSGeDGjq8mLFGxmnx+pTq5xP0hB
RVJtnmEYbjVqgGrt01VoP3Lr5per4JOLjmIHx1FwmQG/4QNAxoCGRRYUZ2CC
3YarPwGELqmecuLlmhqa5zLKTxy2p53Ksxn8OELz4zxvTZPWt1psM/EQfEs6
MLm05DLg4f1SS6qx9a1oy/UteV6my1rYVDfYVGfYVGfY9Jj2YQpjs5XmqumP
LUxkNqwMfdA/e1tW/zKQ4ISeP5Qffj/x02ymvK3x1v2M67o1rOtt/Qa30oE8
y+F1rSmJB8vxP/3Z76bqejYvr4Eq2sm2gUC6dpKKi5XvqqyzZLAqB3WY3dQO
/JXmv6DovLr5O7FMTYcu82M782iLB0/5vZby6KAP6x+fx1YGegWIP7LEswxs
h1/GwHX72yoCLQPbrisxsDdaJwb2enRlYK9TVwb2OpUYuLzopbTQjOAus1cY
+DPPX2Fg8291I5YMV92EVgpzHqby4C+Tt3yc3VQ+rtB+h0233UbZqE8wLFUJ
vG4Rm9X9WTBajuRqtyvQ1tq5r7YbrXHZHkifoooptaqUKLP/0k1YjV+dXcAK
v/liZreiW79ZsejrzM732QeGtytGrRnbaS5S58Q6NBjp0EcDl0fd59F94uAi
jD+YQjpyu1F19VNvy8R3B0k0p2zxDnRQq6G3C49uhK+PuVH87XKo67ikdvEd
lm5n7Ior5/Li854Zmm05Dfx3dd+rRlWs9K9aopPVN19pcbbbaseiveHpMA9J
xvlktS0cj1NHWrYSu/94obcqVwtW7hf12PeatOHda9gF416HdlwTQ8bpdenZ
XMdOpiRE4wzxzeRlSrJjLN8Zvq3g2k53hu+d4fupDd87I7YV3NWZ0et0Z8Te
GbErdLszYmsBvTNiS33ujNg7I7br0u+MWPm5M2L/PzFiJVjjTUNlWrFbVdUm
VWVWV5353GvZqgY7k+xWu3ZXg0031VUNLvfodKyWO3VSg8udXDXY/a6TSKnp
0E4D5dl9Nfjzz++rwe631Y1YMlx1E1opzHCwahOeqjR6Pe+WW3UBegWIKzap
/dgyo13ZMmas26vGlj4z2q4rMaOH4k7M6PXoyoxep67MqFqYUa3KDOUOS7dW
tTLjZ56/woxqVboud+gyf8kmNaPUkfdbzxxyP67Qvvy0wWm7dbFJa7p1sUlb
urXZpC3d2mzSMqaKKqbUqlKizP5LN2E1fnV2oYtNWtOvk03agtBWm7SC0Q42
ablPF5u03KeLTdrUp80m7U4hHbm9YpOab6rjLF2I6bLUJlW2sbVJPaAahEc3
wtfHXJtN6s+222HxHZa+1CatzFDJCvtcZ4ZmW9cmLX2vGtWqUiu1RL+qb77S
4my31Y7FpTZpucNSm7TcYalNakH3bVLvK1ej9b6ox77XpA3vXsMuGPc6NOPa
f62DYuGdUmBOEPz4g4PgDz4sCN59p6nbM00eNprbmaD5LG16uqVT+LwZpOkN
ra9UrZrtzVyN81Sax2nklktst+Gy6Ha37bL49vK6amJR/VbtMKoVYFQrwGjH
LR9FdTNWxjCk1fX5qNXIpj6E/7dEMjUuJfi0s1PJ26QlFFfjWMrS93ctVfo2
L9Xt8z7upTIpdu/W7mJaQpwNXVZy80D7ZY6mzwPFMnfTSlDUbcsS6qt1OsHn
S9xOWdrN8dQR/JVg/yTyt8Zt1YHhVe3OLxHJNc6rVRm+tFkrO7BWYPhSt/dx
YlUZXq3OatUuK+nMdQz/q0CxzKW1EhR127KE+hocWzUsYL5o9Kt4HCI/nRwd
KGDey8GFcue9XFxOx9WcXE7HFdxcqJA0uTFWlCv1zq4l2/KeDi/cl/dzeSF/
vZ/Ty0HwKm4vxPDqjq8sfR/XlwPiCs4vp9cK7q8llNPdBUbTNzvBaoikk/xa
xRFWZ38sFzeruMPw8OvqEKvhpQZUdELEqm4xjYxGx9inPn8siy91j9UrgKV2
pulqLrJVl+l2XPWwXdVRhlJ1RVcZKpmdnWUsfhrcZSVtvPTVcpfZkp0oNV3V
bbYE+8Zj0PZ0cduXq3kQGkNEPtB9cOcIuHME/DpQ3DkCVobddwTcmfR3Jv2v
A8WdSX9n0t+Z9PUIvjPp70z6O5P+zqRv7Hhn0v82TXo/FkbtjfD13jgcX8qT
nG++CEofveu9GfJr5OH4D2uTIM5DXa5SHg8zz/SO09GC3AX8/GkSTqKC3mzA
ZzEncNxQLU3668dTdRpd0SPpp2kSJOqnADThTbU/zWCgg/C7bBEl/CTVcZCN
0lydBck/6ZmyIOGHor4Lk/Q//leh9uMgyqHrj2mIv2evQ3ruVJ2EBT6BeBxM
w3yqfgwL6AnjBUm0qU6CRaz2ouJ1KJOcwj+36rsFtJzwy7L4YFUUXssraTN+
b8yd/3kANkocXKnn07R4HZh+GCh08HL//OXpmYyR4zN22WWEMMdpUUSm7cuT
s4OjU2kGrbAw6gJALnKAJJrZQY9enDsNewcg1fFBvBN6D1U3Ojvcd0cDxEbq
EF/61g2+P3yxd3puGhB2o9E0wDCo//jfN07L87M/25besg+i8BIWn87Df1Lr
fBrOpyG9yMHvWWsi4L2rIN9MsXdghv9/vgFhA71TAQA=

-->

</rfc>
