[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1447799594-6050-1-git-send-email-alex.aring@gmail.com>
Date: Tue, 17 Nov 2015 23:33:11 +0100
From: Alexander Aring <alex.aring@...il.com>
To: linux-wpan@...r.kernel.org
Cc: linux-bluetooth@...r.kernel.org, netdev@...r.kernel.org,
kernel@...gutronix.de, mcr@...delman.ca, lukasz.duda@...dicsemi.no,
martin.gergeleit@...rm.de, Alexander Aring <alex.aring@...il.com>
Subject: [RFCv2 bluetooth-next 0/3] 6lowpan: debugfs and stateful compression support
Hi,
This patch based on the work of Lukasz Duda. It doesn't contain any interface
lookup methods since we have a generic private dataroom per 6lowpan interface.
Also I dropped the list implementation and do a simple array one. It also
contains support for multicast stateful compression.
To access the context we supporting a complete callback structure for
operations, the include/net/6lowpan.h header contains static inline functions
to call these operations. With such behaviour we don't get any module
dependencies if we need upcomming runtime decisions inside the IPv6 stack.
The alternative would be to do everything inside static inline functions, but
there are few different to handling unicast and multicast context id's, so
it's maybe better to do this as "ops callback structure".
Few things which I am not sure about if it's correct:
- I implement the dci multicast context table and dci unicast as different
table. I don't know if when I have a context id "6" which is multicast
then, I don't can have a unicast context id which is "6". I think they are
different and we can indicate which table we need to use by the IPHC M bit
(receiving side) or the multicast address scope (transmit side).
- Unicast context prefix length can be shorter than 64 bits. Yes this can be,
but if somebody wants to do that he usually means "expand the bits until 64
with zeros". I forbid to add prefix below 64 bits for now.
Each stateful compression has cases for the IID bits (last 8 byte, use it as
inline data/do compression, etc.). When I have a prefix 2000:: with prefix
length 16, then I we hit the case of "Any remaining bits are zero." of
stateful compression, this means it can be converted by "2000::" prefix
length 64, then we don't need to care about that when doing a lookup of
context.
- I tried to get wireshark know about the available context without success.
What I successful get working is tell prefix length exact 64 bits long. I
don't know if wireshark do a correct context handling here, but it's also
possible to have a prefix length above 64 (In my opinion). E.g. unicast
stateful compression in case of SAM/DAM 01:
"Bits covered by context information are always used. Any IID bits not
covered by context information are taken directly from the corresponding
bits carried in-line.
This patch series do following handling for this case:
1. generate ipv6 address with inline IID data.
2. copy the prefix bits from context to the address, which _maybe_ overwrite
the IID (last eight bytes) data which was carried as inline data.
This means, if my context is a full address 2001::1/128, then it will be
the case of SAM/DAM = 11, which means the address is fully elided. (Don't
care about the IID bits, which will be reconstructed from encapsulating
header.
All others SAM/DAM cases has a similar handling.
Nevertheless I don't know how I can tell that wireshark, I can tell prefix which
are 64 bit's long only.
Any comments are welcome.
- Alex
changes since RFCv2:
- fix cleanup for 6LoWPAN per interface debugfs
- add ipv6_addr_prefix_cpy
- replace lowpan_iphc_bitcpy with ipv6_addr_prefix_cpy (unicast)
replace lowpan_iphc_bitcpy with ipv6_addr_prefix and memcpy (multicast)
- add netdev mailinglist into cc
Alexander Aring (3):
6lowpan: add debugfs support
ipv6: add ipv6_addr_prefix_cpy
6lowpan: iphc: add support for stateful compression
include/net/6lowpan.h | 68 +++++-
include/net/ipv6.h | 15 ++
net/6lowpan/6lowpan_i.h | 31 +++
net/6lowpan/Kconfig | 8 +
net/6lowpan/Makefile | 1 +
net/6lowpan/core.c | 42 +++-
net/6lowpan/debugfs.c | 163 ++++++++++++++
net/6lowpan/iphc.c | 500 +++++++++++++++++++++++++++++++++++++-----
net/bluetooth/6lowpan.c | 21 +-
net/ieee802154/6lowpan/core.c | 18 +-
10 files changed, 796 insertions(+), 71 deletions(-)
create mode 100644 net/6lowpan/6lowpan_i.h
create mode 100644 net/6lowpan/debugfs.c
--
2.6.1
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists