Blame include/lttng/bitfield.h

Packit c04fcb
#ifndef _BABELTRACE_BITFIELD_H
Packit c04fcb
#define _BABELTRACE_BITFIELD_H
Packit c04fcb
Packit c04fcb
/*
Packit c04fcb
 * BabelTrace
Packit c04fcb
 *
Packit c04fcb
 * Bitfields read/write functions.
Packit c04fcb
 *
Packit c04fcb
 * Copyright 2010 - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Packit c04fcb
 *
Packit c04fcb
 * Permission is hereby granted, free of charge, to any person obtaining a copy
Packit c04fcb
 * of this software and associated documentation files (the "Software"), to deal
Packit c04fcb
 * in the Software without restriction, including without limitation the rights
Packit c04fcb
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
Packit c04fcb
 * copies of the Software, and to permit persons to whom the Software is
Packit c04fcb
 * furnished to do so, subject to the following conditions:
Packit c04fcb
 *
Packit c04fcb
 * The above copyright notice and this permission notice shall be included in
Packit c04fcb
 * all copies or substantial portions of the Software.
Packit c04fcb
 *
Packit c04fcb
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Packit c04fcb
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit c04fcb
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Packit c04fcb
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Packit c04fcb
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Packit c04fcb
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
Packit c04fcb
 * SOFTWARE.
Packit c04fcb
 */
Packit c04fcb
Packit c04fcb
#include <stdint.h>	/* C99 5.2.4.2 Numerical limits */
Packit c04fcb
#include <limits.h>	/* C99 5.2.4.2 Numerical limits */
Packit c04fcb
#include <lttng/ust-endian.h>	/* Non-standard BIG_ENDIAN, LITTLE_ENDIAN, BYTE_ORDER */
Packit c04fcb
Packit c04fcb
/* We can't shift a int from 32 bit, >> 32 and << 32 on int is undefined */
Packit c04fcb
#define _bt_piecewise_rshift(_v, _shift)				\
Packit c04fcb
({									\
Packit c04fcb
	__typeof__(_v) ___v = (_v);						\
Packit c04fcb
	__typeof__(_shift) ___shift = (_shift);				\
Packit c04fcb
	unsigned long sb = (___shift) / (sizeof(___v) * CHAR_BIT - 1);	\
Packit c04fcb
	unsigned long final = (___shift) % (sizeof(___v) * CHAR_BIT - 1); \
Packit c04fcb
									\
Packit c04fcb
	for (; sb; sb--)						\
Packit c04fcb
		___v >>= sizeof(___v) * CHAR_BIT - 1;			\
Packit c04fcb
	___v >>= final;							\
Packit c04fcb
})
Packit c04fcb
Packit c04fcb
#define _bt_piecewise_lshift(_v, _shift)				\
Packit c04fcb
({									\
Packit c04fcb
	__typeof__(_v) ___v = (_v);						\
Packit c04fcb
	__typeof__(_shift) ___shift = (_shift);				\
Packit c04fcb
	unsigned long sb = (___shift) / (sizeof(___v) * CHAR_BIT - 1);	\
Packit c04fcb
	unsigned long final = (___shift) % (sizeof(___v) * CHAR_BIT - 1); \
Packit c04fcb
									\
Packit c04fcb
	for (; sb; sb--)						\
Packit c04fcb
		___v <<= sizeof(___v) * CHAR_BIT - 1;			\
Packit c04fcb
	___v <<= final;							\
Packit c04fcb
})
Packit c04fcb
Packit c04fcb
#define _bt_is_signed_type(type)	((type) -1 < (type) 0)
Packit c04fcb
Packit c04fcb
#define _bt_unsigned_cast(type, v)					\
Packit c04fcb
({									\
Packit c04fcb
	(sizeof(v) < sizeof(type)) ?					\
Packit c04fcb
		((type) (v)) & (~(~(type) 0 << (sizeof(v) * CHAR_BIT))) : \
Packit c04fcb
		(type) (v);						\
Packit c04fcb
})
Packit c04fcb
Packit c04fcb
/*
Packit c04fcb
 * bt_bitfield_write - write integer to a bitfield in native endianness
Packit c04fcb
 *
Packit c04fcb
 * Save integer to the bitfield, which starts at the "start" bit, has "len"
Packit c04fcb
 * bits.
Packit c04fcb
 * The inside of a bitfield is from high bits to low bits.
Packit c04fcb
 * Uses native endianness.
Packit c04fcb
 * For unsigned "v", pad MSB with 0 if bitfield is larger than v.
Packit c04fcb
 * For signed "v", sign-extend v if bitfield is larger than v.
Packit c04fcb
 *
Packit c04fcb
 * On little endian, bytes are placed from the less significant to the most
Packit c04fcb
 * significant. Also, consecutive bitfields are placed from lower bits to higher
Packit c04fcb
 * bits.
Packit c04fcb
 *
Packit c04fcb
 * On big endian, bytes are places from most significant to less significant.
Packit c04fcb
 * Also, consecutive bitfields are placed from higher to lower bits.
Packit c04fcb
 */
