util: Carry own definition of __bswap_constant{16,32}
musl doesn't define those, use our own definition there. This is a trivial implementation, similar to what's shipped by e.g. uClibc, glibc, libiio. Reported-by: Chris Kuhn <kuhnchris+github@kuhnchris.eu> Signed-off-by: Stefano Brivio <sbrivio@redhat.com> Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
89e38f5540
commit
50687616e4
1 changed files with 11 additions and 0 deletions
11
util.h
11
util.h
|
@ -88,6 +88,17 @@
|
||||||
#define MAC_ZERO ((uint8_t [ETH_ALEN]){ 0 })
|
#define MAC_ZERO ((uint8_t [ETH_ALEN]){ 0 })
|
||||||
#define MAC_IS_ZERO(addr) (!memcmp((addr), MAC_ZERO, ETH_ALEN))
|
#define MAC_IS_ZERO(addr) (!memcmp((addr), MAC_ZERO, ETH_ALEN))
|
||||||
|
|
||||||
|
#ifndef __bswap_constant_16
|
||||||
|
#define __bswap_constant_16(x) \
|
||||||
|
((uint16_t) ((((x) >> 8) & 0xff) | (((x) & 0xff) << 8)))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __bswap_constant_32
|
||||||
|
#define __bswap_constant_32(x) \
|
||||||
|
((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >> 8) | \
|
||||||
|
(((x) & 0x0000ff00) << 8) | (((x) & 0x000000ff) << 24))
|
||||||
|
#endif
|
||||||
|
|
||||||
#if __BYTE_ORDER == __BIG_ENDIAN
|
#if __BYTE_ORDER == __BIG_ENDIAN
|
||||||
#define htons_constant(x) (x)
|
#define htons_constant(x) (x)
|
||||||
#define htonl_constant(x) (x)
|
#define htonl_constant(x) (x)
|
||||||
|
|
Loading…
Reference in a new issue