summaryrefslogtreecommitdiffstats
path: root/task/umode_vma.c
diff options
context:
space:
mode:
authorJon Santmyer <jon@jonsantmyer.com>2024-05-22 13:00:41 -0400
committerJon Santmyer <jon@jonsantmyer.com>2024-05-22 13:00:41 -0400
commitace65b453151845bc361f21f3e5b651c35f9f126 (patch)
tree262ebd29b0ca1d8584f0b6f1efa7a00d9f4f3e43 /task/umode_vma.c
parentf004c1ade8d617a82cea2fe249434cccb47a2358 (diff)
downloadjove-kernel-ace65b453151845bc361f21f3e5b651c35f9f126.tar.gz
jove-kernel-ace65b453151845bc361f21f3e5b651c35f9f126.tar.bz2
jove-kernel-ace65b453151845bc361f21f3e5b651c35f9f126.zip
massive refactor for mp and organizationHEADmaster
Diffstat (limited to 'task/umode_vma.c')
-rw-r--r--task/umode_vma.c37
1 files changed, 37 insertions, 0 deletions
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;
+}