summaryrefslogtreecommitdiff
path: root/kernel/fs/vfs.c
diff options
context:
space:
mode:
authorAnton Kling <anton@kling.gg>2024-03-28 10:34:00 +0100
committerAnton Kling <anton@kling.gg>2024-03-28 10:34:00 +0100
commit7eceb43433634ee253507208baf1d8298b40e377 (patch)
tree59c399d8bd9a24d9a74c52f3830125b1dd217e95 /kernel/fs/vfs.c
parent873c45b99fe05e43c71763c385da54b0945bf8a3 (diff)
new stuff
Diffstat (limited to 'kernel/fs/vfs.c')
-rw-r--r--kernel/fs/vfs.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/kernel/fs/vfs.c b/kernel/fs/vfs.c
index f2b763c..505d6ae 100644
--- a/kernel/fs/vfs.c
+++ b/kernel/fs/vfs.c
@@ -375,7 +375,23 @@ int vfs_pwrite(int fd, void *buf, u64 count, u64 offset) {
if (!(vfs_fd->flags & O_WRITE)) {
return -EBADF;
}
- return raw_vfs_pwrite(vfs_fd, buf, count, offset);
+ int rc = raw_vfs_pwrite(vfs_fd, buf, count, offset);
+ if (-EAGAIN == rc) {
+ if (!(vfs_fd->flags & O_NONBLOCK)) {
+ struct pollfd fds;
+ do {
+ fds.fd = fd;
+ fds.events = POLLOUT;
+ fds.revents = 0;
+ int rc = poll(&fds, 1, 0);
+ if (-EINTR == rc) {
+ return -EINTR;
+ }
+ } while (!(fds.revents & POLLOUT));
+ return vfs_pwrite(fd, buf, count, offset);
+ }
+ }
+ return rc;
}
vfs_vm_object_t *vfs_get_vm_object(int fd, u64 length, u64 offset) {