aboutsummaryrefslogtreecommitdiff
path: root/02-usart/include/mem.h
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2020-11-21 21:24:04 -0700
committerJosh Rahm <joshuarahm@gmail.com>2020-11-21 21:24:04 -0700
commitb073c19f9ec330423fa07c66d1c0604883044f6b (patch)
tree476959ae1e0691d4c8175112e4189133db2be54b /02-usart/include/mem.h
parent14a651cda0bd8dfb992d2a6a1544300c39492ca3 (diff)
downloadstm32l4-b073c19f9ec330423fa07c66d1c0604883044f6b.tar.gz
stm32l4-b073c19f9ec330423fa07c66d1c0604883044f6b.tar.bz2
stm32l4-b073c19f9ec330423fa07c66d1c0604883044f6b.zip
Added halloc for allocating memory on the heap.
The new halloc() call allocates memory on the STM32l's SRAM2 starting right above the DATA section. The implementation uses a very-dense, albeit slower, linked-list allocation as opposed to fancy B-trees or something. However, the overhead is just 1 32-bit word per allocation and thus allows for reasonably dense memory-packing on the small 16K memory chip.
Diffstat (limited to '02-usart/include/mem.h')
-rw-r--r--02-usart/include/mem.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/02-usart/include/mem.h b/02-usart/include/mem.h
index aa4ce12..f376e7d 100644
--- a/02-usart/include/mem.h
+++ b/02-usart/include/mem.h
@@ -1,4 +1,27 @@
#ifndef MEM_H_
#define MEM_H_
+#include "arch.h"
+#include <stddef.h>
+
+#define MAX_HEAP_SIZE \
+ ((16384 - (DATA_SEGMENT_STOP - DATA_SEGMENT_START)) / 4 * 4)
+
+/* allocates memory on the head, which is stored in sram2 */
+void* halloc(size_t n);
+
+/* Frees the memory allocated by halloc. */
+void hfree(void* mem);
+
+#ifdef FOR_TESTING
+
+void* debug_halloc_get_next_ptr(void* ptr);
+
+void* debug_halloc_get_prev_ptr(void* ptr);
+
+int debug_halloc_assert_consistency(char* error, size_t len);
+
+#endif
+
+
#endif