aboutsummaryrefslogtreecommitdiffstats
path: root/boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h
diff options
context:
space:
mode:
authorinmarket <andrewh@inmarket.com.au>2014-07-09 18:47:59 +1000
committerinmarket <andrewh@inmarket.com.au>2014-07-09 18:47:59 +1000
commit6dea259ea2dd0afc4b610961e211d77460cfd0c6 (patch)
tree225a157a5ac0c7cf8d4e1b451b47075a57e3110b /boards/base/RaspberryPi/example-FreeRTOS/Drivers/mmio.h
parentab9ce99647965d0d3e9ea65ea92ad694c8b8ee1b (diff)
downloaduGFX-6dea259ea2dd0afc4b610961e211d77460cfd0c6.tar.gz
uGFX-6dea259ea2dd0afc4b610961e211d77460cfd0c6.tar.bz2
uGFX-6dea259ea2dd0afc4b610961e211d77460cfd0c6.zip
Example added for FreeRTOS on Raspberry Pi
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