Re: [Roll] [roll] #93: A single P2P-RPL invocation can discovery upto 4 source routes. Why 4?

C Chauvenet <> Thu, 05 April 2012 14:17 UTC

Return-Path: <>
Received: from localhost (localhost []) by (Postfix) with ESMTP id 24BBF21F8749 for <>; Thu, 5 Apr 2012 07:17:35 -0700 (PDT)
X-Virus-Scanned: amavisd-new at
X-Spam-Flag: NO
X-Spam-Score: -3.599
X-Spam-Status: No, score=-3.599 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, RCVD_IN_DNSWL_LOW=-1]
Received: from ([]) by localhost ( []) (amavisd-new, port 10024) with ESMTP id w6q4iPrX-NgG for <>; Thu, 5 Apr 2012 07:17:34 -0700 (PDT)
Received: from ( []) by (Postfix) with ESMTP id 10A1621F8748 for <>; Thu, 5 Apr 2012 07:17:33 -0700 (PDT)
Received: from ( by ( with Microsoft SMTP Server id; Thu, 5 Apr 2012 14:17:33 +0000
Received: from mail107-va3 (localhost []) by (Postfix) with ESMTP id 5E17B1E03AE; Thu, 5 Apr 2012 14:17:33 +0000 (UTC)
X-SpamScore: -70
X-BigFish: VPS-70(zzc89bh15caKJzz1202hzz1033IL8275bh8275dhz2dh2a8h668h839h93fhd25h)
X-Forefront-Antispam-Report: CIP:; KIP:(null); UIP:(null); IPV:NLI;; RD:none; EFVD:NLI
Received: from mail107-va3 (localhost.localdomain []) by mail107-va3 (MessageSwitch) id 1333635449945212_28484; Thu, 5 Apr 2012 14:17:29 +0000 (UTC)
Received: from (unknown []) by (Postfix) with ESMTP id C8E50A0097; Thu, 5 Apr 2012 14:17:29 +0000 (UTC)
Received: from ( by ( with Microsoft SMTP Server (TLS) id; Thu, 5 Apr 2012 14:17:23 +0000
Received: from ([]) by ([]) with mapi id 14.16.0135.002; Thu, 5 Apr 2012 14:17:21 +0000
From: C Chauvenet <>
To: "mukul@UWM.EDU" <mukul@UWM.EDU>
Thread-Topic: [Roll] [roll] #93: A single P2P-RPL invocation can discovery upto 4 source routes. Why 4?
Thread-Index: AQHNExt2WB0Ei/9t6USXDGCl+MKLpJaMPEqw
Date: Thu, 05 Apr 2012 14:17:21 +0000
Message-ID: <>
References: <>
In-Reply-To: <>
Accept-Language: fr-FR, en-US
Content-Language: fr-FR
x-originating-ip: []
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: base64
MIME-Version: 1.0
Cc: "" <>
Subject: Re: [Roll] [roll] #93: A single P2P-RPL invocation can discovery upto 4 source routes. Why 4?
X-Mailman-Version: 2.1.12
Precedence: list
List-Id: Routing Over Low power and Lossy networks <>
List-Unsubscribe: <>, <>
List-Archive: <>
List-Post: <>
List-Help: <>
List-Subscribe: <>, <>
X-List-Received-Date: Thu, 05 Apr 2012 14:17:35 -0000


-----Message d'origine-----
De : [] De la part de roll issue tracker
Envoyé : jeudi 5 avril 2012 13:01
À : mukul@UWM.EDU;
Cc :
Objet : [Roll] [roll] #93: A single P2P-RPL invocation can discovery upto 4 source routes. Why 4?

#93: A single P2P-RPL invocation can discovery upto 4 source routes. Why 4?

 Resolution: Open


 p12 :  This specification does not allow for the establishment of hop-by-  hop routes in the backward direction.

 Why ? This would enable to establish 2 routes within a single route  request.
 Furthermore, you stipulates in the draft that links have to be  bidirectional to propagates RDO, in order to be able to send back the DRO.
 So if I understand it correctly you ensure that you have a reliable path  in both ways. Why using it in a single way only ?

 Suppose a DRO establishing a forward hop-by-hop route fails to make it to  the origin. In this case, all we have is some nodes storing the hop-by-hop  state for a broken route but that route is never used since the origin  never gets the DRO. On the other hand, if the DRO establishing a backward  hop-by-hop route fails to make it to the origin, we have a broken route  that the target is likely to use (to reach the origin). So, if we want  P2P-RPL to establish a backward hop-by-hop route, the target MUST ask for  a DRO-ACK from the origin (to make sure that the DRO does reach the origin  and hence the backward route is not broken). This can be done if you think  it will be useful. We did not include this in P2P-RPL because we did not  have a usecase for backward hop-by-hop routes and we wanted to avoid the  additional complexity.

 This is how we can implement this functionality: we will let the target  decide whether it wants the DRO to establish a backward hop-by-hop route.
 In that case:
 1) the target will set a new flag, the B flag (B for backward hop-by-hop  route), inside the DRO to let intermediate routers know that backward  route state needs to be established as well;
 2) the target will set the A flag to require a DRO-ACK from the origin;
 3) the target will specify (inside a new field in the DRO), an  RPLInstanceID under which the hop-by-hop state for the backward route will  be stored. Note that the RPLInstanceID of the forward route (selected by  the origin) may not be OK for use in backward route (because the target  may have already used this RPLInstanceID for another hop-by-hop route,  using different routing-metrics/constraints/OF, to the origin).
 When the intermediate routers receive this DRO, they will store the hop-  by-hop state for the backward route. This hop-by-hop state will consist
 1) Target address (taken from P2P-RDO inside the DRO).
 2) RPLInstanceID specified by the target
 3) The destination, i.e., the origin address (same as DODAGID inside the  DRO).

 Do you want this functionality?

The group has to discuss and decide wether it is usefull or not. I personnaly think that RPL-P2P draft may be used for binding devices, so it could be valuable to create a 2 way path between the origin and the target. So I would vote in favor of such a mechanism. 
Though, I don't think we should create a new DAG (i.e. select a new RPLInstanceID) for the backward route. What I would like is just the ability for 2 devices to exchange packet in both ways using the same temporary DAG created by RPL-P2P. Let me explain the use case with an example : For instance, if you have nodes deployed in a building or a city, and you want to configure some of them. An operator could go in the area where devices to be programmed are installed (or in the neighborhood at least) with a "configurator node", and need to established a P2P route between this configurator node and the node(s) to be configurated. They create a temporary DAG (possibly through several hops) and exchange configuration frames. Because such messages are  critically important, you often need application layer acknowledgments, so a backward route is needed.
Is the actual specification compliant with such a use case without modification ? (using piggybacked DATA inside RDO and DRO messages) ? Or do wee need an additional mechanism such as the one you described ?

 Reporter:  jpv@…                  |      Owner:  mukul@…
     Type:  defect                 |     Status:  new
 Priority:  major                  |  Milestone:
Component:  p2p-rpl                |    Version:
 Severity:  Submitted WG Document  |   Keywords:

Ticket URL: <>
roll <>

Roll mailing list