git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Second Extended Filesystem (ext2) and other improvements (#33)
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
spike.h
diff --git
a/lunaix-os/includes/lunaix/spike.h
b/lunaix-os/includes/lunaix/spike.h
index e35cfdc52742b0a589d3b32a74949164bfdd7693..8abd8b0aaecfec6c9358511ee6ba6ecc45d31e88 100644
(file)
--- 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
*
*/
* https://elixir.bootlin.com/linux/v4.4/source/include/linux/log2.h#L85
*
*/
-#define
ILOG
2(x) \
+#define
ilog
2(x) \
(__builtin_constant_p(x) ? ((x) == 0 ? 0 \
: ((x) & (1ul << 31)) ? 31 \
: ((x) & (1ul << 30)) ? 30 \
(__builtin_constant_p(x) ? ((x) == 0 ? 0 \
: ((x) & (1ul << 31)) ? 31 \
: ((x) & (1ul << 30)) ? 30 \
@@
-64,23
+64,39
@@
: ((x) & (1ul << 2)) ? 2 \
: ((x) & (1ul << 1)) ? 1 \
: 0) \
: ((x) & (1ul << 2)) ? 2 \
: ((x) & (1ul << 1)) ? 1 \
: 0) \
- : (31 - clz(x)))
+ : (msbiti - clz(x)))
+
+#define llog2(x) (msbitl - clzl(x))
#ifndef CONFIG_NO_ASSERT
#define assert(cond) \
do { \
#ifndef CONFIG_NO_ASSERT
#define assert(cond) \
do { \
- if (unlikely(!(cond))) {
\
+ if (unlikely(!(cond))) { \
__assert_fail(#cond, __FILE__, __LINE__); \
} \
} while(0)
__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) \
do { \
#define assert_msg(cond, msg) \
do { \
- if (unlikely(!(cond))) {
\
+ if (unlikely(!(cond))) { \
__assert_fail(msg, __FILE__, __LINE__); \
} \
} while(0)
__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); \
#define must_success(statement) \
do { \
int err = (statement); \
@@
-88,6
+104,7
@@
} while(0)
#define fail(msg) __assert_fail(msg, __FILE__, __LINE__);
} 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)
void
__assert_fail(const char* expr, const char* file, unsigned int line)