Re: [spring] AD Review of draft-ietf-spring-segment-routing-mpls-10

"Ahmed Bashandy (bashandy)" <bashandy@cisco.com> Fri, 01 December 2017 11:44 UTC

Return-Path: <bashandy@cisco.com>
X-Original-To: spring@ietfa.amsl.com
Delivered-To: spring@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 260DA128BA2; Fri, 1 Dec 2017 03:44:29 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -14.52
X-Spam-Level:
X-Spam-Status: No, score=-14.52 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_HI=-5, RCVD_IN_MSPIKE_H4=-0.01, RCVD_IN_MSPIKE_WL=-0.01, SPF_PASS=-0.001, USER_IN_DEF_DKIM_WL=-7.5] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=cisco.com
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 9MSaUAnImmfO; Fri, 1 Dec 2017 03:44:25 -0800 (PST)
Received: from alln-iport-1.cisco.com (alln-iport-1.cisco.com [173.37.142.88]) (using TLSv1.2 with cipher DHE-RSA-SEED-SHA (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id CE120128B90; Fri, 1 Dec 2017 03:44:23 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=cisco.com; i=@cisco.com; l=37223; q=dns/txt; s=iport; t=1512128663; x=1513338263; h=message-id:date:from:mime-version:to:cc:subject: references:in-reply-to; bh=mhAUWpRsAcSqIICRpgLrBpWyN3a5TWRU5T6a3GbGyTs=; b=TRYim1WWW9/4x3kbZRExpbuTVa/TCdyWZOKqmqRA1v10mfqqAtB3w48G ibeg0iUhUxgDP9LFHejXjyatWeDX4pZpvnThvipVSHommp++3FwXRSw/T rD89iEXxjhbeJVIYrE9yiXvG7Vxtzq04/2hkQU4Nu3klJXNDrXZ+0gbgk c=;
X-IronPort-AV: E=Sophos; i="5.45,344,1508803200"; d="scan'208,217"; a="38883996"
Received: from rcdn-core-7.cisco.com ([173.37.93.143]) by alln-iport-1.cisco.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 Dec 2017 11:44:23 +0000
Received: from [10.82.177.212] ([10.82.177.212]) by rcdn-core-7.cisco.com (8.14.5/8.14.5) with ESMTP id vB1BiLwm014586; Fri, 1 Dec 2017 11:44:21 GMT
Message-ID: <5A214094.4010105@cisco.com>
Date: Fri, 01 Dec 2017 03:44:20 -0800
From: "Ahmed Bashandy (bashandy)" <bashandy@cisco.com>
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:24.0) Gecko/20100101 Thunderbird/24.3.0
MIME-Version: 1.0
To: Alvaro Retana <aretana.ietf@gmail.com>
CC: SPRING WG <spring@ietf.org>, "spring-chairs@ietf.org" <spring-chairs@ietf.org>, "draft-ietf-spring-segment-routing-mpls@ietf.org" <draft-ietf-spring-segment-routing-mpls@ietf.org>, Martin Vigoureux <martin.vigoureux@nokia.com>
References: <74FB72FC-AD69-4EA3-ACA2-739168EE0A44@cisco.com> <aa2ed0f2b0a845cc83b16adda7566b37@XCH-ALN-001.cisco.com> <50d87236662f49bb8a81308dff6abbf5@XCH-RTP-020.cisco.com> <CAMMESswqFYQe_=zp8cPsuvvxMBFxUEe3t3DvkL=ZnZhA7RZO0w@mail.gmail.com> <CAMMESszXTnoii_dkSPf4iBdKXDtBVdHwApOVOocTMUc1cW0E_Q@mail.gmail.com>
In-Reply-To: <CAMMESszXTnoii_dkSPf4iBdKXDtBVdHwApOVOocTMUc1cW0E_Q@mail.gmail.com>
Content-Type: multipart/alternative; boundary="------------030106010600090000070805"
Archived-At: <https://mailarchive.ietf.org/arch/msg/spring/r0XAa9gu4mTXiNsLKjfQ37SIuo0>
Subject: Re: [spring] AD Review of draft-ietf-spring-segment-routing-mpls-10
X-BeenThere: spring@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: "Stacked Tunnels for Source Routing \(STATUS\)." <spring.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/spring>, <mailto:spring-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/spring/>
List-Post: <mailto:spring@ietf.org>
List-Help: <mailto:spring-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/spring>, <mailto:spring-request@ietf.org?subject=subscribe>
X-List-Received-Date: Fri, 01 Dec 2017 11:44:29 -0000

Les replied to that on the thread "[spring] AD Review of 
draft-ietf-spring-segment-routing-12"

So Les and I are still working to resolve some overlap between 
architecture document and sr mpls document and we hope to have new 
versions soon.

Ahmed


On 11/30/2017 2:26 PM, Alvaro Retana wrote:
> Ahmed:
>
> Hi!
>
> It’s been almost a month, and I haven’t seen a reply from you.
>
> I will send the document back to the WG by the end of this week.
>
> Thanks!
>
> Alvaro.
>
> On November 2, 2017 at 6:49:10 PM, Alvaro Retana 
> (aretana.ietf@gmail.com <mailto:aretana.ietf@gmail.com>) wrote:
>
>> On October 30, 2017 at 2:12:18 PM, Ahmed Bashandy (bashandy) 
>> (bashandy@cisco.com <mailto:bashandy@cisco.com> ) wrote:
>>
>> Ahmed:
>>
>> Hi!  How are you?
>>
>> ...
>>
>>> The main questions/concerns that I have related to this document is 
>>> not just for the authors, but for the Shepherd and the Chairs too.
>>>
>>> Q1. Why is this document on the Standards Track? From the 
>>> Introduction: “This drafts describes how Segment Routing operates on 
>>> top of the MPLS data plane.”  Describes, yes.  On the other hand, 
>>> the Shepherd’s write-up says that it “specifies the generic 
>>> functions of the architecture” – I don’t see a specification, just a 
>>> description.  As such, I think this document should be Informational.
>>>
>>> #Ahmed: The new version of the draft specifies many things that are 
>>> applicable to instantiation of SR over MPLS
>>>
>> I’ll take your answer as confirming that the old version (-10) wasn’t 
>> really specifying anything.
>>
>> For this new version (-11), can you please be specific on what these 
>> “many things” are?
>>
>> I see some new Normative Language in the new 2.x sub-sections.  I 
>> have some specific comments on that:
>>
>> Q1.A. Section 2.2. (SID Representation in the MPLS Forwarding Plane):
>>
>> The MCC MUST ensure that any label value corresponding to any SID it
>>     installs in the forwarding plane follows the following rules:
>>
>>     o  The label value MUST be unique within the router on which the MCC
>>        is running. i.e. the label MUST only be used to represent the SID.
>>
>>     o  The label value MUST NOT be identical to or within the range of
>>        any reserved label value or range [reserved-MPLS  <https://tools.ietf.org/html/draft-ietf-spring-segment-routing-mpls-11#ref-reserved-MPLS>], respectively.
>>
>>
>> These seem to be new requirements for the MCCs. Given that the protocol extensions (and LDP) are defined (in Section 2) as MCCs, how are they supposed to follow these rules, specially the first one? As far as I can tell, the IGP extensions (for example) can carry Label/SID information from an advertising node, so I don’t know how a local MCC (remote to that advertising node, which is locally "installing forwarding entries in the MPLS data plane”) can guarantee what the label is used for (“only used to represent the SID”). Maybe I’m missing something and this is already specified somewhere else…??
>> The second rule is just what the MPLS Architecture already specifies, 
>> no nothing new, right? BTW, the link in the reserved-MPLS reference 
>> doesn’t work — a better reference might be rfc3032 or rfc7274.
>>
>>
>> Q1.B. Section 2.3. (Segment Routing Global Block and Local Block):
>>
>> The following rules apply to the list of MPLS ranges representing the
>>     SRGB
>>
>>     o  The list of label ranges MUST only be used to instantiate global
>>        SIDs into the MPLS forwarding plane
>>
>>     o  Every range in the list of ranges specifying the SRGB MUST NOT
>>        cover or overlap with a reserved label value or range [reserved-
>>        MPLS], respectively.
>>       . . .
>>     Just like SRGB, the SRLB need not be a single
>>     contiguous range of label, except the SRGB MUST only be used to
>>     instantiate global SIDs into the MPLS forwarding plane.
>>
>> The first rule (and the text below them) points to the global nature 
>> of the SR *global* Block. The architecture document already says that 
>> "In SR-MPLS, SRGB is a local property of a node and identifies the 
>> set of local labels reserved for global segments.” Nothing new 
>> specified here.
>>              
>>
>>                                    
>> Q1.C. Section2.4. (Mapping a SID Index to an MPLS label) introduces an algorithm to calculate the label value.  Note that the architecture document now includes an algorithm (in Section 3.1.2) as well — the algorithm in this document doesn’t look to be the same, but even if it is, it would be confusing to specify the same thing in two places.
>>                    
>>                    
>>                    
>> Q1.D. The rest of the sub-sections seem to rehash forwarding behaviors, which, because of the fact that the MPLS architecture is not changing, seem to add nothing interesting or important to this document.
>>                    
>>
>> Having said all that, I still don’t see a clear justification for this document to be in the Standards Track.
>>                            
>>>
>>> Q2. Section 2. (MPLS Instantiation of Segment Routing) is the only 
>>> one with any real content…but there are only a couple of things in 
>>> it that are not in the Architecture document: the introduction of 
>>> the SRLB, and some words about the index – both of which should be 
>>> really explained in the Architecture document, and not here.  I 
>>> wonder what the value of publishing this document really is. What 
>>> long-term archival value does it provide?
>>>
>>> #Ahmed: The long term plan is to move details of MPLS-specific 
>>> specifications to this document and keep the architecture document 
>>> more general
>>>
>> The “long term plan” ??  What do you mean?  The architecture document 
>> is already in IETF Last Call — are you saying that both documents 
>> still require more changes and are not ready for publication?  I 
>> really hope that is not what you mean.
>>
>> In any case, you did not answer my question about the value of the 
>> document as is.  No worries, the intent is not to stop publication, 
>> but to understand whether there is something I’m missing and the 
>> relationship to the proposed Status.
>>
>>
>>> Q3. I also have to wonder about the IPR declared for this document.  
>>> If most of the information here is already defined, described or 
>>> specified in draft-ietf-spring-segment-routing, should the IPR 
>>> declaration apply to that document as well (or maybe instead of this 
>>> one)?  It is not the IETF’s role (including the WG) to discuss 
>>> whether a piece of IPR is valid or not – I just want to make sure 
>>> the disclosures apply to the right document.
>>>
>>> #Ahmed: We will make sure that all IPR is declared
>>>
>> That was not my question!   And declaring IPR at this point in time 
>> is very, very late (rfc6701).
>>
>>
>>> I didn’t find a discussion on the list about any of these points.
>>>
>> I am concerned about all the text that has been added (which in my 
>> opinion doesn’t contribute much to the document), resulting in about 
>> a 70% increase the document length!  I will wait for your answer to 
>> my points above before returning the document to the WG for a 
>> thorough review.
>>
>>
>> I have some other specific comments below.
>>
>> Thanks!
>>
>> Alvaro.
>>
>> ...
>>
>>> P3. Section 2. (MPLS Instantiation of Segment Routing) says that “a 
>>> controller-driven network…MAY use the control plane to discover the 
>>> available set of local SIDs”.  The “MAY” implies that there is a 
>>> choice (i.e. it is optional) and that other discovery mechanisms 
>>> exist.  What are those other choices?  Note that earlier in this 
>>> section you already wrote that IGPs are used for flooding the 
>>> information. s/MAY/may
>>>
>>> #Ahmed: This document gives an example of a use of the SRLB. Listing 
>>> all possible uses of the SRLB is certainly not within the scope of 
>>> this document.
>>>
>> I’m not sure what your answer has to do with my comment…but giving 
>> examples is a good reason to *not* use Normative language.
>>
>> In any case, that piece of text was not changed from:
>>
>> In a controller-driven network, some controllers or
>>     applications MAY use the control plane to discover the available set
>>     of local SIDs on a particular router.  In such cases, the SRLB is
>>     advertised in the control plane (e.g., using
>>     [I-D.ietf-isis-segment-routing-extensions  <https://tools.ietf.org/html/draft-ietf-spring-segment-routing-mpls-10#ref-I-D.ietf-isis-segment-routing-extensions>]).
>>
>>                  
>>   …to…
>>                        
>> In a controller-driven network, some controllers or
>>     applications MAY use the control plane to discover the available set
>>     of local SIDs on a particular router [I.D. filsfils-spring-segment-
>>     routing-policy].
>>
>> The “MAY” is still there (which was the main point of the comment above), and you added a new reference to apparently illustrate the point that the control plane can be used "to discover the available set of local SIDs on a particular router”.  Isn’t that already specified in the architecture document?  Why do we need this new reference?
>>                        
>>                        
>> ...
>>>
>>> P5. References. Please take a look at rfc8174 and update the 
>>> “Requirements Language” and associated references.
>>>
>>> #Ahmed: I agree. I modified the paragraph about requirements 
>>> language to conform to rfc8174
>>>
>> You forgot to include the rfc8174 reference.
>>
>>> Nits
>>>
>>> N1. I think that the references to *-segment-routing-extensions are 
>>> superfluous.  BTW, the fourth paragraph of the Introduction uses a 
>>> reference to *-segment-routing-extensions to point at ISIS/OSPF (the 
>>> protocols!).
>>>
>>> #Ahmed: I agree. Now we have clear references to each IGP extensions 
>>> separately
>>>
>> The point was that I think all references to the extensions are 
>> superfluous — not a request to add them.
>>