aboutsummaryrefslogtreecommitdiff
path: root/include/kern/common.h
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2020-11-24 13:46:41 -0700
committerJosh Rahm <joshuarahm@gmail.com>2020-11-24 13:46:41 -0700
commit93b063fedfcf7409a67df035170ea5670cad22e1 (patch)
treea23321a7465d966b1ccf196ca00e65a70c9f9110 /include/kern/common.h
parentb040195d31df6ad759f16ea3456471897f55daa1 (diff)
downloadstm32l4-93b063fedfcf7409a67df035170ea5670cad22e1.tar.gz
stm32l4-93b063fedfcf7409a67df035170ea5670cad22e1.tar.bz2
stm32l4-93b063fedfcf7409a67df035170ea5670cad22e1.zip
Moved action to top level.
Removed old iterations of the project and moved the files from 02-usart to the root directory since that's the sole place where the action is and that subproject has outgrown its initial title.
Diffstat (limited to 'include/kern/common.h')
-rw-r--r--include/kern/common.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/include/kern/common.h b/include/kern/common.h
new file mode 100644
index 0000000..653279e
--- /dev/null
+++ b/include/kern/common.h
@@ -0,0 +1,50 @@
+#ifndef COMMON__H
+#define COMMON__H
+
+#include <stdint.h>
+#include <stddef.h>
+#include <assert.h>
+
+#define WEAK __attribute__((weak))
+#define NORETURN __attribute__((noreturn))
+
+#ifndef static_assert
+#define static_assert(a, b)
+#endif
+
+/* Define __IO to be volatile if it's not already. */
+#ifndef __IO
+#define __IO volatile
+#endif
+
+#define CTZ(n) __builtin_ctz(n)
+
+#define bool int
+#ifndef __cplusplus
+#define true 1
+#define false 0
+#endif
+
+#define PACKED __attribute__((packed))
+#define BIT(n) (1 << (n))
+
+#define RESERVED_CONCAT_IMPL(x, y) x ## y
+#define RESERVED_MACRO_CONCAT(x, y) RESERVED_CONCAT_IMPL(x, y)
+#define RESERVED(n) \
+ bits_t RESERVED_MACRO_CONCAT(_r, __COUNTER__) :n
+
+#define RESERVE(type) \
+ __IO type RESERVED_MACRO_CONCAT(_r, __COUNTER__)
+
+#define ptr2reg(ptr) \
+ ((uint32_t) (ptrdiff_t) (ptr))
+
+typedef __IO uint32_t bits_t;
+
+#define regset(reg, mask, val) \
+ ((reg) = ((reg) & ~mask) | (val << CTZ(mask)))
+
+#define regget(reg, mask) \
+ (((reg) & mask) >> (CTZ(mask)))
+
+#endif /* COMMON_H */