[ofw] Re: [ofa-general] [RFC] 3/5: IB ACM: libibacm

Ira Weiny weiny2 at llnl.gov
Fri Sep 18 15:28:48 PDT 2009


On Fri, 18 Sep 2009 15:23:40 -0700
"Sean Hefty" <sean.hefty at intel.com> wrote:

> >Rough hack.  Does windows have stdint.h, byteswap.h, and endian.h?
> 
> If not, adding the headers with the needed definitions is trivial.
> 
> >+/* 16bit */
> >+#if __BYTE_ORDER == __LITTLE_ENDIAN
> >+#define CL_NTOH16( x )		(uint16_t)(		\
> >+			(((uint16_t)(x) & 0x00FF) << 8) |		\
> >+			(((uint16_t)(x) & 0xFF00) >> 8) )
> >+#else
> >+#define CL_NTOH16( x )	(x)
> >+#endif
> >+#define CL_HTON16				CL_NTOH16
> >+
> >+/* 32bit */
> >+#if __BYTE_ORDER == __LITTLE_ENDIAN
> >+#define CL_NTOH32( x )		(uint32_t)(			\
> >+			(((uint32_t)(x) & 0x000000FF) << 24) |	\
> >+			(((uint32_t)(x) & 0x0000FF00) << 8) |	\
> >+			(((uint32_t)(x) & 0x00FF0000) >> 8) |	\
> >+			(((uint32_t)(x) & 0xFF000000) >> 24) )
> >+#else
> >+#define CL_NTOH32( x )		(x)
> >+#endif
> >+#define CL_HTON32	CL_NTOH32
> >+
> >+/* 64bit */
> >+#if __BYTE_ORDER == __LITTLE_ENDIAN
> >+#define CL_NTOH64( x )		(uint64_t)(
> \
> >+			(((uint64_t)(x) & 0x00000000000000FFULL) << 56) |
> \
> >+			(((uint64_t)(x) & 0x000000000000FF00ULL) << 40) |
> \
> >+			(((uint64_t)(x) & 0x0000000000FF0000ULL) << 24) |
> \
> >+			(((uint64_t)(x) & 0x00000000FF000000ULL) << 8 ) |
> \
> >+			(((uint64_t)(x) & 0x000000FF00000000ULL) >> 8 ) |
> \
> >+			(((uint64_t)(x) & 0x0000FF0000000000ULL) >> 24) |
> \
> >+			(((uint64_t)(x) & 0x00FF000000000000ULL) >> 40) |
> \
> >+			(((uint64_t)(x) & 0xFF00000000000000ULL) >> 56) )
> >+#else
> >+#define CL_NTOH64( x )		(x)
> >+#endif
> >+#define CL_HTON64				CL_NTOH64
> >+
> >+#if __BYTE_ORDER == __LITTLE_ENDIAN
> >+#define cl_ntoh16(x)	bswap_16(x)
> >+#define cl_hton16(x)	bswap_16(x)
> >+#define cl_ntoh32(x)	bswap_32(x)
> >+#define cl_hton32(x)	bswap_32(x)
> >+#define cl_ntoh64(x)	(uint64_t)bswap_64(x)
> >+#define cl_hton64(x)	(uint64_t)bswap_64(x)
> >+#else				/* Big Endian */
> >+#define cl_ntoh16(x)	(x)
> >+#define cl_hton16(x)	(x)
> >+#define cl_ntoh32(x)	(x)
> >+#define cl_hton32(x)	(x)
> >+#define cl_ntoh64(x)	(x)
> >+#define cl_hton64(x)	(x)
> >+#endif
> 
> Why the different defines for cl_noth and CL_NTOH?

One is for static defines CL_NTOH and the other is for variables at run time.  I found this code in Linux.

__bswap_constant_16
__bswap_constant_32
__bswap_constant_64

Which does the same thing, but I am not sure if they are universal or not as they are in <bits/byteswap.h> rather than byteswap.h

Ira

-- 
Ira Weiny
Math Programmer/Computer Scientist
Lawrence Livermore National Lab
925-423-8008
weiny2 at llnl.gov



More information about the ofw mailing list