| /* GPLv2 or OpenIB.org BSD (MIT) See COPYING file */ |
| #ifndef UTIL_UTIL_H |
| #define UTIL_UTIL_H |
| |
| #include <ccan/ilog.h> |
| #include <stdbool.h> |
| #include <sys/types.h> |
| #include <stdio.h> |
| |
| /* Return true if the snprintf succeeded, false if there was truncation or |
| * error */ |
| static inline bool __good_snprintf(size_t len, int rc) |
| { |
| return (rc < len && rc >= 0); |
| } |
| |
| #define check_snprintf(buf, len, fmt, ...) \ |
| __good_snprintf(len, snprintf(buf, len, fmt, ##__VA_ARGS__)) |
| |
| /* a CMP b. See also the BSD macro timercmp(). */ |
| #define ts_cmp(a, b, CMP) \ |
| (((a)->tv_sec == (b)->tv_sec) ? \ |
| ((a)->tv_nsec CMP (b)->tv_nsec) : \ |
| ((a)->tv_sec CMP (b)->tv_sec)) |
| |
| #define offsetofend(_type, _member) \ |
| (offsetof(_type, _member) + sizeof(((_type *)0)->_member)) |
| |
| #define BITS_PER_LONG (8 * sizeof(long)) |
| #define BITS_PER_LONG_LONG (8 * sizeof(long long)) |
| #define BITS_TO_LONGS(nr) (((nr) + BITS_PER_LONG - 1) / BITS_PER_LONG) |
| |
| #define GENMASK(h, l) \ |
| (((~0UL) - (1UL << (l)) + 1) & (~0UL >> (BITS_PER_LONG - 1 - (h)))) |
| #define GENMASK_ULL(h, l) \ |
| (((~0ULL) << (l)) & (~0ULL >> (BITS_PER_LONG_LONG - 1 - (h)))) |
| |
| #define BIT(nr) (1UL << (nr)) |
| #define BIT_ULL(nr) (1ULL << (nr)) |
| |
| #define __bf_shf(x) (__builtin_ffsll(x) - 1) |
| |
| /** |
| * FIELD_PREP() - prepare a bitfield element |
| * @_mask: shifted mask defining the field's length and position |
| * @_val: value to put in the field |
| * |
| * FIELD_PREP() masks and shifts up the value. The result should |
| * be combined with other fields of the bitfield using logical OR. |
| */ |
| #define FIELD_PREP(_mask, _val) \ |
| ({ \ |
| ((typeof(_mask))(_val) << __bf_shf(_mask)) & (_mask); \ |
| }) |
| |
| /** |
| * FIELD_GET() - extract a bitfield element |
| * @_mask: shifted mask defining the field's length and position |
| * @_reg: value of entire bitfield |
| * |
| * FIELD_GET() extracts the field specified by @_mask from the |
| * bitfield passed in as @_reg by masking and shifting it down. |
| */ |
| #define FIELD_GET(_mask, _reg) \ |
| ({ \ |
| (typeof(_mask))(((_reg) & (_mask)) >> __bf_shf(_mask)); \ |
| }) |
| |
| static inline unsigned long align(unsigned long val, unsigned long align) |
| { |
| return (val + align - 1) & ~(align - 1); |
| } |
| |
| static inline unsigned long align_down(unsigned long val, unsigned long _align) |
| { |
| return align(val - (_align - 1), _align); |
| } |
| |
| static inline uint64_t roundup_pow_of_two(uint64_t n) |
| { |
| return n == 1 ? 1 : 1ULL << ilog64(n - 1); |
| } |
| |
| static inline unsigned long DIV_ROUND_UP(unsigned long n, unsigned long d) |
| { |
| return (n + d - 1) / d; |
| } |
| |
| struct xorshift32_state { |
| /* The state word must be initialized to non-zero */ |
| uint32_t seed; |
| }; |
| |
| uint32_t xorshift32(struct xorshift32_state *state); |
| |
| int set_fd_nonblock(int fd, bool nonblock); |
| |
| int open_cdev(const char *devname_hint, dev_t cdev); |
| |
| unsigned int get_random(void); |
| |
| bool check_env(const char *var); |
| #endif |