[bess] Comments on draft-sajassi-bess-evpn-mvpn-seamless-interop

Eric C Rosen <erosen@juniper.net> Thu, 09 November 2017 17:42 UTC

Return-Path: <erosen@juniper.net>
X-Original-To: bess@ietfa.amsl.com
Delivered-To: bess@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 7F259127B60 for <bess@ietfa.amsl.com>; Thu, 9 Nov 2017 09:42:43 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.02
X-Spam-Level:
X-Spam-Status: No, score=-2.02 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=juniper.net
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id a_K5N45LnhhH for <bess@ietfa.amsl.com>; Thu, 9 Nov 2017 09:42:34 -0800 (PST)
Received: from NAM03-DM3-obe.outbound.protection.outlook.com (mail-dm3nam03on0103.outbound.protection.outlook.com [104.47.41.103]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id A4C4112726E for <bess@ietf.org>; Thu, 9 Nov 2017 09:42:33 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=juniper.net; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=WR/7Aq2LAz3xtf1dRHVgmyhNK1uAC50FOYO6LAxW0ZU=; b=NfPM+Od8lx2l4QT9AMfte2m/lUpAg14JQUMOjC1CnSIZvU98Yj0W/TlnObyT8v/kBUvcUjfPkkqlFPviVEScgq0JmSy9VTl+E1SGkWGlBxUer0JrswlMNaeoR9MPAj3XOYc3HR93fejqTBwlhJd3lC/pYsYEpd+fJptKnDeAjSU=
Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=erosen@juniper.net;
Received: from [172.29.35.192] (66.129.241.13) by CY1PR05MB2299.namprd05.prod.outlook.com (10.166.192.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.218.6; Thu, 9 Nov 2017 17:42:30 +0000
From: Eric C Rosen <erosen@juniper.net>
To: Bess WG <bess@ietf.org>
Message-ID: <d1e53751-289d-6ac9-d019-2fe07cc33602@juniper.net>
Date: Thu, 09 Nov 2017 12:42:26 -0500
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0
MIME-Version: 1.0
Content-Type: multipart/mixed; boundary="------------1240AD04C029E1854EA51A69"
Content-Language: en-US
X-Originating-IP: [66.129.241.13]
X-ClientProxiedBy: MWHPR19CA0085.namprd19.prod.outlook.com (10.175.0.151) To CY1PR05MB2299.namprd05.prod.outlook.com (10.166.192.145)
X-MS-PublicTrafficType: Email
X-MS-Office365-Filtering-Correlation-Id: 54411441-27d1-4223-d111-08d5279940d3
X-MS-Office365-Filtering-HT: Tenant
X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(4534020)(4602075)(4627115)(201703031133081)(201702281549075)(48565401081)(2017052603199)(49563074); SRVR:CY1PR05MB2299;
X-Microsoft-Exchange-Diagnostics: 1; CY1PR05MB2299; 3:T0g/kpsysFB1z3z9rNzoFxtKpKpgAIgvco5L7OxsOUXVCqMogXittJmHkkB16FJbZx1LsokmwPwvljqd1Gd9ASKFdKdPj//4GumjRBQMR6lqgXMiKDU5RHUFAnzHrOEmApRWy6jTJ1dwKcVbn9zYEWbBRKsGWQlHvDPFVANJdFe2Rf8uo4OpJaLYPZcsCQWJ6SDC9mn0M37dL3bx4QCsHSqAwaemAx7pU3Ygx1sTRfw3b2OrTCSKvOykhunL3fTv; 25:mZa8yhZE5X73QO05TMPA9WELZ23IqF+e6DEFIWFSCSy4tJ40hYPNDwAzExOv4TmPmkxn5P/LbVevmW3riUbpvC1ky5vo75VTOiDYi6biD1moOJ9ylcosxJSuquuXZ8rgPUcFWwc/MRfskpdMGsqTnRl0CI8skNg1Y/68CFwzhQGQWXCeAOSqlm8xYpFpiAEHpQRpE1oA8Bf4qRB1x/IKrMBgVmRLeFPmnRVFfJQEB3xoRO3PpXhoUSCvpBJgwgwTK1viVsH5Ioc00hidQeS22/AiVxQGKsEIXvn4c4wGaTsuZ4Ebhw0589+OvQTBoTwebeArS+CuldFCIMUTtK52TA==; 31:9iCT+9ZBKUTjS6WNKGKQKbx4XG/1ShSkCiDmjCVVhI2pV2Mx1WRIfMmADc/MJoTsb18sndt5QDccrnXBv4pi1lotFZpbaQOHEc5W9ay15qfmxchKIeSoWal2HF64z5eVGN5xxt1C7Ikp1yfEcI+0XNp+exkWVsc3eYXLVpmbS4KDRVy+x0Sm9zENYS1fov8nH5Fz3cn6LGHYSLLAxFheYliyA2SxaI6IqN9ePDZfBj0=
X-MS-TrafficTypeDiagnostic: CY1PR05MB2299:
X-Microsoft-Exchange-Diagnostics: 1; CY1PR05MB2299; 20:681VPD3Q2G62Sw+GMMytXwD2zybaVxrqihEr1bJRXQF+YC1dPRNKaUAVJ/khXTOk1WNzgX7Q2cv6/y0k39Jz3oULgH1x98aeYOWQLoj/uSKZ1d4kqVBPXMWtnlEw8326h3vKsuj7HD6DzENP7mh0+FakZCmOkaUqwPPimKWOwHR/0BDScJG9Gj0+EOqcyU1Mu3D9+0EaT1qaLlarIUtHKx5sAxU2U1kkvjuKvhJAVSy7tvPsZgmRPaTbrwlqEtqmRM1YAdn0mG9cPmmbM03PcmYUASytBiowDIcVw8LCMNpAP8PhxeHDBC0ZoLaNXd9W+R0sbrVwJ9R2/qFyxEgCj2nUD4CVYiSjZHu7pWOYRj/kctxo9txM1RE0xO4Yloo/ZQ2kE0eT73gcSRkocX29fQmq96EUs26/8uG0FdXUHnmfMIEopUGygYIjTBsAETdHRt0dk8f5U34bE96tuDitO1P9FFm3CNzOtdl0hLHUzFmdg0GF3xCUrQ/zH6z2122wcQ/5FU2sGEfoJWoj+wri6ED0USjZLpXOnO9cOTVZ/90OKhJsZNR4cqUQNfG3PBZxUuiREVrGZrXxoxxKo4NdeAHxU3OYUi+DKclpWCa9jcs=; 4:MGQpGGiDuG3fCQNNvFVE/zC//zGA97sMsO5DYkil/vV/vjIHf3mFHowJVph+AXwi13LENbUzf2ORXkz1I1GcLw6lhgXfHmfaawP7VlVzfOiKvDBPqPdHDVFctGvURviSL2yNYq6gOEnOH23VfYT9krshk8Ged1UqLb1EYI3i3t4cbp4G1Cet25Z787DlgZMpEE5X3q7dxrfNdAffNtrEjvQFAJnIzcNRCpVFZqjeCwgHh2mfoU3nN5Picn6NymatXauJmak2rsYtFWxUIa1aCJJjyWUxNirqkI5UtTjyYJrCMYNIo2Im7urHLd3RPbnv
X-Exchange-Antispam-Report-Test: UriScan:(278428928389397);
X-Microsoft-Antispam-PRVS: <CY1PR05MB22993F0F9673FCF7626B6760D4570@CY1PR05MB2299.namprd05.prod.outlook.com>
X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(102415395)(6040450)(2401047)(8121501046)(5005006)(100000703101)(100105400095)(10201501046)(93006095)(93001095)(3002001)(3231021)(6055026)(6041248)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123558100)(20161123564025)(20161123555025)(20161123562025)(20161123560025)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:CY1PR05MB2299; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:CY1PR05MB2299;
X-Forefront-PRVS: 0486A0CB86
X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10019020)(6009001)(6049001)(346002)(376002)(39860400002)(51444003)(199003)(189002)(37854004)(84326002)(86362001)(6116002)(568964002)(3846002)(8936002)(25786009)(2906002)(7736002)(305945005)(50986999)(3260700006)(31686004)(33646002)(561944003)(54356999)(189998001)(478600001)(101416001)(105586002)(2476003)(21480400003)(106356001)(90366009)(6486002)(65826007)(4610100001)(77096006)(97736004)(64126003)(230783001)(81166006)(68736007)(8676002)(6916009)(16526018)(81156014)(5660300001)(66066001)(6666003)(65806001)(58126008)(31696002)(53936002)(16586007)(83506002)(5890100001)(36756003)(16576012)(37036004)(65956001)(316002); DIR:OUT; SFP:1102; SCL:1; SRVR:CY1PR05MB2299; H:[172.29.35.192]; FPR:; SPF:None; PTR:InfoNoRecords; A:1; MX:1; LANG:en;
Received-SPF: None (protection.outlook.com: juniper.net does not designate permitted sender hosts)
X-Microsoft-Exchange-Diagnostics: 1; CY1PR05MB2299; 23:7XnZ5WrZcwe7Rjd6MGiX50I2nme82h50Mg3yXBINcUmA77ckjQ/dJpovi3T2t5TOlwgEg7bha/4E0cxCHPBEamXJvHhB2wAef9qdmHzPxFza1aP+Ocko3mIcDK3Pn659HBTg+oZQmFc9hER/OolMAhQ5AzxJKm2pzy5rKzQVnnmWWZv4DKuOQqAhtFLxyt5y3qeppIIhQOea5M5yM0Vr35TgzRgJOf+76Wix4JE0WAr+f9KbEQ3Qo5tOROg1Djn3yAHBF/l1xjJCSQl0ewwKuuCQ5ioFrZYZBHoAKeUO/jT5W0t7qjWjPa1mMDHwMalnDef/ytVdx5NzLuBWw/Ogdp6TMcAzPpRtD0xQIX6b48FnaK4A7N2s9OVpLWn+oPtDGfMZuCd7eRd3eVQzuwlSMiJx/ZxLed8PllgSLHmAo0AUdi2cHnTXHnzst8vaJ9WOqZlWG4/Ocv2Y0RDr8Xd9Kz5qMwJ73FDkGnsL4YzONe13irC5R2U7BnlGqzbfiUYKDfcrf+aJBUotxxuM8Egq6Eps6hlI1mfmwfZnu1o8ijHfU8LpgLTZ7YqqVFkT4NC3C2Rr/CIyefvEsWHQC+riFEQV6bwwjOoj8uN77jdMG30QnhJQ87Hv8v5Xn5zkGL+s04k4PEe004qJ486uEmQmGEMl/LFtKiQASxRJUrt8RJQfxK4GNFUxAMn8QgkwbmuthloxBIpnyy1qKc70mL+Dhh8+LWQlUWaCb5/q/HTSZ/EwXlS2IO3phiJQtGAIB4oCKJNzdxDVYkj991+25epdNoqA47UknWWaLtwsbXJ2wli8xOiUYoi4KCuFS+rc2u/kMsNn6KhQRohMAByl/xa4lmTDqG17geahX2MAe5RK4BJwSmkD5dHwdtz6S+cmAIaZWPOg7Gg6MwgfDKEZGbJk/ReEr/mVMGJZCgQzmAwQsP0bzkYFypqWdufAJGwwv3lMDKBa7qhmOwME6ZSfhbVK2v72VqD89dmQMd8+v8ppqqiiIJPuW3Tr+8lFxmUUwk1sQnhCQ3bBxhkVp+ZYj3j6T64H/S+ql0z2nhNm8zpDDrmC3Kn6IW/evAjtrUxpBZEdQ+5UZuHynKkNFdC45en2+DWORVNopMZXH9NDDVvbws/llPV99kMKHNTmhlPGsfPv+4KSqdES6gbWsPdhIvAfihdud0eO7yprfwdcXJuvEPgQEcKH0b2vxxa/v2wzFuG8YcFPKDnaHIRWInjVo8o5PhBHXY3IWTc2nSScoum05tYI6Kg/a/2E+m6isQFFD2FVCe6cjHgcqjTLHvLyWqx5pqCQ3sdiO757W9tpp/b+ktpzhGYtuCd1mZzhc4WgAkYGaWOlsPhwJHlD66rJ5LoLCnv1Be2jkcsjiC7lyQm10tjSaRLWyn3hsRO5C7DkPTIpc8yqpHvOuLdBnePlz3XPig==
X-Microsoft-Exchange-Diagnostics: 1; CY1PR05MB2299; 6:ld2VorDDmKlMfstDBkdD/7aYX/wK21Qp2J3HbRdfQzJpJFzf5bGA2XuyFjHp6fTOT36QIjjz9/bYyyiMoXV/4Z2ZYO42z05w2zlRxxk7BN/zrVKydM3qnPG3SmK9eD/FNNnwA/XapaUtPMCq3ECMewjCMRC2KEMrAKlG7Rn2bPfYRJFxFkilYPzO3hDKjDW9fgM4Ya64gONjGARQxd8pwEqr//qIPLairzBlXC0fla3dvHcBFIJjJ1q3v0m/eT1vyCGgjwtVWoWut+stCpBPOPqdJQ07B8ebGm5SykQYLfOt8zp4C05ks2x9xYBMiTjPNTAdKKpK2YLQQl4NFYvL5khNxZgUozLM0OJww3cPMBw=; 5:9LtUG5UiX1s3Cdp4tR5q4oVAHmvngmf9X2KFvyS2jKeRJ8zse3uw8OAK6Dp3q13wd0mwXKTDztuEhUQg09Ooy9H48H2S3zvS41UoScV8rNGzJrDoG3+FM0tqiJ7BHyinlDjG3UE6pknyRnqQ8G0No6fGrs7W1w9KrVulsqV/Tn0=; 24:doCjGWroOUeH/jNKAv2gq60rjyOIIqxtJgV8GwzRVow4YqHQmbvm7gWJE4dYSt8qAFVXEaUOtL4xYxwTE4jRQVfzmD1DR54oM5tiyBjL1NU=; 7:je+ZD3p4VufkxWM/4HT07ffHc3eam++LVAvpKtbjS/V5IIjVR5rWyqQh8GJgYjMNCwxiZQbOym3W4gjwNheRwAdkjlGKaKIZa4U4D5aNLZhuSWbGD21Zl+qc7I1O2pDDJLM+yAE6AYL+OfD2cODvXsKkNRYP4PeVcZDM81nk8ryeNkUByYWkxLAhM1gpPv3Bmsmjb23weu1xVnJqVoMunpASu/E+fQYRsWB5n9AHlYhJ6/U0vf/5XKvcPfbER+AZ
SpamDiagnosticOutput: 1:99
SpamDiagnosticMetadata: NSPM
X-OriginatorOrg: juniper.net
X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Nov 2017 17:42:30.7958 (UTC)
X-MS-Exchange-CrossTenant-Network-Message-Id: 54411441-27d1-4223-d111-08d5279940d3
X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted
X-MS-Exchange-CrossTenant-Id: bea78b3c-4cdb-4130-854a-1d193232e5f4
X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY1PR05MB2299
Archived-At: <https://mailarchive.ietf.org/arch/msg/bess/7HalVZMyTGZ5vGUFwCpg_8O7dGg>
Subject: [bess] Comments on draft-sajassi-bess-evpn-mvpn-seamless-interop
X-BeenThere: bess@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: BGP-Enabled ServiceS working group discussion list <bess.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/bess>, <mailto:bess-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/bess/>
List-Post: <mailto:bess@ietf.org>
List-Help: <mailto:bess-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/bess>, <mailto:bess-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 09 Nov 2017 17:42:43 -0000

