Re: [PATCH linux-wpan v4] ieee802154: 6lowpan: ensure header compression does not corrupt ipv6 header

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Alex,

On ti, 2014-09-23 at 11:26 +0200, Alexander Aring wrote:
> On Tue, Sep 23, 2014 at 12:13:54PM +0300, Jukka Rissanen wrote:
> > Hi Alex,
> > 
> > On ma, 2014-09-22 at 18:21 +0200, Alexander Aring wrote:
> > 
> > > grml, I overlooked something the last version. But I will fix it while
> > > >  
> > > > -	cb->ackreq = !lowpan_is_addr_broadcast(daddr);
> > > > +	/* TODO: Currently we only support extended_addr */
> > > > +	info->daddr.mode = IEEE802154_ADDR_LONG;
> > > 
> > > now IEEE802154_ADDR_LONG is no little endian value copied from mac
> > > header. Somewhere else converted the little endian value to an host understandable
> > > enum/define number. For the rework I will remove this value. We should never
> > > ever convert this value for parsing.
> > > 
> > > We use it only for af_802154 and userspace specification what addresses
> > > should be used. But the above one to make this __le16 is incorrect. For
> > > userspace we should create some enums for declaring different address
> > > types. Then we can use this for 802.15.4 sockets.
> > 
> > BTW, at some point we might want to change the IEEE802154_ADDR_LONG in
> > net/6lowpan/iphc.c to more generic. Now this IEEE 802154 specific enum
> > needs to be mentioned in net/bluetooth/6lowpan.c which looks quite
> > confusing.
> > 
> 
> Yep, the generic name for such address is EUI-64. Forget the hyphen
> there. There is alot of 802.15.4 specific 6lowpan defines in iphc.c.
> They are defined in include/net/6lowpan.h, which should moved into an
> internal header of "net/ieee802154/...".
> 
> And also we could do this maybe not as address type, more a address
> length. EUI64 is 8 and the SHORT address is 2 bytes long. No special
> handling about some address types, only handling about different lengt,
> only handling about different lengths.

Agreed, the address length would be better.

> 
> so we have some:
> 
> switch (address_length) {
> case IEEE_EUI64_ADDRLEN:
> case IEEE802154_SHORT_ADDRLEN:
> default:
> 	/* not supported */
> }
> 
> the second case is only for IEEE802154 handling, maybe we could also
> check the netdev type, but that's not necessary. bluetooth should never
> set IEEE802154_SHORT_ADDRLEN by calling lowpan_header_create.
> 
> Also we don't support the case IEEE802154_SHORT_ADDRLEN right now. :-)
> That's currently dead code, it's a complicated issue to support that...
> but in near future we will support it, otherwise our stack is in an
> unusable state.
> 
> I mean IEEE_EUI64_ADDRLEN, is in 802154 the extended address. In
> bluetooth you need to generate the EUI64 with filling ff:fe pattern.
> Like behaviour in ethernet. And drop the special type handling.
> 
> Is this okay?

Yes, that sounds like a good plan.


Cheers,
Jukka



--
To unsubscribe from this list: send the line "unsubscribe linux-wpan" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux