X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fbyte-order.h;h=544f46fbcb68bc4ff9e9ec868d3fdac3d7c4eb50;hb=0ef165ecb57943e17a8ee8270df68ffb8d032e29;hp=352f91ee634b0b544ad346a9fedff1338c6eb1ca;hpb=4cf5406ba2e8bb8271940b2f54967c9fd1270212;p=sliver-openvswitch.git diff --git a/lib/byte-order.h b/lib/byte-order.h index 352f91ee6..544f46fbc 100644 --- a/lib/byte-order.h +++ b/lib/byte-order.h @@ -22,6 +22,7 @@ #include "openvswitch/types.h" #ifndef __CHECKER__ +#ifndef _WIN32 static inline ovs_be64 htonll(uint64_t n) { @@ -33,6 +34,7 @@ ntohll(ovs_be64 n) { return htonl(1) == 1 ? n : ((uint64_t) ntohl(n) << 32) | ntohl(n >> 32); } +#endif /* _WIN32 */ #else /* Making sparse happy with these functions also makes them unreadable, so * don't bother to show it their implementations. */ @@ -76,4 +78,16 @@ uint32_byteswap(uint32_t crc) { ((((ovs_be64) (VALUE)) & UINT64_C(0xff00000000000000)) >> 56)) #endif +#if WORDS_BIGENDIAN +#define BYTES_TO_BE32(B1, B2, B3, B4) \ + (OVS_FORCE ovs_be32)((uint32_t)(B1) << 24 | (B2) << 16 | (B3) << 8 | (B4)) +#define BE16S_TO_BE32(B1, B2) \ + (OVS_FORCE ovs_be32)((uint32_t)(B1) << 16 | (B2)) +#else +#define BYTES_TO_BE32(B1, B2, B3, B4) \ + (OVS_FORCE ovs_be32)((uint32_t)(B1) | (B2) << 8 | (B3) << 16 | (B4) << 24) +#define BE16S_TO_BE32(B1, B2) \ + (OVS_FORCE ovs_be32)((uint32_t)(B1) | (B2) << 16) +#endif + #endif /* byte-order.h */