X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/1375eb51603466b723ab7dd1ca4194ee5d662f75..69777bdcab284335651a8002e2896f3862fa423d:/lunaix-os/includes/lunaix/spike.h diff --git a/lunaix-os/includes/lunaix/spike.h b/lunaix-os/includes/lunaix/spike.h index 9e2d427..cf40bab 100644 --- a/lunaix-os/includes/lunaix/spike.h +++ b/lunaix-os/includes/lunaix/spike.h @@ -68,14 +68,24 @@ #ifndef __LUNAIXOS_NASSERT__ #define assert(cond) \ - if (!(cond)) { \ - __assert_fail(#cond, __FILE__, __LINE__); \ - } + do { \ + if (unlikely(!(cond))) { \ + __assert_fail(#cond, __FILE__, __LINE__); \ + } \ + } while(0) #define assert_msg(cond, msg) \ - if (!(cond)) { \ - __assert_fail(msg, __FILE__, __LINE__); \ - } + do { \ + if (unlikely(!(cond))) { \ + __assert_fail(msg, __FILE__, __LINE__); \ + } \ + } while(0) + +#define must_success(statement) \ + do { \ + int err = (statement); \ + if (err) fail(#statement " failed"); \ + } while(0) #define fail(msg) __assert_fail(msg, __FILE__, __LINE__); @@ -91,9 +101,6 @@ __assert_fail(const char* expr, const char* file, unsigned int line) void noret panick(const char* msg); -void noret -panickf(const char* fmt, ...); - #define wait_until(cond) \ while (!(cond)) \ ;