aboutsummaryrefslogtreecommitdiff
path: root/03-refactor/include/common.h
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2018-01-23 23:24:53 -0700
committerJosh Rahm <joshuarahm@gmail.com>2018-01-23 23:24:53 -0700
commit2545ae2d57e5b70975e3fd3b3e570da13dbf62f0 (patch)
treea8fe7fe54688defdab1ce5fcd83f66f17eb5bb4b /03-refactor/include/common.h
parent7aa10db46c13ad8adc88aadff39b8cf6b15db09d (diff)
downloadstm32l4-2545ae2d57e5b70975e3fd3b3e570da13dbf62f0.tar.gz
stm32l4-2545ae2d57e5b70975e3fd3b3e570da13dbf62f0.tar.bz2
stm32l4-2545ae2d57e5b70975e3fd3b3e570da13dbf62f0.zip
start refactor process. Change rcc->c_r to bitfield.
Diffstat (limited to '03-refactor/include/common.h')
-rw-r--r--03-refactor/include/common.h30
1 files changed, 30 insertions, 0 deletions
diff --git a/03-refactor/include/common.h b/03-refactor/include/common.h
new file mode 100644
index 0000000..9d5c7cd
--- /dev/null
+++ b/03-refactor/include/common.h
@@ -0,0 +1,30 @@
+#ifndef COMMON__H
+#define COMMON__H
+
+#include <stdint.h>
+
+/* Define __IO to be volatile if it's not already. */
+#ifndef __IO
+#define __IO volatile
+#endif
+
+#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__)
+
+typedef uint32_t bits_t;
+
+#endif /* COMMON_H */