Internet Engineering Task Force (IETF)                             Y. Li
Request for Comments: 8302                               D. Eastlake 3rd
Category: Standards Track                                      L. Dunbar
ISSN: 2070-1721                                      Huawei Technologies
                                                              R. Perlman
                                                                Dell EMC
                                                                M. Umair
                                                                   Cisco
                                                            January 2018


         Transparent Interconnection of Lots of Links (TRILL):
              ARP and Neighbor Discovery (ND) Optimization

Abstract

   This document describes mechanisms to optimize the Address Resolution
   Protocol (ARP) and Neighbor Discovery (ND) traffic in a Transparent
   Interconnection of Lots of Links (TRILL) campus.  TRILL switches
   maintain a cache of IP / Media Access Control (MAC) address / Data
   Label bindings that are learned from ARP/ND requests and responses
   that pass through them.  In many cases, this cache allows an edge
   Routing Bridge (RBridge) to avoid flooding an ARP/ND request by
   either responding to it directly or encapsulating it and unicasting
   it.  Such optimization reduces packet flooding over a TRILL campus.

Status of This Memo

   This is an Internet Standards Track document.

   This document is a product of the Internet Engineering Task Force
   (IETF).  It represents the consensus of the IETF community.  It has
   received public review and has been approved for publication by the
   Internet Engineering Steering Group (IESG).  Further information on
   Internet Standards is available in Section 2 of RFC 7841.

   Information about the current status of this document, any errata,
   and how to provide feedback on it may be obtained at
   https://www.rfc-editor.org/info/rfc8302.












Li, et al.                   Standards Track                    [Page 1]

RFC 8302                TRILL ARP/ND Optimization           January 2018


