aboutsummaryrefslogtreecommitdiffstats
path: root/boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h
diff options
context:
space:
mode:
authorpashamray <pashamray@gmail.com>2014-07-10 08:04:52 +0300
committerpashamray <pashamray@gmail.com>2014-07-10 08:04:52 +0300
commitb46e58ba6ccd80130b05dc662739cde55a8275f8 (patch)
treeabb566e21fbea1f475cb3e1496cd5f5eaae3823e /boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h
parentddeeacea0e31ee6d2dad798b6a5f79bbd548b8b9 (diff)
parent5c8c0c7b36cd8f2c94b67cce56e99804a048a906 (diff)
downloaduGFX-b46e58ba6ccd80130b05dc662739cde55a8275f8.tar.gz
uGFX-b46e58ba6ccd80130b05dc662739cde55a8275f8.tar.bz2
uGFX-b46e58ba6ccd80130b05dc662739cde55a8275f8.zip
Tectu/ugfx слито с master
Diffstat (limited to 'boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h')
-rw-r--r--boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h b/boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h
new file mode 100644
index 00000000..89bea700
--- /dev/null
+++ b/boards/base/RaspberryPi/example-FreeRTOS/Drivers/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