X-Git-Url: http://git.efficios.com/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fcommon%2Fmacros.h;h=f242da481b6f8c7c47ddf30064894b3ef35564e8;hp=9304388554d0af82e61ab6ae2e0abddca933960d;hb=18710679a8ac57fda5dbd26cf16bb180dce9e286;hpb=f6835b82a8dbb3a9688c7b28fd4d673dca371272 diff --git a/src/common/macros.h b/src/common/macros.h index 930438855..f242da481 100644 --- a/src/common/macros.h +++ b/src/common/macros.h @@ -20,7 +20,9 @@ #define _MACROS_H #include +#include #include +#include /* * Takes a pointer x and transform it so we can use it to access members @@ -57,26 +59,55 @@ void *zmalloc(size_t len) #define ARRAY_SIZE(array) (sizeof(array) / (sizeof((array)[0]))) #endif +#ifndef container_of +#define container_of(ptr, type, member) \ + ({ \ + const typeof(((type *)NULL)->member) * __ptr = (ptr); \ + (type *)((char *)__ptr - offsetof(type, member)); \ + }) +#endif + #ifndef max #define max(a, b) ((a) > (b) ? (a) : (b)) #endif #ifndef max_t -#define max_t(type, a, b) ((type) max(a, b)) +#define max_t(type, a, b) max((type) a, (type) b) #endif #ifndef min #define min(a, b) ((a) < (b) ? (a) : (b)) #endif +#ifndef min_t +#define min_t(type, a, b) min((type) a, (type) b) +#endif + #ifndef LTTNG_PACKED #define LTTNG_PACKED __attribute__((__packed__)) #endif -#ifndef LTTNG_HIDDEN +/* + * Align value to the next multiple of align. Returns val if it already is a + * multiple of align. Align must be a power of two. + */ +#define ALIGN_TO(value, align) ((value + (align - 1)) & ~(align - 1)) + +/* + * LTTNG_HIDDEN: set the hidden attribute for internal functions + * On Windows, symbols are local unless explicitly exported, + * see https://gcc.gnu.org/wiki/Visibility + */ +#if defined(_WIN32) || defined(__CYGWIN__) +#define LTTNG_HIDDEN +#else #define LTTNG_HIDDEN __attribute__((visibility("hidden"))) #endif +#define member_sizeof(type, field) sizeof(((type *) 0)->field) + +#define ASSERT_LOCKED(lock) assert(pthread_mutex_trylock(&lock)) + /* * lttng_strncpy returns 0 on success, or nonzero on failure. * It checks that the @src string fits into @dst_len before performing @@ -87,17 +118,11 @@ void *zmalloc(size_t len) static inline int lttng_strncpy(char *dst, const char *src, size_t dst_len) { - if (strnlen(src, dst_len) == dst_len) { + if (lttng_strnlen(src, dst_len) >= dst_len) { /* Fail since copying would result in truncation. */ return -1; } - strncpy(dst, src, dst_len); - /* - * Be extra careful and put final \0 at the end after strncpy(), - * even though we checked the length before. This makes Coverity - * happy. - */ - dst[dst_len - 1] = '\0'; + strcpy(dst, src); return 0; }