Re: [OSPF] Comments draft-ietf-ospf-segment-routing-extensions-00.txt

Acee Lindem <acee.lindem@ericsson.com> Wed, 09 July 2014 09:50 UTC

Return-Path: <acee.lindem@ericsson.com>
X-Original-To: ospf@ietfa.amsl.com
Delivered-To: ospf@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 44F561A03D0 for <ospf@ietfa.amsl.com>; Wed, 9 Jul 2014 02:50:19 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.901
X-Spam-Level:
X-Spam-Status: No, score=-1.901 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, SPF_PASS=-0.001] autolearn=ham
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 lOTu1_Z9ClG9 for <ospf@ietfa.amsl.com>; Wed, 9 Jul 2014 02:50:17 -0700 (PDT)
Received: from usevmg21.ericsson.net (usevmg21.ericsson.net [198.24.6.65]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 01B391A03CD for <ospf@ietf.org>; Wed, 9 Jul 2014 02:50:16 -0700 (PDT)
X-AuditID: c6180641-f79916d00000623a-a6-53bcbbad6570
Received: from EUSAAHC008.ericsson.se (Unknown_Domain [147.117.188.96]) by usevmg21.ericsson.net (Symantec Mail Security) with SMTP id DC.89.25146.DABBCB35; Wed, 9 Jul 2014 05:49:02 +0200 (CEST)
Received: from EUSAAMB101.ericsson.se ([147.117.188.118]) by EUSAAHC008.ericsson.se ([147.117.188.96]) with mapi id 14.03.0174.001; Wed, 9 Jul 2014 05:50:15 -0400
From: Acee Lindem <acee.lindem@ericsson.com>
To: Peter Psenak <ppsenak@cisco.com>, Anton Smirnov <asmirnov@cisco.com>
Thread-Topic: [OSPF] Comments draft-ietf-ospf-segment-routing-extensions-00.txt
Thread-Index: AQHPm1suriU3Kd577EqxpPjMGdPJdQ==
Date: Wed, 09 Jul 2014 09:50:14 +0000
Message-ID: <CFE25E61.325AD%acee.lindem@ericsson.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
user-agent: Microsoft-MacOutlook/14.4.2.140509
x-originating-ip: [147.117.188.11]
Content-Type: text/plain; charset="euc-kr"
Content-ID: <CA91926B32C8EE4BB562084FF42C7EE0@ericsson.com>
Content-Transfer-Encoding: base64
MIME-Version: 1.0
X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFvrELMWRmVeSWpSXmKPExsUyuXRPgu663XuCDZZ+5bBo2cZq0XLvHrvF jt3tbA7MHlN+b2T1WLLkJ1MAUxSXTUpqTmZZapG+XQJXxvL9a5kKtvUyVtx/8YqpgfFJJ2MX IyeHhICJxPW3u9ghbDGJC/fWs3UxcnEICRxllLjR/YMJwlnGKDH11BoWkCo2AR2J54/+MYPY IgIeEs9X7gTrZhaQlXi2rQksLiwQIPH2/iIgmwOoJlDixqxkiHI9iVltR1lBbBYBFYk3l0CW cXLwCphKPG19CHYQI9AR30+tYYIYKS5x68l8JojjBCSW7DnPDGGLSrx8/A9sjijQzOauN1DP KEl8/D0f6hwtiS8/9rFB2NYSkx7/YoGwFSWmdD9kh9grKHFy5hOWCYxis5Csm4WkfRaS9llI 2mchaV/AyLqKkaO0OLUsN93IcBMjMJKOSbA57mBc8MnyEKMAB6MSD6/Cwd3BQqyJZcWVuYcY pTlYlMR5NavnBQsJpCeWpGanphakFsUXleakFh9iZOLglGpglDyw6tPUE6p8oYJ7GgoulfCm nFj4neseW20k/+sV/DMvHnqjHfZm4v5HzK5ZK/lTXCduWeIhV35wXmZYgEj40wMG/3894RJL 6M74kcs+a/PS8+4znhq+/rlq0tvQ2jRTM9X8JQ0Vkw5eOtZQ+6l3xbZ5q2Q6W+Vir8oYP36/ 7UJ2gU3tzT6ldiWW4oxEQy3mouJEAIy8ceKFAgAA
Archived-At: http://mailarchive.ietf.org/arch/msg/ospf/NlkVZewIuw6baUqXkXREyFXEDJA
Cc: OSPF List <ospf@ietf.org>
Subject: Re: [OSPF] Comments draft-ietf-ospf-segment-routing-extensions-00.txt
X-BeenThere: ospf@ietf.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: The Official IETF OSPG WG Mailing List <ospf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/ospf>, <mailto:ospf-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/ospf/>
List-Post: <mailto:ospf@ietf.org>
List-Help: <mailto:ospf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ospf>, <mailto:ospf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 09 Jul 2014 09:50:19 -0000

Hi Peter, Anton, 

-----Original Message-----
From: Peter Psenak <ppsenak@cisco.com>
Date: Wednesday, July 9, 2014 at 1:21 AM
To: Anton Smirnov <asmirnov@cisco.com>, Ericsson <acee.lindem@ericsson.com>
Cc: OSPF - OSPF WG List <ospf@ietf.org>
Subject: Re: [OSPF] Comments
draft-ietf-ospf-segment-routing-extensions-00.txt

>Hi Anton,
>
>please see inline:
>
>
>On 7/9/14 09:35 , Anton Smirnov wrote:
>>     Hi Peter,
>>     I don't understand your answers. Let me give an example of encoding:
>>
>> Extended Prefix TLV
>>   192.0.2.1/32
>>      Prefix SID Sub-TLV
>>       Range 2
>>      SID/Label Binding sub-TLV
>>       Range 4
>>
>>
>> Extended Prefix TLV
>>   192.0.2.4/32
>>      Prefix SID Sub-TLV
>>       Range 1
>>      SID/Label Binding sub-TLV
>>       Range 1
>>
>> This is valid encoding per current text and it expands into:
>>
>> 192.0.2.1 - 1 SID 1 Binding
>> 192.0.2.2 - 1 SID 1 Binding
>> 192.0.2.3 - 1 Binding
>> 192.0.2.4 - 1 SID 2 Bindings
>>
>> Obviously this encoding is very difficult to work with because ranges
>> are different for attributes, because prefix 192.0.2.4/32 is served by
>> two ranges.
>
>the fact you have two SIDs or two Bindings for a single prefix is not a
>result of the current encoding. Moving the 'range' to top level TLV is
>not going to address it - you can have a top level TLV with
>192.0.2.1/32/4 and 192.0.2.4/32/1 resulting in the exactly the same
>situation.
>
>>
>>
>> It is more logical to define range as part of top-level TLV:
>>
>> Extended Prefix TLV
>>   Prefix/mask; Range
>
>as I mentioned in the previous email, we want to preserve the prefix
>representation by prefix/length in top-level TLV as that is sufficient
>for almost all attributes. If people do not like the range in the Prefix
>SID and SID/Label Binding sub-TLVs, then I prefer to define a new top
>level TLV that would be used to advertise attributes for a prefix block,
>which would be represented by prefix/length/count. I'm afraid it will
>not be used for anything except the Prefix SID & SID/Label Binding
>sub-TLV though - history shows we never needed such prefix block in the
>past.

Is this the only downside of a separate range top-level TLV? If so, then
it seems this would provide a cleaner encoding.I don¹t like allowing range
attributes and single prefix attributes to be mixed. Even with the current
encoding, we are going to have to handle the ambiguity of overlapping
ranges so I don¹t see a separate top-level TLV and adding more complexity.

Thanks,
Acee 


>
>thanks,
>Peter
>
>>      Prefix SID Sub-TLV
>>       SID
>>      SID/Label Binding sub-TLV
>>       Binding
>>
>> Anton
>>
>>
>> On 07/08/2014 10:04 PM, Peter Psenak wrote:
>>> Anton,
>>>
>>> please see inline:
>>>
>>> On 7/8/14 20:08 , Anton Smirnov wrote:
>>>>     Hi Peter,
>>>>     in current text ranges are not required to be processed and I
>>>>think
>>>> this kills their potential usage:
>>>>
>>>>     If multiple Prefix-SIDs are advertised for the same prefix, the
>>>>     receiving router MUST use the first encoded SID and MAY use the
>>>>     subsequent ones.
>>>
>>> I do not see any connection between ranges and the above text. Above
>>> text says that if there are multiple prefix SIDs advertised, for a
>>> single prefix, every implementation MUST process at least the first
>>>one.
>>> Typically only a single SID will be advertised for each prefix
>>> regardless of the range being 1 or more.
>>>
>>>>
>>>> (and similar text for inter-area LSA origination).
>>>>     Subsequent prefixes may be used or may be ignored. And if they are
>>>
>>> there are no subsequent prefixes. Each prefix is advertised in a
>>> separate top level TLV and will have it's own prefix-SID sub-TLV, only
>>> belonging to that prefix.
>>>
>>>> ignored then it is originator's fault, receiver has all rights to
>>>>ignore
>>>> them. If the mapping server wants to ensure every router installs
>>>>prefix
>>>> attributes then it has no choice but to break the range and advertise
>>>> each prefix individually.
>>>>     So IMO ranges processing must be required on every step, otherwise
>>>> they will never be used.
>>>>
>>>
>>> please see above.
>>>
>>>>
>>>>
>>>>
>>>>  > high level TLV advertise a single prefix/mask. It's the sub-TLV
>>>>which
>>>>  > may extend the applicability to the range if required, so the
>>>> scope is
>>>>  > defined by each sub-TLV.
>>>
>>> the way to look at it is that the top-level TLV always advertises a
>>> single prefix in a form of prefix/length. Nested sub-TLVs have their
>>>own
>>> data, which are interpreted based on the sub-TLV specification, they do
>>> not change what is in the top-level TLV. The fact that some sub-TLV has
>>> a count variable and use the prefix/mask as starting point makes no
>>> impact on the top-level data.
>>>
>>>>
>>>>     That what makes ranges counter intuitive. Intuitive hierarchy is
>>>> object on the top and then subordinate items describing properties of
>>>> the object:
>>>>
>>>> Object ---
>>>>           |
>>>>           |- attribute1
>>>>           |- attribute2
>>>>
>>>>
>>>> But the current scheme does not define object at the top of the
>>>> hierarchy, real object is defined together with property:
>>>>
>>>> Anchor ---
>>>>           |
>>>>           |- range-of-objects-and-attribute1
>>>>           |- range-of-objects-and-attribute2
>>>>
>>>> There are three problems with this representation:
>>>> 1. Anchor (i.e. top level TLV) is not enough to determine which
>>>>objects
>>>> (i.e. prefixes) are affected and which are not
>>>
>>> actually it is enough. We are not changing or replacing the top-level
>>> data. We are just using it differently - for prefix-SID sub-TLV the
>>> prefix/length in the top-level TLV is used as a 'start' object.
>>>
>>>> 2. Set of objects (i.e. the range) may be different in each sub-TLV
>>>>thus
>>>> raising concerns of ambiguity
>>>
>>> this does not introduce any more ambiguity then any other encoding
>>>which
>>> includes prefix/mask/count variables.
>>>
>>>> 3. Text requires that anchor is advertised only once but there is no
>>>> requirement that ranges advertised for different anchors cannot
>>>>overlap
>>>
>>> actually there is no reason why they can not overlap. We have overlaps
>>> today with prefix/mask semantics as well and we deal with them.
>>>
>>>>
>>>> It would have been more logical to define range in the "OSPF Extended
>>>> Prefix TLV" header itself, not in each sub-TLV. This specifies the
>>>> object (i.e. the range) in the topmost TLV and resolves problems
>>>> mentioned above.
>>>
>>> we wanted to preserve the prefix/length semantics well known from
>>> current OSPF. Making size mandatory would be a significant deviation
>>> from the current OSPF spec.
>>>
>>> Prefix-SID 'count' semantics is something specific to the SID and is
>>> more of an exception and IMHO should not force us to to deviate from
>>> representation we are used to work with.
>>>
>>> thanks,
>>> Peter
>>>
>>>
>>>
>>>>
>>>> Anton
>>>>
>>>>
>>>> On 07/03/2014 10:09 AM, Peter Psenak wrote:
>>>>> Hi Acee,
>>>>>
>>>>> please see inline:
>>>>>
>>>>> On 7/2/14 19:17 , Acee Lindem wrote:
>>>>>> Hi Peter,
>>>>>> It seems there are two distinct deployment scenarios - one where SR
>>>>>> routers are given a range and policy and allocate their own SIDs and
>>>>>> another where a mapping server does it for the routing domain.
>>>>>
>>>>> yes, that is correct. The latter is used mainly during migration from
>>>>> LDP to SR.
>>>>>
>>>>>
>>>>>
>>>>>>>>         6. Section 4.2 - I really don¹t like having his sub-TLV
>>>>>>>> redefine the subsuming top-level TLV as a range of prefixes of the
>>>>>>>> same length rather than a single prefix. Although this is my first
>>>>>>>> serious reading of the draft, this encoding seems really unwieldy
>>>>>>>> and, in practice, I¹d expect the range size always advertised as
>>>>>>>>1.
>>>>>>>> We can discuss this more in Toronto.
>>>>>>>
>>>>>>> an example where the range would be more then 1 is a mapping server
>>>>>>> case. This helps you to advertise SIDs for loopback addresses of
>>>>>>>all
>>>>>>> routers in a non-SR capable part of the network, assuming they are
>>>>>>> allocated from the contiguous address space. Instead of advertising
>>>>>>> hundreds of mappings for each /32 address, you can compact it to a
>>>>>>> single advertisement.
>>>>>>
>>>>>> I¹ve seen loopbacks allocated sequentially in a few networks but
>>>>>>many
>>>>>> more where there weren¹t.
>>>>>
>>>>> still, having a mechanism to compact the advertisements if possible
>>>>> looks appealing.
>>>>>
>>>>>>
>>>>>>>
>>>>>>> What you need in such case is component prefix/length plus the
>>>>>>>number
>>>>>>> of components - OSPF Extended Prefix TLV gives you the component
>>>>>>>info
>>>>>>> and Prefix SID Sub-TLV "Range Size' gives you the number of
>>>>>>> components.
>>>>>>
>>>>>> I understood it but I don¹t like the sub-TLV extending the
>>>>>> specification of the higher level TLV. I especially don¹t like it
>>>>>> since the top-level TLV is a generic mechanism to advertise
>>>>>> attributes.  When additional attributes are defined, it begs the of
>>>>>> whether or not they apply solely to the prefix or to the range.
>>>>>
>>>>> high level TLV advertise a single prefix/mask. It's the sub-TLV which
>>>>> may extend the applicability to the range if required, so the scope
>>>>>is
>>>>> defined by each sub-TLV.
>>>>>
>>>>>>
>>>>>>>
>>>>>>> We could have defined a separate top level TLV in OSPF Extended
>>>>>>> Prefix LSA for the advertisement of range of components, but it
>>>>>>>looks
>>>>>>> to me that would be an overkill.
>>>>>>
>>>>>> I would have preferred that. When the SID attributes are embedded
>>>>>> (OSPFv3 and ISIS), I think the semantics are even more unnatural
>>>>>>since
>>>>>> reachability MAY be advertised for the prefix while SID mapping is
>>>>>> being advertised for the range.
>>>>>
>>>>> I had the same reservations at the beginning :)
>>>>> But there is no problem really. Prefix-SID sub-TLV never advertises
>>>>>any
>>>>> reachability, whether it advertises a single SID or a range of SIDs.
>>>>> For
>>>>> Prefix-SID sub-TLV, prefix from the higher level TLV has a meaning of
>>>>> "start" and Prefix-SID sub-TLV always carry its own "size" - just a
>>>>> different interpretation of the data from the higher level TLV.
>>>>>
>>>>> Please note that SID range is quite different from the address range
>>>>>we
>>>>> are used to from summarization. SID range requires three parameters
>>>>> (address/mask and count), compared to two parameter (address/mask)
>>>>>that
>>>>> traditional address range uses. As a result, Extended prefix TLV as
>>>>> such
>>>>> can not cover the SID range, because it only has address/mask.
>>>>>Defining
>>>>> a top-level TLV for a SID range itself does not really fit into
>>>>> Extended
>>>>> Prefix LSA and having a new LSA for it is not an option I would say.
>>>>>So
>>>>> the current encoding looks like a good compromise to me.
>>>>>
>>>>> thanks,
>>>>> Peter
>>>>>
>>>>>>
>>>>>>> Current encoding of Prefix SID Sub-TLV gives us all the flexibility
>>>>>>> we need. In addition it matches what ISIS has done.
>>>>>>
>>>>>> I haven¹t seen any discussion of the draft on the ISIS list other
>>>>>>than
>>>>>> the revision updates.
>>>>>>
>>>>>> Thanks,
>>>>>> Acee
>>>>>>
>>>>>>
>>>>>>
>>>>>>>
>>>>>>>
>>>>>>>>
>>>>>>>>         7. Section 4.2 - Shouldn¹t the reference for the mapping
>>>>>>>> server be the ³Segment Routing Architecture² rather than the
>>>>>>>> ³Segment Routing Use Cases²? In general, the usage of a mapping
>>>>>>>> server and the scope of assignment needs to be described better
>>>>>>>> somewhere (not in the OSPF encoding document).
>>>>>>>
>>>>>>> will fix the reference
>>>>>>>
>>>>>>>>
>>>>>>>>         8. Section 6 - It would seem that an entity calculating a
>>>>>>>> multi-area SR path would need access to the topology for all the
>>>>>>>> areas and the SID would need to be globally assigned? Right?
>>>>>>>
>>>>>>> correct.
>>>>>>>
>>>>>>>> So rules are primarily for the population of the forwarding plane.
>>>>>>>> Right?
>>>>>>>
>>>>>>> for advertisement/propagation of SIDs and for forwarding plane
>>>>>>> programming.
>>>>>>>
>>>>>>>>
>>>>>>>>         9. Section 6.2 - In standard OSPF, inter-area summary
>>>>>>>> propagation only applies to inter-area routes learned over the
>>>>>>>> backbone. Is this any different?
>>>>>>>
>>>>>>> no, the mechanism is the same as for type-3s.
>>>>>>>
>>>>>>> thanks,
>>>>>>> Peter
>>>>>>>
>>>>>>>>
>>>>>>>> Thanks,
>>>>>>>> Acee
>>>>>>>>
>>>>>>>>
>>>>>>>>
>>>>>>>> .
>>>>>>>>
>>>>>>>
>>>>>>
>>>>>> .
>>>>>>
>>>>>
>>>>> _______________________________________________
>>>>> OSPF mailing list
>>>>> OSPF@ietf.org
>>>>> https://www.ietf.org/mailman/listinfo/ospf
>>>> .
>>>>
>>>
>> .
>>
>