Packit c04fcb
Packit c04fcb
#define _bt_bitfield_write_le(_ptr, type, _start, _length, _v)		\
Packit c04fcb
do {									\
Packit c04fcb
	__typeof__(_v) __v = (_v);						\
Packit c04fcb
	type *__ptr = (void *) (_ptr);					\
Packit c04fcb
	unsigned long __start = (_start), __length = (_length);		\
Packit c04fcb
	type mask, cmask;						\
Packit c04fcb
	unsigned long ts = sizeof(type) * CHAR_BIT; /* type size */	\
Packit c04fcb
	unsigned long start_unit, end_unit, this_unit;			\
Packit c04fcb
	unsigned long end, cshift; /* cshift is "complement shift" */	\
Packit c04fcb
									\
Packit c04fcb
	if (!__length)							\
Packit c04fcb
		break;							\
Packit c04fcb
									\
Packit c04fcb
	end = __start + __length;					\
Packit c04fcb
	start_unit = __start / ts;					\
Packit c04fcb
	end_unit = (end + (ts - 1)) / ts;				\
Packit c04fcb
									\
Packit c04fcb
	/* Trim v high bits */						\
Packit c04fcb
	if (__length < sizeof(__v) * CHAR_BIT)				\
Packit c04fcb
		__v &= ~((~(__typeof__(__v)) 0) << __length);		\
Packit c04fcb
									\
Packit c04fcb
	/* We can now append v with a simple "or", shift it piece-wise */ \
Packit c04fcb
	this_unit = start_unit;						\
Packit c04fcb
	if (start_unit == end_unit - 1) {				\
Packit c04fcb
		mask = ~((~(type) 0) << (__start % ts));		\
Packit c04fcb
		if (end % ts)						\
Packit c04fcb
			mask |= (~(type) 0) << (end % ts);		\
Packit c04fcb
		cmask = (type) __v << (__start % ts);			\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
	if (__start % ts) {						\
Packit c04fcb
		cshift = __start % ts;					\
Packit c04fcb
		mask = ~((~(type) 0) << cshift);			\
Packit c04fcb
		cmask = (type) __v << cshift;				\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
		__v = _bt_piecewise_rshift(__v, ts - cshift);		\
Packit c04fcb
		__start += ts - cshift;					\
Packit c04fcb
		this_unit++;						\
Packit c04fcb
	}								\
Packit c04fcb
	for (; this_unit < end_unit - 1; this_unit++) {			\
Packit c04fcb
		__ptr[this_unit] = (type) __v;				\
Packit c04fcb
		__v = _bt_piecewise_rshift(__v, ts);			\
Packit c04fcb
		__start += ts;						\
Packit c04fcb
	}								\
Packit c04fcb
	if (end % ts) {							\
Packit c04fcb
		mask = (~(type) 0) << (end % ts);			\
Packit c04fcb
		cmask = (type) __v;					\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
	} else								\
Packit c04fcb
		__ptr[this_unit] = (type) __v;				\
Packit c04fcb
} while (0)
Packit c04fcb
Packit c04fcb
#define _bt_bitfield_write_be(_ptr, type, _start, _length, _v)		\
Packit c04fcb
do {									\
Packit c04fcb
	__typeof__(_v) __v = (_v);						\
Packit c04fcb
	type *__ptr = (void *) (_ptr);					\
Packit c04fcb
	unsigned long __start = (_start), __length = (_length);		\
Packit c04fcb
	type mask, cmask;						\
Packit c04fcb
	unsigned long ts = sizeof(type) * CHAR_BIT; /* type size */	\
Packit c04fcb
	unsigned long start_unit, end_unit, this_unit;			\
Packit c04fcb
	unsigned long end, cshift; /* cshift is "complement shift" */	\
Packit c04fcb
									\
Packit c04fcb
	if (!__length)							\
Packit c04fcb
		break;							\
Packit c04fcb
									\
Packit c04fcb
	end = __start + __length;					\
Packit c04fcb
	start_unit = __start / ts;					\
Packit c04fcb
	end_unit = (end + (ts - 1)) / ts;				\
Packit c04fcb
									\
Packit c04fcb
	/* Trim v high bits */						\
Packit c04fcb
	if (__length < sizeof(__v) * CHAR_BIT)				\
Packit c04fcb
		__v &= ~((~(__typeof__(__v)) 0) << __length);		\
Packit c04fcb
									\
Packit c04fcb
	/* We can now append v with a simple "or", shift it piece-wise */ \
Packit c04fcb
	this_unit = end_unit - 1;					\
Packit c04fcb
	if (start_unit == end_unit - 1) {				\
Packit c04fcb
		mask = ~((~(type) 0) << ((ts - (end % ts)) % ts));	\
Packit c04fcb
		if (__start % ts)					\
Packit c04fcb
			mask |= (~((type) 0)) << (ts - (__start % ts));	\
Packit c04fcb
		cmask = (type) __v << ((ts - (end % ts)) % ts);		\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
	if (end % ts) {							\
Packit c04fcb
		cshift = end % ts;					\
Packit c04fcb
		mask = ~((~(type) 0) << (ts - cshift));			\
Packit c04fcb
		cmask = (type) __v << (ts - cshift);			\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
		__v = _bt_piecewise_rshift(__v, cshift);		\
Packit c04fcb
		end -= cshift;						\
Packit c04fcb
		this_unit--;						\
Packit c04fcb
	}								\
Packit c04fcb
	for (; (long) this_unit >= (long) start_unit + 1; this_unit--) { \
Packit c04fcb
		__ptr[this_unit] = (type) __v;				\
Packit c04fcb
		__v = _bt_piecewise_rshift(__v, ts);			\
Packit c04fcb
		end -= ts;						\
Packit c04fcb
	}								\
Packit c04fcb
	if (__start % ts) {						\
Packit c04fcb
		mask = (~(type) 0) << (ts - (__start % ts));		\
Packit c04fcb
		cmask = (type) __v;					\
Packit c04fcb
		cmask &= ~mask;						\
Packit c04fcb
		__ptr[this_unit] &= mask;				\
Packit c04fcb
		__ptr[this_unit] |= cmask;				\
Packit c04fcb
	} else								\
Packit c04fcb
		__ptr[this_unit] = (type) __v;				\
Packit c04fcb
} while (0)
Packit c04fcb
Packit c04fcb
/*
Packit c04fcb
 * bt_bitfield_write - write integer to a bitfield in native endianness
Packit c04fcb
 * bt_bitfield_write_le - write integer to a bitfield in little endian
Packit c04fcb
 * bt_bitfield_write_be - write integer to a bitfield in big endian
Packit c04fcb
 */
Packit c04fcb
Packit c04fcb
#if (BYTE_ORDER == LITTLE_ENDIAN)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_write(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_le(ptr, type, _start, _length, _v)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_write_le(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_le(ptr, type, _start, _length, _v)
Packit c04fcb
	
Packit c04fcb
#define bt_bitfield_write_be(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_be(ptr, unsigned char, _start, _length, _v)
Packit c04fcb
Packit c04fcb
#elif (BYTE_ORDER == BIG_ENDIAN)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_write(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_be(ptr, type, _start, _length, _v)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_write_le(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_le(ptr, unsigned char, _start, _length, _v)
Packit c04fcb
	
Packit c04fcb
#define bt_bitfield_write_be(ptr, type, _start, _length, _v)		\
Packit c04fcb
	_bt_bitfield_write_be(ptr, type, _start, _length, _v)
Packit c04fcb
Packit c04fcb
#else /* (BYTE_ORDER == PDP_ENDIAN) */
Packit c04fcb
Packit c04fcb
#error "Byte order not supported"
Packit c04fcb
Packit c04fcb
#endif
Packit c04fcb
Packit c04fcb
#define _bt_bitfield_read_le(_ptr, type, _start, _length, _vptr)	\
Packit c04fcb
do {									\
Packit c04fcb
	__typeof__(*(_vptr)) *__vptr = (_vptr);				\
Packit c04fcb
	__typeof__(*__vptr) __v;						\
Packit c04fcb
	type *__ptr = (void *) (_ptr);					\
Packit c04fcb
	unsigned long __start = (_start), __length = (_length);		\
Packit c04fcb
	type mask, cmask;						\
Packit c04fcb
	unsigned long ts = sizeof(type) * CHAR_BIT; /* type size */	\
Packit c04fcb
	unsigned long start_unit, end_unit, this_unit;			\
Packit c04fcb
	unsigned long end, cshift; /* cshift is "complement shift" */	\
Packit c04fcb
									\
Packit c04fcb
	if (!__length) {						\
Packit c04fcb
		*__vptr = 0;						\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
									\
Packit c04fcb
	end = __start + __length;					\
Packit c04fcb
	start_unit = __start / ts;					\
Packit c04fcb
	end_unit = (end + (ts - 1)) / ts;				\
Packit c04fcb
									\
Packit c04fcb
	this_unit = end_unit - 1;					\
Packit c04fcb
	if (_bt_is_signed_type(__typeof__(__v))				\
Packit c04fcb
	    && (__ptr[this_unit] & ((type) 1 << ((end % ts ? : ts) - 1)))) \
Packit c04fcb
		__v = ~(__typeof__(__v)) 0;					\
Packit c04fcb
	else								\
Packit c04fcb
		__v = 0;						\
Packit c04fcb
	if (start_unit == end_unit - 1) {				\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask >>= (__start % ts);				\
Packit c04fcb
		if ((end - __start) % ts) {				\
Packit c04fcb
			mask = ~((~(type) 0) << (end - __start));	\
Packit c04fcb
			cmask &= mask;					\
Packit c04fcb
		}							\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, end - __start);		\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
		*__vptr = __v;						\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
	if (end % ts) {							\
Packit c04fcb
		cshift = end % ts;					\
Packit c04fcb
		mask = ~((~(type) 0) << cshift);			\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask &= mask;						\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, cshift);		\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
		end -= cshift;						\
Packit c04fcb
		this_unit--;						\
Packit c04fcb
	}								\
Packit c04fcb
	for (; (long) this_unit >= (long) start_unit + 1; this_unit--) { \
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts);			\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), __ptr[this_unit]);\
Packit c04fcb
		end -= ts;						\
Packit c04fcb
	}								\
