Started building the kernel memory manager in userspace
This commit is contained in:
2
sandbox/vm/Makefile
Normal file
2
sandbox/vm/Makefile
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
include ../sandbox-config.mk
|
||||||
|
include ../sandbox-template.mk
|
||||||
29
sandbox/vm/main.c
Normal file
29
sandbox/vm/main.c
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include "vm.h"
|
||||||
|
|
||||||
|
/* amount of memory to allocate for system RAM in megabytes */
|
||||||
|
#define SIMULATED_MEMORY_MB 16
|
||||||
|
|
||||||
|
#define MEMPTR(offset) ((void *)((uintptr_t)system_memory) + (offset))
|
||||||
|
|
||||||
|
int main(int argc, const char **argv)
|
||||||
|
{
|
||||||
|
printf("Hello, world!\n");
|
||||||
|
|
||||||
|
void *system_memory = mmap(
|
||||||
|
NULL,
|
||||||
|
SIMULATED_MEMORY_MB * 0x100000,
|
||||||
|
PROT_READ | PROT_WRITE,
|
||||||
|
MAP_PRIVATE | MAP_ANONYMOUS,
|
||||||
|
-1, 0);
|
||||||
|
|
||||||
|
if (system_memory == MAP_FAILED) {
|
||||||
|
perror("mmap");
|
||||||
|
fprintf(stderr, "cannot allocated simulated system RAM buffer\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
munmap(system_memory, SIMULATED_MEMORY_MB * 0x100000);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
51
sandbox/vm/vm.h
Normal file
51
sandbox/vm/vm.h
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
#ifndef SOCKS_VM_H_
|
||||||
|
#define SOCKS_VM_H_
|
||||||
|
|
||||||
|
#include <socks/types.h>
|
||||||
|
|
||||||
|
/*******************************************
|
||||||
|
* Beginning of machine-specific definitions
|
||||||
|
*******************************************/
|
||||||
|
typedef enum vm_zone_id {
|
||||||
|
VM_ZONE_DMA = 0x01u,
|
||||||
|
VM_ZONE_NORMAL = 0x02u,
|
||||||
|
VM_ZONE_HIGHMEM = 0x03u,
|
||||||
|
} vm_zone_id_t;
|
||||||
|
/*******************************************
|
||||||
|
* End of machine-specific definitions.
|
||||||
|
*******************************************/
|
||||||
|
|
||||||
|
typedef enum vm_memory_region_status {
|
||||||
|
VM_REGION_FREE = 0x01u,
|
||||||
|
VM_REGION_RESERVED = 0x02u,
|
||||||
|
} vm_memory_region_status_t;
|
||||||
|
|
||||||
|
typedef struct vm_zone_descriptor {
|
||||||
|
vm_zone_id_t zd_id;
|
||||||
|
phys_addr_t zd_base;
|
||||||
|
phys_addr_t zd_limit;
|
||||||
|
} vm_zone_descriptor_t;
|
||||||
|
|
||||||
|
typedef struct vm_zone {
|
||||||
|
unsigned z_reserved[32];
|
||||||
|
} vm_zone_t;
|
||||||
|
|
||||||
|
typedef struct vm_region {
|
||||||
|
vm_memory_region_status_t r_status;
|
||||||
|
phys_addr_t r_base;
|
||||||
|
phys_addr_t r_limit;
|
||||||
|
} vm_region_t;
|
||||||
|
|
||||||
|
typedef enum vm_page_flags {
|
||||||
|
VM_PAGE_RESERVED = 0x01u,
|
||||||
|
} vm_page_flags_t;
|
||||||
|
|
||||||
|
typedef struct vm_page {
|
||||||
|
uint32_t p_flags; /* vm_page_flags_t bitfield */
|
||||||
|
} __attribute__((packed)) vm_page_t;
|
||||||
|
|
||||||
|
extern void vm_bootstrap(void);
|
||||||
|
|
||||||
|
extern void vm_page_init(vm_page_t *pg);
|
||||||
|
|
||||||
|
#endif
|
||||||
Reference in New Issue
Block a user