I have a number of comments on 
draft-sajassi-bess-evpn-mvpn-seamless-interop.

1. It seems that the proposal does not do correct ethernet emulation.  
Intra-subnet multicast only sometimes preserves MAC SA and IP TTL, 
sometimes not, depending upon the topology.  TTL handling for 
inter-subnet multicast seems inconsistent as well, depending upon the 
topology.  The proposal exposes the operator's internal network 
structure to the user, and will cause "LAN-only" applications to break.  
These concerns are acknowledged, then quickly dismissed based on wishful 
thinking.  (In my experience, wishful thinking doesn't work out very 
well in routing.)

2. In order to do inter-subnet multicast in EVPN, the proposal requires 
L3VPN/MVPN configuration on ALL the EVPN PEs.  This is required even 
when there is no need for MVPN/EVPN interworking. This is portrayed as a 
"low provisioning" solution!

3. The draft claims that the exact same control plane should be used for 
EVPN and MVPN, despite the fact that MVPN's control plane is unaware of 
certain information that is very important in EVPN (e.g., EVIs, 
TagIDs).  (This is largely responsible for point 1 above.) This is 
claimed to be a way of providing a "uniform solution".  As we examine 
the problems that arise, perhaps this will be seen as more a case of 
"pounding square pegs into round holes".  When interworking between two 
domains, generally one gets a more flexible and robust scheme by 
maintaining clean interfaces and having well-defined points of 
attachment, not by entangling the internal protocols of one domain with 
the internal protocols of the other.

