[6lowpan] (cutting overhead) RE: LoWPAN simple fragment Recovery

Rene Struik <rstruik@certicom.com> Wed, 17 June 2009 14:06 UTC

Return-Path: <rstruik@certicom.com>
X-Original-To: 6lowpan@core3.amsl.com
Delivered-To: 6lowpan@core3.amsl.com
Received: from localhost (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id 514543A6E5E for <6lowpan@core3.amsl.com>; Wed, 17 Jun 2009 07:06:06 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.999
X-Spam-Level:
X-Spam-Status: No, score=-1.999 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, J_CHICKENPOX_14=0.6]
Received: from mail.ietf.org ([64.170.98.32]) by localhost (core3.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id RWzuuwVvak-6 for <6lowpan@core3.amsl.com>; Wed, 17 Jun 2009 07:06:06 -0700 (PDT)
Received: from cx297.800onemail.com (CX297.800onemail.com [209.20.1.115]) by core3.amsl.com (Postfix) with ESMTP id 107563A6BD6 for <6lowpan@ietf.org>; Wed, 17 Jun 2009 07:06:05 -0700 (PDT)
Received: from ex13-n01.exchserver.com ([192.168.162.157]) by cx297.800onemail.com (8.13.8/8.13.8) with ESMTP id n5HDxhKA022762 for <6lowpan@ietf.org>; Wed, 17 Jun 2009 09:59:43 -0400
Received: from EX41.exchserver.com ([169.254.1.219]) by ex13-n01.exchserver.com ([192.168.162.160]) with mapi; Wed, 17 Jun 2009 10:02:46 -0400
From: Rene Struik <rstruik@certicom.com>
To: "6lowpan@ietf.org" <6lowpan@ietf.org>
Date: Wed, 17 Jun 2009 10:02:44 -0400
Thread-Topic: (cutting overhead) RE: [6lowpan] LoWPAN simple fragment Recovery
Thread-Index: AcnvE/8kJCaRMuJTRyO8jU2VvjoVRAABJ6EwAA12A/AAAXMdYA==
Message-ID: <473C2CD540AC5141858AD4D50149C4B3AB14FC@EX41.exchserver.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
acceptlanguage: en-US
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: quoted-printable
MIME-Version: 1.0
X-CRXEFW-Info: Please contact Ceryx for more information
X-CRXEFW-Virus: Clean
X-CRXEFW-From: rstruik@certicom.com
Subject: [6lowpan] (cutting overhead) RE: LoWPAN simple fragment Recovery
X-BeenThere: 6lowpan@ietf.org
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: Working group discussion for IPv6 over LowPan networks <6lowpan.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/listinfo/6lowpan>, <mailto:6lowpan-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/6lowpan>
List-Post: <mailto:6lowpan@ietf.org>
List-Help: <mailto:6lowpan-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/6lowpan>, <mailto:6lowpan-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 17 Jun 2009 14:06:06 -0000

Hi Pascal:

If one does fragmentation and has multiple frames, one should be able to compress 802.15.4 headers for the subsequent frames. 

One could proceed as follows:
a) first frame could use full header;
b) subsequent frames would use truncated MAC header overhead (under assumption that this can be faithfully reconstructed at recipient's end (who stores header intelligence if frame pending bit is set).
c) crypto overhead (message authentication tag) can be seriously shortened for typical frames.

This would potentially lead to the following:
a) first frame has full header;
b) subsequent frames: 5 octets of non payload fields total;
- reduced MAC header: 3 octets (sFCF: 1 octet; DSN: 1 octet; Header fields: 0 octets; AuxSecHeader: 1 octet); 
- reduced crypto expansion: 2 octets (typically - if realizing what I dubbed "Frame Security Dream");
- elided CRC-16: 0 octets (if one uses authenticity tag (with default key if no security)).
Thus, with frame fragmentation, all but the first frame may have payload field of up to 122 octets.

This is not always possible with 802.15.4-2006 techniques, but intention is that 802.15.4e amendment enables this.
For further info, cf. IEEE 802.15.4e document: 15-08-0828-08-004e-security-and-efficiency-enhancements.ppt

I should remember to take this into account when writing up the draft text for overhead reduction techniques for 802.15.4e, making sure to make the link to frame pending stuff. 

Any comments appreciated.

Best regards, 

Rene

