X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/45e1f8b055043e54be35462852ab6649d634da7c..7b8a1bcad75628f9add4590db2bb9b8e418ee8eb:/lunaix-os/includes/lunaix/spike.h diff --git a/lunaix-os/includes/lunaix/spike.h b/lunaix-os/includes/lunaix/spike.h index 2d718f5..f73fbe1 100644 --- a/lunaix-os/includes/lunaix/spike.h +++ b/lunaix-os/includes/lunaix/spike.h @@ -1,6 +1,8 @@ #ifndef __LUNAIX_SPIKE_H #define __LUNAIX_SPIKE_H +#include + /** Some helper functions. As helpful as Spike the Dragon! :) **/ // 除法 v/(2^k) 向上取整 @@ -20,7 +22,7 @@ #define MIN(a, b) ((a) < (b) ? (a) : (b)) #define MAX(a, b) ((a) > (b) ? (a) : (b)) -#define likely(x) __builtin_expect((x), 1) +#define is_pot(val) (((val) != 0) || ((val) & ((val)-1)) == 0) /** * @brief Fast log base 2 for integer, utilizing constant unfolding. @@ -62,46 +64,44 @@ : ((x) & (1ul << 2)) ? 2 \ : ((x) & (1ul << 1)) ? 1 \ : 0) \ - : (31 - __builtin_clz(x))) - -#define __USER__ __attribute__((section(".usrtext"))) - -#define DO_SPIN \ - while (1) \ - ; - -inline static void -spin() -{ - DO_SPIN -} + : (31 - clz(x))) #ifndef __LUNAIXOS_NASSERT__ #define assert(cond) \ - if (!(cond)) { \ - __assert_fail(#cond, __FILE__, __LINE__); \ - } + do { \ + if (!(cond)) { \ + __assert_fail(#cond, __FILE__, __LINE__); \ + } \ + } while(0) #define assert_msg(cond, msg) \ - if (!(cond)) { \ - __assert_fail(msg, __FILE__, __LINE__); \ - } + do { \ + if (!(cond)) { \ + __assert_fail(msg, __FILE__, __LINE__); \ + } \ + } while(0) + +#define must_success(statement) \ + do { \ + int err = (statement); \ + if (err) panickf(#statement "failed with errcode=%d", err); \ + } while(0) #define fail(msg) __assert_fail(msg, __FILE__, __LINE__); void __assert_fail(const char* expr, const char* file, unsigned int line) - __attribute__((noinline, noreturn)); + __attribute__((noinline, noreturn)); #else #define assert(cond) (void)(cond); // assert nothing #define assert_msg(cond, msg) (void)(cond); // assert nothing -#endif // __LUNAIXOS_NASSERT__ +#endif // __LUNAIXOS_NASSERT__ -void +void noret panick(const char* msg); -void +void noret panickf(const char* fmt, ...); #define wait_until(cond) \