<?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-13" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.33.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-13"/>
    <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="04"/>
    <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>
        <dt/>
        <dd>
          <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) which is out of scope for this specification.</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 discard-stats {control-plane-stats}?
       +--ro discard-order-capability*   identityref
       +--ro traffic* [direction]
       |  ...
       +--ro discards* [direction]
          ...
  augment /if:interfaces/if:interface/if:statistics:
    +--ro discard-order-capability*   identityref {interface-stats}?
    +--ro traffic* [direction] {interface-stats}?
    |  +--ro direction    identityref
    |  +--ro l2
    |  |  ...
    |  +--ro l3
    |  |  ...
    |  +--ro qos!
    |     +--ro class* [id]
    |        ...
    +--ro discards* [direction] {interface-stats}?
       +--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 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/traffic[direction="ingress"]/l3/address-family-stat[address-family="ipv6"]/unicast/packets</tt></t>
          </li>
          <li>
            <t><tt>interface/traffic[direction="ingress"]/l3/address-family-stat[address-family="ipv6"]/unicast/bytes</tt></t>
          </li>
          <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 discard-stats {
      nacm:default-deny-all;
      config false;
      description
        "List of 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 packet discard reporting to the interface statistics.";
    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 packet counters.";

    container discard-stats {
      nacm:default-deny-all;
      config false;
      description
        "List of 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="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:discard-stats, if:statistics/pdr:traffic, if:statistics/pdr:discards, and lne:logical-network-element/pdr: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 1585?>

<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 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 discard-order-capability*   identityref
    |       {pdr-common:interface-stats}?
    +--ro traffic* [direction] {pdr-common:interface-stats}?
    |  +--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] {pdr-common:interface-stats}?
       +--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 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, and Satoru Matsushima for the INTDIR 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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
EL005tYoxgbdB58Wcul0wcW09b3YR6fVS5EMj5QvReJLlrSIMpXqrmAiYWgA
c67fE50/ymrv9SJVPAzwhiQ7X+7GriBIbzpqlyvraiomG5HF47EURxzQLVOM
VVsXHwky0pel2+t7xt71PetfuoOalKaQnawYyurjr75qooO5ffOy+TtzSU+W
ajLVVWOa7+aptKD6+/1RsJBzvC9U9ZIR06jxfhxVvtLAG6Tmhhr+4QYGO9HE
7uq59xf+YYMn6ma+Yh7qdf21QM3zamrxxo688l4W+Mq7g8W/OwXf7re9/S3N
/0U/MbCSJAJIo7F714/yLgdpQn3TnFSnOanSnBoW3bszpPLWTwMso6mCixpk
tX5TDlWuu5MkS0v3dNwfirq+667nKK1n6Xl5Sd2fEovESTiUbaIv24TJ0W57
2SIsGm+NeUcp8cHW2EVjG2eoGuYozyyvLNLKm2k8KJu/abidpmaEhstgasZp
/rL7HTUV6n8/oDUM1XBXTRM/qC4soZovuhm3XHRz1HTRDbl3aPv3roysXsA3
Ll/AB+rRiae7qHO+vZa1wNefZc6fejSn2rbzLVaduNNeQ18h0sYxTEBrbaZE
Pl1Tm0v9PXNLs99crjm1V6leQ9tUlCJQEQpygMrlF+b2V3Luysu+uVoFU9Dm
US6HCnxnTcKpV+pncwXnkXtFJqpwWThDdf461Bf1WIsjcevDbVfujj09+Ksp
cRegi1U64JLwrP+ay8i55EVqCmAbgRWJxeJaQC76B+rH9AaD/2oAeHlxCeQY
UunnsXhQxYliBia7ydwwRJYGKOt0GabcKMloAZrxKGS3v7svdaw5o0Uq1nHo
YfniTbmYWduVvGDONNTuQ+ksd3sbY73sRGpy0/+iaZSwa1iqoelOh73e7oA8
vWwTjLgymx++Z6oimRA7SppaFNs6TyHnDET3+hbGo5vtheAMensfaLiLH1+8
fHZEAxbm7hBZh8XsLidDC7rWNpd10BniIhIy1zLJFUwDBXRuHo2CBA2o2lEc
TwB9axBQ+VJfObQPuEjolgQQPEu8HJ0QQA3JxiujDykijKRqX1i5jEfuX/df
lixasrXoWilt69t7ZNnTCqY4cIXch8AZ3HhltfnNuYYKqwvyTdhU62+cLrGK
DgFMp0EPyxOUBV1zhvttM9z/XWf4JcxQ1wrz5hEUZgVots9fVLnBfrRPxEwE
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
OES/FnSldrWgdWuO4B7DB7panc476MpZZrGb17aNNarYavsaB/uOjEhMphvh
YSHNGuBJTTU3qmZ6HZoijj5z7a3NXXtbutj555p1P9eetc/dffJzUBvi5ZxO
H69SsJl9fqRqqcb9IGX1SLX5HiNtq4EBVHGdTjv7kVs9vVwLnVx0FB44joJp
BvyG97AYAxomWVAogYlnG65/Ewu6pECpXH2nnbksoXzTXHuynndBSPNdKW/M
J6tuEJHPxEPwLenA5NKSw4BHD0tfUmWib0Vbrv+Sx2W6rIVNdYNNdYZNdYZN
92mvJzA2W2msmvb4hQm+hpmhD/oXb8na7nPhW+jkh6+x+zCL6d0HI8+4GlbD
vN7UL3ArHXjXysizmkJiMB3/6S9+M1XXsnl6DVTRTrYNBNK1kdSpq7yrss6K
zqoc1GF0U3Htdxr/igLw6sbvxDI1DbqMj9+5VxNZeGruJvJ6B31Y//g8tjbQ
a0D8niWeZWDb/SoGrlvfVhFoGdg2XYuBvd46MbDXoisDe426MrDXqMTA5Umv
pIVmBHcZvcLAH3n8CgObf6sLsaK76iK0UphzPZEHf5m85XF2W3lcof0Oi26b
jbJRn2BYqRJ4zSI2q/vzYLQaydVm16CttXNfbTOa46o1kDZFFVNqXSlRZv+V
i7AevzqrgHVR8+XcLkW3dvNi2dfJm/dZB4a3K0atGdtpLFLnxDo0GOnQRgOX
R93H0W3i4CqM35lCOnK7UXX1hV+rxHcHSbSghPAOdFCrobcLj26Er7e5Ufzt
aqjruKR28h2mbkfsiivn8OLj7hmabTnT+1/q3qtGVaz0r1qhk9V/vtbkbLP1
tkV7wtNhHJKMi8l6Szgep460bCV2/wo7b1alCzrti8ZLOrvh3fuwC8a9Bu24
JoaM05vSxaCNd6P7ZnKHS0+9+x8tX38yfD8Zvp8M39/L8P1kxLaCuz4zeo0+
GbGfjNg1mn0yYmsB/WTEltp8MmI/GbFdp/7JiJWfT0bs/ydGrARrvG4oTyp2
q6rapKrM6qozn3tftqrBziD71abd1WDTTHVVg8stOm2r5Uad1OByI1cNdt91
Eik1DdppoDy6rwZ//PF9Ndh9W12IFd1VF6GVwgwHqzbhqUq91/Nu+asuQK8B
ccUmtY8tM9qZrWLGurVq/NJnRtt0LWb0UNyJGb0WXZnRa9SVGVULM6p1maHc
YOXSqlZm/MjjV5hRrUvX5QZdxi/ZpKaXOvJ+45lD7uMK7ctPG5y2WRebtKZZ
F5u0pVmbTdrSrM0mLWOqqGJKrSslyuy/chHW41dnFbrYpDXtOtmkLQhttUkr
GO1gk5bbdLFJy2262KRNbdps0u4U0pHbKzapeVPtZ+VETJOVNqmyH1ub1AOq
QXh0I3y9zbXZpP5o+x0m32HqK23SygiVrLCPtWdotnVt0tJ71ahWlb5SK/Sr
+s/Xmpxttt62uNImLTdYaZOWG6y0SS3ovk3qvXI1Wu9FPfa9T9rw7n3YBeNe
g2Zc+3c6UCy8U+3LCYIfv3MQ/NG7BcG7t9t0u9zGw0bzdyZoPkvLl3l0Cpuv
NC7fOPSFqlWvuVFjgLbSvE09txxeux+uimp3v10V116eV00Mqv9VO4xqDRjV
GjDafstbUN2IlT4MSXW9gKeOXLqsuBZ+qwP7mwmjc1bAqvUwX3nBDfyoQ2xD
eXEaj3FxhP1Kw3UDG1R9w4aJuQ3WCGuop7mObapBDaqeK9u6quPM1UPXRTR8
tMHrwhm6cl7d911CA+CzkueXHzZ6ffn1Co9vR3i7A9siOzuwseoqVj02dnHU
wR3cgY1ViY3dhuv6glV3Ni41WMMTXLc6ndtU/cCqMydVv+/iBVX1bPyRB6/z
ALuLv5Yvtcvg/JnvcSrvScrfNKyr443/oqO7qdSqo7ep1Kqjs6mh1QpfU0Or
Fa4mt0lRwpFaWxjUnPm04X69IxqL/I5OplKzrj6mBkSucjF5mOzmYXKbdHQw
1UG2wr9U12SFe6kTVXRhaz2q71tqE86rxU03z1KdVr9CRnQ+AsVNaIVXqZ4l
Gma9es5dXEpe/75H6ePsBpZBS+6kN86/9dpW6SPz3YrDuvttNOtuNy7gXTxJ
7vddHEnu9138SEZgVNxIJf229LzNibQC3aXvuruQVqPYmNBtF7m2vezmgWmM
kXhH18sHkC3dAiwat9t7B1msoVvfU72+p4bdrmTfQ7jdQ76t0rY/PhSrAi/W
gqJuWVZQX234RZtsVyvFzMcxHOoDMTzWdefZ+Zi1A+uqKuu6ze8dktGVdUtt
7hOWsQbrqlbWVeszTbXJWudAdaz7u0CxKkxjLSjqlmUF9TUEa9SwQI0RZ17U
cIj8dDq8725GVxveL2yjuzHd3HCN0A3PeDIv1H3kSn0Ax4pluWcQxxoWdrXl
PQM51rCzyxheP5iju7Wt6kFcI6Cju829BuV0D+uoMb5V+xbQSX6tE9xRscJd
4BrFzTohHh3McW/M2jCPjkZ5qcm6oR5V09y8/Tj7j2XxlSEfjRaj+535dL2w
j3Wn6TZcd7NdN/ijo9VeatI9AKTBdjcvm4JAVljwqstKlD5dNxSkFft+MIg6
GOENtXE4nsq1k68/C0qP3vZeD/nG7XD8x41JEOehrtcoF2SZq2jH6WhJbgK+
4jMJJ1FBlxbg1Y8T2G6omCT99dO5Oo+u6SLw8zQJEvVzAJrwtjqcZdDRUfhd
towSvovpNMhGaa4uguQfdBVXkPBNSd+FSfp//lehDuMgyqHpT2mIv2evQrrS
U52FBV7zdxrMwnymfgoLaAn9BUm0rc6CZawOouJVKIOcwz936rslfDnh21Px
xqYovJGbwOZ8p5Y7/rMAbJQ4uFbPZmnxKjDtMFLm6MXh5YvzC+kjx6vasmmE
MMdpUUTm2xdnF0cn5/IZQ3KB1UGXAHaRAzTR3HZ88vzSfuyBchSFUwAoXYT/
oK/zWbiYhXRNBN+jrBeG8VlBiBni4Mh0//8AFKZuCHdRAQA=

-->

</rfc>
