aboutsummaryrefslogtreecommitdiffstats
path: root/boards/base/RaspberryPi/FreeRTOS/mmio.h
diff options
context:
space:
mode:
authorinmarket <andrewh@inmarket.com.au>2014-10-06 17:05:16 +1000
committerinmarket <andrewh@inmarket.com.au>2014-10-06 17:05:48 +1000
commit211254ed6c5a945be18334aa540de55db885000c (patch)
tree19b94dd69a4a95d4b718c06c0d6eb27f6aa7a9a8 /boards/base/RaspberryPi/FreeRTOS/mmio.h
parent3348128fe289aae37f2df46802709aaa7aedb0c1 (diff)
downloaduGFX-211254ed6c5a945be18334aa540de55db885000c.tar.gz
uGFX-211254ed6c5a945be18334aa540de55db885000c.tar.bz2
uGFX-211254ed6c5a945be18334aa540de55db885000c.zip
Add support for FreeRTOS into make system
Diffstat (limited to 'boards/base/RaspberryPi/FreeRTOS/mmio.h')
-rw-r--r--boards/base/RaspberryPi/FreeRTOS/mmio.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/boards/base/RaspberryPi/FreeRTOS/mmio.h b/boards/base/RaspberryPi/FreeRTOS/mmio.h
new file mode 100644
index 00000000..89bea700
--- /dev/null
+++ b/boards/base/RaspberryPi/FreeRTOS/mmio.h
@@ -0,0 +1,24 @@
+/* mmio.h - access to MMIO registers */
+
+#ifndef MMIO_H
+#define MMIO_H
+
+#include <stdint.h>
+
+// write to MMIO register
+static inline void mmio_write(uint32_t reg, uint32_t data) {
+ uint32_t *ptr = (uint32_t*)reg;
+ asm volatile("str %[data], [%[reg]]"
+ : : [reg]"r"(ptr), [data]"r"(data));
+}
+
+// read from MMIO register
+static inline uint32_t mmio_read(uint32_t reg) {
+ uint32_t *ptr = (uint32_t*)reg;
+ uint32_t data;
+ asm volatile("ldr %[data], [%[reg]]"
+ : [data]"=r"(data) : [reg]"r"(ptr));
+ return data;
+}
+
+#endif // #ifndef MMIO_H