2015-08-17 16:41:38 +00:00
|
|
|
#include "mem.h"
|
|
|
|
|
2015-08-18 08:31:28 +00:00
|
|
|
void memory_copy(uint8_t *source, uint8_t *dest, int nbytes) {
|
2015-08-17 16:41:38 +00:00
|
|
|
int i;
|
|
|
|
for (i = 0; i < nbytes; i++) {
|
|
|
|
*(dest + i) = *(source + i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-18 08:31:28 +00:00
|
|
|
void memory_set(uint8_t *dest, uint8_t val, uint32_t len) {
|
|
|
|
uint8_t *temp = (uint8_t *)dest;
|
2015-08-17 16:41:38 +00:00
|
|
|
for ( ; len != 0; len--) *temp++ = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This should be computed at link time, but a hardcoded
|
|
|
|
* value is fine for now. Remember that our kernel starts
|
|
|
|
* at 0x1000 as defined on the Makefile */
|
2015-08-18 08:31:28 +00:00
|
|
|
uint32_t free_mem_addr = 0x10000;
|
2015-08-17 16:41:38 +00:00
|
|
|
/* Implementation is just a pointer to some free memory which
|
|
|
|
* keeps growing */
|
2015-08-18 08:38:09 +00:00
|
|
|
uint32_t kmalloc(size_t size, int align, uint32_t *phys_addr) {
|
2015-08-17 16:41:38 +00:00
|
|
|
/* Pages are aligned to 4K, or 0x1000 */
|
|
|
|
if (align == 1 && (free_mem_addr & 0xFFFFF000)) {
|
|
|
|
free_mem_addr &= 0xFFFFF000;
|
|
|
|
free_mem_addr += 0x1000;
|
|
|
|
}
|
|
|
|
/* Save also the physical address */
|
|
|
|
if (phys_addr) *phys_addr = free_mem_addr;
|
|
|
|
|
2015-08-18 08:31:28 +00:00
|
|
|
uint32_t ret = free_mem_addr;
|
2015-08-17 16:41:38 +00:00
|
|
|
free_mem_addr += size; /* Remember to increment the pointer */
|
|
|
|
return ret;
|
|
|
|
}
|