From 2a755fcd93ead7bbc2d0a881136c1862762b9957 Mon Sep 17 00:00:00 2001 From: apio Date: Tue, 11 Oct 2022 17:03:16 +0200 Subject: [PATCH] sys_open(): actually return EMFILE if the process has used all of its file slots --- kernel/src/sys/stdio.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/src/sys/stdio.cpp b/kernel/src/sys/stdio.cpp index 91b1a63d..fa20d141 100644 --- a/kernel/src/sys/stdio.cpp +++ b/kernel/src/sys/stdio.cpp @@ -19,12 +19,12 @@ void sys_write(Context* context, const char* addr, size_t size) void sys_open(Context* context, const char* filename, int flags) { Task* current_task = Scheduler::current_task(); - int fd = -1; + int fd; for (fd = 0; fd < TASK_MAX_FDS; fd++) { if (!current_task->files[fd].is_open()) break; } - if (fd == -1) + if (fd == TASK_MAX_FDS) { STDIO_FAIL(open, EMFILE); context->rax = -EMFILE;