From 239e33019117f4ab59dd26550d7969e45c290166 Mon Sep 17 00:00:00 2001 From: Anton Kling Date: Mon, 19 Feb 2024 18:52:30 +0100 Subject: Kernel/VFS: Cleanup of file descriptor halts --- kernel/poll.c | 43 ++++++++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 19 deletions(-) (limited to 'kernel/poll.c') diff --git a/kernel/poll.c b/kernel/poll.c index 7e9c8e8..0452bc8 100644 --- a/kernel/poll.c +++ b/kernel/poll.c @@ -1,14 +1,19 @@ #include #include +#include +#include #include #include int poll(struct pollfd *fds, size_t nfds, int timeout) { (void)timeout; int rc = 0; - int read_locks[nfds]; - int write_locks[nfds]; - int disconnect_locks[nfds]; + + disable_interrupts(); + + struct list *read_list = &get_current_task()->read_list; + struct list *write_list = &get_current_task()->write_list; + struct list *disconnect_list = &get_current_task()->disconnect_list; for (size_t i = 0; i < nfds; i++) { if (fds[i].fd < 0) continue; @@ -16,26 +21,25 @@ int poll(struct pollfd *fds, size_t nfds, int timeout) { if (NULL == f) { continue; } - if (fds[i].events & POLLIN) - read_locks[i] = create_read_fdhalt(f); - if (fds[i].events & POLLOUT) - write_locks[i] = create_write_fdhalt(f); - if (fds[i].events & POLLHUP) - disconnect_locks[i] = create_disconnect_fdhalt(f); + + if (fds[i].events & POLLIN) { + list_add(read_list, f->inode); + } + if (fds[i].events & POLLOUT) { + list_add(write_list, f->inode); + } + if (fds[i].events & POLLHUP) { + list_add(disconnect_list, f->inode); + } } switch_task(); + disable_interrupts(); + + list_reset(read_list); + list_reset(write_list); + list_reset(disconnect_list); - for (size_t i = 0; i < nfds; i++) { - if (fds[i].fd < 0) - continue; - if (fds[i].events & POLLIN) - unset_read_fdhalt(read_locks[i]); - if (fds[i].events & POLLOUT) - unset_write_fdhalt(write_locks[i]); - if (fds[i].events & POLLHUP) - unset_disconnect_fdhalt(disconnect_locks[i]); - } for (size_t i = 0; i < nfds; i++) { if (0 > fds[i].fd) { fds[i].revents = 0; @@ -56,5 +60,6 @@ int poll(struct pollfd *fds, size_t nfds, int timeout) { rc++; } } + enable_interrupts(); return rc; } -- cgit v1.2.3