4. The draft proposes to use the same tunnels for MVPN and EVPN, i.e., 
to have tunnels that traverse both the MVPN and the EVPN domains.  
Various "requirements" are stated that seem to require this solution.  
Somewhere along the line it was realized that this requirement cannot be 
met if MVPN and EVPN do not use the same tunnel types.  So for this very 
common scenario, a completely different solution is proposed, that (a) 
tries to keep the EVPN control plane out of the MVPN domain, and vice 
versa, and (b) uses different tunnels in the two domains.  Perhaps the 
"requirements" that suggest using a single cross-domain tunnel are not 
really requirements!  And why would we want different solutions for 
different deployment scenarios?  Yes, the solution needs to handle all 
the use cases, but we don't want to look at the use cases one at a time 
and design a different solution for each one.

While the authors have realized that one cannot have cross-domain 
tunnels when EVPN uses VxLAN and MVPN uses MPLS, they do not seem to 
have acknowledged the multitude of other scenarios in which cross-domain 
tunnels cannot be used.  For instance, MVPN may be using mLDP, while 
EVPN is using IR.  Or MVPN may be using RSVP-TE P2MP while EVPN is using 
AR.  Etc., etc.  I suspect that "different tunnel types" will be the 
common case, especially when trying to interwork existing MVPN and EVPN 
deployments.

