summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2024-03-25 21:59:24 -0400
committerIan Moffett <ian@osmora.org>2024-03-25 21:59:24 -0400
commitadd3e844cf9eaf49010fbee2aa73977086e47428 (patch)
tree358f06ac38e67ab9389e705803210227ddc0f4bc
parent51e23753f4e98ef278324e3ea13f9617fe3a7a80 (diff)
kernel: filedesc: Return status in fd_alloc()
It is better for fd_alloc() to return the status and have one of the arguments point to an output than have fd_alloc() return the allocated file descriptor just like that. Signed-off-by: Ian Moffett <ian@osmora.org>
-rw-r--r--sys/include/sys/filedesc.h2
-rw-r--r--sys/kern/kern_filedesc.c20
-rw-r--r--sys/kern/kern_sched.c6
3 files changed, 19 insertions, 9 deletions
diff --git a/sys/include/sys/filedesc.h b/sys/include/sys/filedesc.h
index df30c69..49d8d52 100644
--- a/sys/include/sys/filedesc.h
+++ b/sys/include/sys/filedesc.h
@@ -46,7 +46,7 @@ struct filedesc {
};
#if defined(_KERNEL)
-struct filedesc *fd_alloc(struct proc *td);
+int fd_alloc(struct proc *td, struct filedesc **fd_out);
struct filedesc *fd_from_fdnum(const struct proc *td, int fdno);
void fd_close_fdnum(struct proc *td, int fdno);
ssize_t write(int fd, const void *buf, size_t count);
diff --git a/sys/kern/kern_filedesc.c b/sys/kern/kern_filedesc.c
index 72f9c06..0037f55 100644
--- a/sys/kern/kern_filedesc.c
+++ b/sys/kern/kern_filedesc.c
@@ -111,9 +111,15 @@ do_write(struct vnode *vp, const char *buf, size_t count)
* Allocate a file descriptor.
*
* @td: Thread to allocate from, NULL for current thread.
+ * @fd_out: Pointer to allocated file descriptor output.
+ *
+ * This routine will create a new file descriptor
+ * table entry.
+ *
+ * Returns 0 on success.
*/
-struct filedesc *
-fd_alloc(struct proc *td)
+int
+fd_alloc(struct proc *td, struct filedesc **fd_out)
{
struct filedesc *fd;
@@ -131,15 +137,19 @@ fd_alloc(struct proc *td)
memset(fd, 0, sizeof(struct filedesc));
if (fd == NULL) {
- return NULL;
+ return -ENOMEM;
}
fd->fdno = i;
td->fds[i] = fd;
- return fd;
+
+ if (fd_out != NULL)
+ *fd_out = fd;
+
+ return 0;
}
- return NULL;
+ return -EMFILE;
}
/*
diff --git a/sys/kern/kern_sched.c b/sys/kern/kern_sched.c
index 776aaff..055b11a 100644
--- a/sys/kern/kern_sched.c
+++ b/sys/kern/kern_sched.c
@@ -271,9 +271,9 @@ sched_create_td(uintptr_t rip, char *argvp[], char *envp[], struct auxval auxv,
processor_init_pcb(td);
/* Allocate standard file descriptors */
- __assert(fd_alloc(td) != NULL); /* STDIN */
- __assert(fd_alloc(td) != NULL); /* STDOUT */
- __assert(fd_alloc(td) != NULL); /* STDERR */
+ __assert(fd_alloc(td, NULL) == 0); /* STDIN */
+ __assert(fd_alloc(td, NULL) == 0); /* STDOUT */
+ __assert(fd_alloc(td, NULL) == 0); /* STDERR */
/* Setup trapframe */
if (!is_user) {