sandbox: vm: add temporary vm_virt_to_phys() implementation
This commit is contained in:
@@ -41,7 +41,7 @@ static struct mem_map_region mem_map[] = {
|
|||||||
{ .base = 0x00800000, .limit = MB_TO_BYTES(MEMORY_SIZE_MB) - 1, .status = REGION_FREE },
|
{ .base = 0x00800000, .limit = MB_TO_BYTES(MEMORY_SIZE_MB) - 1, .status = REGION_FREE },
|
||||||
};
|
};
|
||||||
|
|
||||||
extern void tmp_set_vaddr_base(void *);
|
extern void tmp_set_vaddr_base(void *, size_t);
|
||||||
|
|
||||||
/* virtual address of where system memory is mapped */
|
/* virtual address of where system memory is mapped */
|
||||||
static void *system_memory = NULL;
|
static void *system_memory = NULL;
|
||||||
@@ -110,7 +110,9 @@ int memory_test(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tmp_set_vaddr_base(system_memory);
|
printf("virtual memory range: 0x%" PRIxPTR "-0x%" PRIxPTR "\n", (uintptr_t)system_memory, (uintptr_t)system_memory + MB_TO_BYTES(MEMORY_SIZE_MB));
|
||||||
|
|
||||||
|
tmp_set_vaddr_base(system_memory, MB_TO_BYTES(MEMORY_SIZE_MB));
|
||||||
memblock_add(pmem_base, pmem_limit + 1);
|
memblock_add(pmem_base, pmem_limit + 1);
|
||||||
|
|
||||||
for (size_t i = 0; i < nr_mem_map_entries; i++) {
|
for (size_t i = 0; i < nr_mem_map_entries; i++) {
|
||||||
|
|||||||
@@ -199,6 +199,8 @@ extern kern_status_t vm_bootstrap(const vm_zone_descriptor_t *zones, size_t nr_z
|
|||||||
|
|
||||||
extern vm_pg_data_t *vm_pg_data_get(vm_node_id_t node);
|
extern vm_pg_data_t *vm_pg_data_get(vm_node_id_t node);
|
||||||
|
|
||||||
|
extern phys_addr_t vm_virt_to_phys(void *p);
|
||||||
|
|
||||||
extern void vm_page_init_array();
|
extern void vm_page_init_array();
|
||||||
extern vm_page_t *vm_page_get(phys_addr_t addr);
|
extern vm_page_t *vm_page_get(phys_addr_t addr);
|
||||||
extern phys_addr_t vm_page_get_paddr(vm_page_t *pg);
|
extern phys_addr_t vm_page_get_paddr(vm_page_t *pg);
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
#include <socks/memblock.h>
|
#include <socks/memblock.h>
|
||||||
#include <socks/vm.h>
|
#include <socks/vm.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <assert.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
/* array of pages, one for each physical page frame present in RAM */
|
/* array of pages, one for each physical page frame present in RAM */
|
||||||
@@ -41,9 +42,18 @@ static size_t page_order_bytes[] = {
|
|||||||
|
|
||||||
/* temporary */
|
/* temporary */
|
||||||
static void *tmp_vaddr_base = NULL;
|
static void *tmp_vaddr_base = NULL;
|
||||||
void tmp_set_vaddr_base(void *p)
|
static size_t tmp_vaddr_len = 0;
|
||||||
|
void tmp_set_vaddr_base(void *p, size_t len)
|
||||||
{
|
{
|
||||||
tmp_vaddr_base = p;
|
tmp_vaddr_base = p;
|
||||||
|
tmp_vaddr_len = len;
|
||||||
|
}
|
||||||
|
|
||||||
|
phys_addr_t vm_virt_to_phys(void *p)
|
||||||
|
{
|
||||||
|
phys_addr_t x = (phys_addr_t)p - (phys_addr_t)tmp_vaddr_base;
|
||||||
|
assert(x < tmp_vaddr_len);
|
||||||
|
return x;
|
||||||
}
|
}
|
||||||
|
|
||||||
void vm_page_init_array()
|
void vm_page_init_array()
|
||||||
|
|||||||
Reference in New Issue
Block a user