#ifndef NFTABLES_UTILS_H #define NFTABLES_UTILS_H #include #include #include #include #include #include #include #include #include #define BITS_PER_BYTE 8 #if defined(DEBUG) #define pr_debug(fmt, arg...) printf(fmt, ##arg) #else #define pr_debug(fmt, arg...) ({ if (false) {}; 0; }) #endif #if defined(DEBUG) && defined(HAVE_LIBGMP) #define pr_gmp_debug(fmt, arg...) gmp_printf(fmt, ##arg) #else #define pr_gmp_debug(fmt, arg...) ({ if (false) {}; 0; }) #endif #define __fmtstring(x, y) __attribute__((format(printf, x, y))) #if 0 #define __gmp_fmtstring(x, y) __fmtstring(x, y) #else #define __gmp_fmtstring(x, y) #endif #define __init __attribute__((constructor)) #define __exit __attribute__((destructor)) #define __must_check __attribute__((warn_unused_result)) #define __noreturn __attribute__((__noreturn__)) #ifdef DEBUG #define BUG(fmt, arg...) ({ fprintf(stderr, "BUG: " fmt, ##arg); assert(0); }) #else #define BUG(fmt, arg...) assert(0) #endif #define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2*!!(condition)])) #define BUILD_BUG_ON_ZERO(e) (sizeof(char[1 - 2 * !!(e)]) - 1) #define __must_be_array(a) \ BUILD_BUG_ON_ZERO(__builtin_types_compatible_p(typeof(a), typeof(&a[0]))) #define container_of(ptr, type, member) ({ \ typeof( ((type *)0)->member ) *__mptr = (ptr); \ (type *)( (void *)__mptr - offsetof(type,member) );}) /** * Return a pointer to a constant variable of a size smaller than the variable. */ #ifdef __LITTLE_ENDIAN_BITFIELD #define constant_data_ptr(val, len) \ ((void *)&(val)) #elif defined(__BIG_ENDIAN_BITFIELD) #define constant_data_ptr(val, len) \ ((void *)&(val) + sizeof(val) - (len) / BITS_PER_BYTE) #else #error "byteorder undefined" #endif #define field_sizeof(t, f) (sizeof(((t *)NULL)->f)) #define array_size(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr)) #define div_round_up(n, d) (((n) + (d) - 1) / (d)) #define round_up(n, b) (div_round_up(n, b) * b) #define min(x, y) ({ \ typeof(x) _min1 = (x); \ typeof(y) _min2 = (y); \ (void) (&_min1 == &_min2); \ _min1 < _min2 ? _min1 : _min2; }) #define max(x, y) ({ \ typeof(x) _max1 = (x); \ typeof(y) _max2 = (y); \ (void) (&_max1 == &_max2); \ _max1 > _max2 ? _max1 : _max2; }) /** * fls - find last (most-significant) bit set * @x: the word to search * * This is defined the same way as ffs. * Note fls(0) = 0, fls(1) = 1, fls(0x80000000) = 32. */ static inline int fls(int x) { int r = 32; if (!x) return 0; if (!(x & 0xffff0000u)) { x <<= 16; r -= 16; } if (!(x & 0xff000000u)) { x <<= 8; r -= 8; } if (!(x & 0xf0000000u)) { x <<= 4; r -= 4; } if (!(x & 0xc0000000u)) { x <<= 2; r -= 2; } if (!(x & 0x80000000u)) { x <<= 1; r -= 1; } return r; } extern void __memory_allocation_error(const char *filename, uint32_t line) __noreturn; #define memory_allocation_error() \ __memory_allocation_error(__FILE__, __LINE__); extern void xfree(const void *ptr); extern void *xmalloc(size_t size); extern void *xrealloc(void *ptr, size_t size); extern void *xzalloc(size_t size); extern char *xstrdup(const char *s); extern void xstrunescape(const char *in, char *out); #endif /* NFTABLES_UTILS_H */