mirror of
https://github.com/systemd/systemd.git
synced 2025-01-12 13:18:14 +03:00
macro: hookup assert logic with log logic
This commit is contained in:
parent
40531a555a
commit
dd8f71ee9f
28
macro.h
28
macro.h
@ -35,6 +35,8 @@
|
|||||||
#define _deprecated __attribute__ ((deprecated))
|
#define _deprecated __attribute__ ((deprecated))
|
||||||
#define _packed __attribute__ ((packed))
|
#define _packed __attribute__ ((packed))
|
||||||
#define _malloc __attribute__ ((malloc))
|
#define _malloc __attribute__ ((malloc))
|
||||||
|
#define _likely(x) (__builtin_expect(!!(x),1))
|
||||||
|
#define _unlikely(x) (__builtin_expect(!!(x),0))
|
||||||
|
|
||||||
/* Rounds up */
|
/* Rounds up */
|
||||||
static inline size_t ALIGN(size_t l) {
|
static inline size_t ALIGN(size_t l) {
|
||||||
@ -65,11 +67,29 @@ static inline size_t ALIGN(size_t l) {
|
|||||||
((_x > _high) ? _high : ((_x < _low) ? _low : _x)); \
|
((_x > _high) ? _high : ((_x < _low) ? _low : _x)); \
|
||||||
})
|
})
|
||||||
|
|
||||||
|
#define assert_se(expr) \
|
||||||
|
do { \
|
||||||
|
if (_unlikely(!(expr))) { \
|
||||||
|
log_error("Assertion '%s' failed at %s:%u, function %s(). Aborting.", \
|
||||||
|
#expr , __FILE__, __LINE__, __PRETTY_FUNCTION__); \
|
||||||
|
abort(); \
|
||||||
|
} \
|
||||||
|
} while (false) \
|
||||||
|
|
||||||
|
/* We override the glibc assert() here. */
|
||||||
|
#undef assert
|
||||||
|
#ifdef NDEBUG
|
||||||
|
#define assert(expr) do {} while(false)
|
||||||
|
#else
|
||||||
|
#define assert(expr) assert_se(expr)
|
||||||
|
#endif
|
||||||
|
|
||||||
#define assert_not_reached(t) assert(!(t))
|
#define assert_not_reached(t) \
|
||||||
|
do { \
|
||||||
#define assert_se(x) assert(x)
|
log_error("Code should not be reached '%s' at %s:%u, function %s(). Aborting.", \
|
||||||
|
t, __FILE__, __LINE__, __PRETTY_FUNCTION__); \
|
||||||
|
abort(); \
|
||||||
|
} while (false)
|
||||||
|
|
||||||
#define assert_cc(expr) \
|
#define assert_cc(expr) \
|
||||||
do { \
|
do { \
|
||||||
@ -103,4 +123,6 @@ static inline size_t ALIGN(size_t l) {
|
|||||||
(iovec).iov_len = strlen(s); \
|
(iovec).iov_len = strlen(s); \
|
||||||
} while(false);
|
} while(false);
|
||||||
|
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user