Hi Andrei, On Mon, Oct 24, 2011 at 11:20 AM, Emeltchenko Andrei <Andrei.Emeltchenko.news@xxxxxxxxx> wrote: > From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx> > > Helpers to access LE / BE values. In bluetooth there is a mixture > of LE / BE network byte order. > --- Sorry if this comes too late, but here's an idea: How about changing the name of the functions to something a little more high level, for example: in attrib/att.h we have att_{get,put}_u16() that uses the byte order defined in the ATT spec (little endian). So my suggestion is to have bt_{get,put}_u*() and sdp_{get,put}_u* functions (perhaps also no_{get,put}_u* for cases when we use the host byte order). The bt_ functions will be used for everything that uses the Bluetooth byte order and the sdp_ ones for SDP, which is the only case of Big Endian defined by Bluetooth, correct me if I am wrong. What do you think? > lib/bluetooth.h | 64 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ > 1 files changed, 64 insertions(+), 0 deletions(-) > > diff --git a/lib/bluetooth.h b/lib/bluetooth.h > index b0680e2..5bd4f03 100644 > --- a/lib/bluetooth.h > +++ b/lib/bluetooth.h > @@ -125,6 +125,70 @@ do { \ > __p->__v = (val); \ > } while(0) > > +#if __BYTE_ORDER == __LITTLE_ENDIAN > +static inline uint64_t bt_get_le64(void *ptr) > +{ > + return bt_get_unaligned((uint64_t *) ptr); > +} > + > +static inline uint64_t bt_get_be64(void *ptr) > +{ > + return bswap_64(bt_get_unaligned((uint64_t *) ptr)); > +} > + > +static inline uint32_t bt_get_le32(void *ptr) > +{ > + return bt_get_unaligned((uint32_t *) ptr); > +} > + > +static inline uint32_t bt_get_be32(void *ptr) > +{ > + return bswap_32(bt_get_unaligned((uint32_t *) ptr)); > +} > + > +static inline uint16_t bt_get_le16(void *ptr) > +{ > + return bt_get_unaligned((uint16_t *) ptr); > +} > + > +static inline uint16_t bt_get_be16(void *ptr) > +{ > + return bswap_16(bt_get_unaligned((uint16_t *) ptr)); > +} > +#elif __BYTE_ORDER == __BIG_ENDIAN > +static inline uint64_t bt_get_le64(void *ptr) > +{ > + return bswap_64(bt_get_unaligned((uint64_t *) ptr)); > +} > + > +static inline uint64_t bt_get_be64(void *ptr) > +{ > + return bt_get_unaligned((uint64_t *) ptr); > +} > + > +static inline uint32_t bt_get_le32(void *ptr) > +{ > + return bswap_32(bt_get_unaligned((uint32_t *) ptr)); > +} > + > +static inline uint32_t bt_get_be32(void *ptr) > +{ > + return bt_get_unaligned((uint32_t *) ptr); > +} > + > +static inline uint16_t bt_get_le16(void *ptr) > +{ > + return bswap_16(bt_get_unaligned((uint16_t *) ptr)); > +} > + > +static inline uint16_t bt_get_be16(void *ptr) > +{ > + return bt_get_unaligned((uint16_t *) ptr); > +} > +#else > +#error "Unknown byte order" > +#endif > + > /* BD Address */ > typedef struct { > uint8_t b[6]; > -- > 1.7.4.1 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > Cheers, -- Vinicius -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html