Re: [Pce] Comments on draft-ietf-pce-gmpls-pcep-extensions-08

"Margaria, Cyril (Coriant - DE/Munich)" <cyril.margaria@coriant.com> Thu, 25 July 2013 14:41 UTC

Return-Path: <cyril.margaria@coriant.com>
X-Original-To: pce@ietfa.amsl.com
Delivered-To: pce@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id BFA9F21F9A8F for <pce@ietfa.amsl.com>; Thu, 25 Jul 2013 07:41:55 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.566
X-Spam-Level:
X-Spam-Status: No, score=-2.566 tagged_above=-999 required=5 tests=[AWL=1.032, BAYES_00=-2.599, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_LOW=-1]
Received: from mail.ietf.org ([12.22.58.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id xt1VMtENqD6i for <pce@ietfa.amsl.com>; Thu, 25 Jul 2013 07:41:50 -0700 (PDT)
Received: from ch1outboundpool.messaging.microsoft.com (ch1ehsobe001.messaging.microsoft.com [216.32.181.181]) by ietfa.amsl.com (Postfix) with ESMTP id 028B421F8F6D for <pce@ietf.org>; Thu, 25 Jul 2013 07:41:49 -0700 (PDT)
Received: from mail193-ch1-R.bigfish.com (10.43.68.250) by CH1EHSOBE019.bigfish.com (10.43.70.76) with Microsoft SMTP Server id 14.1.225.22; Thu, 25 Jul 2013 14:41:45 +0000
Received: from mail193-ch1 (localhost [127.0.0.1]) by mail193-ch1-R.bigfish.com (Postfix) with ESMTP id B07D1380087; Thu, 25 Jul 2013 14:41:45 +0000 (UTC)
X-Forefront-Antispam-Report: CIP:157.56.253.53; KIP:(null); UIP:(null); IPV:NLI; H:DB3PRD0411HT002.eurprd04.prod.outlook.com; RD:none; EFVD:NLI
X-SpamScore: -24
X-BigFish: PS-24(zz9371Ic89bhc85dh1418I31c5I1447Izz1f42h208ch1ee6h1de0h1fdah2073h1202h1e76h1d1ah1d2ah1fc6hzz1d7338h1de098h1033IL17326ah18c673h1c8fb4h1de097h1de096h8275bh8275dhz2fh2a8h668h839hd25hf0ah1288h12a5h12bdh137ah1441h1504h1537h153bh15d0h162dh1631h1758h18e1h1946h19b5h19ceh1ad9h1b0ah1bceh1d07h1d0ch1d2eh1d3fh1de9h1dfeh1dffh1e1dh1155h)
Received-SPF: pass (mail193-ch1: domain of coriant.com designates 157.56.253.53 as permitted sender) client-ip=157.56.253.53; envelope-from=cyril.margaria@coriant.com; helo=DB3PRD0411HT002.eurprd04.prod.outlook.com ; .outlook.com ;
Received: from mail193-ch1 (localhost.localdomain [127.0.0.1]) by mail193-ch1 (MessageSwitch) id 1374763295220589_1854; Thu, 25 Jul 2013 14:41:35 +0000 (UTC)
Received: from CH1EHSMHS031.bigfish.com (snatpool1.int.messaging.microsoft.com [10.43.68.249]) by mail193-ch1.bigfish.com (Postfix) with ESMTP id 30BFF30004A; Thu, 25 Jul 2013 14:41:35 +0000 (UTC)
Received: from DB3PRD0411HT002.eurprd04.prod.outlook.com (157.56.253.53) by CH1EHSMHS031.bigfish.com (10.43.70.31) with Microsoft SMTP Server (TLS) id 14.16.227.3; Thu, 25 Jul 2013 14:41:34 +0000
Received: from DB3PRD0411MB427.eurprd04.prod.outlook.com ([169.254.6.251]) by DB3PRD0411HT002.eurprd04.prod.outlook.com ([10.255.73.37]) with mapi id 14.16.0329.000; Thu, 25 Jul 2013 14:41:30 +0000
From: "Margaria, Cyril (Coriant - DE/Munich)" <cyril.margaria@coriant.com>
To: Jonathan Hardwick <Jonathan.Hardwick@metaswitch.com>, "draft-ietf-pce-gmpls-pcep-extensions@tools.ietf.org" <draft-ietf-pce-gmpls-pcep-extensions@tools.ietf.org>
Thread-Topic: Comments on draft-ietf-pce-gmpls-pcep-extensions-08
Thread-Index: Ac6HsAzdUISi4eHgQZqcl365JKGg0QBjjtbQ
Date: Thu, 25 Jul 2013 14:41:30 +0000
Message-ID: <523C37072C291347B9730C9291CCA07D0CC675@DB3PRD0411MB427.eurprd04.prod.outlook.com>
References: <09CE6C3BE5E1EA40B987BF5F25D8DDBAE10F61A5@ENFICSMBX1.datcon.co.uk>
In-Reply-To: <09CE6C3BE5E1EA40B987BF5F25D8DDBAE10F61A5@ENFICSMBX1.datcon.co.uk>
Accept-Language: fr-FR, en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-originating-ip: [62.159.77.165]
Content-Type: multipart/alternative; boundary="_000_523C37072C291347B9730C9291CCA07D0CC675DB3PRD0411MB427eu_"
MIME-Version: 1.0
X-OriginatorOrg: coriant.com
X-FOPE-CONNECTOR: Id%0$Dn%*$RO%0$TLS%0$FQDN%$TlsDn%
Cc: "pce@ietf.org" <pce@ietf.org>
Subject: Re: [Pce] Comments on draft-ietf-pce-gmpls-pcep-extensions-08
X-BeenThere: pce@ietf.org
X-Mailman-Version: 2.1.12
Precedence: list
List-Id: Path Computation Element <pce.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/pce>, <mailto:pce-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/pce>
List-Post: <mailto:pce@ietf.org>
List-Help: <mailto:pce-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/pce>, <mailto:pce-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 25 Jul 2013 14:41:55 -0000

Hi Jonathan,

Thanks for the review, please see inline .

Mit freundlichen Grüßen / Best Regards
Cyril Margaria
From: Jonathan Hardwick [mailto:Jonathan.Hardwick@metaswitch.com]
Sent: Tuesday, July 23, 2013 4:22 PM
To: draft-ietf-pce-gmpls-pcep-extensions@tools.ietf.org
Cc: pce@ietf.org
Subject: Comments on draft-ietf-pce-gmpls-pcep-extensions-08

Hello

I have reviewed this draft and have the following comments and questions.

Best regards
Jon


Section 2 RBNF
The RBNF implies that BANDWITH and GENERALIZED-BANDWIDTH can be mixed on a single request & response.  That looks wrong to me, I think that either one or the other should be supplied but not both.  If both really can be used, please could you add text explaining why?
Same comment for LOAD-BALANCING and GENERALIZED-LOAD-BALANCING.

[[Margaria.C]] This is for backward-compatibility : for instance for reoptimization request the BANDWIDTH MUST be provided. We did not want to change existing  logic but to enhance the information. The GENERALIZED-BANDWIDTH is present as a detailed expression of the BANDWIDTH.


Section 2.1 RP object
The bits used for the RG flag are not defined until section 5.4.  Please at least xref from 2.1 to 5.4 for the definition.  Better still, define them in section 2.1.

[[Margaria.C]] OK


"The RG flag is backward-compatible with

[RFC5440<http://tools.ietf.org/html/rfc5440>]: the value sent by an implementation (PCC or PCE) not

   supporting it will indicate a node granularity."

Pre-existing implementations may calculate at node or link granularity so I don't think you can assume that a back-level implementation will always return node-level granularity.  So, backwards-compatibility does not work as you expect.

[[Margaria.C]] In that case the ERO contains nodes, the intent is more to ask for a more detailed route rather than to force a less detailed route. The values should be read as node (or better) , not node-only ERO (Wording can be added).  Do you see a use case for node-only ERO (or link-only ERO) ?

My suggestion is to make 0 the reserved value for the RG flags (not 3).  Then the backwards compatibility problem is resolved, since the value RG==0 implies that the sender is a back-level node and so is ignoring the RG field.


"If a PCE honored the the requested routing granularity for a request,

it SHOULD indicate the selected routing granularity in the RP object

included in the response"

Suggest changing the above excerpt to:


"The PCE MUST indicate the selected routing granularity in the RP object

included in the response"

Justification: I think you mean MUST, not SHOULD.  Otherwise the PCC can't rely on the RG flag, rendering it useless.
[[Margaria.C]] In the absence of flag the PCC should check. The SHOULD is here to allow PCEs supporting the other object but not filling this bit, but in any case they can put 0 (PCC has to check then), so a MUST can be added.
Also, why should the PCE do this only if it honoured the RG?  I think the PCE should be free to use policy to choose to route at a different RG than that given in the request, and whatever RG is chooses to do the routing at, it should return that RG in the response.
[[Margaria.C]] OK

  Along the same lines:


"The PCE MAY return

finer granularity on the route based on its policy.  The PCC can

decide if the ERO is acceptable based on its content."

Suggest changing the above excerpt to


"The PCE MAY return

any granularity it likes on the route based on its policy.  The PCC can

decide if the ERO is acceptable based on its content."

[[Margaria.C]] OK
Comment on the following statement:


"The PCE MAY try to follow this granularity and MAY return a NO-PATH

if the requested granularity cannot be provided."

If the PCE cannot supply a path at the given granularity then it is either a problem with the PCE's capabilities or a policy issue.  As such, NO-PATH is not appropriate; the PCE should respond with PCErr with a suitable error code.
[[Margaria.C]] The PCE may also miss TE information (loose routing over a domain or missing label information) , so a NO-PATH is valid in that case (if policy dictate it should not return a lower granularity).
I will add the PCErr for the case you mentioned.


Section 2.2 and 2.3 GENERALIZED-BANDWIDTH and GENERALIZED-LOAD-BALANCING
I think it is better to specify a format for the GENERALIZED-BANDWIDTH and GENERALIZED-LOAD-BALANCING objects that allows a single instance of the object to specify both forwards and reverse bandwidth.  By having two objects you complicate matters because you then need to specify (and write extra code for!) all the consistency rules between the objects (e.g. you don't say what happens if the max-LSPs field differs between the forwards and reverse direction GEN-LB object).  This in turn will make implementation more fiddly and potentially less interoperable.  How about including the reverse-direction TSPEC in the same object as the forwards-direction TSPEC if the R bit is set?
[[Margaria.C]] Its a good point, I will consider it.

You state that multiple objects with the same TSPEC type are dealt with by ignoring all but the first.  Why do you allow multiple objects with a different TSPEC type?
[[Margaria.C]] To be permissive, this is done in other protocols
 And what is the PCE to so with a request containing different types of TSPEC?  I think that all TSPECs need to have the same type.
[[Margaria.C]] This is to address draft-ietf-pce-inter-layer-ext, I do not think we should disallow requesting an Ethernet LSP using a SDH or OTN layer (and specifying if we do prefer ODU 0 or ODUFLex)


Section 2.4.1 Generalized-Endpoint object type
To aid clarity, suggest rewording this:


"A PCE not supporting those
   TLVs but not being able to fulfill the label restriction MUST respond
   with a response with NO-PATH with the bit "No endpoint label
   resource" or "No endpoint label resource in range" in the NO-PATH-
   VECTOR TLV, the response SHOULD include the ENDPOINT object in the
   response with only the TLV where it could not met the constraint."

to this:


"A PCE supporting those
   TLVs but not being able to fulfil the label restriction MUST send
   a response with a NO-PATH object which has the bit "No endpoint label
   resource" or "No endpoint label resource in range" set in the NO-PATH-
   VECTOR TLV.  The response SHOULD include an ENDPOINT object
   containing only the TLV where the PCE could not meet the constraint."

[[Margaria.C]] OK

Section 2.4.2.5 Labels TLV
Suggest changing


"This Bit SHOULD be set to 0 in a SUGGESTED-LABEL-SET
      TLV Set."

to


"This Bit SHOULD be set to 0 in a SUGGESTED-LABEL-SET
      TLV Set and ignored on receipt."
[[Margaria.C]] OK
Delete orphaned text which says "Table 5" - no table present in this section.
[[Margaria.C]] OK


Section 2.5
Stipulate that IP address subobject MUST be a link subobject.
Clarify that >1 label subobject may follow each link-address or unnumbered-link subobject.

[[Margaria.C]] OK
Section 2.6 XRO
Better to just define the X bit than refer to RFC 5521.  The definition is simple enough.
[[Margaria.C]] I would do both.
You say the C-Type is "copied from the label object" - what label object?  Isn't this just a number which identifies the type of the labels?
[[Margaria.C]] Yes, I will correct.
Does the label field specify a single label or an array of labels?  (Suppose single label but it is not quite clear.)
[[Margaria.C]] A single label, for multiple label this should be repeated

Section 2.7 PROTECTION-ATTRIBUTE TLV
I am not sure that re-using the format from RFC 4872/4873 is the right way to go.  It leaves us with a format containing many elements that are superfluous (or at least, not obviously applicable) to path computation.  It would help if you could add some text explaining why each field is applicable to path computation.
[[Margaria.C]] --> keeping the same format is done for simplicity of the definition, and this object is used as policy input.
For example, on the PROTECTION-ATTRIBUTE TLV flags:

·         S bit: since the PCE server does not assign resources, it seems that this bit will not be used in PCEP, correct?

·         N bit: I think this is irrelevant to PCEP.

·         O bit: ditto.

·         I bit: ditto.

·         R bit: ditto.

Unless I have misunderstood, I think It would be better not to define these bits in the object format.  If you must have them then I think you should at least stipulate that they are ignored on receipt.

[[Margaria.C]] So it woud be better to state "contains the value of the PROTECTION object defined by RFC4872" and its used for policy input.

You say "LSP Flags can be considered for routing policy based on the protection type."  I think you must mean the Link Flags, since these specify the link attributes that the path requires.  I am not sure what use the LSP flags are to the PCE; please could you explain?  Same comment applies to segment recovery flags.


Where you say "The other attributes are only meaningful for a stateful PCE", please could you say why a stateful PCE might make use of them, or point me at a draft where this is discussed?
Some semantic are covered in draft-tanaka-pce-stateful-pce-mbb-01 ,  draft-crabbe-pce-stateful-pce-protection-00 and they also were present in draft-ietf-pce-stateful-pce .