Packit c04fcb
	if (__start % ts) {						\
Packit c04fcb
		mask = ~((~(type) 0) << (ts - (__start % ts)));		\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask >>= (__start % ts);				\
Packit c04fcb
		cmask &= mask;						\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts - (__start % ts));	\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
	} else {							\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts);			\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), __ptr[this_unit]);\
Packit c04fcb
	}								\
Packit c04fcb
	*__vptr = __v;							\
Packit c04fcb
} while (0)
Packit c04fcb
Packit c04fcb
#define _bt_bitfield_read_be(_ptr, type, _start, _length, _vptr)	\
Packit c04fcb
do {									\
Packit c04fcb
	__typeof__(*(_vptr)) *__vptr = (_vptr);				\
Packit c04fcb
	__typeof__(*__vptr) __v;						\
Packit c04fcb
	type *__ptr = (void *) (_ptr);					\
Packit c04fcb
	unsigned long __start = (_start), __length = (_length);		\
Packit c04fcb
	type mask, cmask;						\
Packit c04fcb
	unsigned long ts = sizeof(type) * CHAR_BIT; /* type size */	\
Packit c04fcb
	unsigned long start_unit, end_unit, this_unit;			\
Packit c04fcb
	unsigned long end, cshift; /* cshift is "complement shift" */	\
Packit c04fcb
									\
Packit c04fcb
	if (!__length) {						\
Packit c04fcb
		*__vptr = 0;						\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
									\
Packit c04fcb
	end = __start + __length;					\
Packit c04fcb
	start_unit = __start / ts;					\
Packit c04fcb
	end_unit = (end + (ts - 1)) / ts;				\
Packit c04fcb
									\
Packit c04fcb
	this_unit = start_unit;						\
Packit c04fcb
	if (_bt_is_signed_type(__typeof__(__v))				\
Packit c04fcb
	    && (__ptr[this_unit] & ((type) 1 << (ts - (__start % ts) - 1)))) \
Packit c04fcb
		__v = ~(__typeof__(__v)) 0;					\
Packit c04fcb
	else								\
Packit c04fcb
		__v = 0;						\
Packit c04fcb
	if (start_unit == end_unit - 1) {				\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask >>= (ts - (end % ts)) % ts;			\
Packit c04fcb
		if ((end - __start) % ts) {				\
Packit c04fcb
			mask = ~((~(type) 0) << (end - __start));	\
Packit c04fcb
			cmask &= mask;					\
Packit c04fcb
		}							\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, end - __start);		\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
		*__vptr = __v;						\
Packit c04fcb
		break;							\
Packit c04fcb
	}								\
Packit c04fcb
	if (__start % ts) {						\
Packit c04fcb
		cshift = __start % ts;					\
Packit c04fcb
		mask = ~((~(type) 0) << (ts - cshift));			\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask &= mask;						\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts - cshift);		\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
		__start += ts - cshift;					\
Packit c04fcb
		this_unit++;						\
Packit c04fcb
	}								\