Copyright Notice

   Copyright (c) 2018 IETF Trust and the persons identified as the
   document authors.  All rights reserved.

   This document is subject to BCP 78 and the IETF Trust's Legal
   Provisions Relating to IETF Documents
   (https://trustee.ietf.org/license-info) in effect on the date of
   publication of this document.  Please review these documents
   carefully, as they describe your rights and restrictions with respect
   to this document.  Code Components extracted from this document must
   include Simplified BSD License text as described in Section 4.e of
   the Trust Legal Provisions and are provided without warranty as
   described in the Simplified BSD License.

Table of Contents

   1.  Introduction  . . . . . . . . . . . . . . . . . . . . . . . .   3
     1.1.  Terminology . . . . . . . . . . . . . . . . . . . . . . .   3
   2.  ARP/ND Optimization Requirement and Solution  . . . . . . . .   4
   3.  IP/MAC Address Mappings . . . . . . . . . . . . . . . . . . .   5
   4.  Handling ARP/ND/SEND Messages . . . . . . . . . . . . . . . .   6
     4.1.  SEND Considerations . . . . . . . . . . . . . . . . . . .   7
     4.2.  Address Verification  . . . . . . . . . . . . . . . . . .   7
     4.3.  Extracting Local Mapping Information for End-Station
           IP/MAC Addresses  . . . . . . . . . . . . . . . . . . . .   8
     4.4.  Determining How to Reply to ARP/ND  . . . . . . . . . . .   9
     4.5.  Determining How to Handle the ARP/ND Response . . . . . .  10
   5.  Handling of Reverse Address Resolution Protocol (RARP)
       Messages  . . . . . . . . . . . . . . . . . . . . . . . . . .  11
   6.  Handling of DHCP Messages . . . . . . . . . . . . . . . . . .  11
   7.  Handling of Duplicate IP Addresses  . . . . . . . . . . . . .  11
   8.  RBridge ARP/ND Cache Liveness and MAC Mobility  . . . . . . .  12
   9.  Security Considerations . . . . . . . . . . . . . . . . . . .  13
     9.1.  Data-Plane-Based Considerations . . . . . . . . . . . . .  13
     9.2.  Directory-Based Considerations  . . . . . . . . . . . . .  14
     9.3.  Use of the Confidence Level Feature . . . . . . . . . . .  14
   10. IANA Considerations . . . . . . . . . . . . . . . . . . . . .  14
   11. References  . . . . . . . . . . . . . . . . . . . . . . . . .  15
     11.1.  Normative References . . . . . . . . . . . . . . . . . .  15
     11.2.  Informative References . . . . . . . . . . . . . . . . .  16
   Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . .  17
   Authors' Addresses  . . . . . . . . . . . . . . . . . . . . . . .  18








Li, et al.                   Standards Track                    [Page 2]

RFC 8302                TRILL ARP/ND Optimization           January 2018


1.  Introduction

   ARP [RFC826] and ND [RFC4861] messages are normally sent by broadcast
   and multicast, respectively.  To reduce the burden on a TRILL campus
   caused by these multi-destination messages, RBridges MAY implement an
   "optimized ARP/ND response", as specified herein, when the target's
   location is known by the ingress RBridge or can be obtained from a
   directory.  This avoids ARP/ND query and answer flooding.

1.1.  Terminology

   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
   "OPTIONAL" in this document are to be interpreted as described in BCP
   14 [RFC2119] [RFC8174] when, and only when, they appear in all
   capitals, as shown here.

   The abbreviations and terminology in [RFC6325] are used herein.  Some
   of these are listed below for convenience along with some additions:

   APPsub-TLV   Application sub-Type-Length-Value [RFC6823]

   ARP          Address Resolution Protocol [RFC826]

   Campus       A TRILL network consisting of RBridges, links, and
                possibly bridges bounded by end stations and IP routers
                [RFC6325]

   DAD          Duplicate Address Detection [RFC3756] [RFC5227]

   Data Label   VLAN or Fine-Grained Label (FGL)

   DHCP         Dynamic Host Configuration Protocol.  In this document,
                DHCP refers to both DHCP for IPv4 [RFC2131] and DHCPv6
                [RFC3315]

   ESADI        End Station Address Distribution Information [RFC7357]

   FGL          Fine-Grained Label [RFC7172]

   IA           Interface Address; a TRILL APPsub-TLV [RFC7961]

   IP           Internet Protocol, both IPv4 and IPv6

   MAC          Media Access Control [RFC7042]

   ND           Neighbor Discovery [RFC4861]




Li, et al.                   Standards Track                    [Page 3]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   RBridge      A contraction of "Routing Bridge".  A device
                implementing the TRILL protocol.

   SEND         Secure Neighbor Discovery [RFC3971]

   TRILL        Transparent Interconnection of Lots of Links or Tunneled
                Routing in the Link Layer [RFC6325] [RFC7780]

2.  ARP/ND Optimization Requirement and Solution

   IP address resolution can create significant issues in data centers
   due to flooded packets, as discussed in [RFC6820].  Such flooding can
   be avoided by a proxy ARP/ND function on edge RBridges as described
   in this document, particularly in Section 4.  This section is a
   general discussion of this problem and is not intended to be
   normative.

   To support such ARP/ND optimization, edge RBridges need to know an
   end station's IP/MAC address mapping through manual configuration
   (management), control-plane mechanisms such as directories [RFC8171],
   or data-plane learning by snooping of messages such as ARP/ND
   (including DHCP or gratuitous ARP messages).

   When all the end station's IP/MAC address mappings are known to edge
   RBridges, provisioned through management, or learned via the control
   plane on the edge RBridges, it should be possible to completely
   suppress flooding of ARP/ND messages in a TRILL campus.  When all end
   station MAC addresses are similarly known, it should be possible to
   suppress unknown unicast flooding by dropping any unknown unicast
   received at an edge RBridge.

   An ARP/ND optimization mechanism should include provisions for an
   edge RBridge to issue an ARP/ND request to an attached end station to
   confirm or update information and should allow an end station to
   detect duplication of its IP address.

   Most of the end station hosts send either DHCP messages requesting an
   IP address or gratuitous ARP or Reverse Address Resolution Protocol
   (RARP) requests to announce themselves to the network right after
   they come online.  Thus, the local edge RBridge will immediately have
   the opportunity to snoop and learn their MAC and IP addresses and
   distribute this information to other edge RBridges through the TRILL
   control-plane End Station Address Distribution Information (ESADI)
   [RFC7357] protocol.  Once remote RBridges receive this information
   via the control plane, they should add IP-to-MAC mapping information
   to their ARP/ND cache along with the nickname and Data Label of the
   address information.  Therefore, most active IP hosts in the TRILL




Li, et al.                   Standards Track                    [Page 4]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   network can be learned by the edge RBridges through either local
   learning or control-plane-based remote learning.  As a result, ARP
   suppression can vastly reduce the network flooding caused by host ARP
   learning behavior.

   When complete directory information is available, the default data-
   plane learning of end-station MAC addresses is not only unnecessary
   but could be harmful if there is learning based on frames with forged
   source addresses.  Such data-plane learning can be suppressed because
   TRILL already provides an option to disable data-plane learning from
   the source MAC address of end-station frames (see Section 5.3 of
   [RFC6325]).

3.  IP/MAC Address Mappings

   By default, an RBridge [RFC6325] [RFC7172] learns egress nickname
   mapping information for the MAC address and Data Label (VLAN or FGL)
   of TRILL data frames it receives and decapsulates.  No IP address
   information is learned directly from the TRILL data frame.  The IA
   APPsub-TLV [RFC7961] enhances the TRILL base protocol by allowing IP/
   MAC address mappings to be distributed in the control plane by any
   RBridge.  This APPsub-TLV appears inside the TRILL GENINFO TLV in
   ESADI [RFC7357], but the value data structure it specifies may also
   occur in other application contexts.  Edge RBridge Directory Assist
   Mechanisms [RFC8171] make use of this APPsub-TLV for its push model
   and use the value data structure it specifies in its pull model.

   An RBridge can easily know the IP/MAC address mappings of the local
   end stations that it is attached to via its access ports by receiving
   ARP [RFC826] or ND [RFC4861] messages.  If the edge RBridge has
   extracted the sender's IP/MAC address pair from the received data
   frame (either ARP or ND), it may save the information and then use
   the IA APPsub-TLV to link the IP and MAC addresses and distribute it
   to other RBridges through ESADI.  Then, the relevant remote RBridges
   (normally those interested in the same Data Label as the original
   ARP/ND messages) also receive and save such mapping information.
   There are other ways that RBridges save IP/MAC address mappings in
   advance, e.g., importing them from the management system and
   distributing them by directory servers [RFC8171].

   The examples given above show that RBridges might have saved an end
   station's triplet of {IP address, MAC address, ingress nickname} for
   a given Data Label (VLAN or FGL) before that end station sends or
   receives any real data packet.  Note that such information might or
   might not be a complete list and might or might not exist on all
   RBridges; the information could possibly be from different sources.
   RBridges can then use the Flags field in an IA APPsub-TLV to identify




Li, et al.                   Standards Track                    [Page 5]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   if the source is a directory server or local observation by the
   sender.  A different confidence level may also be used to indicate
   the reliability of the mapping information.

4.  Handling ARP/ND/SEND Messages

   A native frame that is an ARP [RFC826] message is detected by its
   Ethertype of 0x0806.  A native frame that is an ND [RFC4861] is
   detected by being one of five different ICMPv6 packet types.  ARP/ND
   is commonly used on a link to (1) query for the MAC address
   corresponding to an IPv4 or IPv6 address, (2) test if an IPv4/IPv6
   address is already in use, or (3) announce the new or updated info on
   any of the following: IPv4/IPv6 address, MAC address, and/or point of
   attachment.

   To simplify the text, we use the following terms in this section.

   1.  IP address -- indicated protocol address that is normally an IPv4
       address in ARP or an IPv6 address in ND.

   2.  sender's IP/MAC address -- sender IP/MAC address in ARP, source
       IP address, and source link-layer address in ND.

   3.  target's IP/MAC address -- target IP/MAC address in ARP, target
       address, and target link-layer address in ND.

   When an ingress RBridge receives an ARP/ND/SEND message, it can
   perform the steps described within the subsections below.  In
   particular, Section 4.4 describes the options for such an ingress
   handling an ARP/ND message and, in the cases where it forwards the
   message, Section 4.5 describes how to handle any response that may be
   returned due to the forwarded message.

   Section 4.3 describes the extraction of address information by an
   RBridge from ARP/ND messages it handles.  Under some circumstances,
   this extraction may prompt verification with an end station.
   Section 4.2 describes an optional use of ARP/ND messages originated
   by RBridges to verify addresses or liveness.

   As described in Section 4.1, SEND messages are not optimized by the
   mechanisms specified in this document but are snooped on.










Li, et al.                   Standards Track                    [Page 6]

RFC 8302                TRILL ARP/ND Optimization           January 2018


4.1.  SEND Considerations

   Secure Neighbor Discovery (SEND) [RFC3971] is a method of securing ND
   that addresses the threats discussed in [RFC3756].  Typical TRILL
   campuses are inside data centers, Internet exchange points, or
   carrier facilities.  These are generally controlled and protected
   environments where these threats are of less concern.  Nevertheless,
   SEND provides an additional layer of protection.

   Secure SEND messages require knowledge of cryptographic keys.
   Methods of communicating such keys to RBridges for use in SEND are
   beyond the scope of this document.  Thus, using the optimizations in
   this document, RBridges do not attempt to construct SEND messages and
   are generally transparent to them.  RBridges only construct ARP,
   RARP, or insecure ND messages, as appropriate.  Nevertheless,
   RBridges implementing ARP/ND optimization SHOULD snoop on SEND
   messages to extract the addressing information that would be present
   if the SEND had been sent as an insecure ND message and is still
   present in the SEND message.

4.2.  Address Verification

   RBridges may use ARP/ND to probe directly attached or remote end
   stations for address or liveness verification.  This is typically
   most appropriate in less-managed and/or higher-mobility environments.
   In strongly managed environments, such as a typical data center,
   where a central orchestration/directory system has complete
   addressing knowledge [RFC7067], optimized ARP/ND responses can use
   that knowledge.  In such cases, there is little reason for
   verification except for debugging operational problems or the like.





















Li, et al.                   Standards Track                    [Page 7]

RFC 8302                TRILL ARP/ND Optimization           January 2018


4.3.  Extracting Local Mapping Information for End-Station IP/MAC
      Addresses

   Edge RBridges extract and use information about the correspondence
   between local end-station IP and MAC addresses from the ARP/ND
   messages those end stations send, as described below.  An apparent
   zero source IP address means that the end station is probing for
   duplicate IP addresses, and messages with such a zero source IP
   address are not used for the extraction of IP/MAC address mapping
   information.

   o  If the sender's IP is not present in the ingress RBridge's ARP/ND
      cache, populate the information of the sender's IP/MAC address
      mapping in its ARP/ND cache table.  The ingress RBridge correlates
      its nickname and that IP/MAC address mapping information.  Such a
      triplet of {IP address, MAC address, ingress nickname} information
      is saved locally and can be distributed to other RBridges, as
      explained later.

   o  Else, if the sender's IP has been saved before but with a
      different MAC address mapped or a different ingress nickname
      associated with the same pair of IP/MAC, the RBridge SHOULD verify
      if a duplicate IP address has already been in use or an end
      station has changed its attaching RBridge.  The RBridge may use
      different strategies to do so.  For example, the RBridge might ask
      an authoritative entity like directory servers or it might
      encapsulate and unicast the ARP/ND message to the location where
      it believes the address is in use (Section 4.2).  RBridge SHOULD
      update the saved triplet of {IP address, MAC address, ingress
      nickname} based on the verification results.  An RBridge might not
      verify an IP address if the network manager's policy is to have
      the network behave, for each Data Label, as if it were a single
      link and just believe an ARP/ND it receives.

   The ingress RBridge MAY use the IA APPsub-TLV [RFC7961] with the
   Local flag set in ESADI [RFC7357] to distribute any new or updated
   triplet of {IP address, MAC address, ingress nickname} information
   obtained.  If a Push Directory server is used, such information can
   be distributed as specified in [RFC8171].












Li, et al.                   Standards Track                    [Page 8]

RFC 8302                TRILL ARP/ND Optimization           January 2018


4.4.  Determining How to Reply to ARP/ND

   The options for an edge RBridge to handle a native ARP/ND are given
   below.  For generic ARP/ND requests seeking the MAC address
   corresponding to an IP address, if the edge RBridge knows the IP
   address and corresponding MAC, behavior is as in item (a), otherwise
   behavior is as in item (b).  Behavior for gratuitous ARP and ND
   unsolicited Neighbor Advertisements (NAs) [RFC4861] is given in item
   (c).  And item (d) covers the handling of an Address Probe ARP query.
   Within each lettered item, it is an implementation decision as to
   which numbered strategy to use for any particular ARP/ND query
   falling under that item.

   a.  If the message is a generic ARP/ND request, and the ingress
       RBridge knows the target's IP address and associated MAC address,
       the ingress RBridge MUST take one or a combination of the actions
       below.  In the case of SEND [RFC3971], cryptography would prevent
       a local reply by the ingress RBridge, since the RBridge would not
       be able to sign the response with the target's private key, and
       only action a.2 or a.5 is valid.

       a.1.  Send an ARP/ND response directly to the querier, using the
             target's MAC address present in the ingress RBridge's ARP/
             ND cache table.  Because the edge RBridge might not have an
             IPv6 address, the source IP address for such an ND response
             MUST be that of the target end station.

       a.2.  Encapsulate the ARP/ND/SEND request to the target's
             Designated RBridge and have the egress RBridge for the
             target forward the query to the target.  This behavior has
             the advantage that a response to the request is
             authoritative.  If the request does not reach the target,
             then the querier does not get a response.

       a.3.  Block ARP/ND requests that occur for some time after a
             request to the same target has been launched, and then
             respond to the querier when the response to the recently
             launched query to that target is received.

       a.4.  Reply to the querier based on directory information
             [RFC8171] such as information obtained from a Pull
             Directory server or directory information that the ingress
             RBridge has requested to be pushed to it.

       a.5.  Flood the ARP/ND/SEND request as per [RFC6325].






Li, et al.                   Standards Track                    [Page 9]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   b.  If the message is a generic ARP/ND/SEND request and the ingress
       RBridge does not know the target's IP address, the ingress
       RBridge MUST take one of the following actions.  In the case of
       SEND [RFC3971], cryptography would prevent local reply by the
       ingress RBridge, since the RBridge would not be able to sign the
       response with the target's private key; therefore, only action
       b.1 is valid.

       b.1.  Flood the ARP/ND/SEND message as per [RFC6325].

       b.2.  Use a directory server to pull the information [RFC8171]
             and reply to the querier.

       b.3.  Drop the message if there should be no response because the
             directory server gives authoritative information that the
             address being queried is nonexistent.

   c.  If the message is a gratuitous ARP, which can be identified by
       the same sender's and target's "protocol" address fields, or an
       unsolicited Neighbor Advertisement [RFC4861] in ND/SEND then:

       The RBridge MAY use an IA APPsub-TLV [RFC7961] with the Local
       flag set to distribute the sender's IP/MAC address mapping
       information.  When one or more directory servers are deployed and
       complete Push Directory information is used by all the RBridges
       in the Data Label, a gratuitous ARP or unsolicited NA SHOULD be
       discarded rather than ingressed.  Otherwise, they are either
       ingressed and flooded as per [RFC6325] or discarded depending on
       local policy.

   d.  If the message is an Address Probe ARP query [RFC5227], which can
       be identified by the sender's protocol (IPv4) address field being
       zero and the target's protocol address field being the IPv4
       address to be tested or a Neighbor Solicitation for Duplicate
       Address Detection (DAD) that has the unspecified source address
       [RFC4862], it SHOULD be handled as the generic ARP message as in
       (a) or (b) above.

4.5.  Determining How to Handle the ARP/ND Response

   If the ingress RBridge R1 decides to unicast the ARP/ND request to
   the target's egress RBridge R2 as discussed in Section 4.4, item a.2
   or to flood the request as per item a.5 and [RFC6325], then R2
   decapsulates the query and initiates an ARP/ND query on the target's
   link.  If and when the target responds, R2 encapsulates and unicasts
   the response to R1, which decapsulates the response and sends it to
   the querier.  R2 SHOULD initiate a link state update to inform all
   the other RBridges of the target's location, Layer 3 address, and



Li, et al.                   Standards Track                   [Page 10]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   Layer 2 address, in addition to forwarding the reply to the querier.
   The update uses an IA APPsub-TLV [RFC7961] (so the Layer 3 and Layer
   2 addresses can be linked) with the Local flag set in ESADI [RFC7357]
   or as per [RFC8171] if the Push Directory server is in use.

5.  Handling of Reverse Address Resolution Protocol (RARP) Messages

   RARP [RFC903] uses the same packet format as ARP but different
   Ethertype (0x8035) and opcode values.  Its processing is similar to
   the generic ARP request/response as described in Section 4.4, items
   a. and b.  The difference is that it is intended to query for the
   target "protocol" (IP) address corresponding to the target "hardware"
   (MAC) address provided.  It SHOULD be handled by doing a local cache
   or directory server lookup on the target "hardware" address provided
   to find a mapping to the desired "protocol" address.

6.  Handling of DHCP Messages

   When a newly connected end station exchanges messages with a DHCP
   [RFC3315][RFC2131] server, an edge RBridge should snoop them (mainly
   the DHCPAck message) and store IP/MAC address mapping information in
   its ARP/ND cache and should also send the information out through the
   TRILL control plane using ESADI.

7.  Handling of Duplicate IP Addresses

   Duplicate IP addresses within a Data Label can occur due to an
   attacker sending fake ARP/ND messages or due to human/configuration
   errors.  If complete, trustworthy directory information is available,
   then, by definition, the IP location information in the directory is
   correct.  Any appearance of an IP address in a different place
   (different edge RBridge or port) from other sources is not correct.

   Without complete directory information, the ARP/ND optimization
   function should support duplicate IP detection.  This is critical in
   a data center to stop an attacker from using ARP/ND spoofing to
   divert traffic from its intended destination.

   Duplicate IP addresses can be detected when an existing active IP/MAC
   address mapping gets modified.  Also, an edge RBridge may send a
   query called a Duplicate Address Detection query (DAD-query) asking
   about the IP address in question to the former owner of that IP
   address by using the MAC address formerly associated with that IP
   address.  A DAD-query is a unicast ARP/ND message with sender IP
   0.0.0.0 in case of ARP (or a configurable IP address per RBridge
   called the DAD-Query source IP) and an IPv6 Link Local Address in
   case of ND with the source MAC set to the DAD-querier RBridge's MAC.
   If the querying RBridge does not receive an answer within a given



Li, et al.                   Standards Track                   [Page 11]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   time, it may be a case of mobility; in any case, the new IP entry
   will be confirmed and activated in its ARP/ND cache.

   In the case where the former owner replies, a duplicate address has
   been detected.  In this case, the querying RBridge SHOULD log the
   duplicate so that the network administrator can take appropriate
   action.

   It is an implementation choice how to respond to a query for an
   address that is duplicated in the network when authoritative
   information is not available from a directory or configuration.
   Typically, the information most recently snooped is returned.

8.  RBridge ARP/ND Cache Liveness and MAC Mobility

   A maintenance procedure is needed for RBridge ARP/ND caching to
   ensure IP end stations connected to ingress RBridges are still
   active.

   Some links provide a physical-layer indication of link liveness.  A
   dynamic proxy ARP/ND entry (one learned from data-plane observation)
   MUST be removed from the table if the link over which it was learned
   fails.

   Similarly, a dynamic proxy ARP/ND entry SHOULD be flushed out of the
   table if the IP/MAC address mapping has not been refreshed within a
   given age-time.  The entry is refreshed if an ARP or ND message is
   received for the same IP/MAC address mapping entry from any location.
   The IP/MAC address mapping information Ageing Timer is configurable
   per RBridge and defaults to 3/4 of the MAC address learning Ageing
   Timer [RFC6325].

   For example, end station "A" is connected to edge-RBridge1 (RB1) and
   has been learned as a local entry on RB1.  If end station "A" moves
   to some other location (MAC / Virtual Machine (VM) Mobility) and gets
   connected to edge-RBridge (RB2), after learning on RB2's access port,
   RB2 advertises this entry through the TRILL control plane, and it is
   learned on RB1 as a remote entry.  The old entry on RB1 SHOULD get
   replaced, and all other edge-RBridges with end-station service
   enabled for that Data Label should update the entry to show
   reachability from RB2 instead of RB1.

   If an ARP/ND entry in the cache is not refreshed, then the RBridge
   connected to that end station MAY send periodic refresh messages
   (ARP/ND "probes") to that end station, so that the entries can be
   refreshed before they age out.  The end station would reply to the
   ARP/ND probe, and the reply resets the corresponding entry age-timer.




Li, et al.                   Standards Track                   [Page 12]

RFC 8302                TRILL ARP/ND Optimization           January 2018


9.  Security Considerations

   There are generally two modes of learning the address information
   that is the basis of ARP/ND optimization: data-plane mode and
   directory mode.  The data-plane mode is the traditional bridge
   address learning [IEEE802.1Q] that is also implemented in TRILL
   switches [RFC6325] and is discussed in Section 9.1.  The directory
   mode uses data obtained from a directory [RFC8171] and is discussed
   in Section 9.2.  The TRILL confidence-level feature, which can help
   arbitrate between conflicting address information, is discussed in
   Section 9.3.

   RBridges should rate limit ARP/ND queries injected into the TRILL
   campus to limit some potential denial-of-service attacks.

9.1.  Data-Plane-Based Considerations

   Generally speaking, when ARP/ND optimization is operating in the
   data-plane mode, the information learned by RBridges is the same as
   that which is learned by end stations.  Thus, the answers generated
   by RBridges to the query messages being optimized are generally those
   that would be generated by end stations in the absence of
   optimization, and the security considerations are those of the
   underlying ARP/ND protocols.

   RBridges that snoop on DHCPack messages respond to ARP/ND messages in
   essentially the same way that the end stations sending those DHCPack
   messages would.  Thus, for security considerations of ARP/ND
   optimization for DHCP messages that may be snooped, see the Security
   Considerations sections of [RFC3315] and [RFC2131].

   Unless SEND [RFC3971] is used, ARP and ND messages can be easily
   forged.  Therefore, the learning of IP/MAC addresses by RBridges from
   ARP/ND is hackable, but this is what is available for data-plane
   learning without SEND.  See "SEND Considerations", Section 4.1.

   Since end stations communicate with edge RBridges using Ethernet,
   some security improvements could be obtained by the use of
   [IEEE802.1AE] between end stations and edge RBridges.  Such link
   security is beyond the scope of this document and would impose
   requirements on edge stations, while TRILL is generally designed to
   operate with unmodified, TRILL-ignorant end stations.









Li, et al.                   Standards Track                   [Page 13]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   ARP/ND address mapping information learned locally at an RBridge can
   be distributed to other RBridges using the TRILL ESADI protocol that
   can be secured as specified in [RFC7357].  (ESADI is also used for
   Push Directories with flags in the data indicating whether data comes
   from a directory or from data-plane learning, as well as from a
   confidence level (see Section 9.3).)

9.2.  Directory-Based Considerations

   ARP/ND optimization can be based on directory information [RFC8171].
   If the directory information is known to be trustworthy and complete,
   then trustworthy responses to ARP/ND queries can be entirely based on
   this information.  This bounds the damage that forged ARP/ND messages
   can do to the local link between end stations and edge RBridges.  (In
   TRILL, such a "link" can be a bridged LAN.)

   Of course, there can also be incomplete and/or unreliable directory
   address mapping data.  The network administrator can configure their
   TRILL campus to use such directory data in place of data-plane-
   learned data.  Alternatively, such directory data can be used along
   with data-plane-learned data arbitrated by the confidence level as
   discussed in Section 9.3.

9.3.  Use of the Confidence Level Feature

   An RBridge can use the confidence level in IA APPsub-TLV information
   received via ESADI or Pull Directory retrievals to determine the
   configured relative reliability of IP/MAC address mapping information
   from those sources and from locally learned address information.
   Push Directory information is sent via ESADI, which can be secured as
   provided in [RFC7357]; Pull Directory information can be secured as
   provided in [RFC8171].  The implementation decides if an RBridge will
   distribute the IP and MAC address mappings received from local native
   ARP/ND messages to other RBridges in the same Data Label, and with
   what confidence level it does so.  Thus, the implementer can, to some
   extent, cause sources that they know are more reliable to dominate
   those they know to be less reliable.  How the implementer determines
   this is beyond the scope of this document.

10.  IANA Considerations

   This document does not require any IANA actions.









Li, et al.                   Standards Track                   [Page 14]

RFC 8302                TRILL ARP/ND Optimization           January 2018


11.  References

11.1.  Normative References

   [RFC826]   Plummer, D., "Ethernet Address Resolution Protocol: Or
              Converting Network Protocol Addresses to 48.bit Ethernet
              Address for Transmission on Ethernet Hardware", STD 37,
              RFC 826, DOI 10.17487/RFC0826, November 1982,
              <https://www.rfc-editor.org/info/rfc826>.

   [RFC903]   Finlayson, R., Mann, T., Mogul, J., and M. Theimer, "A
              Reverse Address Resolution Protocol", STD 38, RFC 903,
              DOI 10.17487/RFC0903, June 1984,
              <https://www.rfc-editor.org/info/rfc903>.

   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119,
              DOI 10.17487/RFC2119, March 1997,
              <https://www.rfc-editor.org/info/rfc2119>.

   [RFC2131]  Droms, R., "Dynamic Host Configuration Protocol",
              RFC 2131, DOI 10.17487/RFC2131, March 1997,
              <https://www.rfc-editor.org/info/rfc2131>.

   [RFC3315]  Droms, R., Ed., Bound, J., Volz, B., Lemon, T., Perkins,
              C., and M. Carney, "Dynamic Host Configuration Protocol
              for IPv6 (DHCPv6)", RFC 3315, DOI 10.17487/RFC3315, July
              2003, <https://www.rfc-editor.org/info/rfc3315>.

   [RFC4861]  Narten, T., Nordmark, E., Simpson, W., and H. Soliman,
              "Neighbor Discovery for IP version 6 (IPv6)", RFC 4861,
              DOI 10.17487/RFC4861, September 2007,
              <https://www.rfc-editor.org/info/rfc4861>.

   [RFC4862]  Thomson, S., Narten, T., and T. Jinmei, "IPv6 Stateless
              Address Autoconfiguration", RFC 4862,
              DOI 10.17487/RFC4862, September 2007,
              <https://www.rfc-editor.org/info/rfc4862>.

   [RFC6325]  Perlman, R., Eastlake 3rd, D., Dutt, D., Gai, S., and A.
              Ghanwani, "Routing Bridges (RBridges): Base Protocol
              Specification", RFC 6325, DOI 10.17487/RFC6325, July 2011,
              <https://www.rfc-editor.org/info/rfc6325>.








Li, et al.                   Standards Track                   [Page 15]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   [RFC7172]  Eastlake 3rd, D., Zhang, M., Agarwal, P., Perlman, R., and
              D. Dutt, "Transparent Interconnection of Lots of Links
              (TRILL): Fine-Grained Labeling", RFC 7172,
              DOI 10.17487/RFC7172, May 2014,
              <https://www.rfc-editor.org/info/rfc7172>.

   [RFC7357]  Zhai, H., Hu, F., Perlman, R., Eastlake 3rd, D., and O.
              Stokes, "Transparent Interconnection of Lots of Links
              (TRILL): End Station Address Distribution Information
              (ESADI) Protocol", RFC 7357, DOI 10.17487/RFC7357,
              September 2014, <https://www.rfc-editor.org/info/rfc7357>.

   [RFC7780]  Eastlake 3rd, D., Zhang, M., Perlman, R., Banerjee, A.,
              Ghanwani, A., and S. Gupta, "Transparent Interconnection
              of Lots of Links (TRILL): Clarifications, Corrections, and
              Updates", RFC 7780, DOI 10.17487/RFC7780, February 2016,
              <https://www.rfc-editor.org/info/rfc7780>.

   [RFC7961]  Eastlake 3rd, D. and L. Yizhou, "Transparent
              Interconnection of Lots of Links (TRILL): Interface
              Addresses APPsub-TLV", RFC 7961, DOI 10.17487/RFC7961,
              August 2016, <https://www.rfc-editor.org/info/rfc7961>.

   [RFC8171]  Eastlake 3rd, D., Dunbar, L., Perlman, R., and Y. Li,
              "Transparent Interconnection of Lots of Links (TRILL):
              Edge Directory Assistance Mechanisms", RFC 8171,
              DOI 10.17487/RFC8171, June 2017,
              <https://www.rfc-editor.org/info/rfc8171>.

   [RFC8174]  Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
              2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
              May 2017, <https://www.rfc-editor.org/info/rfc8174>.

11.2.  Informative References

   [IEEE802.1AE]
              IEEE, "IEEE Standard for Local and metropolitan area
              networks: Media Access Control (MAC) Security", IEEE
              Std 802.1AE.

   [IEEE802.1Q]
              IEEE, "IEEE Standard for Local and metropolitan area
              networks -- Bridges and Bridged Networks", IEEE
              Std 802.1Q.







Li, et al.                   Standards Track                   [Page 16]

RFC 8302                TRILL ARP/ND Optimization           January 2018


   [RFC3756]  Nikander, P., Ed., Kempf, J., and E. Nordmark, "IPv6
              Neighbor Discovery (ND) Trust Models and Threats",
              RFC 3756, DOI 10.17487/RFC3756, May 2004,
              <https://www.rfc-editor.org/info/rfc3756>.

   [RFC3971]  Arkko, J., Ed., Kempf, J., Zill, B., and P. Nikander,
              "SEcure Neighbor Discovery (SEND)", RFC 3971,
              DOI 10.17487/RFC3971, March 2005,
              <https://www.rfc-editor.org/info/rfc3971>.

   [RFC5227]  Cheshire, S., "IPv4 Address Conflict Detection", RFC 5227,
              DOI 10.17487/RFC5227, July 2008,
              <https://www.rfc-editor.org/info/rfc5227>.

   [RFC6820]  Narten, T., Karir, M., and I. Foo, "Address Resolution
              Problems in Large Data Center Networks", RFC 6820,
              DOI 10.17487/RFC6820, January 2013,
              <https://www.rfc-editor.org/info/rfc6820>.

   [RFC6823]  Ginsberg, L., Previdi, S., and M. Shand, "Advertising
              Generic Information in IS-IS", RFC 6823,
              DOI 10.17487/RFC6823, December 2012,
              <https://www.rfc-editor.org/info/rfc6823>.

   [RFC7042]  Eastlake 3rd, D. and J. Abley, "IANA Considerations and
              IETF Protocol and Documentation Usage for IEEE 802
              Parameters", BCP 141, RFC 7042, DOI 10.17487/RFC7042,
              October 2013, <https://www.rfc-editor.org/info/rfc7042>.

   [RFC7067]  Dunbar, L., Eastlake 3rd, D., Perlman, R., and I.
              Gashinsky, "Directory Assistance Problem and High-Level
              Design Proposal", RFC 7067, DOI 10.17487/RFC7067, November
              2013, <https://www.rfc-editor.org/info/rfc7067>.

Acknowledgments

   The authors would like to thank Igor Gashinsky and Sue Hares for
   their contributions.













Li, et al.                   Standards Track                   [Page 17]

RFC 8302                TRILL ARP/ND Optimization           January 2018


Authors' Addresses

   Yizhou Li
   Huawei Technologies
   101 Software Avenue,
   Nanjing  210012
   China
   Phone: +86-25-56625375
   Email: liyizhou@huawei.com


   Donald Eastlake 3rd
   Huawei R&D USA
   155 Beaver Street
   Milford, MA  01757
   United States of America
   Phone: +1-508-333-2270
   Email: d3e3e3@gmail.com


   Linda Dunbar
   Huawei Technologies
   5430 Legacy Drive, Suite #175
   Plano, TX  75024
   United States of America
   Phone: +1-469-277-5840
   Email: ldunbar@huawei.com


   Radia Perlman
   Dell EMC
   176 South Street
   Hopkinton, MA  01748
   United States of America
   Email: Radia@alum.mit.edu


   Mohammed Umair
   Cisco
   Cessna Business Park, Kadubeesanahalli Village, Hobli,
   Sarjapur, Varthur Main Road, Marathahalli,
   Bengaluru, Karnataka  560087
   India
   Email: mohammed.umair2@gmail.com







Li, et al.                   Standards Track                   [Page 18]