summaryrefslogtreecommitdiff
path: root/src/kernel/syscalls.c
diff options
context:
space:
mode:
authordzwdz2022-10-08 16:05:37 +0200
committerdzwdz2022-10-08 16:07:04 +0200
commitf25b6a7d38f1a4b656e3a7ad431afcf535f1fdce (patch)
tree83199e9a70cc903ce46d0f30cc1a74ccfc6e729b /src/kernel/syscalls.c
parente83dca9817614d0dc77ce1e5dc13eed44b61eb2f (diff)
tests: some tests for when a process has no free handles
Diffstat (limited to 'src/kernel/syscalls.c')
-rw-r--r--src/kernel/syscalls.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/kernel/syscalls.c b/src/kernel/syscalls.c
index dc8f9df..1909eb7 100644
--- a/src/kernel/syscalls.c
+++ b/src/kernel/syscalls.c
@@ -51,11 +51,10 @@ long _syscall_fork(int flags, handle_t __user *fs_front) {
child = process_fork(process_current, flags);
regs_savereturn(&child->regs, 0);
- if ((flags & FORK_NEWFS) && fs_front) {
+ if (flags & FORK_NEWFS) {
struct handle *h;
handle_t hid = process_handle_init(process_current, HANDLE_FS_FRONT, &h);
if (hid < 0) {
- // TODO test
child->noreap = true;
process_kill(child, -EMFILE);
SYSCALL_RETURN(-EMFILE);
@@ -87,8 +86,9 @@ handle_t _syscall_open(const char __user *path, long len, int flags) {
if (PATH_MAX < len)
SYSCALL_RETURN(-1);
+ // TODO remove this check - it's not worth it w/ threads
if (process_find_free_handle(process_current, 0) < 0)
- SYSCALL_RETURN(-1);
+ SYSCALL_RETURN(-EMFILE);
path_buf = kmalloc(len);
if (!path_buf) goto fail;