Packit c04fcb
	for (; this_unit < end_unit - 1; this_unit++) {			\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts);			\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), __ptr[this_unit]);\
Packit c04fcb
		__start += ts;						\
Packit c04fcb
	}								\
Packit c04fcb
	if (end % ts) {							\
Packit c04fcb
		mask = ~((~(type) 0) << (end % ts));			\
Packit c04fcb
		cmask = __ptr[this_unit];				\
Packit c04fcb
		cmask >>= ts - (end % ts);				\
Packit c04fcb
		cmask &= mask;						\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, end % ts);		\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), cmask);		\
Packit c04fcb
	} else {							\
Packit c04fcb
		__v = _bt_piecewise_lshift(__v, ts);			\
Packit c04fcb
		__v |= _bt_unsigned_cast(__typeof__(__v), __ptr[this_unit]);\
Packit c04fcb
	}								\
Packit c04fcb
	*__vptr = __v;							\
Packit c04fcb
} while (0)
Packit c04fcb
Packit c04fcb
/*
Packit c04fcb
 * bt_bitfield_read - read integer from a bitfield in native endianness
Packit c04fcb
 * bt_bitfield_read_le - read integer from a bitfield in little endian
Packit c04fcb
 * bt_bitfield_read_be - read integer from a bitfield in big endian
Packit c04fcb
 */
