summaryrefslogtreecommitdiff
path: root/src/sys/os
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2025-09-20 21:32:01 -0400
committerIan Moffett <ian@osmora.org>2025-09-20 21:32:01 -0400
commitebc26c8259160193dde5b0baecf7230c8388fd29 (patch)
tree0e110b8fd4c8e6c28a1d2fda4af35b804719746b /src/sys/os
parente0504467b11ca122d76d7a5bf0dc66451ac8f293 (diff)
kern: proc: Add address checking routine
Add routine to check if an address is valid within a process's address space. More work will need to be done with this but this introduces a great starting point Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'src/sys/os')
-rw-r--r--src/sys/os/os_proc.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/sys/os/os_proc.c b/src/sys/os/os_proc.c
index 3a42496..f21fc69 100644
--- a/src/sys/os/os_proc.c
+++ b/src/sys/os/os_proc.c
@@ -139,3 +139,26 @@ proc_kill(struct proc *procp, int status)
proc_clear_ranges(procp);
return md_proc_kill(procp, 0);
}
+
+
+/*
+ * Check that an address is within the bounds of a
+ * process.
+ */
+int
+proc_check_addr(struct proc *proc, uintptr_t addr, size_t len)
+{
+ uintptr_t stack_base;
+ uintptr_t stack_end;
+
+ /* Within the bounds of the stack? */
+ stack_base = STACK_TOP - STACK_LEN;
+ if (addr >= stack_base && addr <= STACK_TOP) {
+ return 0;
+ }
+ if ((stack_base + len) < stack_end) {
+ return 0;
+ }
+
+ return -EFAULT;
+}