The inability to use EVPN-specific tunnels also causes a number of 
specific problems when attempting to interwork with MVPN; these will be 
examined below.


5. A number of the draft's stated "requirements" seem to be entirely bogus.

a. In some cases, the "requirements" for optimality in one or another 
respect (e.g., routing, replication) are really only considerations that 
an operator should be able to trade off against other considerations.  
The real requirement is to be able to create a deployment scenario in 
which such optimality is achievable.  Other deployment scenarios, that 
optimize for other considerations, should not be prohibited.

b. Many of the "requirements" are applied very selectively, e.g., the 
"requirement" for MVPN and EVPN to use the same set of multicast 
tunnels, and the requirement for there to be no "gateways".


6. The gateway-based proposal for interworking MVPN and EVPN when they 
use different tunnel types is severely underspecified.

One possible approach to this would be to have a single MVPN domain that 
includes the EVPN PEs, and to use MVPN tunnel segmentation at the 
boundary. While that is a complicated solution, at least it is known to 
work. However, that does not seem to be what is being proposed.

Another approach would be to set up two independent MVPN domains and 
carefully assign RTs to ensure that routes are not leaked from one 
domain to another.  One would also have to ensure that the boundary 
points send the proper set of routes into the "other" domain.  (This 
includes the unicast routes as well as the multicast routes.)  And one 
would have to include a whole bunch of applicability restrictions, such 
as "don't use the same RR to hold routes of both domains".  I think 
that's what's being proposed, but there isn't enough discussion of RT 
and RD management to be sure, and there isn't much discussion of what 
information the boundary points send into each domain.

