Re: [Roll] Semantics of DAO ACK

Csaba Kiraly <kiraly@fbk.eu> Thu, 05 November 2015 02:07 UTC

Return-Path: <kiraly@fbk.eu>
X-Original-To: roll@ietfa.amsl.com
Delivered-To: roll@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 366B51B380E for <roll@ietfa.amsl.com>; Wed, 4 Nov 2015 18:07:41 -0800 (PST)
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, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, 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 CS4L1LlKuxvF for <roll@ietfa.amsl.com>; Wed, 4 Nov 2015 18:07:36 -0800 (PST)
Received: from mail-wm0-x22b.google.com (mail-wm0-x22b.google.com [IPv6:2a00:1450:400c:c09::22b]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id E099B1B37CE for <roll@ietf.org>; Wed, 4 Nov 2015 18:07:35 -0800 (PST)
Received: by wmeg8 with SMTP id g8so2019873wme.0 for <roll@ietf.org>; Wed, 04 Nov 2015 18:07:34 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fbk_eu.20150623.gappssmtp.com; s=20150623; h=from:subject:to:references:message-id:date:user-agent:mime-version :in-reply-to:content-type:content-transfer-encoding; bh=RzwqomqtA+dcKPDqj27kwR93rT9vP9vbudMRFAgahsg=; b=M7YzqKiiMeUteipgfELywmwHAEAcsT30uAat298lyYm+KQzlYxlu8TXPW3JN/fps3a 1pbN+d82/Z1QGgYwI8YHYs9jS0I8cKICChftbFIms11W1m6kVfytA1ne7jhsiwsY19R/ bxYui1NomJNAXplGpBa/YMWPAjEFDrMArV6Un6AtB+7kVvBorKD2AKJlGiCV8lM22Wbp 70tZ6QK8Z7cBD0u81C3USLAFg4L18Vs7+EYjOjY3LyebX2P6017gYtCla7fFc1kAsq5d 6xxJM4eXmc2L1zti/r8Yl5H3mGu3xpUmtfnrisknAKe/aGYVoGC5IYMb0rxj5rmbEXw3 S/sQ==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:subject:to:references:message-id:date :user-agent:mime-version:in-reply-to:content-type :content-transfer-encoding; bh=RzwqomqtA+dcKPDqj27kwR93rT9vP9vbudMRFAgahsg=; b=S8glI2j3/6uT0FhYvpINb93rh5duXUZpFpsb9locCDZWAe1CSfckqf4IdZWXFFrpO1 tosiXG1mM0KGgDpeCMg3L593yJfw/5rveyqDLsbhEiAD+VRgCGMEAiGSCax/hL1WV8oP oylV8oxhk4GpLwgQqtU1vIYMuFaehMBYc/y0nhYVhOe9DfRJwD2U6hlQN1g5t1BFUvY7 IaNZsq4DsDs5e+Ii0f0eX7zRMjvMzElR4+MbfdjxseJUKXTIuqIg5L57SGkxa0UVYAME PlDsciZuPqNGpBGS0XIjdFDx7vDiPytUuIxUQ1HMx1UDhNc7ml1XRjAKQWHWyM9nZ7Gs CVFg==
X-Gm-Message-State: ALoCoQkJxttlxBbbBq3bkWORpeKsAlzUBWvOg7ErPvyBKTITt66htsiKBoLjHdjiLQwmuukOWxC06IMf8LQtbbzfZXAkufesbLH6f3As/GaKMdEFhe0x9wKK8sgJLBB4JXtLJU4bN8x0xvFhmWGsKArTGEju2WeVfmgwPq8/DJqHPUFxRwTL7i4=
X-Received: by 10.28.18.11 with SMTP id 11mr317491wms.68.1446689254438; Wed, 04 Nov 2015 18:07:34 -0800 (PST)
Received: from cskiralys-air.homenet.telecomitalia.it (host65-109-dynamic.21-79-r.retail.telecomitalia.it. [79.21.109.65]) by smtp.googlemail.com with ESMTPSA id d22sm31471513wma.21.2015.11.04.18.07.33 for <roll@ietf.org> (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 04 Nov 2015 18:07:33 -0800 (PST)
From: Csaba Kiraly <kiraly@fbk.eu>
To: roll@ietf.org
References: <DB5PR01MB10807DAF503BBFF45787599C80420@DB5PR01MB1080.eurprd01.prod.exchangelabs.com> <6d21d0f86ab14ae7a99ff9fe6873b1fd@XCH-RCD-001.cisco.com> <C885EE62-D889-4229-9CCB-B3CB540F5692@sics.se> <560AFDBB.8050505@gmail.com> <560B68B2.6030501@fbk.eu> <245E0C92-6ED6-426B-95E1-09BA8736F1BC@sics.se> <560D8386.6000502@fbk.eu> <C00C9B6A-65F3-4C30-9982-44C94925D5D1@sics.se> <c905b2df38e8446cb71459ee3f66f50a@XCH-RCD-001.cisco.com> <560EA05A.3080002@fbk.eu> <B806D72C-BF7E-416B-A49C-B65FD52DE86E@sics.se> <560F5C5E.8010806@fbk.eu> <982B626E107E334DBE601D979F31785C5C500798@szxeml558-mbs.china.huawei.com> <5620B51C.1050103@fbk.eu> <982B626E107E334DBE601D979F31785C5C5007EE@szxeml558-mbs.china.huawei.com>
Message-ID: <563AB9EE.3010906@fbk.eu>
Date: Thu, 05 Nov 2015 03:07:42 +0100
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:38.0) Gecko/20100101 Thunderbird/38.3.0
MIME-Version: 1.0
In-Reply-To: <982B626E107E334DBE601D979F31785C5C5007EE@szxeml558-mbs.china.huawei.com>
Content-Type: text/plain; charset="utf-8"; format="flowed"
Content-Transfer-Encoding: 8bit
Archived-At: <http://mailarchive.ietf.org/arch/msg/roll/d-6Za4KtLS-QDNOFvKhtfg1a7R4>
Subject: Re: [Roll] Semantics of DAO ACK
X-BeenThere: roll@ietf.org
X-Mailman-Version: 2.1.15
Precedence: list
Reply-To: Routing Over Low power and Lossy networks <roll@ietf.org>
List-Id: Routing Over Low power and Lossy networks <roll.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/roll>, <mailto:roll-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/roll/>
List-Post: <mailto:roll@ietf.org>
List-Help: <mailto:roll-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/roll>, <mailto:roll-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 05 Nov 2015 02:07:41 -0000

Hi Rahul,

On 16/10/15 14:09, Rahul Arvind Jadhav (Rahul Arvind Jadhav, 2012 Labs) 
wrote:
> Hi Csaba,
>
> Responses inline...
>
> Regards,
> Rahul
>
> -----Original Message-----
> From: Roll [mailto:roll-bounces@ietf.org] On Behalf Of Csaba Kiraly
> Sent: 16 October 2015 PM 01:58
> To: Routing Over Low power and Lossy networks
> Subject: Re: [Roll] Semantics of DAO ACK
>
> Hi Rahul,
>
> On 16/10/15 08:50, Rahul Arvind Jadhav (Rahul Arvind Jadhav, 2012 Labs)
> wrote:
>> We have also implemented this end-to-end ACK feature in our solution in Huawei. And this end-to-end ACK has become important especially in context to bigger networks. Without this feature it is impossible for the node to know when to initiate the application traffic (especially bidirectional traffic, like Joakim mentioned). Secondly it also reduces network convergence time for bigger networks (of-course at the cost of additional ACK traffic), because the repairs are triggered soon when the ACKs do not arrive. We had found good performance improvements for 1K node network (with roughly 16 hops) and it certainly improves the network convergence time and the nodes have  more deterministic way of knowing when to initiate the traffic.
>>
>> IMO, this extension will help in a big way.
> Glad to hear that you've came to the same conclusions. I think it really shows that the possibility is there among the lines of the RFC, but not spelled out in a way to make it evident. IMHO this could lead to interoperability problems, but I would be interested to know if anyone actually did interoperability tests between implementations going with different interpretations.
>
> You speak of additional ACK traffic, which suggests that you use both end-to-end ACKs and one-hop ACKs. Is this the case, or are you just referring to more ACKs because of more information and thus more events to react to?
>
> --[RJ]--
> The additional ACK traffic that I talk of is of the end-to-end ACKs alone. One-hop ACKs are not useful in any case, imo, and we never have used it. I m referring to the additional traffic generated for E2E-ACKs and retransmissions of DAOs on not reception of these ACKs. My point is, in a bigger network, there is scope of aggregating these downstream ACKs provided these ACKs are sent back to the nodes on hop-by-hop basis (just like DAO travel upstream hop-by-hop, E2E aggregated Acks can travel downstream hop-by-hop). But then like DAO, these E2E-ACKs also need to carry target information in the payload for it to be aggregated.
> --[RJ-End]--
So I misunderstood, and your additional traffic is ACKs vs. not having 
ACKs at all. Sorry for that.

>> There are few more points:
>> 1. Can the E2E-ACK sent by the grounded root be aggregated ? This is possible with the E2E-ACK going one hop.
> What you mean by E2E-ACK going one hop? I've seen ACK traffic near the root being a problem in our tests, and ACK aggregation could be supported at low implementation overhead, so I think it is a good option. If we don't want to mandate support for it, we can still consider a capability flag such as the "F" flag mentioned below to make it optional and interoperable.
>
> --[RJ]--
> Sorry my statement above was incorrect. Sent the mail in a haste. I meant "E2E-ACK going on hop-by-hop basis".. This is needed for aggregation to work. But as mentioned above, for aggregation to work, one needs to add target information back in the E2E-ACK.
> --[RJ-End]--
>
>> 2. Some guidelines on what timers the end nodes should use for DAO retry in case the E2E-ACK is not received. The timers need to be set to a conservative (higher) value otherwise the cumulative DAO retries will negatively impact the network.
> Reasonable values for timers really depend on the decision logic. More precisely, on whether nodes in the chain can only forward DAO-NACKs or could also act on them e.g. by trying another parent (which takes some time). Since we don't want to mandate the decision logic, agreeing on limits on the timers without limiting scalability could be tough. I think having guidelines is a good idea, but we should be careful not to limit implementations and deployments.
>
> What about a push-back mechanism which tells the originator of the DAO to slow down with retries? For example, as part of the ACK, you could set a the "S" flag with the following meaning: "while I was processing this, I've seen several identical DAOs from you". This wouldn't slow down the normal DAO sending, just the retry timeout. Then, how the end node should handle this flag can be left to the implementation. I don't think we need to mandate how the timeout should scale up and down, it will work even without mandating the logic.
>
> --[RJ]--
> I think this flag is not necessary, since if the E2E-ACK reaches the node then anyways it will cease sending DAO.
> --[RJ-End]--

I think my description wasn't clear enough. I was speaking of changing 
the timeout on the long-term, not for a single E2E DAO/ACK transaction. 
The information would not have effect on the single transaction, so you 
would have several copies flying for that, but it would optimize 
operation on the long term. Having said that, this flag is just an idea 
which was not tested in action. I would come back to it once I had a 
chance to evaluate it. Having guidelines with conservative values could 
be a good idea.

Regards,
Csaba


> Regards,
> Csaba
>
>> Regards,
>> Rahul
>>
>>
>> -----Original Message-----
>> From: Roll [mailto:roll-bounces@ietf.org] On Behalf Of Csaba Kiraly
>> Sent: 03 October 2015 AM 10:11
>> To:roll@ietf.org
>> Subject: Re: [Roll] Semantics of DAO ACK
>>
>> Since we were jumping through several topics around the DAO-ACK semantics in this thread, I wrote a quick memo of what had been brought up till now. I thought it might worth sharing:
>>
>> DAO-ACK semantics
>> -----------------
>>
>> 1, ACK for DAO with multiple T+T [Joakim]
>>     - status code 1-127, and copy rejected Target [Cenk]
>>     - new option with individual status codes (same semantics as with multiple individual messages) [Csaba]
>>       - send individual ACKs for each Target [Joakim]
>>         - memory concerns, better to include Target in response [Joakim]
>>           - “F” flag in DAO to request full ACK with T+T or partial ACK with status codes only [Csaba]
>>     - meaning of status code [Pascal]
>>       - enumeration
>>         - both Joakim and we use this (not for multiple T+T, but to differentiate different reasons of DAO rejection)
>>         - would need registry for interoperability [Pascal]
>>       - metric: as “scalar degree of unwillingness” calculated based on available resources [Pascal]
>>         - could be difficult to combine it into one scalar degree in one byte [Joakim, Csaba]
>>         - might be better to put the resource info in DIO or in a DAO option [Csaba]
>>     - ACK with rejected T+T and status code for each; relation to path control [Pascal]
>>     - “All-or-nothing” flag in DAO [Joakim]
>>
>> 2, ACK semantics: one-hop vs. end-to-end context [Csaba]
>>     - when speaking of end-to-end context, we do not refer to a DAO addressed directly to the root, like in non-storing, but to a different interpretation of the ACK of the one-hop DAO [Csaba, Joakim]
>>     - used in Yanzi [Joakim]
>>     - drafted advantages and disadvantages [Pascal, Csaba, Joakim]
>>       - possible deadlock [Pascal]
>>       - is it RFC6550?
>>       - one-hop ACK is not enough info, needs end-to-end for decision
>> logic [Csaba, Joakim]
>>
>> 3, fix meaning of status code 127 (just a typo in the RFC) [Csaba]
>>
>> 4, status code in ACK for No-path DAO not defined clearly [Csaba]
>>     - only code 0 makes sense [Joakim]
>>     - not using end-to-end context in this case [Joakim]
>>
>> 5, multiple DAO ACKs for same DAO [Joakim, Csaba]
>>     - to handle multiple T+T [Joakim]
>>     - to have both end-to-end and one-hop ACK semantics [Csaba]
>>
>> Disclaimer: this doesn't want to be a full summary, and I obviously skipped many detail in such a brief writeup.
>>
>> Cheers,
>> Csaba
>>
>> On 02/10/15 17:39, Joakim Eriksson wrote:
>>>    From my perspective we really need the end-to-end ACK that is
>>> needed
>>> - the single hop ACK is of no use at all if you aim at building scalable RPL networks that have bi-directional communication.
>>>
>>> We have worked with this for quite a while at Yanzi Networks and I
>>> would say that if we get a deadlock somewhere that is probably an
>>> indication that the selected path/parent was a bad one and that the
>>> node should look for alternatives. If we instead would have gotten a
>>> DAO ACK over single-hop the node would assume connectivity - but be
>>> wrong and some other mechanism (usually the application) needs to
>>> kick in and trigger repairs. This is for me not the wanted behaviour
>>> and I rather take the risk of one or a few
>>> (short-term) dead-locks if a node in the path towards root reboots or in other ways is gone.
>>>
>>> Of course combining DAO ACK (end-to-end) with infinite lifetime
>>> routes is not an optimal configuration if there are many reboots and
>>> dead-locks. That is why we try to keep routing lifetime reasonably
>>> short
>>> (30 minutes) so that any routes that ended up being “stuck” somewhere
>>> will be garbage collected after a while.
>>>
>>> Best regards,
>>> — Joakim Eriksson, SICS
>>>
>>>
>>>> On 02 Oct 2015, at 17:18, Csaba Kiraly<kiraly@fbk.eu>  wrote:
>>>>
>>>> Hi Pascal,
>>>>
>>>> The core observation behind the end-to-end, or delayed ACK (at least on my side, I don't know for Joakim) is that while the one-hop NACK contains important information, the one-hop ACK is not really what you are interested in. In fact, implementations I've checked either don't even ask for it, or if they do, they still don't do anything on a positive ACK. If instead you delay ACKs, or in other words wait for all the parents to ACK, this ACK or NACK brings in an important piece of information.
>>>>
>>>> Notice that if your immediate parent would NACK, it would NACK immediately in both interpretations. Feedback only changes where things go well, or things go well till some point on the recursive path, but fail after. In the first, you get an ACK and you know you are reachable. In the latter, you do get to know the problem and you can act upon. Convergence is surely something that needs to be studied carefully, but I think delayed ACK will not create more issues than what you already have with the one-hop ACK.
>>>>
>>>> The point that I tried to raise when I brought this up, but maybe it wasn't clear, is that I think both are conformant to RFC6550. Which, if I'm correct, brings me to the point that clarifications might be needed about ACKs in an RFC to avoid interoperability problems, and I think it is needed independent of whether the end-to-end context is a good idea or not. You could even think of sending both types of ACKs, but that would bring the implementation out of RFC6550.
>>>>
>>>> Cheers,
>>>> Csaba
>>>>
>>>> On 02/10/15 15:04, Pascal Thubert (pthubert) wrote:
>>>>> Hello Joakim:
>>>>>
>>>>> What I read here boils down to a limited diffusion algorithm. We tried to avoid that in RPL because any movement within the convergence would cause a deadlock. IOW if every node waits for (all of) the parents to ack, then this recursively takes you to the root, and if any node in the chain moves or dies, the diffusion will not be complete.
>>>>>
>>>>> Cheers,
>>>>>
>>>>> Pascal
>>>>>
>>>>>> -----Original Message-----
>>>>>> From: Roll [mailto:roll-bounces@ietf.org] On Behalf Of Joakim
>>>>>> Eriksson
>>>>>> Sent: jeudi 1 octobre 2015 22:11
>>>>>> To: Routing Over Low power and Lossy networks<roll@ietf.org>
>>>>>> Subject: Re: [Roll] Semantics of DAO ACK
>>>>>>
>>>>>>
>>>>>>> On 01 Oct 2015, at 21:03, Csaba Kiraly<kiraly@fbk.eu>  wrote:
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> On 30/09/15 17:55, Joakim Eriksson wrote:
>>>>>>>>> On 30 Sep 2015, at 06:44, Csaba Kiraly<kiraly@fbk.eu>  wrote:
>>>>>>>>>
>>>>>>>>> Hello Joakim,
>>>>>>>>>
>>>>>>>>> I have also worked on the Contiki DAO-ACK code, enabling ACKs,
>>>>>> implementing fixes to the DAOSequence handling, and looking into
>>>>>> multiple targets.
>>>>>>>> Nice, I have a PR on Contiki now with what we have been doing to
>>>>>>>> get
>>>>>> Contiki RPL more scalable (but still only single targets / paths).
>>>>>>>>> What Cenk is saying sounds a reasonable hack, but the standard
>>>>>>>>> itself
>>>>>> is in my opinion a bit underspecified for the semantics of DAO-ACK
>>>>>> messages in several ways.
>>>>>>>> Yes, it is underspecified. There is need for clarifications and
>>>>>>>> more details
>>>>>> on the DAO / DAO ACK!
>>>>>>>>> My preferred solution for ACKing DAO messages with multiple
>>>>>>>>> targets
>>>>>> would be to have support for the same semantics that you would
>>>>>> have had with one DAO message per Target, i.e., I would prefer an
>>>>>> option field that gives an individual status for each Target.
>>>>>>>> Yes, but that would require more memory in the sending node to
>>>>>>>> keep
>>>>>> track of things or full specification of the target in the response.
>>>>>>>> I guess it might be solved by allowing multiple DAO ACKs for the
>>>>>>>> same
>>>>>> DAO and to have the Target options included in the DAO ACK.
>>>>>>> This is a compromise to consider for sure. If you look at my
>>>>>> implementation, you can see that I use the routing table entry to
>>>>>> match the DAO ACK, and I keep only DAOSequence (SEQ) as extra
>>>>>> state. I'm not sure it would work in all cases, but it did work
>>>>>> for the case I considered. I'm keeping only the SEQ, and I think
>>>>>> this is a must if you have no aggregation, and you want to match
>>>>>> in case you forward multiple DAOs before getting the ACK or timing
>>>>>> out on it. In fact, simply enabling ACKs in the original code was
>>>>>> messing up the match between DAOs and their ACKs because it wasn't even keeping track of the DAO sequence numbers.
>>>>>>> If you do aggregate ACKs, or you have more complex Target+Transit
>>>>>> scenarios, the game changes, and I don't know what would be the
>>>>>> balance between state you have to keep anyway and state you keep
>>>>>> just to be able to interpret a later ACK correctly. I think it is
>>>>>> implementation specific, so my suggestion would be a flag to
>>>>>> indicate whether you request full ACK (bumping back all T+T info
>>>>>> for rejected entries in the DAO) or a much smaller partial ACK
>>>>>> with SEQ and similar IDs only. This flag (lets call it F for now),
>>>>>> could go right next to K. As the DAO propagates, each node could
>>>>>> set F based on whether it is able to store and/or reproduce info
>>>>>> (F not
>>>>>> set) or chose to remain stateless (set F ). This would exclude aggregation in the DAO-ACK sent down, but still allow for aggregation in the DAO sent up.
>>>>>>>>> To give another example of subtle problems with DAO-ACK, it was
>>>>>>>>> not
>>>>>> clear to me whether I want my implementation to ACK when the
>>>>>> Target is added to the routing table, or only when this node
>>>>>> itself receives an ACK for the same Target from its parent. Both
>>>>>> makes sense, with the former giving a quick one-hop ACK, while the
>>>>>> latter works as an end-to-end ACK, ensuring that the path is
>>>>>> actually built. Both look conformant to the standard, but I
>>>>>> suppose the original author was thinking of the former, and I can
>>>>>> easily see interoperability problems arising between two implementations using different semantics.
>>>>>>>> We did go for the end-to-end ACK to achieve better scalability.
>>>>>>>> There is to me no point having a route to the parent if it is
>>>>>>>> not possible to get
>>>>>> it all the way to root. But I totally agree - this is not obvious
>>>>>> from the RPL RFC either.
>>>>>>> Do you mean end-to-end ACK as in non-storing, or end-to-end ACK
>>>>>>> in the
>>>>>> sense that it is still addressed to the next hop but you delay ACK
>>>>>> till you know your parent (and all its parents) ACKed?
>>>>>> I mean end-to-end as in waiting for all the parents to ACK so that
>>>>>> before ACKing it is known that the route is properly installed where it needs to.
>>>>>>
>>>>>>>> Do you have your Contiki code somewhere in the open-source?
>>>>>>> I did some cleanup and pushed the clean part of the code to github:
>>>>>>> https://github.com/cskiraly/contiki/tree/DAO-NACK
>>>>>>> It is not yet rebased to the latest master, but it should apply.
>>>>>>> I suppose
>>>>>> describing it would be too off-topic for the list.
>>>>>>> There is also the more experimental part of the code in a PR, if interested.
>>>>>> Ok - I’ll take a look!
>>>>>>
>>>>>> BTW: We have done a few deployments using our implementation using
>>>>>> Yanzi networks products - take a look at this video where 1000
>>>>>> nodes is deployed with Contiki RPL + our fixes and 20 neighbors
>>>>>> and routes per node. If without our fixes it would not work since
>>>>>> Contiki RPL did not allow scaling beyond number of neighbors and
>>>>>> routes / node that well before these fixes.
>>>>>>
>>>>>> http://www.yanzi.se/video.jsp?id=7
>>>>>>
>>>>>> Best regards,
>>>>>> — Joakim Eriksson
>>>>>>
>>>>>>> Best regards,
>>>>>>> Csaba
>>>>>>>> Best regards,
>>>>>>>> — Joakim
>>>>>>>>
>>>>>>>>> Best regards,
>>>>>>>>> Csaba
>>>>>>>>>
>>>>>>>>> On 29/09/15 23:08, Cenk Gündogan wrote:
>>>>>>>>>> Hello Joakim,
>>>>>>>>>>
>>>>>>>>>> This is an interesting question and I also couldn't find any
>>>>>>>>>> answers in
>>>>>> RFC 6550.
>>>>>>>>>> However, my thoughts on this are as follows:
>>>>>>>>>> Since a sub-set of the announced RPL targets could have been
>>>>>>>>>> accepted before filling up the routing table (e.g.), I would
>>>>>>>>>> choose a
>>>>>> status code between 1 and 127.
>>>>>>>>>> I would expect a node to choose another parent if a more
>>>>>>>>>> aggressive
>>>>>> status code is received ([128-255]).
>>>>>>>>>> But a full routing table can have free space again until the
>>>>>>>>>> next or any
>>>>>> subsequent DAO arrives ..
>>>>>>>>>> therefore I prefer a "mild rejection" with a status code of [1-127].
>>>>>>>>>>
>>>>>>>>>> To give some feedback to the originator of the DAO, it might
>>>>>>>>>> be sensible to copy the rejected RPL Target options from the
>>>>>>>>>> affected DAO to the DAO-ACK, so that the originator is fully
>>>>>>>>>> aware of which
>>>>>> Target prefixes got rejected (and which ones got accepted, implicitly).
>>>>>>>>>> I would choose this method, because it doesn't require the
>>>>>>>>>> originator of the DAO to save any extra state about the DAO
>>>>>>>>>> and its
>>>>>> contents.
>>>>>>>>>> Nonetheless, everything I wrote is nonconform and I am also
>>>>>>>>>> interested in the RPL experts' opinions and solutions.
>>>>>>>>>>
>>>>>>>>>> Best,
>>>>>>>>>> Cenk
>>>>>>>>>>
>>>>>>>>>> On 29.09.2015 21:44, Joakim Eriksson wrote:
>>>>>>>>>>> Hello All,
>>>>>>>>>>>
>>>>>>>>>>> I have spend quite some time to get a more stable
>>>>>>>>>>> implementation of DAO handling for Contiki RPL and I am
>>>>>>>>>>> currently looking into DAO aggregation. But I realised that
>>>>>>>>>>> it is for me not 100% clear what a node that receives a DAO
>>>>>>>>>>> with several prefixes to be registered but can only accept a
>>>>>>>>>>> sub-set of them. Should it be a
>>>>>> DAO_NACK in this case or is there any other way to handle that case?
>>>>>>>>>>> If each would have been sent separately it is obvious that
>>>>>>>>>>> the receiving node can do a NACK when the routing table is
>>>>>>>>>>> full and therefore it is possible to get fine-grained
>>>>>>>>>>> answers. But with
>>>>>> aggregation of DAOs this is not the case.
>>>>>>>>>>> Any ideas?
>>>>>>>>>>>
>>>>>>>>>>> Best regards,
>>>>>>>>>>> — Joakim Eriksson, SICS
>>>>>>>>>>> _______________________________________________
>>>>>>>>>>> Roll mailing list
>>>>>>>>>>> Roll@ietf.org
>>>>>>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>>>>>> _______________________________________________
>>>>>>>>>> Roll mailing list
>>>>>>>>>> Roll@ietf.org
>>>>>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>>>>> _______________________________________________
>>>>>>>>> Roll mailing list
>>>>>>>>> Roll@ietf.org
>>>>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>>>> _______________________________________________
>>>>>>>> Roll mailing list
>>>>>>>> Roll@ietf.org
>>>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>>> _______________________________________________
>>>>>>> Roll mailing list
>>>>>>> Roll@ietf.org
>>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>> _______________________________________________
>>>>>> Roll mailing list
>>>>>> Roll@ietf.org
>>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>> _______________________________________________
>>>>> Roll mailing list
>>>>> Roll@ietf.org
>>>>> https://www.ietf.org/mailman/listinfo/roll
>>>>>
>>>>>
>>>> _______________________________________________
>>>> Roll mailing list
>>>> Roll@ietf.org
>>>> https://www.ietf.org/mailman/listinfo/roll
>>> _______________________________________________
>>> Roll mailing list
>>> Roll@ietf.org
>>> https://www.ietf.org/mailman/listinfo/roll
>> _______________________________________________
>> Roll mailing list
>> Roll@ietf.org
>> https://www.ietf.org/mailman/listinfo/roll
>> _______________________________________________
>> Roll mailing list
>> Roll@ietf.org
>> https://www.ietf.org/mailman/listinfo/roll
> _______________________________________________
> Roll mailing list
> Roll@ietf.org
> https://www.ietf.org/mailman/listinfo/roll
> _______________________________________________
> Roll mailing list
> Roll@ietf.org
> https://www.ietf.org/mailman/listinfo/roll