Packit c04fcb
Packit c04fcb
#if (BYTE_ORDER == LITTLE_ENDIAN)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_read(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_le(_ptr, type, _start, _length, _vptr)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_read_le(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_le(_ptr, type, _start, _length, _vptr)
Packit c04fcb
	
Packit c04fcb
#define bt_bitfield_read_be(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_be(_ptr, unsigned char, _start, _length, _vptr)
Packit c04fcb
Packit c04fcb
#elif (BYTE_ORDER == BIG_ENDIAN)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_read(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_be(_ptr, type, _start, _length, _vptr)
Packit c04fcb
Packit c04fcb
#define bt_bitfield_read_le(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_le(_ptr, unsigned char, _start, _length, _vptr)
Packit c04fcb
	
Packit c04fcb
#define bt_bitfield_read_be(_ptr, type, _start, _length, _vptr)		\
Packit c04fcb
	_bt_bitfield_read_be(_ptr, type, _start, _length, _vptr)
Packit c04fcb
Packit c04fcb
#else /* (BYTE_ORDER == PDP_ENDIAN) */
Packit c04fcb
Packit c04fcb
#error "Byte order not supported"
Packit c04fcb
Packit c04fcb
#endif
Packit c04fcb
Packit c04fcb
#endif /* _BABELTRACE_BITFIELD_H */