Internet Working Group                                 Ali Sajassi
   Internet Draft                                         Samer Salam
   Category: Standards Track                             Sami Boutros
                                                                Cisco
   Florin Balus
   Wim Henderickx                                         Nabil Bitar
   Alcatel-Lucent                                             Verizon
  
   Clarence Filsfils                                     Aldrin Issac
   Dennis Cai                                               Bloomberg
   Cisco
                                                           Lizhong Jin
                                                                   ZTE
  
   Expires: April 28, 2012                           October 28, 2011
  
  
                                 PBB E-VPN
                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   Status of this Memo
  
   This Internet-Draft is submitted to IETF in full conformance with
   the provisions of BCP 78 and BCP 79.
  
   Internet-Drafts are working documents of the Internet Engineering
   Task Force (IETF), its areas, and its working groups.  Note that
   other groups may also distribute working documents as Internet-
   Drafts.
  
   Internet-Drafts are draft documents valid for a maximum of six
   months and may be updated, replaced, or obsoleted by other documents
   at any time.  It is inappropriate to use Internet-Drafts as
   reference material or to cite them other than as "work in progress."
  
   The list of current Internet-Drafts can be accessed at
   http://www.ietf.org/ietf/1id-abstracts.txt
  
   The list of Internet-Draft Shadow Directories can be accessed at
   http://www.ietf.org/shadow.html
  
   This Internet-Draft will expire on April 28, 2012.
  
   Copyright Notice
  
   Copyright (c) 2011 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
   (http://trustee.ietf.org/license-info) in effect on the date of
  
  
   Sajassi, et. al.                                           [Page 1]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   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.
  
  
   Abstract
   This document discusses how Ethernet Provider Backbone Bridging
   [802.1ah] can be combined with E-VPN in order to reduce the number
   of BGP MAC advertisement routes by aggregating Customer/Client MAC
   (C-MAC) addresses via Provider Backbone MAC address (B-MAC), provide
   client MAC address mobility using C-MAC aggregation and B-MAC sub-
   netting, confine the scope of C-MAC learning to only active flows,
   offer per site policies and avoid C-MAC address flushing on topology
   changes. The combined solution is referred to as PBB-EVPN.
  
  
  
  
  
   Conventions
  
   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
   document are to be interpreted as described in RFC 2119
  
  
   Table of Contents
  
   1. Introduction.................................................... 3
   2. Contributors.................................................... 4
   3. Terminology..................................................... 4
   4. Requirements.................................................... 4
   4.1. MAC Advertisement Route Scalability........................... 4
   4.2. C-MAC Mobility with MAC Sub-netting........................... 5
   4.3. C-MAC Address Learning and Confinement........................ 5
   4.4. Interworking with TRILL and 802.1aq Access Networks with C-MAC
   Address Transparency............................................... 5
   4.5. Per Site Policy Support....................................... 6
   4.6. Avoiding C-MAC Address Flushing............................... 6
   5. Solution Overview............................................... 6
   6. BGP Encoding.................................................... 7
   6.1. BGP MAC Advertisement Route................................... 7
   6.2. Ethernet Auto-Discovery Route................................. 8
   6.3. Per VPN Route Targets......................................... 8
   6.4. MAC Mobility Extended Community............................... 8
  
  
   Sajassi, et al.                                            [Page 2]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   7. Operation....................................................... 8
   7.1. MAC Address Distribution over Core............................ 8
   7.2. Device Multi-homing........................................... 8
   7.2.1. MES MAC Layer Addressing & Multi-homing..................... 8
   7.2.2. Split Horizon and Designated Forwarder Election............ 11
   7.3. Network Multi-homing......................................... 11
   7.3.1. B-MAC Address Advertisement................................ 12
   7.3.2. Failure Handling........................................... 12
   7.4. Frame Forwarding............................................. 13
   7.4.1. Unicast.................................................... 13
   7.4.2. Multicast/Broadcast........................................ 14
   8. Minimizing ARP Broadcast....................................... 14
   9. Seamless Interworking with TRILL and IEEE 802.1aq/802.1Qbp..... 14
   9.1. TRILL Nickname Advertisement Route........................... 15
   9.2. IEEE 802.1aq / 802.1Qbp B-MAC Advertisement Route............ 16
   9.3. Operation.................................................... 16
   10. Solution Advantages........................................... 17
   10.1. MAC Advertisement Route Scalability......................... 18
   10.2. C-MAC Mobility with MAC Sub-netting......................... 18
   10.3. C-MAC Address Learning and Confinement...................... 18
   10.4. Interworking with TRILL and 802.1aq Access Networks with C-MAC
   Address Transparency.............................................. 18
   10.5. Per Site Policy Support..................................... 19
   10.6. Avoiding C-MAC Address Flushing............................. 19
   11. Acknowledgements.............................................. 20
   12. Security Considerations....................................... 20
   13. IANA Considerations........................................... 20
   14. Intellectual Property Considerations.......................... 20
   15. Normative References.......................................... 20
   16. Informative References........................................ 20
   17. Authors' Addresses............................................ 20
  
  
  
  
  
   1.
      Introduction
  
   [E-VPN] introduces a solution for multipoint L2VPN services with
   advanced multi-homing capabilities using BGP for distributing
   customer/clinent MAC address reach-ability information over the core
   MPLS/IP network. [802.1ah] defines an architecture for Ethernet
   Provider Backbone Bridging (PBB), where MAC tunneling is employed to
   improve service instance and MAC address scalability in Ethernet
   networks and in VPLS networks [PBB-VPLS].
  
  
  
   Sajassi, et al.                                            [Page 3]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   In this document, we discuss how PBB can be combined with E-VPN in
   order to reduce the number of BGP MAC advertisement routes by
   aggregating Customer/Client MAC (C-MAC) addresses via Provider
   Backbone MAC address (B-MAC), provide client MAC address mobility
   using C-MAC aggregation and B-MAC sub-netting, confine the scope of
   C-MAC learning to only active flows, offer per site policies and
   avoid C-MAC address flushing on topology changes. The combined
   solution is referred to as PBB-EVPN.
  
  
   2.
      Contributors
  
   In addition to the authors listed above, the following individuals
   also contributed to this document.
  
   Keyur Patel
   Cisco
  
   3.
      Terminology
  
   BEB: Backbone Edge Bridge
   B-MAC: Backbone MAC Address
   CE: Customer Edge
   C-MAC: Customer/Client MAC Address
   DHD: Dual-homed Device
   DHN: Dual-homed Network
   LACP: Link Aggregation Control Protocol
   LSM: Label Switched Multicast
   MDT: Multicast Delivery Tree
   MES: MPLS Edge Switch
   MP2MP: Multipoint to Multipoint
   P2MP: Point to Multipoint
   P2P: Point to Point
   PoA: Point of Attachment
   PW: Pseudowire
   E-VPN: Ethernet VPN
  
   4.
      Requirements
  
   The requirements for PBB-EVPN include all the requirements for E-VPN
   that were described in [EVPN-REQ], in addition to the following:
  
   4.1.
        MAC Advertisement Route Scalability
  
   In typical operation, an [E-VPN] MES sends a BGP MAC Advertisement
   Route per customer/client MAC (C-MAC) address. In certain
   applications, this poses scalability challenges, as is the case in
   virtualized data center environments where the number of virtual
   machines (VMs), and hence the number of C-MAC addresses, can be in
   the millions. In such scenarios, it is required to reduce the number
   of BGP MAC Advertisement routes by relying on a MAC 'summarization'
  
  
   Sajassi, et al.                                            [Page 4]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   scheme, as is provided by PBB. Note that the MAC sub-netting
   capability already built into E-VPN is not sufficient in those
   environments, as will be discussed next.
  
   4.2.
        C-MAC Mobility with MAC Sub-netting
  
   Certain applications, such as virtual machine mobility, require
   support for fast C-MAC address mobility. For these applications, it
   is not possible to use MAC address sub-netting in E-VPN, i.e.
   advertise reach-ability to a MAC address prefix. Rather, the exact
   virtual machine MAC address needs to be transmitted in BGP MAC
   Advertisement route. Otherwise, traffic would be forwarded to the
   wrong segment when a virtual machine moves from one Ethernet segment
   to another. This hinders the scalability benefits of sub-netting.
  
   It is required to support C-MAC address mobility, while retaining
   the scalability benefits of MAC sub-netting. This can be achieved by
   leveraging PBB technology, which defines a Backbone MAC (B-MAC)
   address space that is independent of the C-MAC address space, and
   aggregate C-MAC addresses via a B-MAC address and then apply sub-
   netting to B-MAC addresses.
  
   4.3.
        C-MAC Address Learning and Confinement
  
   In E-VPN, all the MES nodes participating in the same E-VPN instance
   are exposed to all the C-MAC addresses learnt by any one of these
   MES nodes because a C-MAC learned by one of the MES nodes is
   advertise in BGP to other MES nodes in that E-VPN instance. This is
   the case even if some of the MES nodes for that E-VPN instance are
   not involved in forwarding traffic to, or from, these C-MAC
   addresses. Even if an implementation does not install hardware
   forwarding entries for C-MAC addresses that are not part of active
   traffic flows on that MES, the device memory is still consumed by
   keeping record of the C-MAC addresses in the routing table (RIB). In
   network applications with millions of C-MAC addresses, this
   introduces a non-trivial waste of MES resources. As such, it is
   required to confine the scope of visibility of C-MAC addresses only
   to those MES nodes that are actively involved in forwarding traffic
   to, or from, these addresses.
  
   4.4.
        Interworking with TRILL and 802.1aq Access Networks with C-MAC
  Address Transparency
  
   [TRILL] and [802.1aq] define next generation Ethernet bridging
   technologies that offer optimal forwarding using IS-IS control
   plane, and C-MAC address transparency via Ethernet tunneling
   technologies. When access networks based on TRILL or 802.1aq are
   interconnected over an MPLS/IP network, it is required to guarantee
   C-MAC address transparency on the hand-off point and the edge (i.e.
   MES) of the MPLS network. As such, solutions that require
   termination of the access data-plane encapsulation (i.e. TRILL or
  
  
   Sajassi, et al.                                            [Page 5]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   802.1aq) at the hand-off to the MPLS network do not meet this
   transparency requirement, and expose the MPLS edge devices to the
   MAC address scalability problem.
  
   PBB-EVPN supports seamless interconnect with these next generation
   Ethernet solutions while guaranteeing C-MAC address transparency on
   the MES nodes.
  
   4.5.
        Per Site Policy Support
  
   In many applications, it is required to be able to enforce
   connectivity policy rules at the granularity of a site (or segment).
   This includes the ability to control which MES nodes in the network
   can forward traffic to, or from, a given site. PBB-EVPN is capable
   of providing this granularity of policy control. In the case where
   per C-MAC address granularity is required, the EVI can always
   continue to operate in E-VPN mode.
  
   4.6.
        Avoiding C-MAC Address Flushing
  
   It is required to avoid C-MAC address flushing upon link, port or
   node failure for multi-homed devices and networks. This is in order
   to speed up re-convergence upon failure.
  
   5.
      Solution Overview
  
   The solution involves incorporating IEEE 802.1ah Backbone Edge
   Bridge (BEB) functionality on the E-VPN MES nodes similar to PBB-
   VPLS PEs (PBB-VPLS) where BEB functionality is incorporated in PE
   nodes. The MES devices would then receive 802.1Q Ethernet frames
   from their attachment circuits, encapsulate them in the PBB header
   and forward the frames over the IP/MPLS core. On the egress E-VPN
   MES, the PBB header is removed following the MPLS disposition, and
   the original 802.1Q Ethernet frame is delivered to the customer
   equipment.
  
  
                   BEB   +--------------+  BEB
                   ||    |              |  ||
                   \/    |              |  \/
       +----+ AC1 +----+ |              | +----+   +----+
       | CE1|-----|    | |              | |    |---| CE2|
       +----+\    |MES1| |   IP/MPLS    | |MES3|   +----+
              \   +----+ |   Network    | +----+
               \         |              |
             AC2\ +----+ |              |
                 \|    | |              |
                  |MES2| |              |
                  +----+ |              |
                    /\   +--------------+
                    ||
  
  
   Sajassi, et al.                                            [Page 6]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
                    BEB
         <-802.1Q-> <------PBB over MPLS------> <-802.1Q->
  
                        Figure 1: PBB-EVPN Network
  
  
   The MES nodes perform the following functions:
   - Learn customer/client MAC addresses (C-MACs) over the attachment
   circuits in the data-plane, per normal bridge operation.
  
   - Learn remote C-MAC to B-MAC bindings in the data-plane from
   traffic ingress from the core per [802.1ah] bridging operation.
  
   - Advertise local B-MAC address reach-ability information in BGP to
   all other MES nodes in the same set of service instances. Note that
   every MES has a set of local B-MAC addresses that uniquely identify
   the device. More on the MES addressing in section 5.
  
   - Build a forwarding table from remote BGP advertisements received
   associating remote B-MAC addresses with remote MES IP addresses and
   the associated MPLS label(s).
  
  
   6.
      BGP Encoding
  
   PBB-EVPN leverages the same BGP Routes and Attributes defined in [E-
   VPN], adapted as follows:
  
   6.1.
        BGP MAC Advertisement Route
  
   The E-VPN MAC Advertisement Route is used to distribute B-MAC
   addresses of the MES nodes instead of the C-MAC addresses of end-
   stations/hosts. This is because the C-MAC addresses are learnt in
   the data-plane for traffic arriving from the core. The MAC
   Advertisement Route is encoded as follows:
  
   - The RD is set to a Type 1 RD RD [RFC4364]. The value field encodes
     the IP address of the MES (typically, the loopback address)
     followed by 0.  The reason for such encoding is that the RD cannot
     be that of a single EVI since the same B-MAC address can span
     across multiple EVIs.
  
   - The MAC address field contains the B-MAC address.
   - The Ethernet Tag field is set to 0.
  
   The route is tagged with the set of RTs corresponding to all EVIs
   associated with the B-MAC address.
  
   All other fields are set as defined in [E-VPN].
  
  
  
   Sajassi, et al.                                            [Page 7]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   6.2.
        Ethernet Auto-Discovery Route
  
   This route and any of its associated modes is not needed in PBB-
   EVPN.
  
  
   6.3.
        Per VPN Route Targets
  
   PBB-EVPN uses the same set of route targets defined in [E-VPN]. More
   specifically, the RT associated with a VPN is set to the value of
   the I-SID associated with the service instance. This eliminates the
   need for manually configuring the VPN-RT.
  
   6.4.
        MAC Mobility Extended Community
  
   This extended community is a new transitive extended community. It
   may be advertised along with MAC Advertisement routes. When used in
   PBB-EVPN, it indicates that the C-MAC forwarding tables for the I-
   SIDs associated with the RTs tagging the MAC Advertisement routes
   must be flushed. This extended community is encoded in 8-bytes as
   follows:
   - Type (1 byte) = Pending IANA assignment.
   - Sub-Type (1 byte) = Pending IANA assignment.
   - Reserved (2 bytes)
   - Counter (4 bytes)
  
   Note that all other BGP messages and/or attributes are used as
   defined in [E-VPN].
  
   7.
      Operation
  
   This section discusses the operation of PBB-EVPN, specifically in
   areas where it differs from [E-VPN].
  
   7.1.
        MAC Address Distribution over Core
  
   In PBB-EVPN, host MAC addresses (i.e. C-MAC addresses) need not be
   distributed in BGP. Rather, every MES independently learns the C-MAC
   addresses in the data-plane via normal bridging operation. Every MES
   has a set of one or more unicast B-MAC addresses associated with it,
   and those are the addresses distributed over the core in MAC
   Advertisement routes. Given that these B-MAC addresses are global
   within the provider's network, there's no need to advertise them on
   a per service instance basis.
  
   7.2.
        Device Multi-homing
  
   7.2.1.
          MES MAC Layer Addressing & Multi-homing
  
   In [802.1ah] every BEB is uniquely identified by one or more B-MAC
   addresses. These addresses are usually locally administered by the
  
  
   Sajassi, et al.                                            [Page 8]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   Service Provider. For PBB-EVPN, the choice of B-MAC address(es) for
   the MES nodes must be examined carefully as it has implications on
   the proper operation of multi-homing. In particular, for the
   scenario where a CE is multi-homed to a number of MES nodes with
   all-active redundancy and flow-based load-balancing, a given C-MAC
   address would be reachable via multiple MES nodes concurrently.
   Given that any given remote MES will bind the C-MAC address to a
   single B-MAC address, then the various MES nodes connected to the
   same CE must share the same B-MAC address. Otherwise, the MAC
   address table of the remote MES nodes will keep flip-flopping
   between the B-MAC addresses of the various MES devices. For example,
   consider the network of Figure 1, and assume that MES1 has B-MAC BM1
   and MES2 has B-MAC BM2. Also, assume that both links from CE1 to the
   MES nodes are part of an all-active multi-chassis Ethernet link
   aggregation group. If BM1 is not equal to BM2, the consequence is
   that the MAC address table on MES3 will keep oscillating such that
   the C-MAC address CM of CE1 would flip-flop between BM1 or BM2,
   depending on the load-balancing decision on CE1 for traffic destined
   to the core.
  
   Considering that there could be multiple sites (e.g. CEs) that are
   multi-homed to the same set of MES nodes, then it is required for
   all the MES devices in a Redundancy Group to have a unique B-MAC
   address per site. This way, it is possible to achieve fast
   convergence in the case where a link or port failure impacts the
   attachment circuit connecting a single site to a given MES.
  
  
  
                               +---------+
                +-------+ MES1 | IP/MPLS |
               /               |         |
            CE1                | Network |    MESr
           M1  \               |         |
                +-------+ MES2 |         |
                /-------+      |         |
               /               |         |
            CE2                |         |
          M2   \               |         |
                \              |         |
                 +------+ MES3 +---------+
  
   Figure 2: B-MAC Address Assignment
  
   In the example network shown in Figure 2 above, two sites
   corresponding to CE1 and CE2 are dual-homed to MES1/MES2 and
   MES2/MES3, respectively. Assume that BM1 is the B-MAC used for the
   site corresponding to CE1. Similarly, BM2 is the B-MAC used for the
   site corresponding to CE2. On MES1, a single B-MAC address (BM1) is
   required for the site corresponding to CE1. On MES2, two B-MAC
   addresses (BM1 and BM2) are required, one per site. Whereas on MES3,
  
  
   Sajassi, et al.                                            [Page 9]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   a single B-MAC address (BM2) is required for the site corresponding
   to CE2. All three MES nodes would advertise their respective B-MAC
   addresses in BGP using the MAC Advertisement routes defined in [E-
   VPN]. The remote MES, MESr, would learn via BGP that BM1 is
   reachable via MES1 and MES2, whereas BM2 is reachable via both MES2
   and MES3. Furthermore, MESr establishes via the normal bridge
   learning that C-MAC M1 is reachable via BM1, and C-MAC M2 is
   reachable via BM2. As a result, MESr can load-balance traffic
   destined to M1 between MES1 and MES2, as well as traffic destined to
   M2 between both MES2 and MES3. In the case of a failure that causes,
   for example, CE1 to be isolated from MES1, the latter can withdraw
   the route it has advertised for BM1. This way, MESr would update its
   path list for BM1, and will send all traffic destined to M1 over to
   MES2 only.
  
   For single-homed sites, it is possible to assign a unique B-MAC
   address per site, or have all the single-homed sites connected to a
   given MES share a single B-MAC address. The advantage of the first
   model over the second model is the ability to avoid C-MAC
   destination address lookup on the disposition PE (even though source
   C-MAC learning is still required in the data-plane). Also, by
   assigning the B-MAC addresses from a contiguous range, it is
   possible to advertise a single B-MAC subnet for all single-homed
   sites, thereby rendering the number of MAC advertisement routes
   required at par with the second model.
  
   In summary, every MES may use a unicast B-MAC address shared by all
   single-homed CEs or a unicast B-MAC address per single-homed CE, and
   in addition a unicast B-MAC address per dual-homed CE. In the latter
   case, the B-MAC address MUST be the same for all MES nodes in a
   Redundancy Group connected to the same CE.
  
   7.2.1.1.
            Automating B-MAC Address Assignment
  
   The MES B-MAC address used for single-homed sites can be
   automatically derived from the hardware (using for e.g. the
   backplane's address). However, the B-MAC address used for multi-
   homed sites must be coordinated among the RG members. To automate
   the assignment of this latter address, the MES can derive this B-MAC
   address from the MAC Address portion of the CE's LACP System
   Identifier by flipping the 'Locally Administered' bit of the CE's
   address. This guarantees the uniqueness of the B-MAC address within
   the network, and ensures that all MES nodes connected to the same
   multi-homed CE use the same value for the B-MAC address.
  
   Note that with this automatic provisioning of the B-MAC address
   associated with mult-homed CEs, it is not possible to support the
   uncommon scenario where a CE has multiple bundles towards the MES
   nodes, and the service involves hair-pinning traffic from one bundle
   to another. This is because the split-horizon filtering relies on B-
   MAC addresses rather than Site-ID Labels (as will be described in
  
  
   Sajassi, et al.                                           [Page 10]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   the next section). The operator must explicitly configure the B-MAC
   address for this fairly uncommon service scenario.
  
   Whenever a B-MAC address is provisioned on the MES, either manually
   or automatically (as an outcome of CE auto-discovery), the MES MUST
   transmit an MAC Advertisement Route for the B-MAC address with a
   downstream assigned MPLS label that uniquely identifies that address
   on the advertising MES. The route is tagged with the RTs of the
   associated EVIs as described above.
  
   7.2.2.
          Split Horizon and Designated Forwarder Election
  
   [E-VPN] relies on access split horizon, where the Ethernet Segment
   Label is used for egress filtering on the attachment circuit in
   order to prevent forwarding loops. In PBB-EVPN, the B-MAC source
   address can be used for the same purpose, as it uniquely identifies
   the originating site of a given frame. As such, Segment Labels are
   not used in PBB-EVPN, and the egress filtering is done based on the
   B-MAC source address. It is worth noting here that [802.1ah] defines
   this B-MAC address based filtering function as part of the I-
   Component options, hence no new functions are required to support
   split-horizon beyond what is already defined in [802.1ah].
   Given that the Segment label is not used in PBB-EVPN, the MES sets
   the Label field in the Ethernet Segment Route to 0.
  
   The Designated Forwarder election procedures remain unchanged from
   [E-VPN].
  
  
   7.3.
        Network Multi-homing
  
   When an Ethernet network is multi-homed to a set of MES nodes
   running PBB-EVPN, an all-active redundancy model can be supported
   with per service instance (i.e. I-SID) load-balancing. In this
   model, DF election is performed to ensure that a single MES node in
   the redundancy group is responsible for forwarding traffic
   associated with a given I-SID. This guarantees that no forwarding
   loops are created. Filtering based on DF state applies to both
   unicast and multicast traffic, and in both access-to-core as well as
   core-to-access directions (unlike the multi-homed device scenario
   where DF filtering is limited to multi-destination frames in the
   core-to-access direction).
   Similar to the multi-homed device scenario, a unique B-MAC address
   is used on the MES per multi-homed network (Segment). This helps
   eliminate the need for C-MAC address flushing in all but one failure
   scenario (more details on this in the Failure Handling section
   below). The B-MAC address may be auto-provisioned by snooping on the
   BPDUs of the multi-homed network: the B-MAC address is set to the
   root bridge ID of the CIST albeit with the 'Locally Administered'
   bit set.
  
  
  
   Sajassi, et al.                                           [Page 11]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   7.3.1.
          B-MAC Address Advertisement
  
   For every multi-homed network, the MES advertises two MAC
   Advertisement routes with different RDs and identical MAC addresses
   and ESIs. One of these routes will be tagged with a lower Local Pref
   attribute than the other. The route with the higher Local Pref will
   be tagged with the RTs corresponding to the I-SIDs for which the
   advertising MES is the DF. Whereas, the route with the lower Local
   Pref will be tagged with the RTs corresponding to the I-SIDs for
   which the advertising MES is the backup DF. Consider the example
   network of the figure below, where a multi-homed network (MHN1) is
   connected to two MES nodes (MES1 and MES2).
  
                               +---------+
                +-------+ MES1 | IP/MPLS |
       +------+         BM1    |         |
       |      |                | Network |    MESr
       | MHN1 |         BM1    |         |
       +------+ +-------+ MES2 |         |
                               +---------+
  
   Figure 3: Multi-homed Network
  
   Both MES nodes use the same B-MAC address (BM1) for the Ethernet
   Segment (ESI1) associated with MHN1. Assume, for instance, that MES1
   is the DF for the even I-SIDs whereas MES2 is the DF for the odd I-
   SIDs. In this example, the routes advertised by MES1 and MES2 would
   be as follows:
  
   MES1:
  
   Route 1: RD11, BM1, ESI1, Local Pref = 120, RT2, RT4, RT6...
   Route 2: RD12, BM1, ESI1, Local Pref = 80, RT1, RT3, RT5...
  
   MES2:
  
   Route 1: RD21, BM1, ESI1, Local Pref = 120, RT1, RT3, RT5...
   Route 2: RD22, BM1, ESI1, Local Pref = 80, RT2, RT4, RT6
  
   Upon receiving the above MAC Advertisement routes, the remote MES
   nodes (e.g. MESr) would install forwarding entries for BM1 towards
   MES1 for the even I-SIDs, and towards MES2 for the odd I-SIDs.
  
   It is worth noting that the procedures of this section can also be
   used for a multi-homed device in order to support all-active
   redundancy with per I-SID load-balancing.
  
   7.3.2.
          Failure Handling
  
   In the case of an MES node failure, or when the MES is isolated from
   the multi-homed network due to a port or link failure, the affected
  
  
   Sajassi, et al.                                           [Page 12]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   MES withdraws its MAC Advertisement routes for the associated B-MAC.
   This serves as a trigger for the remote MES nodes to adjust their
   forwarding entries to point to the backup DF. Because the same B-MAC
   address is used on both the DF and backup DF nodes, then there is no
   need to flush the C-MAC address table upon the occurrence of these
   failures.
  
   In the case where the multi-homed network is partitioned, the MES
   nodes can detect this condition by snooping on the network's BPDUs.
   When a MES detects that the root bridge ID has changed, it must
   change the value of the B-MAC address associated with the Ethernet
   Segment. This is done by the MES withdrawing the previous MAC
   Advertisement route, and advertising a new route for the updated B-
   MAC. The MES, which detects the failure, must inform the remote MES
   nodes to flush their C-MAC address tables for the affected I-SIDs.
   This is required because when the multi-homed network is
   partitioned, certain C-MAC addresses will move from being associated
   with the old B-MAC address to the new B-MAC addresses. Other C-MAC
   addresses will have their reachability remaining intact. Given that
   the MES node has no means of identifying which C-MACs have moved and
   which have not, the entire C-MAC forwarding table for the affected
   I-SIDs must be flushed. The affected MES signals the need for the C-
   MAC flushing by sending the MAC Mobility Extended Community in the
   MP_UNREACH_NLRI attribute containing the E-VPN NLRI for the
   withdrawn MAC Advertisement route.
  
  
   7.4.
        Frame Forwarding
  
   The frame forwarding functions are divided in between the Bridge
   Module, which hosts the [802.1ah] Backbone Edge Bridge (BEB)
   functionality, and the MPLS Forwarder which handles the MPLS
   imposition/disposition. The details of frame forwarding for unicast
   and multi-destination frames are discussed next.
  
   7.4.1.
          Unicast
  
   Known unicast traffic received from the AC will be PBB-encapsulated
   by the MES using the B-MAC source address corresponding to the
   originating site. The unicast B-MAC destination address is
   determined based on a lookup of the C-MAC destination address (the
   binding of the two is done via transparent learning of reverse
   traffic). The resulting frame is then encapsulated with an LSP
   tunnel label and the MPLS label which uniquely identifies the B-MAC
   destination address on the egress MES. If per flow load-balancing
   over ECMPs in the MPLS core is required, then a flow label is added
   as the end of stack label.
  
   For unknown unicast traffic, the MES forwards these frames over MPLS
   core. When these frames are to be forwarded, then the same set of
  
  
   Sajassi, et al.                                           [Page 13]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   options used for forwarding multicast/broadcast frames (as described
   in next section) are used.
  
   7.4.2.
          Multicast/Broadcast
  
   Multi-destination frames received from the AC will be PBB-
   encapsulated by the MES using the B-MAC source address corresponding
   to the originating site. The multicast B-MAC destination address is
   selected based on the value of the I-SID as defined in [802.1ah].
   The resulting frame is then forwarded over the MPLS core using one
   out of the following two options:
  
   Option 1: the MPLS Forwarder can perform ingress replication over a
   set of MP2P tunnel LSPs. The frame is encapsulated with a tunnel LSP
   label and the E-VPN ingress replication label advertised in the
   Inclusive Multicast Route.
  
   Option 2: the MPLS Forwarder can use P2MP tunnel LSP per the
   procedures defined in [E-VPN]. This includes either the use of
   Inclusive or Aggregate Inclusive trees.
  
   Note that the same procedures for advertising and handling the
   Inclusive Multicast Route defined in [E-VPN] apply here.
  
   8.
      Minimizing ARP Broadcast
  
   The MES nodes implement an ARP-proxy function in order to minimize
   the volume of ARP traffic that is broadcasted over the MPLS network.
   This is achieved by having each MES node snoop on ARP request and
   response messages received over the access interfaces or the MPLS
   core. The MES builds a cache of IP / MAC address bindings from these
   snooped messages. The MES then uses this cache to respond to ARP
   requests ingress on access ports and targeting hosts that are in
   remote sites. If the MES finds a match for the IP address in its ARP
   cache, it responds back to the requesting host and drops the
   request. Otherwise, if it does not find a match, then the request is
   flooded over the MPLS network using either ingress replication or
   LSM.
  
   9.
      Seamless Interworking with TRILL and IEEE 802.1aq/802.1Qbp
  
   PBB-EVPN enables seamless connectivity of TRILL or 802.1aq/802.1Qbp
   networks over an MPLS/IP core while maintaining control-plane
   separation among these networks. We will refer to one or any of
   TRILL, 802.1aq or 802.1Qbp networks collectively as 'NG-Ethernet
   networks' thereafter.
   Every NG-Ethernet network that is connected to the MPLS core runs an
   independent instance of the corresponding IS-IS control-plane. Each
   MES participates in the NG-Ethernet network control plane of its
   local site. The MES peers, in IS-IS protocol, with the switches
   internal to the site, but does not terminate the TRILL / PBB data-
  
  
   Sajassi, et al.                                           [Page 14]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   plane encapsulation. So, from a control-plane viewpoint, the MES
   appears as an edge switch; whereas, from a data-plane viewpoint, the
   MES appears as a core switch to the NG-Ethernet network.
   The MES nodes encapsulate TRILL / PBB frames with MPLS in the
   imposition path, and de-capsulate them in the disposition path.
  
  
   9.1.
        TRILL Nickname Advertisement Route
  
   A new BGP route is defined to support the interconnection of TRILL
   networks over PBB-EVPN: the TRILL Nickname Advertisement' route,
   encoded as follows:
  
   +---------------------------------------+
   | RD (8 octets)                         |
   +---------------------------------------+
   |Ethernet Segment Identifier (10 octets)|
   +---------------------------------------+
   | Ethernet Tag ID (4 octets)            |
   +---------------------------------------+
   | Nickname Length (1 octet)             |
   +---------------------------------------+
   | RBridge Nickname (2 octets)           |
   +---------------------------------------+
   | MPLS Label (n * 3 octets)             |
   +---------------------------------------+
  
   Figure 4: TRILL Nickname Advertisement Route
  
   The MES uses this route to advertise the reachability of TRILL
   RBridge nicknames to other MES nodes in the VPN instance. The MPLS
   label advertised in this route can be allocated on a per VPN basis
   and serves the purpose of identifying to the disposition MES that
   the MPLS-encapsulated packet holds an MPLS encapsulated TRILL frame.
  
   The encapsulation for the transport of TRILL frames over MPLS is
   encoded as shown in the figure below:
  
   +------------------+
   | IP/MPLS Header   |
   +------------------+
   | TRILL Header     |
   +------------------+
   | Ethernet Header  |
   +------------------+
   | Ethernet Payload |
   +------------------+
   | Ethernet FCS     |
   +------------------+
  
   Figure 5: TRILL over MPLS Encapsulation
  
  
   Sajassi, et al.                                           [Page 15]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
  
   It is worth noting here that while it is possible to transport
   Ethernet encapsulated TRILL frames over MPLS, that approach
   unnecessarily wastes 16 bytes per packet. That approach further
   requires either the use of well-known MAC addresses or having the
   MES nodes advertise in BGP their device MAC addresses, in order to
   resolve the TRILL next-hop L2 adjacency. To that end, it is simpler
   and more efficient to transport TRILL natively over MPLS and that is
   why we are defining the above BGP route for TRILL Nickname
   advertisement.
  
  
   9.2.
        IEEE 802.1aq / 802.1Qbp B-MAC Advertisement Route
  
   B-MAC addresses associated with 802.1aq / 802.1Qbp switches are
   advertised using the BGP MAC Advertisement route already defined in
   [E-VPN].
  
   The encapsulation for the transport of PBB frames over MPLS is
   similar to that of classical Ethernet, albeit with the additional
   PBB header, as shown in the figure below:
  
   +------------------+
   | IP/MPLS Header   |
   +------------------+
   | PBB Header       |
   +------------------+
   | Ethernet Header  |
   +------------------+
   | Ethernet Payload |
   +------------------+
   | Ethernet FCS     |
   +------------------+
  
   Figure 6: PBB over MPLS Encapsulation
  
   9.3.
        Operation
  
   For correct connectivity, the TRILL Nicknames or 802.1aq/802.1Qbp B-
   MACs must be globally unique in the network. This can be achieved,
   for instance, by using a hierarchical Nickname (or B-MAC) assignment
   paradigm, and encoding a Site ID in the high-order bits of the
   Nickname (or B-MAC):
  
   Nickname (or B-MAC) = [Site ID : Rbridge ID (or MAC)]
  
   The only practical difference between TRILL Nicknames and B-MACs, in
   this regards, is with respect to the size of the address space:
   Nicknames are 16-bits wide whereas B-MACs are 48-bits wide.
  
  
  
   Sajassi, et al.                                           [Page 16]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   Every MES then advertises (in BGP) the Nicknames (or B-MACs) of all
   switches local to its site in the TRILL Nickname Advertisement
   routes (or MAC Advertisement routes).
   Furthermore, the MES advertises in IS-IS (to the local island) the
   Rbridge nicknames (or B-MACs) of all remote switches in all the
   other TRILL (or IEEE 802.1aq/802.1Qbp) islands that the MES has
   learned via BGP.
  
   Note that by having multiple MES nodes (connected to the same TRILL
   or 802.1aq /802.1Qbp island) advertise routes to the same RBridge
   nickname (or B-MAC), with equal BGP Local_Pref attribute, it is
   possible to perform active/active load-balancing to/from the MPLS
   core.
  
   When a MES receives an Ethernet-encapsulated TRILL frame from the
   access side, it removes the Ethernet encapsulation (i.e. outer MAC
   header), and performs a lookup on the egress RBridge nickname in the
   TRILL header to identify the next-hop. If the lookup yields that the
   next hop is a remote MES, the local MES would then encapsulate the
   TRILL frame in MPLS. The label stack comprises of the VPN label
   (advertised by the remote MES), followed by an LSP/IGP label. From
   that point onwards, regular MPLS forwarding is applied.
  
   On the disposition MES, assuming penultimate-hop-popping is
   employed, the MES receives the MPLS-encapsulated TRILL frame with a
   single label: the VPN label. The value of the label indicates to the
   disposition MES that this is a TRILL packet, so the label is popped,
   the TTL field (in the TRILL header) is reinitialized and normal
   TRILL processing is employed from this point onwards.
  
   By the same token, when a MES receives a PBB-encapsulated Ethernet
   frame from the access side, it performs a lookup on the B-MAC
   destination address to identify the next hop. If the lookup yields
   that the next hop is a remote MES, the local MES would then
   encapsulate the PBB frame in MPLS. The label stack comprises of the
   VPN label (advertised by the remote PE), followed by an LSP/IGP
   label. From that point onwards, regular MPLS forwarding is applied.
  
   On the disposition MES, assuming penultimate-hop-popping is
   employed, the MES receives the MPLS-encapsulated PBB frame with a
   single label: the VPN label. The value of the label indicates to the
   disposition MES that this is a PBB frame, so the label is popped,
   the TTL field (in the 802.1Qbp F-Tag) is reinitialized and normal
   PBB processing is employed from this point onwards.
  
   10.
       Solution Advantages
  
   In this section, we discuss the advantages of the PBB-EVPN solution
   in the context of the requirements set forth in section 3 above.
  
  
  
   Sajassi, et al.                                           [Page 17]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   10.1.
         MAC Advertisement Route Scalability
  
   In PBB-EVPN the number of MAC Advertisement Routes is a function of
   the number of segments (sites), rather than the number of
   hosts/servers. This is because the B-MAC addresses of the MESes,
   rather than C-MAC addresses (of hosts/servers) are being advertised
   in BGP. And, as discussed above, there's a one-to-one mapping
   between multi-homed segments and B-MAC addresses, whereas there's a
   one-to-one or many-to-one mapping between single-homed segments and
   B-MAC addresses for a given MES. As a result, the volume of MAC
   Advertisement Routes in PBB-EVPN is multiple orders of magnitude
   less than E-VPN.
  
   10.2.
         C-MAC Mobility with MAC Sub-netting
  
   In PBB-EVPN, if a MES allocates its B-MAC addresses from a
   contiguous range, then it can advertise a MAC prefix rather than
   individual 48-bit addresses. It should be noted that B-MAC addresses
   can easily be assigned from a contiguous range because MES nodes are
   within the provider administrative domain; however, CE devices and
   hosts are typically not within the provider administrative domain.
   The advantage of such MAC address sub-netting can be maintained even
   as C-MAC addresses move from one Ethernet segment to another. This
   is because the C-MAC address to B-MAC address association is learnt
   in the data-plane and C-MAC addresses are not advertised in BGP. To
   illustrate how this compares to E-VPN, consider the following
   example:
  
   If a MES running E-VPN advertises reachability for a MAC subnet that
   spans N addresses via a particular segment, and then 50% of the MAC
   addresses in that subnet move to other segments (e.g. due to virtual
   machine mobility), then in the worst case, N/2 additional MAC
   Advertisement routes need to be sent for the MAC addresses that have
   moved. This defeats the purpose of the sub-netting. With PBB-EVPN,
   on the other hand, the sub-netting applies to the B-MAC addresses
   which are statically associated with MES nodes and are not subject
   to mobility. As C-MAC addresses move from one segment to another,
   the binding of C-MAC to B-MAC addresses is updated via data-plane
   learning.
  
   10.3.
         C-MAC Address Learning and Confinement
  
   In PBB-EVPN, C-MAC address reachability information is built via
   data-plane learning. As such, MES nodes not participating in active
   conversations involving a particular C-MAC address will purge that
   address from their forwarding tables. Furthermore, since C-MAC
   addresses are not distributed in BGP, MES nodes will not maintain
   any record of them in control-plane routing table.
  
   10.4.
         Seamless Interworking with TRILL and 802.1aq Access Networks
  
  
  
   Sajassi, et al.                                           [Page 18]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   Consider the scenario where two access networks, one running MPLS
   and the other running 802.1aq, are interconnected via an MPLS
   backbone network. The figure below shows such an example network.
  
  
  
  
                               +--------------+
                               |              |
               +---------+     |     MPLS     |    +---------+
       +----+  |         |   +----+        +----+  |         |  +----+
       | CE |--|         |   |MES1|        |MES2|  |         |--| CE |
       +----+  | 802.1aq |---|    |        |    |--|  MPLS   |  +----+
       +----+  |         |   +----+        +----+  |         |  +----+
       | CE |--|         |     |   Backbone   |    |         |--| CE |
       +----+  +---------+     +--------------+    +---------+  +----+
  
   Figure 7: Interoperability with 802.1aq
  
   If the MPLS backbone network employs E-VPN, then the 802.1aq data-
   plane encapsulation must be terminated on MES1 or the edge device
   connecting to MES1. Either way, all the MES nodes that are part of
   the associated service instances will be exposed to all the C-MAC
   addresses of all hosts/servers connected to the access networks.
   However, if the MPLS backbone network employs PBB-EVPN, then the
   802.1aq encapsulation can be extended over the MPLS backbone,
   thereby maintaining C-MAC address transparency on MES1. If PBB-EVPN
   is also extended over the MPLS access network on the right, then C-
   MAC addresses would be transparent to MES2 as well.
  
   Interoperability with TRILL access network will be described in
   future revision of this draft.
  
   10.5.
         Per Site Policy Support
  
   In PBB-EVPN, a unique B-MAC address can be associated with every
   site (single-homed or multi-homed). Given that the B-MAC addresses
   are sent in BGP MAC Advertisement routes, it is possible to define
   per site (i.e. B-MAC) forwarding policies including policies for E-
   TREE service.
  
   10.6.
         Avoiding C-MAC Address Flushing
  
   With PBB-EVPN, it is possible to avoid C-MAC address flushing upon
   topology change affecting a multi-homed device. To illustrate this,
   consider the example network of Figure 1. Both MES1 and MES2
   advertize the same B-MAC address (BM1) to MES2. MES2 then learns the
   C-MAC addresses of the servers/hosts behind CE1 via data-plane
   learning. If AC1 fails, then MES3 does not need to flush any of the
   C-MAC addresses learnt and associated with BM1. This is because MES1
   will withdraw the MAC Advertisement routes associated with BM1,
  
  
   Sajassi, et al.                                           [Page 19]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   thereby leading MES3 to have a single adjacency (to MES2) for this
   B-MAC address. Therefore, the topology change is communicated to
   MES3 and no C-MAC address flushing is required.
  
   11.
       Acknowledgements
   TBD.
  
   12.
       Security Considerations
  
   There are no additional security aspects beyond those of VPLS/H-VPLS
   that need to be discussed here.
  
   13.
       IANA Considerations
  
   This document requires IANA to assign a new SAFI value for L2VPN_MAC
   SAFI.
  
  
   14.
       Intellectual Property Considerations
  
   This document is being submitted for use in IETF standards
   discussions.
  
   15.
       Normative References
  
   [802.1ah] "Virtual Bridged Local Area Networks Amendment 7: Provider
   Backbone Bridges", IEEE Std. 802.1ah-2008, August 2008.
  
   16.
       Informative References
  
   [PBB-VPLS] Sajassi et al., "VPLS Interoperability with Provider
   Backbone Bridges", draft-ietf-l2vpn-vpls-pbb-interop-00.txt, work in
   progress, September, 2011.
  
    [EVPN-REQ] Sajassi et al., "Requirements for Ethernet VPN (E-VPN)",
   draft-sajassi-raggarwa-l2vpn-evpn-req-00.txt, work in progress,
   October, 2010.
  
   [E-VPN] Aggarwal et al., "BGP MPLS Based Ethernet VPN", draft-
   raggarwa-sajassi-l2vpn-evpn-01.txt, November, 2010.
   , work in progress, June, 2010.
  
   17.
       Authors' Addresses
  
   Ali Sajassi
   Cisco
   170 West Tasman Drive
   San Jose, CA  95134, US
   Email: sajassi@cisco.com
  
   Samer Salam
  
  
   Sajassi, et al.                                           [Page 20]


                    draft-sajassi-l2vpn-pbb-evpn-03.txt
  
   Cisco
   595 Burrard Street, Suite 2123
   Vancouver, BC V7X 1J1, Canada
   Email: ssalam@cisco.com
  
   Sami Boutros
   Cisco
   170 West Tasman Drive
   San Jose, CA  95134, US
   Email: sboutros@cisco.com
  
   Nabil Bitar
   Verizon Communications
   Email : nabil.n.bitar@verizon.com
  
   Aldrin Isaac
   Bloomberg
   Email: aisaac71@bloomberg.net
  
   Florin Balus
   Alcatel-Lucent
   701 E. Middlefield Road
   Mountain View, CA, USA 94043
   Email: florin.balus@alcatel-lucent.com
  
   Wim Henderickx
   Alcatel-Lucent
   Email: wim.henderickx@alcatel-lucent.be
  
   Clarence Filsfils
   Cisco
   Email: cfilsfil@cisco.com
  
   Dennis Cai
   Cisco
   Email: dcai@cisco.com
  
   Lizhong Jin
   ZTE Corporation
   889, Bibo Road
   Shanghai, 201203, China
   Email: lizhong.jin@zte.com.cn
  
  
   Sajassi, et al.                                           [Page 21]