X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/1375eb51603466b723ab7dd1ca4194ee5d662f75..bffa3430fbbaaad29bec0b5bee9c1f0bfc7fd068:/lunaix-os/includes/lunaix/spike.h diff --git a/lunaix-os/includes/lunaix/spike.h b/lunaix-os/includes/lunaix/spike.h index 9e2d427..8abd8b0 100644 --- a/lunaix-os/includes/lunaix/spike.h +++ b/lunaix-os/includes/lunaix/spike.h @@ -30,7 +30,7 @@ * https://elixir.bootlin.com/linux/v4.4/source/include/linux/log2.h#L85 * */ -#define ILOG2(x) \ +#define ilog2(x) \ (__builtin_constant_p(x) ? ((x) == 0 ? 0 \ : ((x) & (1ul << 31)) ? 31 \ : ((x) & (1ul << 30)) ? 30 \ @@ -64,20 +64,47 @@ : ((x) & (1ul << 2)) ? 2 \ : ((x) & (1ul << 1)) ? 1 \ : 0) \ - : (31 - clz(x))) + : (msbiti - clz(x))) -#ifndef __LUNAIXOS_NASSERT__ +#define llog2(x) (msbitl - clzl(x)) + +#ifndef CONFIG_NO_ASSERT #define assert(cond) \ - if (!(cond)) { \ - __assert_fail(#cond, __FILE__, __LINE__); \ - } + do { \ + if (unlikely(!(cond))) { \ + __assert_fail(#cond, __FILE__, __LINE__); \ + } \ + } while(0) + +#define assert_p(cond, prefix) \ + do { \ + if (unlikely(!(cond))) { \ + __assert_fail(prefix ": " #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 assert_msg_p(cond, prefix, msg) \ + do { \ + if (unlikely(!(cond))) { \ + __assert_fail(prefix ":" 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__); +#define fail_p(msg, prefix) fail(prefix msg); void __assert_fail(const char* expr, const char* file, unsigned int line) @@ -86,14 +113,11 @@ __assert_fail(const char* expr, const char* file, unsigned int line) #define assert(cond) (void)(cond); // assert nothing #define assert_msg(cond, msg) (void)(cond); // assert nothing -#endif // __LUNAIXOS_NASSERT__ +#endif // CONFIG_NO_ASSERT void noret panick(const char* msg); -void noret -panickf(const char* fmt, ...); - #define wait_until(cond) \ while (!(cond)) \ ;