-----Original Message-----
From: 6lowpan-bounces@ietf.org [mailto:6lowpan-bounces@ietf.org] On Behalf Of Pascal Thubert (pthubert)
Sent: Wednesday, June 17, 2009 5:17 AM
To: Carsten Bormann
Cc: draft-thubert-6lowpan-simple-fragment-recovery@tools.ietf.org; 6lowpan@ietf.org; Fred Baker (fred)
Subject: Re: [6lowpan] LoWPAN simple fragment Recovery

Hi Carsten:

I love your suggestions. Thanks a lot :)

Since there is no additional data in the FRACK we could deduce the size
of the ack bitmap from the packet length, but I would not go that way.

Let's see what we have on the table


A) As you say we could elide trailing zeroes.
We'd use the first 2 bits to say how many bytes in the bitmap, trail all
zeroes.


Acknowledging within the first  6 fragments takes one octet coded as
00xxxxxx 
Acknowledging within the first 14 fragments takes one octet coded as
01xxxxxx xxxxxxxx 
Acknowledging within the first 22 fragments takes one octet coded as
10xxxxxx xxxxxxxx xxxxxxxx  
Acknowledging within the first 30 fragments takes one octet coded as
11xxxxxx xxxxxxxx xxxxxxxx xxxxxxxx

B) Or we could use an encoding similar to the LOWPAN_NHC in the header
compression draft.

Acknowledging within the first 7 fragments takes one octet coded as
0xxxxxxx
Acknowledging within the first 14 fragments takes 2 octets coded as
10xxxxxx xxxxxxxx
Acknowledging within the first 21 fragments takes 3 octets coded as
110xxxxx xxxxxxxx xxxxxxxx 
Acknowledging within the first 28 fragments takes 3 octets coded as
1110xxxx xxxxxxxx xxxxxxxx xxxxxxxx

Theoretically that could lead us as far as we care to go but it seems
that 28 is enough.
Also we might want to write right to left to avoid shifting bits around.

Conclusion: 

A) gives us up to 30 fragments and a very simple encoding as opposed to
28 for B
B) is more efficient in that it saves one octet for the 7th fragment
whereas A saves on octet on the 22nd, which is probably a much rarer
occasion.

I'd be more inclined to use B) for the slightly better compression but
I'd appreciate opinions on this. 

Opinions? Votes are:

A, B, or B+read right to left.

Pascal

>-----Original Message-----
>From: Carsten Bormann [mailto:cabo@tzi.org]
>Sent: mercredi 17 juin 2009 08:22
>To: Pascal Thubert (pthubert)
>Cc: Fred Baker (fred);
draft-thubert-6lowpan-simple-fragment-recovery@tools.ietf.org;
6lowpan@ietf.org
>Subject: Re: [6lowpan] LoWPAN simple fragment Recovery
>
>On Jun 17, 2009, at 07:54, Pascal Thubert (pthubert) wrote:
>
>> 80 bytes
>
>Well.
>
>MAC frame mac: 127 bytes
>MAC header/trailer: 5 bytes
>Adresses (usually, if EUI-64 is used): 18 bytes
>Security Header: 0..14 bytes (depending e.g. on key identifier)
>Security Trailer (MIC): 0/4/8/16 bytes
>
>Depending on how security is being used, the MAC payload may be as low
>as 74 bytes.
>With 6 bytes of fragment header overhead, we are at 68; with rounding
>to a multiple of 8, we are at 64.
>1280/64 = 20.
>
>The first fragment may have some additional header overhead (somewhat
>unlikely, but possible), so I'd say:
>
>21 fragments
>
>This is without a mesh header.
>If a mesh header in the current worst case configuration is needed,
>make that 28 (!).
>
>I think rounding up to 32 is about right.
>5 bits for the sequence number also happens to match up with the 11
>bits needed for the datagram size.
>
>Spending a bit or two of those for some form of huffman/rice coding
>might be the more appropriate way to save bytes in the FRACK packet,
>if that is a concern, because many packets will fit into much fewer
>(eg., 7 or less, 14 or less) fragments.  Or, simpler, trailing zeroes
>might be suppressed in the FRACK.
>
>All this pesky bit fiddling...  But someone has to do it.
>
>Gruesse, Carsten

_______________________________________________
6lowpan mailing list
6lowpan@ietf.org
https://www.ietf.org/mailman/listinfo/6lowpan