summaryrefslogtreecommitdiff
path: root/src/kernel/syscalls.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/kernel/syscalls.c')
-rw-r--r--src/kernel/syscalls.c64
1 files changed, 32 insertions, 32 deletions
diff --git a/src/kernel/syscalls.c b/src/kernel/syscalls.c
index 19499d1..a869af5 100644
--- a/src/kernel/syscalls.c
+++ b/src/kernel/syscalls.c
@@ -66,20 +66,20 @@ int _syscall_fork(void) {
return 1;
}
-fd_t _syscall_fs_open(const user_ptr path, int len) {
+handle_t _syscall_fs_open(const user_ptr path, int len) {
struct virt_iter iter;
struct vfs_mount *mount;
static char buffer[PATH_MAX]; // holds the path
- int fd, res;
+ int handle, res;
if (len > PATH_MAX) return -1;
- // find the first free fd
- for (fd = 0; fd < FD_MAX; fd++) {
- if (process_current->fds[fd].type == FD_EMPTY)
+ // find the first free handle
+ for (handle = 0; handle < HANDLE_MAX; handle++) {
+ if (process_current->handles[handle].type == HANDLE_EMPTY)
break;
}
- if (fd == FD_MAX) return -1;
+ if (handle == HANDLE_MAX) return -1;
// copy the path to the kernel
virt_iter_new(&iter, path, len, process_current->pages, true, false);
@@ -93,11 +93,11 @@ fd_t _syscall_fs_open(const user_ptr path, int len) {
mount = vfs_mount_resolve(process_current->mount, buffer, len);
if (!mount) return -1;
- res = fdop_dispatch((struct fdop_args){
- .type = FDOP_OPEN,
- .fd = &mount->fd,
+ res = handleop_dispatch((struct handleop_args){
+ .type = HANDLEOP_OPEN,
+ .handle = &mount->handle,
.open = {
- .target = &process_current->fds[fd],
+ .target = &process_current->handles[handle],
.path = &buffer[mount->prefix_len],
.len = len - mount->prefix_len,
}
@@ -105,17 +105,17 @@ fd_t _syscall_fs_open(const user_ptr path, int len) {
if (res < 0)
return res;
else
- return fd;
+ return handle;
}
-int _syscall_fd_mount(fd_t fd, const user_ptr path, int len) {
+int _syscall_fd_mount(handle_t handle, const user_ptr path, int len) {
struct virt_iter iter;
struct vfs_mount *mount;
char *path_buf;
int res;
if (len > PATH_MAX) return -1;
- if (fd < 0 || fd >= FD_MAX) return -1;
+ if (handle < 0 || handle >= HANDLE_MAX) return -1;
// copy the path to the kernel
path_buf = kmalloc(len);
@@ -134,11 +134,11 @@ int _syscall_fd_mount(fd_t fd, const user_ptr path, int len) {
mount->prev = process_current->mount;
mount->prefix = path_buf;
mount->prefix_len = len;
- memcpy(&mount->fd, &process_current->fds[fd], sizeof(struct fd));
+ memcpy(&mount->handle, &process_current->handles[handle], sizeof(struct handle));
- res = fdop_dispatch((struct fdop_args){
- .type = FDOP_MOUNT,
- .fd = &process_current->fds[fd],
+ res = handleop_dispatch((struct handleop_args){
+ .type = HANDLEOP_MOUNT,
+ .handle = &process_current->handles[handle],
.mnt = {mount},
});
if (res < 0) goto fail;
@@ -150,29 +150,29 @@ fail:
return -1;
}
-int _syscall_fd_read(fd_t fd, user_ptr buf, int len) {
- if (fd < 0 || fd >= FD_MAX) return -1;
- return fdop_dispatch((struct fdop_args){
- .type = FDOP_READ,
- .fd = &process_current->fds[fd],
+int _syscall_fd_read(handle_t handle, user_ptr buf, int len) {
+ if (handle < 0 || handle >= HANDLE_MAX) return -1;
+ return handleop_dispatch((struct handleop_args){
+ .type = HANDLEOP_READ,
+ .handle = &process_current->handles[handle],
.rw = {buf, len}
});
}
-int _syscall_fd_write(fd_t fd, user_ptr buf, int len) {
- if (fd < 0 || fd >= FD_MAX) return -1;
- return fdop_dispatch((struct fdop_args){
- .type = FDOP_WRITE,
- .fd = &process_current->fds[fd],
+int _syscall_fd_write(handle_t handle, user_ptr buf, int len) {
+ if (handle < 0 || handle >= HANDLE_MAX) return -1;
+ return handleop_dispatch((struct handleop_args){
+ .type = HANDLEOP_WRITE,
+ .handle = &process_current->handles[handle],
.rw = {buf, len}
});
}
-int _syscall_fd_close(fd_t fd) {
- if (fd < 0 || fd >= FD_MAX) return -1;
- return fdop_dispatch((struct fdop_args){
- .type = FDOP_CLOSE,
- .fd = &process_current->fds[fd],
+int _syscall_fd_close(handle_t handle) {
+ if (handle < 0 || handle >= HANDLE_MAX) return -1;
+ return handleop_dispatch((struct handleop_args){
+ .type = HANDLEOP_CLOSE,
+ .handle = &process_current->handles[handle],
});
}