7. The proposal requires that EVPN export a host route to MVPN for each 
EVPN-attached multicast source.  It's a good thing that there is no 
requirement like "do not burden existing MVPN deployments with a whole 
bunch of additional host routes".  Wait a minute, maybe there is such a 
requirement.

In fact, whether the host routes are necessary to achieve optimal 
routing depends on the topology.  And this is a case where an operator 
might well want to sacrifice some routing optimality to reduce the 
routing burden on the MVPN nodes.

8. The proposal simply does not work when MVPN receivers are interested 
in multicast flows from EVPN sources that are attached to all-active 
multi-homed ethernet segments.

This issue is worth examining in detail.

Suppose EVPN-PE1 and EVPN-PE2 are both attached to the same ethernet 
segment, using all-active multi-homing.  Suppose there is a multicast 
source S on that segment.  In such a case, (S,G1) traffic might arrive 
at PE1, while (S,G2) traffic might arrive at PE2. (Which PE gets a 
particular flow from S depends on LAG hashing algorithms over which we 
have no control.)  Now suppose that an MVPN PE, say PE3, needs to 
receive (S,G1) traffic.

MVPN requires PE3 to select the "Upstream PE" for the (S,G1) traffic.  
PE3 does this by looking at the VRF Route Import EC on its best route to S.

