From ace65b453151845bc361f21f3e5b651c35f9f126 Mon Sep 17 00:00:00 2001 From: Jon Santmyer Date: Wed, 22 May 2024 13:00:41 -0400 Subject: massive refactor for mp and organization --- task/umode_vma.c | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 task/umode_vma.c (limited to 'task/umode_vma.c') diff --git a/task/umode_vma.c b/task/umode_vma.c new file mode 100644 index 0000000..880e047 --- /dev/null +++ b/task/umode_vma.c @@ -0,0 +1,37 @@ +#include "umode_vma.h" +#include "arch/processor.h" +#include "api/errno.h" +#include "print.h" + +__attribute__((naked)) +int +_umode_vma_fail(void) +{ + __asm__ volatile(" \ + movq %%rbp, %%rsp; \ + popq %%rbp; \ + mov $1, %%eax; \ + retq":::); +} + +int +user_vma_read(void *dest, const void *src, size_t w) +{ + if((uintptr_t)src > USERLAND_MEMORY_LIMIT) return -EACCESS; + + _exrtab_push((void*)_umode_vma_fail); + for(size_t i = 0; i < w; i++) ((char*)dest)[i] = ((const char*)src)[i]; + _exrtab_pop(); + return 0; +} + +int +user_vma_write(void *dest, const void *src, size_t w) +{ + if((uintptr_t)dest > USERLAND_MEMORY_LIMIT) return -EACCESS; + + _exrtab_push((void*)_umode_vma_fail); + for(size_t i = 0; i < w; i++) ((char*)dest)[i] = ((const char*)src)[i]; + _exrtab_pop(); + return 0; +} -- cgit v1.2.1