X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=src%2Fcommon%2Fmacros.h;h=8c35f0c5f3a297144df3259d084518c63f55e732;hb=4878de5c7deb512bbdac4fdfc498907efa06fb7c;hp=e28250f7ed20a7892600c161f6b0921ff10424d3;hpb=1405051ad116a8bd42b68822be6d2f9b3def6c65;p=lttng-tools.git diff --git a/src/common/macros.h b/src/common/macros.h index e28250f7e..8c35f0c5f 100644 --- a/src/common/macros.h +++ b/src/common/macros.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2011 David Goulet + * Copyright (C) 2011 EfficiOS Inc. * Copyright (C) 2011 Mathieu Desnoyers * * SPDX-License-Identifier: GPL-2.0-only @@ -57,22 +57,6 @@ void *zmalloc(size_t len) }) #endif -#ifndef max -#define max(a, b) ((a) > (b) ? (a) : (b)) -#endif - -#ifndef max_t -#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 @@ -85,47 +69,60 @@ void *zmalloc(size_t len) #endif #endif -#define is_signed(type) (((type) (-1)) < 0) +#define member_sizeof(type, field) sizeof(((type *) 0)->field) -/* - * 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)) +#define ASSERT_LOCKED(lock) LTTNG_ASSERT(pthread_mutex_trylock(&lock)) +#define ASSERT_RCU_READ_LOCKED(lock) LTTNG_ASSERT(rcu_read_ongoing()) -/* - * 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 +/* Attribute suitable to tag functions as having printf()-like arguments. */ +#define ATTR_FORMAT_PRINTF(_string_index, _first_to_check) \ + __attribute__((format(printf, _string_index, _first_to_check))) -#define member_sizeof(type, field) sizeof(((type *) 0)->field) +/* Attribute suitable to tag functions as having strftime()-like arguments. */ +#define ATTR_FORMAT_STRFTIME(_string_index) \ + __attribute__((format(strftime, _string_index, 0))) -#define ASSERT_LOCKED(lock) assert(pthread_mutex_trylock(&lock)) +/* Macros used to ignore specific compiler diagnostics. */ -/* - * Get an aligned pointer to a value. This is meant - * as a helper to pass an aligned pointer to a member in a packed structure - * to a function. - */ -#define ALIGNED_CONST_PTR(value) (((const typeof(value) []) { value })) +#define DIAGNOSTIC_PUSH _Pragma("GCC diagnostic push") +#define DIAGNOSTIC_POP _Pragma("GCC diagnostic pop") + +#if defined(__clang__) + /* Clang */ +# define DIAGNOSTIC_IGNORE_SUGGEST_ATTRIBUTE_FORMAT +# define DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL \ + _Pragma("GCC diagnostic ignored \"-Wformat-nonliteral\"") +# define DIAGNOSTIC_IGNORE_LOGICAL_OP +#else + /* GCC */ +# define DIAGNOSTIC_IGNORE_SUGGEST_ATTRIBUTE_FORMAT \ + _Pragma("GCC diagnostic ignored \"-Wsuggest-attribute=format\"") +# define DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL \ + _Pragma("GCC diagnostic ignored \"-Wformat-nonliteral\"") +# define DIAGNOSTIC_IGNORE_LOGICAL_OP \ + _Pragma("GCC diagnostic ignored \"-Wlogical-op\"") +#endif + +/* Used to make specific C++ functions to C code. */ +#ifdef __cplusplus +#define C_LINKAGE extern "C" +#else +#define C_LINKAGE +#endif /* * lttng_strncpy returns 0 on success, or nonzero on failure. * It checks that the @src string fits into @dst_len before performing * the copy. On failure, no copy has been performed. * + * Assumes that 'src' is null-terminated. + * * dst_len includes the string's trailing NULL. */ static inline int lttng_strncpy(char *dst, const char *src, size_t dst_len) { - if (lttng_strnlen(src, dst_len) >= dst_len) { + if (strlen(src) >= dst_len) { /* Fail since copying would result in truncation. */ return -1; } @@ -133,4 +130,15 @@ int lttng_strncpy(char *dst, const char *src, size_t dst_len) return 0; } +#ifdef NDEBUG +/* +* Force usage of the assertion condition to prevent unused variable warnings +* when `assert()` are disabled by the `NDEBUG` definition. +*/ +# define LTTNG_ASSERT(_cond) ((void) sizeof((void) (_cond), 0)) +#else +# include +# define LTTNG_ASSERT(_cond) assert(_cond) +#endif + #endif /* _MACROS_H */