X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/0eabc11fcf240415e39f3873dfce7cd9384b3042..1fe5f5eb5378a47bf0f3451762743c162e40faad:/lunaix-os/includes/lunaix/spike.h diff --git a/lunaix-os/includes/lunaix/spike.h b/lunaix-os/includes/lunaix/spike.h index 6cece75..ae19357 100644 --- a/lunaix-os/includes/lunaix/spike.h +++ b/lunaix-os/includes/lunaix/spike.h @@ -1,7 +1,9 @@ #ifndef __LUNAIX_SPIKE_H #define __LUNAIX_SPIKE_H -// Some helper functions. As helpful as Spike the Dragon! :) +#include + +/** Some helper functions. As helpful as Spike the Dragon! :) **/ // 除法 v/(2^k) 向上取整 #define CEIL(v, k) (((v) + (1 << (k)) - 1) >> (k)) @@ -62,13 +64,14 @@ : 0) \ : (31 - __builtin_clz(x))) -#define __USER__ __attribute__((section(".usrtext"))) +#define DO_SPIN \ + while (1) \ + ; inline static void spin() { - while (1) - ; + DO_SPIN } #ifndef __LUNAIXOS_NASSERT__ @@ -91,12 +94,12 @@ __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 // __LUNAIXOS_NASSERT__ -void +void noret panick(const char* msg); -void +void noret panickf(const char* fmt, ...); #define wait_until(cond) \