In order to receive the (S,G1) traffic, PE3 must select PE1, rather than 
PE2, as the Upstream PE.  However, there is absolutely nothing in the 
MVPN specs or in this document to ensure that PE3 selects PE1 rather 
than PE2. Generally, an MVPN node will select PE2 if it is closer to PE2.

Perhaps the authors are under the impression that MVPN Source Active A-D 
routes can be used to solve this problem.  That is not so. Vanilla MVPN 
nodes do not generally base their selection of the Upstream PE for (S,G) 
on the SA A-D routes.

Let me explain a little about the way SA A-D routes are used.  There are 
two different MVPN "modes" that affect the use of SA A-D routes.

In one mode (sometimes known as 'rpt-spt' mode, and described in Section 
13 of RFC 6514), an SA A-D route for (S,G) is originated by a PE when 
that PE receives a C-multicast route for (S,G).

In another mode (sometimes known as 'spt-only' mode, and described in 
Section 14 of RFC 6514), an SA A-D route for (S,G) is originated by a PE 
when that PE receives a PIM Register message for (S,G), or when that PE 
receives an MSDP SA message for (S,G).  Note that in this mode, the PE 
originating the SA A-D route is not necessarily the best (or even a 
good) ingress PE for the flow.

- In both modes, if an egress PE receives a PIM Join (S,G) from a CE, 
its choice of ingress PE is never impacted by the SA A-D routes.  Note 
that CEs send PIM Join(S,G) messages for both ASM and SSM groups.

- In spt-only mode, the SA A-D routes are used to discover sources, but 
not to select the ingress PE. (The selected ingress PE is not 
necessarily the one originating the SA A-D route.)

- The choice of ingress PE is impacted by the SA A-D routes for (S,G) 
only when (a) rpt-spt mode is being used, (b) the egress PE has received 
a PIM Join (*,G) from a CE, and (c) the egress PE has not received a PIM 
Join (S,G) from a CE.  This is typically just a transient state, as the 
CE will generally emit a PIM Join(S,G) as soon as it sees any (S,G) traffic.

Bottom line: if a source is on an EVPN all-active multi-homed segment, 
MVPN receivers have no way to select the proper ingress PE.  If the 
segment is n-way-homed, the MVPN PEs have just a 1/n chance of getting 
the traffic.

Of course, this problem could be eliminated if EVPN and MVPN didn't have 
to use the same tunnels.  In that case, if an MVPN node selects the 
wrong ingress PE, the selected PE could obtain the traffic from the real 
ingress PE, and then relay it to the MVPN node.  This might result in 
sub-optimal routing, but that's better than a black hole!

Perhaps the gateway-based solution needs to be used whenever there is 
all-active multi-homing? ;-)

One could imagine modifying the MVPN installed based so that the SA A-D 
routes play more of a role in selecting the Upstream PE. However, I 
believe the requirement is to allow MVPN/EVPN interworking without 
modifying the existing MVPN nodes.

9. In the case where all the multicast sources for a given group are 
attached via EVPN, there is a very simple procedure for providing 
Join(*,G) functionality.  This procedure makes use of EVPN-specific 
knowledge.  Since the MVPN protocols cannot take advantage of the 
EVPN-specific knowledge, a more complicated procedure is needed when 
only MVPN protocols are used.  This is explained further in the in-line 
comments.

10. Most of the problems above are the result of (a) trying to use the 
exact same control plane for both MVPN and EVPN, and (b) treating the 
case where both domains use the same tunnel type as the design center.  
It would be better to keep clean interfaces between EVPN and MVPN, with 
clearly defined points of attachment.  The proposal in 
draft-lin-bess-evpn-irb-mcast does this, and thus does not run into the 
above problems.  That proposal also shows how the "optimal routing" 
requirements can be met, and how they can be traded off against other 
considerations. (In fairness, it must be acknowledged that both 
proposals are still works in progress.  It's also worth noting that the 
two proposals have a lot in common.)

A number of additional comments can be found in-line in the attachment.  
(I realize that some of them are repetitive, sorry.) Look for lines 
beginning "****".  The above comments are also repeated at the front of 
the attachment.