Hello,
I have been selected as the Routing Directorate reviewer for this draft. The 
Routing Directorate seeks to review all routing or routing-related drafts as 
they pass through IETF last call and IESG review, and sometimes on special 
request. The purpose of the review is to provide assistance to the Routing ADs. 
For more information about the Routing Directorate, please see 
http://www.ietf.org/iesg/directorate/routing.html
Although these comments are primarily for the use of the Routing ADs, it would 
be helpful if you could consider them along with any other IETF Last Call 
comments that you receive, and strive to resolve them through discussion or by 
updating the draft.
Document: draft-draft-kelsey-intarea-mesh-link-establishment-05.txt 
Reviewer: Thomas Clausen
Review Date: 2013-09-13
IETF LC End Date: 2013-09-16 
Intended Status: Proposed Standard
Summary:
========
I have some minor concerns about this document that I think should be resolved 
before publication.
Comments:
=========
This document is generally well written, and easy to read.
I especially appreciate the the last paragraph of Section 15 "Security 
Considerations"; while it is not a new technique (as is called out), it is 
always of educational value to have such "tricks" called out and explained.
The document specifies several message types (or rather, one message type with 
different "commands" - effectively, being "different message types sharing a 
similar frame format"), TLV types, and other code-points, with "mini IANA 
sections" scattered throughout the text defining these. While there is an IANA 
section in the end of the document, I would much prefer seeing mnemonics used 
for code points through the text, and with the IANA section assigning values 
for these in a single location. It makes it easier to read "FooBar message" 
rather than "message 42" ( or "message 42 (foobar)" ), easier to code, and less 
prone to editorial snafu's.
Also, as the document specifies a number of TLVs, which MAY/MUST be included in 
different messages, would it be possible to provide an overview/table 
centralizing this information? If I was to go implement this protocol, my 
inclination would be to have the parser "know" the required/forbidden TLVs for 
each given message type, and reject on parsing based on that - and such a 
table/overview would help.
Major Issues:
=============
Section 3, "Applicability":
I have an issue with the mention of MLE being blanket-applicable to also "other 
radio standards" here. I find it to be too broad when stated unqualified.
It would be of great value if the applicability statement could point out the 
boundaries within which MLE applies. What I am getting at is, if MLE applies to 
simply /any/ L2, or if there are L2s where it either can't operate -- or, L2s 
where it can't bring any benefit. Not in terms of "it works for IEEE XXX but 
not for IEEE YYY", but in terms of "If a radio standard has the characteristics 
ZZZ and WWW, MLE applies - but if it has the characteristics QQQ, then it 
doesn't".
A secondary question here would be "why /radio/ standards"? Is there something 
inherent in /radio/ that wouldn't also apply in - say - PLC, and which would 
render MLE inappropriate there?
The reliance of the 802.15.4 security suite seems to indicate that there are 
some requirements from an underlaying L2 that could be brought forward, for 
example....
An alternative would be to scope this document narrowly to 802.15.4, which I 
understand to be the targeted usecase, e.g.: "This applies to 802.15.4. It may 
also be applicable elsewhere, but we do not know that, or how, yet."
Section 8 "Message Transmission":
Last paragraph before table with parameter states "Because MLE messages do not 
require complex processing and are not relayed"....yet two paragraphs above, it 
was stated "...allow update messages to be forwarded multiple hops" - does that 
not exactly imply that some MLE messages /are/ indeed relayed? Later (Section 
11, 2nd paragraph) it is even specified that for that relaying, "simple 
flooding" is sufficient. 
Minor Issues:
=============
Section 3 "Applicability":
While the motivation for MLE, given in previous sections, is clear, it is a 
little unclear (by the use of the word "extends") here, in which fashion it is 
for the IETF to "extend" a L2 protocol.
Would it be possible to say something like a variation over "This protocol 
provides a support mechanism for using IEEE 802.15.4 for IPv6-based multi-hop 
mesh networks".
Section 4 "Overview":
The first bullet point has to do with "links", presumably as defined by "pairs 
of interfaces" (although, that's not entirely clear?). The last bullet point, 
then, talks about devices.
How about devices with multiple interfaces on the same radio channel? Take the 
simple case of two devices A (with interfaces a1, a2) and B (with interfaces 
b2, b2), and where links being unidirectional (or, at least, useful in a 
meaningful fashion only in one direction) a1->b1 and b2->a2. Bi-directional 
communication between A and B is (in principle) possible, despite no single 
bidirectional link between A and B. Is this case handled by MLE, or is that a 
condition where MLE doesn't / can't /shouldn't apply? Later in the document, it 
appears that MLE explicitly excludes non-bidirectional links, if so, calling 
that out here  would be helpful. Section 4.3 and Section 12 hint at, but 
doesn't clarify, this issue entirely.
Section 5 and onwards:
While this protocol may follow the usual "custom" of byte order, endianness and 
alignment/padding, and it is, occasionally, specified for some fields in some 
messages/TLVs, I would suggest that what is used should be stated explicitly, 
once, and up-front.
Section 10 "Link Configuration" and Section 11 "Parameter Dissemination":
I am a little surprised  by the use of "SHOULD" in this, and the following, 
sections; it would appear to me that most of the "SHOULD" really ought to be 
"MUST", as they govern when messages are sent and what proper responses to 
those messages are by receivers. Is there a subtlety that I am missing?
Nits:
=====
Section 7.7 "Link quality":
Suggest, for RES, "MUST be set to 000 on transmission, and SHOULD be ignored on 
receipt"
Section 11 "Parameter Dissemination":
In 2nd paragraph, it is suggested that simple flooding is sufficient for 
dissemination of these messages. That is quite likely true. If I may, I would 
suggest explicitly calling out the need for implementing duplicate detection 
for the flooding operation; it won't impact interoperability how exactly such 
is done (unless doing so requires adding, say, an additional sequence number to 
messages - if an existing and always available sequence number can be used, it 
might help to call that out), but it will be harmful if a less-than-vigilant 
implementer forgets this point.